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.2 to 0.10.0

10

lib/app.js

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

if (errors.length > 0) {
const errorList = errors.map(e => `[${e.source.path}] ${e.message}`).join('\n ');
throw new Error(`Stack validation failed with the following errors:\n ${errorList}`);
const errorList = errors.map(e => `[${e.source.path}] ${e.message}`).join('\n ');
throw new Error(`Stack validation failed with the following errors:\n ${errorList}`);
}

@@ -231,3 +231,3 @@ let environment;

* @returns the NPM module infos (aka ``package.json`` contents), or
* ``undefined`` if the lookup was unsuccessful.
* ``undefined`` if the lookup was unsuccessful.
*/

@@ -247,3 +247,3 @@ function findNpmPackage(fileName) {

* @returns ``s`` with any terminating ``/node_modules``
* (or ``\\node_modules``) stripped off.)
* (or ``\\node_modules``) stripped off.)
*/

@@ -258,2 +258,2 @@ function stripNodeModules(s) {

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"app.js","sourceRoot":"","sources":["app.ts"],"names":[],"mappings":"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","sourcesContent":["import cxapi = require('@aws-cdk/cx-api');\nimport jsBase64 = require('js-base64');\nimport { Stack } from './cloudformation/stack';\nimport { Construct, MetadataEntry, PATH_SEP, Root } from './core/construct';\nimport { resolve } from './core/tokens';\n\n/**\n * Cloud Executable interface version.\n */\nconst CX_VERSION = 'CloudExecutable/1.0';\n\n/**\n * Represents a CDK program.\n */\nexport class App extends Root {\n    private readonly progname?: string;\n    private readonly request?: cxapi.CXRequest;\n\n    constructor(argv?: string[]) {\n        super();\n\n        argv = argv || [];\n\n        if (argv.length >= 1) {\n            // if the first argument ends with \"/node\" or \"node.exe\", skip it (this is argv[0] in node programs).\n            if (/[\\/\\\\]node(?:\\.exe)?$/.test(argv[0])) {\n                argv = argv.slice(1);\n            }\n\n            this.progname = argv[0].split('/').pop()!;\n        }\n\n        if (argv.length > 1) {\n            try {\n                this.request = this.parseRequest(argv[1]);\n            } catch (e) {\n                throw new Error(`Cannot parse request '${argv[1]}': ${e.message}`);\n            }\n            this.loadContext();\n        }\n    }\n\n    private get stacks() {\n        const out: { [name: string]: Stack } = { };\n        for (const child of this.children) {\n            if (!(child instanceof Stack)) {\n                throw new Error(`The child ${child.toString()} of Program must be a Stack`);\n            }\n\n            out[child.id] = child as Stack;\n        }\n        return out;\n    }\n\n    /**\n     * Runs the program\n     * @returns STDOUT\n     */\n    public run(): string {\n        // no arguments - print usage and exit successfully.\n        if (!this.request || !this.request.type) {\n            return this.usage;\n        }\n\n        const result = this.runCommand();\n        return JSON.stringify(result, undefined, 2);\n    }\n\n    /**\n     * @deprecated Use app.run().\n     */\n    public async exec(): Promise<string> {\n        return this.run();\n    }\n\n    /**\n     * Lists all stacks in this app.\n     */\n    public listStacks(): cxapi.StackInfo[] {\n        return Object.keys(this.stacks).map(name => {\n            const stack = this.stacks[name];\n            const region = stack.env.region;\n            const account = stack.env.account;\n            let environment: cxapi.Environment | undefined;\n            if (account && region) {\n                environment = { name: `${account}/${region}`, account, region };\n            }\n            return { name, environment };\n        });\n    }\n\n    /**\n     * Synthesize and validate a single stack\n     * @param stackName The name of the stack to synthesize\n     */\n    public synthesizeStack(stackName: string): cxapi.SynthesizedStack {\n        const stack = this.getStack(stackName);\n\n        // first, validate this stack and stop if there are errors.\n        const errors = stack.validateTree();\n        if (errors.length > 0) {\n            const errorList = errors.map(e => `[${e.source.path}] ${e.message}`).join('\\n    ');\n            throw new Error(`Stack validation failed with the following errors:\\n    ${errorList}`);\n        }\n\n        let environment: cxapi.Environment | undefined;\n        if (stack.env.account && stack.env.region) {\n            environment = {\n                name: `${stack.env.account}/${stack.env.region}`,\n                account: stack.env.account,\n                region: stack.env.region\n            };\n        }\n\n        return {\n            name: stack.id,\n            environment,\n            missing: Object.keys(stack.missingContext).length ? stack.missingContext : undefined,\n            template: stack.toCloudFormation(),\n            metadata: this.collectMetadata(stack)\n        };\n    }\n\n    /**\n     * Synthesizes multiple stacks\n     */\n    public synthesizeStacks(stackNames: string[]): cxapi.SynthesizedStack[] {\n        const ret: cxapi.SynthesizedStack[] = [];\n        for (const stackName of stackNames) {\n            ret.push(this.synthesizeStack(stackName));\n        }\n        return ret;\n    }\n\n    /**\n     * Returns metadata for all constructs in the stack.\n     */\n    public collectMetadata(stack: Stack) {\n        const output: { [id: string]: MetadataEntry[] } = { };\n\n        visit(stack);\n\n        // add app-level metadata under \".\"\n        if (this.metadata.length > 0) {\n            output[PATH_SEP] = this.metadata;\n        }\n\n        return output;\n\n        function visit(node: Construct) {\n            if (node.metadata.length > 0) {\n                // Make the path absolute\n                output[PATH_SEP + node.path] = node.metadata.map(md => resolve(md) as MetadataEntry);\n            }\n\n            for (const child of node.children) {\n                visit(child);\n            }\n        }\n    }\n\n    private collectRuntimeInformation(): cxapi.AppRuntime {\n        const libraries: { [name: string]: string } = {};\n\n        for (const fileName of Object.keys(require.cache)) {\n            const pkg = findNpmPackage(fileName);\n            if (pkg && !pkg.private) {\n                libraries[pkg.name] = pkg.version;\n            }\n        }\n\n        return { libraries };\n    }\n\n    private getStack(stackname: string) {\n        if (stackname == null) {\n            throw new Error('Stack name must be defined');\n        }\n\n        const stack = this.stacks[stackname];\n        if (!stack) {\n            throw new Error(`Cannot find stack ${stackname}`);\n        }\n        return stack;\n    }\n\n    private runCommand() {\n        switch (this.request!.type) {\n            case 'list':\n                return {\n                    stacks: this.listStacks()\n                } as cxapi.ListStacksResponse;\n\n            case 'synth':\n                return {\n                    stacks: this.synthesizeStacks((this.request as cxapi.SynthesizeRequest).stacks),\n                    runtime: this.collectRuntimeInformation()\n                } as cxapi.SynthesizeResponse;\n\n            default:\n                throw new Error(`Invalid command: ${this.request!.type}`);\n        }\n    }\n\n    private get usage() {\n        const progname = this.progname ? this.progname + ' ' : '';\n\n        return `${CX_VERSION}\n\nUsage:\n  ${progname}REQUEST\n\nREQUEST is a JSON-encoded request object.\n`;\n    }\n\n    private loadContext() {\n        const context = (this.request && this.request.context) || {};\n        for (const key of Object.keys(context)) {\n            this.setContext(key, context[key]);\n        }\n    }\n\n    private parseRequest(req: string): cxapi.CXRequest {\n        // allow toolkit to send request in base64 if they begin with \"base64:\"\n        // this is in order to avoid shell escaping issues when defining \"--app\"\n        // in the toolkit.\n        if (req.startsWith(cxapi.BASE64_REQ_PREFIX)) {\n            req = jsBase64.Base64.fromBase64(req.slice(cxapi.BASE64_REQ_PREFIX.length));\n        }\n\n        // parse as JSON\n        return JSON.parse(req);\n    }\n}\n\nexport class Program extends App {\n    constructor(argv?: string[]) {\n        super(argv);\n        this.addWarning('\"Program\" is deprecated in favor of \"App\"');\n    }\n}\n\n/**\n * Determines which NPM module a given loaded javascript file is from.\n *\n * The only infromation that is available locally is a list of Javascript files,\n * and every source file is associated with a search path to resolve the further\n * ``require`` calls made from there, which includes its own directory on disk,\n * and parent directories - for example:\n *\n * [ '...repo/packages/aws-cdk-resources/lib/cfn/node_modules',\n *   '...repo/packages/aws-cdk-resources/lib/node_modules',\n *   '...repo/packages/aws-cdk-resources/node_modules',\n *   '...repo/packages/node_modules',\n *   // etc...\n * ]\n *\n * We are looking for ``package.json`` that is anywhere in the tree, except it's\n * in the parent directory, not in the ``node_modules`` directory. For this\n * reason, we strip the ``/node_modules`` suffix off each path and use regular\n * module resolution to obtain a reference to ``package.json``.\n *\n * @param fileName a javascript file name.\n * @returns the NPM module infos (aka ``package.json`` contents), or\n *          ``undefined`` if the lookup was unsuccessful.\n */\nfunction findNpmPackage(fileName: string): { name: string, version: string, private?: boolean } | undefined {\n    const mod = require.cache[fileName];\n    const paths = mod.paths.map(stripNodeModules);\n\n    try {\n        const path = require.resolve('package.json', { paths });\n        return require(path);\n    } catch (e) {\n        return undefined;\n    }\n\n    /**\n     * @param s a path.\n     * @returns ``s`` with any terminating ``/node_modules``\n     *          (or ``\\\\node_modules``) stripped off.)\n     */\n    function stripNodeModules(s: string): string {\n        if (s.endsWith('/node_modules') || s.endsWith('\\\\node_modules')) {\n            // /node_modules is 13 characters\n            return s.substr(0, s.length - 13);\n        }\n        return s;\n    }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"app.js","sourceRoot":"","sources":["app.ts"],"names":[],"mappings":"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","sourcesContent":["import cxapi = require('@aws-cdk/cx-api');\nimport jsBase64 = require('js-base64');\nimport { Stack } from './cloudformation/stack';\nimport { Construct, MetadataEntry, PATH_SEP, Root } from './core/construct';\nimport { resolve } from './core/tokens';\n\n/**\n * Cloud Executable interface version.\n */\nconst CX_VERSION = 'CloudExecutable/1.0';\n\n/**\n * Represents a CDK program.\n */\nexport class App extends Root {\n  private readonly progname?: string;\n  private readonly request?: cxapi.CXRequest;\n\n  constructor(argv?: string[]) {\n    super();\n\n    argv = argv || [];\n\n    if (argv.length >= 1) {\n      // if the first argument ends with \"/node\" or \"node.exe\", skip it (this is argv[0] in node programs).\n      if (/[\\/\\\\]node(?:\\.exe)?$/.test(argv[0])) {\n        argv = argv.slice(1);\n      }\n\n      this.progname = argv[0].split('/').pop()!;\n    }\n\n    if (argv.length > 1) {\n      try {\n        this.request = this.parseRequest(argv[1]);\n      } catch (e) {\n        throw new Error(`Cannot parse request '${argv[1]}': ${e.message}`);\n      }\n      this.loadContext();\n    }\n  }\n\n  private get stacks() {\n    const out: { [name: string]: Stack } = { };\n    for (const child of this.children) {\n      if (!(child instanceof Stack)) {\n        throw new Error(`The child ${child.toString()} of Program must be a Stack`);\n      }\n\n      out[child.id] = child as Stack;\n    }\n    return out;\n  }\n\n  /**\n   * Runs the program\n   * @returns STDOUT\n   */\n  public run(): string {\n    // no arguments - print usage and exit successfully.\n    if (!this.request || !this.request.type) {\n      return this.usage;\n    }\n\n    const result = this.runCommand();\n    return JSON.stringify(result, undefined, 2);\n  }\n\n  /**\n   * @deprecated Use app.run().\n   */\n  public async exec(): Promise<string> {\n    return this.run();\n  }\n\n  /**\n   * Lists all stacks in this app.\n   */\n  public listStacks(): cxapi.StackInfo[] {\n    return Object.keys(this.stacks).map(name => {\n      const stack = this.stacks[name];\n      const region = stack.env.region;\n      const account = stack.env.account;\n      let environment: cxapi.Environment | undefined;\n      if (account && region) {\n        environment = { name: `${account}/${region}`, account, region };\n      }\n      return { name, environment };\n    });\n  }\n\n  /**\n   * Synthesize and validate a single stack\n   * @param stackName The name of the stack to synthesize\n   */\n  public synthesizeStack(stackName: string): cxapi.SynthesizedStack {\n    const stack = this.getStack(stackName);\n\n    // first, validate this stack and stop if there are errors.\n    const errors = stack.validateTree();\n    if (errors.length > 0) {\n      const errorList = errors.map(e => `[${e.source.path}] ${e.message}`).join('\\n  ');\n      throw new Error(`Stack validation failed with the following errors:\\n  ${errorList}`);\n    }\n\n    let environment: cxapi.Environment | undefined;\n    if (stack.env.account && stack.env.region) {\n      environment = {\n        name: `${stack.env.account}/${stack.env.region}`,\n        account: stack.env.account,\n        region: stack.env.region\n      };\n    }\n\n    return {\n      name: stack.id,\n      environment,\n      missing: Object.keys(stack.missingContext).length ? stack.missingContext : undefined,\n      template: stack.toCloudFormation(),\n      metadata: this.collectMetadata(stack)\n    };\n  }\n\n  /**\n   * Synthesizes multiple stacks\n   */\n  public synthesizeStacks(stackNames: string[]): cxapi.SynthesizedStack[] {\n    const ret: cxapi.SynthesizedStack[] = [];\n    for (const stackName of stackNames) {\n      ret.push(this.synthesizeStack(stackName));\n    }\n    return ret;\n  }\n\n  /**\n   * Returns metadata for all constructs in the stack.\n   */\n  public collectMetadata(stack: Stack) {\n    const output: { [id: string]: MetadataEntry[] } = { };\n\n    visit(stack);\n\n    // add app-level metadata under \".\"\n    if (this.metadata.length > 0) {\n      output[PATH_SEP] = this.metadata;\n    }\n\n    return output;\n\n    function visit(node: Construct) {\n      if (node.metadata.length > 0) {\n        // Make the path absolute\n        output[PATH_SEP + node.path] = node.metadata.map(md => resolve(md) as MetadataEntry);\n      }\n\n      for (const child of node.children) {\n        visit(child);\n      }\n    }\n  }\n\n  private collectRuntimeInformation(): cxapi.AppRuntime {\n    const libraries: { [name: string]: string } = {};\n\n    for (const fileName of Object.keys(require.cache)) {\n      const pkg = findNpmPackage(fileName);\n      if (pkg && !pkg.private) {\n        libraries[pkg.name] = pkg.version;\n      }\n    }\n\n    return { libraries };\n  }\n\n  private getStack(stackname: string) {\n    if (stackname == null) {\n      throw new Error('Stack name must be defined');\n    }\n\n    const stack = this.stacks[stackname];\n    if (!stack) {\n      throw new Error(`Cannot find stack ${stackname}`);\n    }\n    return stack;\n  }\n\n  private runCommand() {\n    switch (this.request!.type) {\n      case 'list':\n        return {\n          stacks: this.listStacks()\n        } as cxapi.ListStacksResponse;\n\n      case 'synth':\n        return {\n          stacks: this.synthesizeStacks((this.request as cxapi.SynthesizeRequest).stacks),\n          runtime: this.collectRuntimeInformation()\n        } as cxapi.SynthesizeResponse;\n\n      default:\n        throw new Error(`Invalid command: ${this.request!.type}`);\n    }\n  }\n\n  private get usage() {\n    const progname = this.progname ? this.progname + ' ' : '';\n\n    return `${CX_VERSION}\n\nUsage:\n  ${progname}REQUEST\n\nREQUEST is a JSON-encoded request object.\n`;\n  }\n\n  private loadContext() {\n    const context = (this.request && this.request.context) || {};\n    for (const key of Object.keys(context)) {\n      this.setContext(key, context[key]);\n    }\n  }\n\n  private parseRequest(req: string): cxapi.CXRequest {\n    // allow toolkit to send request in base64 if they begin with \"base64:\"\n    // this is in order to avoid shell escaping issues when defining \"--app\"\n    // in the toolkit.\n    if (req.startsWith(cxapi.BASE64_REQ_PREFIX)) {\n      req = jsBase64.Base64.fromBase64(req.slice(cxapi.BASE64_REQ_PREFIX.length));\n    }\n\n    // parse as JSON\n    return JSON.parse(req);\n  }\n}\n\nexport class Program extends App {\n  constructor(argv?: string[]) {\n    super(argv);\n    this.addWarning('\"Program\" is deprecated in favor of \"App\"');\n  }\n}\n\n/**\n * Determines which NPM module a given loaded javascript file is from.\n *\n * The only infromation that is available locally is a list of Javascript files,\n * and every source file is associated with a search path to resolve the further\n * ``require`` calls made from there, which includes its own directory on disk,\n * and parent directories - for example:\n *\n * [ '...repo/packages/aws-cdk-resources/lib/cfn/node_modules',\n *   '...repo/packages/aws-cdk-resources/lib/node_modules',\n *   '...repo/packages/aws-cdk-resources/node_modules',\n *   '...repo/packages/node_modules',\n *   // etc...\n * ]\n *\n * We are looking for ``package.json`` that is anywhere in the tree, except it's\n * in the parent directory, not in the ``node_modules`` directory. For this\n * reason, we strip the ``/node_modules`` suffix off each path and use regular\n * module resolution to obtain a reference to ``package.json``.\n *\n * @param fileName a javascript file name.\n * @returns the NPM module infos (aka ``package.json`` contents), or\n *      ``undefined`` if the lookup was unsuccessful.\n */\nfunction findNpmPackage(fileName: string): { name: string, version: string, private?: boolean } | undefined {\n  const mod = require.cache[fileName];\n  const paths = mod.paths.map(stripNodeModules);\n\n  try {\n    const path = require.resolve('package.json', { paths });\n    return require(path);\n  } catch (e) {\n    return undefined;\n  }\n\n  /**\n   * @param s a path.\n   * @returns ``s`` with any terminating ``/node_modules``\n   *      (or ``\\\\node_modules``) stripped off.)\n   */\n  function stripNodeModules(s: string): string {\n    if (s.endsWith('/node_modules') || s.endsWith('\\\\node_modules')) {\n      // /node_modules is 13 characters\n      return s.substr(0, s.length - 13);\n    }\n    return s;\n  }\n}\n"]}

@@ -18,3 +18,3 @@ import { Token } from '..';

*
* arn:{partition}:{service}:{region}:{account}:{resource}{sep}}{resource-name}
* arn:{partition}:{service}:{region}:{account}:{resource}{sep}}{resource-name}
*

@@ -43,3 +43,3 @@ */

*
* arn:aws:s3:::my_corporate_bucket/path/to/exampleobject.png
* arn:aws:s3:::my_corporate_bucket/path/to/exampleobject.png
*

@@ -59,3 +59,3 @@ * After parsing the resourceName will not contain

* @returns an ArnComponents object which allows access to the various
* components of the ARN.
* components of the ARN.
*/

@@ -78,3 +78,3 @@ static parse(arn: string, sepIfToken?: string, hasName?: boolean): ArnComponents;

*
* arn:aws:s3:::my_corporate_bucket/path/to/exampleobject.png
* arn:aws:s3:::my_corporate_bucket/path/to/exampleobject.png
*

@@ -81,0 +81,0 @@ * After parsing the resourceName will not contain 'path/to/exampleobject.png'

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

*
* arn:{partition}:{service}:{region}:{account}:{resource}{sep}}{resource-name}
* arn:{partition}:{service}:{region}:{account}:{resource}{sep}}{resource-name}
*

@@ -68,3 +68,3 @@ */

*
* arn:aws:s3:::my_corporate_bucket/path/to/exampleobject.png
* arn:aws:s3:::my_corporate_bucket/path/to/exampleobject.png
*

@@ -84,3 +84,3 @@ * After parsing the resourceName will not contain

* @returns an ArnComponents object which allows access to the various
* components of the ARN.
* components of the ARN.
*/

@@ -165,3 +165,3 @@ static parse(arn, sepIfToken = '/', hasName = true) {

*
* arn:aws:s3:::my_corporate_bucket/path/to/exampleobject.png
* arn:aws:s3:::my_corporate_bucket/path/to/exampleobject.png
*

@@ -218,2 +218,2 @@ * After parsing the resourceName will not contain 'path/to/exampleobject.png'

exports.ArnUtils = ArnUtils;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"arn.js","sourceRoot":"","sources":["arn.ts"],"names":[],"mappings":";;AAAA,0BAA4E;AAC5E,6CAAyD;AACzD,2CAA4C;AAC5C,iEAA6D;AAE7D;;;GAGG;AACH,MAAa,QAAQ;IACjB;;;;;;;;;;;;;OAaG;IACI,MAAM,CAAC,cAAc,CAAC,UAAyB;QAClD,MAAM,SAAS,GAAG,UAAU,CAAC,SAAS,IAAI,IAAI;YAC1C,CAAC,CAAC,IAAI,gBAAY,EAAE;YACpB,CAAC,CAAC,UAAU,CAAC,SAAS,CAAC;QAC3B,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,IAAI,IAAI;YACpC,CAAC,CAAC,IAAI,aAAS,EAAE;YACjB,CAAC,CAAC,UAAU,CAAC,MAAM,CAAC;QACxB,MAAM,OAAO,GAAG,UAAU,CAAC,OAAO,IAAI,IAAI;YACtC,CAAC,CAAC,IAAI,gBAAY,EAAE;YACpB,CAAC,CAAC,UAAU,CAAC,OAAO,CAAC;QAEzB,MAAM,MAAM,GAAG,CAAE,KAAK,EAAE,GAAG,EAAE,SAAS,EAAE,GAAG,EAAE,UAAU,CAAC,OAAO,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,UAAU,CAAC,QAAQ,CAAE,CAAC;QAEvH,MAAM,GAAG,GAAG,UAAU,CAAC,GAAG,IAAI,GAAG,CAAC;QAClC,IAAI,GAAG,KAAK,GAAG,IAAI,GAAG,KAAK,GAAG,EAAE;YAC5B,MAAM,IAAI,KAAK,CAAC,wCAAwC,CAAC,CAAC;SAC7D;QAED,IAAI,UAAU,CAAC,YAAY,IAAI,IAAI,EAAE;YACjC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACjB,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC;SACxC;QAED,OAAO,IAAI,YAAQ,CAAC,GAAG,MAAM,CAAC,CAAC,QAAQ,EAAE,CAAC;IAC9C,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAoCG;IACI,MAAM,CAAC,KAAK,CAAC,GAAW,EAAE,aAAqB,GAAG,EAAE,UAAmB,IAAI;QAC9E,IAAI,mBAAU,CAAC,GAAG,CAAC,EAAE;YACjB,OAAO,QAAQ,CAAC,UAAU,CAAC,IAAI,0CAAmB,CAAC,GAAG,CAAC,EAAE,UAAU,EAAE,OAAO,CAAC,CAAC;SACjF;QAED,MAAM,UAAU,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,CAA8B,CAAC;QAE/D,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE;YACvB,MAAM,IAAI,KAAK,CAAC,wCAAwC,GAAG,GAAG,CAAC,CAAC;SACnE;QAED,MAAM,CAAE,SAAS,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,GAAG,IAAI,CAAE,GAAG,UAAU,CAAC;QAEtF,IAAI,SAAS,KAAK,KAAK,EAAE;YACrB,MAAM,IAAI,KAAK,CAAC,+BAA+B,GAAG,GAAG,CAAC,CAAC;SAC1D;QAED,IAAI,CAAC,OAAO,EAAE;YACV,MAAM,IAAI,KAAK,CAAC,uDAAuD,GAAG,GAAG,CAAC,CAAC;SAClF;QAED,IAAI,CAAC,KAAK,EAAE;YACR,MAAM,IAAI,KAAK,CAAC,wDAAwD,GAAG,GAAG,CAAC,CAAC;SACnF;QAED,IAAI,QAAgB,CAAC;QACrB,IAAI,YAAgC,CAAC;QACrC,IAAI,GAAuB,CAAC;QAE5B,IAAI,QAAQ,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QAClC,IAAI,QAAQ,KAAK,CAAC,CAAC,EAAE;YACjB,GAAG,GAAG,GAAG,CAAC;SACb;aAAM,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE;YACxB,GAAG,GAAG,GAAG,CAAC;YACV,QAAQ,GAAG,CAAC,CAAC,CAAC;SACjB;QAED,IAAI,QAAQ,KAAK,CAAC,CAAC,EAAE;YACjB,QAAQ,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC;YACrC,YAAY,GAAG,KAAK,CAAC,MAAM,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC;SAC7C;aAAM;YACH,QAAQ,GAAG,KAAK,CAAC;SACpB;QAED,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE;YACjB,IAAI,CAAC,YAAY,EAAE;gBACf,YAAY,GAAG,EAAE,CAAC;aACrB;iBAAM;gBACH,YAAY,IAAI,GAAG,CAAC;aACvB;YAED,YAAY,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;SAClC;QAED,MAAM,MAAM,GAAkB,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC;QACpD,IAAI,SAAS,EAAE;YACX,MAAM,CAAC,SAAS,GAAG,SAAS,CAAC;SAChC;QAED,IAAI,MAAM,EAAE;YACR,MAAM,CAAC,MAAM,GAAG,MAAM,CAAC;SAC1B;QAED,IAAI,OAAO,EAAE;YACT,MAAM,CAAC,OAAO,GAAG,OAAO,CAAC;SAC5B;QAED,IAAI,YAAY,EAAE;YACd,MAAM,CAAC,YAAY,GAAG,YAAY,CAAC;SACtC;QAED,IAAI,GAAG,EAAE;YACL,MAAM,CAAC,GAAG,GAAG,GAAG,CAAC;SACpB;QAED,OAAO,MAAM,CAAC;IAClB,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA4BG;IACI,MAAM,CAAC,UAAU,CAAC,GAAU,EAAE,MAAc,GAAG,EAAE,UAAmB,IAAI;QAC3E,sBAAsB;QACtB,mDAAmD;QACnD,gEAAgE;QAChE,gEAAgE;QAEhE,6EAA6E;QAC7E,mBAAmB;QAEnB,MAAM,UAAU,GAAG,IAAI,YAAO,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;QAEzC,MAAM,SAAS,GAAG,IAAI,aAAQ,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC,QAAQ,EAAE,CAAC;QACzD,MAAM,OAAO,GAAG,IAAI,aAAQ,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC,QAAQ,EAAE,CAAC;QACvD,MAAM,MAAM,GAAG,IAAI,aAAQ,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC,QAAQ,EAAE,CAAC;QACtD,MAAM,OAAO,GAAG,IAAI,aAAQ,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC,QAAQ,EAAE,CAAC;QAEvD,IAAI,GAAG,KAAK,GAAG,EAAE;YACb,MAAM,QAAQ,GAAG,IAAI,aAAQ,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC,QAAQ,EAAE,CAAC;YACxD,MAAM,YAAY,GAAG,OAAO,CAAC,CAAC,CAAC,IAAI,aAAQ,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;YAElF,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,GAAG,EAAE,CAAC;SAC/E;aAAM;YACH,MAAM,cAAc,GAAG,IAAI,YAAO,CAAC,GAAG,EAAE,IAAI,aAAQ,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC,CAAC;YAErE,MAAM,QAAQ,GAAG,IAAI,aAAQ,CAAC,CAAC,EAAE,cAAc,CAAC,CAAC,QAAQ,EAAE,CAAC;YAC5D,MAAM,YAAY,GAAG,OAAO,CAAC,CAAC,CAAC,IAAI,aAAQ,CAAC,CAAC,EAAE,cAAc,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;YAEtF,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,GAAG,EAAE,CAAC;SAC/E;IACL,CAAC;IAED;;OAEG;IACI,MAAM,CAAC,iBAAiB,CAAC,GAAW,EAAE,MAAc,GAAG;QAC1D,OAAO,QAAQ,CAAC,UAAU,CAAC,IAAI,SAAK,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC;IAC7D,CAAC;IAED;;OAEG;IACI,MAAM,CAAC,qBAAqB,CAAC,GAAW,EAAE,MAAc,GAAG;QAC9D,OAAO,QAAQ,CAAC,UAAU,CAAC,IAAI,SAAK,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC,YAAa,CAAC;IACxE,CAAC;CACJ;AArOD,4BAqOC","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"]}
//# 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"]}

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

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xvdWRmb3JtYXRpb24tanNvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImNsb3VkZm9ybWF0aW9uLWpzb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSwyQ0FBZ0Q7QUFDaEQsaUVBQTBFO0FBRTFFOztHQUVHO0FBQ0gsTUFBYSxrQkFBa0I7SUFDM0I7Ozs7Ozs7OztPQVNHO0lBQ0ksTUFBTSxDQUFDLFNBQVMsQ0FBQyxHQUFRO1FBQzVCLE9BQU8sSUFBSSxjQUFLLENBQUMsR0FBRyxFQUFFO1lBQ2xCLHFFQUFxRTtZQUNyRSxnREFBZ0Q7WUFDaEQsRUFBRTtZQUNGLGdFQUFnRTtZQUNoRSxrRUFBa0U7WUFDbEUsMERBQTBEO1lBQzFELG9FQUFvRTtZQUNwRSxnRUFBZ0U7WUFDaEUsb0NBQW9DO1lBQ3BDLE1BQU0sUUFBUSxHQUFHLGdCQUFPLENBQUMsR0FBRyxDQUFDLENBQUM7WUFFOUIseUVBQXlFO1lBQ3pFLDhCQUE4QjtZQUM5QixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMscUJBQXFCLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQztRQUMzRCxDQUFDLENBQUMsQ0FBQztRQUVIOztXQUVHO1FBQ0gsU0FBUyxxQkFBcUIsQ0FBQyxDQUFNO1lBQ2pDLElBQUksa0NBQVcsQ0FBQyxDQUFDLENBQUMsRUFBRTtnQkFDaEIsT0FBTyxhQUFhLENBQUMsQ0FBQyxDQUFDLENBQUM7YUFDM0I7WUFFRCxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUU7Z0JBQ2xCLE9BQU8sQ0FBQyxDQUFDLEdBQUcsQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO2FBQ3ZDO1lBRUQsSUFBSSxPQUFPLENBQUMsS0FBSyxRQUFRLEVBQUU7Z0JBQ3ZCLEtBQUssTUFBTSxHQUFHLElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRTtvQkFDOUIsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxHQUFHLHFCQUFxQixDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO2lCQUMxQzthQUNKO1lBRUQsT0FBTyxDQUFDLENBQUM7UUFDYixDQUFDO1FBRUQsU0FBUyxhQUFhLENBQUMsU0FBYztZQUNqQyxPQUFPLElBQUksY0FBYyxDQUFDLEdBQUcsRUFBRSxDQUFDLHVCQUF1QixDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7UUFDeEUsQ0FBQztJQUNMLENBQUM7Q0FDSjtBQXRERCxnREFzREM7QUFFRDs7R0FFRztBQUNILE1BQU0sY0FBZSxTQUFRLDBDQUFtQjtJQUM1Qzs7T0FFRztJQUNJLE1BQU07UUFDVCxPQUFPLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUMzQixDQUFDO0NBQ0o7QUFFRDs7R0FFRztBQUNILFNBQVMsdUJBQXVCLENBQUMsQ0FBTTtJQUNuQyxJQUFJLE9BQU8sQ0FBQyxLQUFLLFFBQVEsRUFBRTtRQUN2QixnRUFBZ0U7UUFDaEUsMkNBQTJDO1FBQzNDLE1BQU0sV0FBVyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDdEMsT0FBTyxXQUFXLENBQUMsU0FBUyxDQUFDLENBQUMsRUFBRSxXQUFXLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDO0tBQzNEO0lBRUQsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFO1FBQ2xCLE9BQU8sQ0FBQyxDQUFDLEdBQUcsQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDO0tBQ3pDO0lBRUQsSUFBSSxPQUFPLENBQUMsS0FBSyxRQUFRLEVBQUU7UUFDdkIsS0FBSyxNQUFNLEdBQUcsSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFO1lBQzlCLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyx1QkFBdUIsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztTQUM1QztLQUNKO0lBRUQsT0FBTyxDQUFDLENBQUM7QUFDYixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgcmVzb2x2ZSwgVG9rZW4gfSBmcm9tIFwiLi4vY29yZS90b2tlbnNcIjtcbmltcG9ydCB7IENsb3VkRm9ybWF0aW9uVG9rZW4sIGlzSW50cmluc2ljIH0gZnJvbSBcIi4vY2xvdWRmb3JtYXRpb24tdG9rZW5cIjtcblxuLyoqXG4gKiBDbGFzcyBmb3IgSlNPTiByb3V0aW5lcyB0aGF0IGFyZSBmcmFtZXdvcmstYXdhcmVcbiAqL1xuZXhwb3J0IGNsYXNzIENsb3VkRm9ybWF0aW9uSlNPTiB7XG4gICAgLyoqXG4gICAgICogVHVybiBhbiBhcmJpdHJhcnkgc3RydWN0dXJlIHBvdGVudGlhbGx5IGNvbnRhaW5pbmcgVG9rZW5zIGludG8gYSBKU09OIHN0cmluZy5cbiAgICAgKlxuICAgICAqIFJldHVybnMgYSBUb2tlbiB3aGljaCB3aWxsIGV2YWx1YXRlIHRvIENsb3VkRm9ybWF0aW9uIGV4cHJlc3Npb24gdGhhdFxuICAgICAqIHdpbGwgYmUgZXZhbHVhdGVkIGJ5IENsb3VkRm9ybWF0aW9uIHRvIHRoZSBKU09OIHJlcHJlc2VudGF0aW9uIG9mIHRoZVxuICAgICAqIGlucHV0IHN0cnVjdHVyZS5cbiAgICAgKlxuICAgICAqIEFsbCBUb2tlbnMgc3Vic3RpdHV0ZWQgaW4gdGhpcyB3YXkgbXVzdCByZXR1cm4gc3RyaW5ncywgb3IgdGhlIGV2YWx1YXRpb25cbiAgICAgKiBpbiBDbG91ZEZvcm1hdGlvbiB3aWxsIGZhaWwuXG4gICAgICovXG4gICAgcHVibGljIHN0YXRpYyBzdHJpbmdpZnkob2JqOiBhbnkpOiBUb2tlbiB7XG4gICAgICAgIHJldHVybiBuZXcgVG9rZW4oKCkgPT4ge1xuICAgICAgICAgICAgLy8gUmVzb2x2ZSBpbm5lciB2YWx1ZSBmaXJzdCBzbyB0aGF0IGlmIHRoZXkgZXZhbHVhdGUgdG8gbGl0ZXJhbHMsIHdlXG4gICAgICAgICAgICAvLyBtYWludGFpbiB0aGUgdHlwZSAoYW5kIGRpc2NhcmQgJ3VuZGVmaW5lZCdzKS5cbiAgICAgICAgICAgIC8vXG4gICAgICAgICAgICAvLyBUaGVuIHJlcGxhY2UgaW50cmluc2ljcyB3aXRoIGEgc3BlY2lhbCBzdWJjbGFzcyBvZiBUb2tlbiB0aGF0XG4gICAgICAgICAgICAvLyBvdmVycmlkZXMgdG9KU09OKCkgdG8gdGhlIG1hcmtlciBzdHJpbmcsIHNvIGlmIHdlIHJlc29sdmUoKSB0aGVcbiAgICAgICAgICAgIC8vIHN0cmluZ3MgYWdhaW4gaXQgZXZhbHVhdGVzIHRvIHRoZSByaWdodCBzdHJpbmcuIEl0IGFsc29cbiAgICAgICAgICAgIC8vIGRlZXAtZXNjYXBlcyBhbnkgc3RyaW5ncyBpbnNpZGUgdGhlIGludHJpbnNpYywgc28gdGhhdCBpZiBsaXRlcmFsXG4gICAgICAgICAgICAvLyBzdHJpbmdzIGFyZSB1c2VkIGluIHtGbjo6Sm9pbn0gb3Igc29tZXRoaW5nLCB0aGV5IHdpbGwgZW5kIHVwXG4gICAgICAgICAgICAvLyBlc2NhcGVkIGluIHRoZSBmaW5hbCBKU09OIG91dHB1dC5cbiAgICAgICAgICAgIGNvbnN0IHJlc29sdmVkID0gcmVzb2x2ZShvYmopO1xuXG4gICAgICAgICAgICAvLyBXZSBjYW4ganVzdCBkaXJlY3RseSByZXR1cm4gdGhpcyB2YWx1ZSwgc2luY2UgcmVzb2x2ZSgpIHdpbGwgYmUgY2FsbGVkXG4gICAgICAgICAgICAvLyBvbiBvdXIgcmV0dXJuIHZhbHVlIGFueXdheS5cbiAgICAgICAgICAgIHJldHVybiBKU09OLnN0cmluZ2lmeShkZWVwUmVwbGFjZUludHJpbnNpY3MocmVzb2x2ZWQpKTtcbiAgICAgICAgfSk7XG5cbiAgICAgICAgLyoqXG4gICAgICAgICAqIFJlY3Vyc2UgaW50byBhIHN0cnVjdHVyZSwgcmVwbGFjZSBhbGwgaW50cmluc2ljcyB3aXRoIEludHJpbnNpY1Rva2Vucy5cbiAgICAgICAgICovXG4gICAgICAgIGZ1bmN0aW9uIGRlZXBSZXBsYWNlSW50cmluc2ljcyh4OiBhbnkpOiBhbnkge1xuICAgICAgICAgICAgaWYgKGlzSW50cmluc2ljKHgpKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIHdyYXBJbnRyaW5zaWMoeCk7XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIGlmIChBcnJheS5pc0FycmF5KHgpKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIHgubWFwKGRlZXBSZXBsYWNlSW50cmluc2ljcyk7XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIGlmICh0eXBlb2YgeCA9PT0gJ29iamVjdCcpIHtcbiAgICAgICAgICAgICAgICBmb3IgKGNvbnN0IGtleSBvZiBPYmplY3Qua2V5cyh4KSkge1xuICAgICAgICAgICAgICAgICAgICB4W2tleV0gPSBkZWVwUmVwbGFjZUludHJpbnNpY3MoeFtrZXldKTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIHJldHVybiB4O1xuICAgICAgICB9XG5cbiAgICAgICAgZnVuY3Rpb24gd3JhcEludHJpbnNpYyhpbnRyaW5zaWM6IGFueSk6IEludHJpbnNpY1Rva2VuIHtcbiAgICAgICAgICAgIHJldHVybiBuZXcgSW50cmluc2ljVG9rZW4oKCkgPT4gZGVlcFF1b3RlU3RyaW5nc0ZvckpTT04oaW50cmluc2ljKSk7XG4gICAgICAgIH1cbiAgICB9XG59XG5cbi8qKlxuICogVG9rZW4gdGhhdCBhbHNvIHN0cmluZ2lmaWVzIGluIHRoZSB0b0pTT04oKSBvcGVyYXRpb24uXG4gKi9cbmNsYXNzIEludHJpbnNpY1Rva2VuIGV4dGVuZHMgQ2xvdWRGb3JtYXRpb25Ub2tlbiB7XG4gICAgLyoqXG4gICAgICogU3BlY2lhbCBoYW5kbGVyIHRoYXQgZ2V0cyBjYWxsZWQgd2hlbiBKU09OLnN0cmluZ2lmeSgpIGlzIHVzZWQuXG4gICAgICovXG4gICAgcHVibGljIHRvSlNPTigpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMudG9TdHJpbmcoKTtcbiAgICB9XG59XG5cbi8qKlxuICogRGVlcCBlc2NhcGUgc3RyaW5ncyBmb3IgdXNlIGluIGEgSlNPTiBjb250ZXh0XG4gKi9cbmZ1bmN0aW9uIGRlZXBRdW90ZVN0cmluZ3NGb3JKU09OKHg6IGFueSk6IGFueSB7XG4gICAgaWYgKHR5cGVvZiB4ID09PSAnc3RyaW5nJykge1xuICAgICAgICAvLyBXaGVuZXZlciB3ZSBlc2NhcGUgYSBzdHJpbmcgd2Ugc3RyaXAgb2ZmIHRoZSBvdXRlcm1vc3QgcXVvdGVzXG4gICAgICAgIC8vIHNpbmNlIHdlJ3JlIGFscmVhZHkgaW4gYSBxdW90ZWQgY29udGV4dC5cbiAgICAgICAgY29uc3Qgc3RyaW5naWZpZWQgPSBKU09OLnN0cmluZ2lmeSh4KTtcbiAgICAgICAgcmV0dXJuIHN0cmluZ2lmaWVkLnN1YnN0cmluZygxLCBzdHJpbmdpZmllZC5sZW5ndGggLSAxKTtcbiAgICB9XG5cbiAgICBpZiAoQXJyYXkuaXNBcnJheSh4KSkge1xuICAgICAgICByZXR1cm4geC5tYXAoZGVlcFF1b3RlU3RyaW5nc0ZvckpTT04pO1xuICAgIH1cblxuICAgIGlmICh0eXBlb2YgeCA9PT0gJ29iamVjdCcpIHtcbiAgICAgICAgZm9yIChjb25zdCBrZXkgb2YgT2JqZWN0LmtleXMoeCkpIHtcbiAgICAgICAgICAgIHhba2V5XSA9IGRlZXBRdW90ZVN0cmluZ3NGb3JKU09OKHhba2V5XSk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICByZXR1cm4geDtcbn0iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xvdWRmb3JtYXRpb24tanNvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImNsb3VkZm9ybWF0aW9uLWpzb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSwyQ0FBZ0Q7QUFDaEQsaUVBQTBFO0FBRTFFOztHQUVHO0FBQ0gsTUFBYSxrQkFBa0I7SUFDN0I7Ozs7Ozs7OztPQVNHO0lBQ0ksTUFBTSxDQUFDLFNBQVMsQ0FBQyxHQUFRO1FBQzlCLE9BQU8sSUFBSSxjQUFLLENBQUMsR0FBRyxFQUFFO1lBQ3BCLHFFQUFxRTtZQUNyRSxnREFBZ0Q7WUFDaEQsRUFBRTtZQUNGLGdFQUFnRTtZQUNoRSxrRUFBa0U7WUFDbEUsMERBQTBEO1lBQzFELG9FQUFvRTtZQUNwRSxnRUFBZ0U7WUFDaEUsb0NBQW9DO1lBQ3BDLE1BQU0sUUFBUSxHQUFHLGdCQUFPLENBQUMsR0FBRyxDQUFDLENBQUM7WUFFOUIseUVBQXlFO1lBQ3pFLDhCQUE4QjtZQUM5QixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMscUJBQXFCLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQztRQUN6RCxDQUFDLENBQUMsQ0FBQztRQUVIOztXQUVHO1FBQ0gsU0FBUyxxQkFBcUIsQ0FBQyxDQUFNO1lBQ25DLElBQUksa0NBQVcsQ0FBQyxDQUFDLENBQUMsRUFBRTtnQkFDbEIsT0FBTyxhQUFhLENBQUMsQ0FBQyxDQUFDLENBQUM7YUFDekI7WUFFRCxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUU7Z0JBQ3BCLE9BQU8sQ0FBQyxDQUFDLEdBQUcsQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO2FBQ3JDO1lBRUQsSUFBSSxPQUFPLENBQUMsS0FBSyxRQUFRLEVBQUU7Z0JBQ3pCLEtBQUssTUFBTSxHQUFHLElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRTtvQkFDaEMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxHQUFHLHFCQUFxQixDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO2lCQUN4QzthQUNGO1lBRUQsT0FBTyxDQUFDLENBQUM7UUFDWCxDQUFDO1FBRUQsU0FBUyxhQUFhLENBQUMsU0FBYztZQUNuQyxPQUFPLElBQUksY0FBYyxDQUFDLEdBQUcsRUFBRSxDQUFDLHVCQUF1QixDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7UUFDdEUsQ0FBQztJQUNILENBQUM7Q0FDRjtBQXRERCxnREFzREM7QUFFRDs7R0FFRztBQUNILE1BQU0sY0FBZSxTQUFRLDBDQUFtQjtJQUM5Qzs7T0FFRztJQUNJLE1BQU07UUFDWCxPQUFPLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUN6QixDQUFDO0NBQ0Y7QUFFRDs7R0FFRztBQUNILFNBQVMsdUJBQXVCLENBQUMsQ0FBTTtJQUNyQyxJQUFJLE9BQU8sQ0FBQyxLQUFLLFFBQVEsRUFBRTtRQUN6QixnRUFBZ0U7UUFDaEUsMkNBQTJDO1FBQzNDLE1BQU0sV0FBVyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDdEMsT0FBTyxXQUFXLENBQUMsU0FBUyxDQUFDLENBQUMsRUFBRSxXQUFXLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDO0tBQ3pEO0lBRUQsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFO1FBQ3BCLE9BQU8sQ0FBQyxDQUFDLEdBQUcsQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDO0tBQ3ZDO0lBRUQsSUFBSSxPQUFPLENBQUMsS0FBSyxRQUFRLEVBQUU7UUFDekIsS0FBSyxNQUFNLEdBQUcsSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFO1lBQ2hDLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyx1QkFBdUIsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztTQUMxQztLQUNGO0lBRUQsT0FBTyxDQUFDLENBQUM7QUFDWCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgcmVzb2x2ZSwgVG9rZW4gfSBmcm9tIFwiLi4vY29yZS90b2tlbnNcIjtcbmltcG9ydCB7IENsb3VkRm9ybWF0aW9uVG9rZW4sIGlzSW50cmluc2ljIH0gZnJvbSBcIi4vY2xvdWRmb3JtYXRpb24tdG9rZW5cIjtcblxuLyoqXG4gKiBDbGFzcyBmb3IgSlNPTiByb3V0aW5lcyB0aGF0IGFyZSBmcmFtZXdvcmstYXdhcmVcbiAqL1xuZXhwb3J0IGNsYXNzIENsb3VkRm9ybWF0aW9uSlNPTiB7XG4gIC8qKlxuICAgKiBUdXJuIGFuIGFyYml0cmFyeSBzdHJ1Y3R1cmUgcG90ZW50aWFsbHkgY29udGFpbmluZyBUb2tlbnMgaW50byBhIEpTT04gc3RyaW5nLlxuICAgKlxuICAgKiBSZXR1cm5zIGEgVG9rZW4gd2hpY2ggd2lsbCBldmFsdWF0ZSB0byBDbG91ZEZvcm1hdGlvbiBleHByZXNzaW9uIHRoYXRcbiAgICogd2lsbCBiZSBldmFsdWF0ZWQgYnkgQ2xvdWRGb3JtYXRpb24gdG8gdGhlIEpTT04gcmVwcmVzZW50YXRpb24gb2YgdGhlXG4gICAqIGlucHV0IHN0cnVjdHVyZS5cbiAgICpcbiAgICogQWxsIFRva2VucyBzdWJzdGl0dXRlZCBpbiB0aGlzIHdheSBtdXN0IHJldHVybiBzdHJpbmdzLCBvciB0aGUgZXZhbHVhdGlvblxuICAgKiBpbiBDbG91ZEZvcm1hdGlvbiB3aWxsIGZhaWwuXG4gICAqL1xuICBwdWJsaWMgc3RhdGljIHN0cmluZ2lmeShvYmo6IGFueSk6IFRva2VuIHtcbiAgICByZXR1cm4gbmV3IFRva2VuKCgpID0+IHtcbiAgICAgIC8vIFJlc29sdmUgaW5uZXIgdmFsdWUgZmlyc3Qgc28gdGhhdCBpZiB0aGV5IGV2YWx1YXRlIHRvIGxpdGVyYWxzLCB3ZVxuICAgICAgLy8gbWFpbnRhaW4gdGhlIHR5cGUgKGFuZCBkaXNjYXJkICd1bmRlZmluZWQncykuXG4gICAgICAvL1xuICAgICAgLy8gVGhlbiByZXBsYWNlIGludHJpbnNpY3Mgd2l0aCBhIHNwZWNpYWwgc3ViY2xhc3Mgb2YgVG9rZW4gdGhhdFxuICAgICAgLy8gb3ZlcnJpZGVzIHRvSlNPTigpIHRvIHRoZSBtYXJrZXIgc3RyaW5nLCBzbyBpZiB3ZSByZXNvbHZlKCkgdGhlXG4gICAgICAvLyBzdHJpbmdzIGFnYWluIGl0IGV2YWx1YXRlcyB0byB0aGUgcmlnaHQgc3RyaW5nLiBJdCBhbHNvXG4gICAgICAvLyBkZWVwLWVzY2FwZXMgYW55IHN0cmluZ3MgaW5zaWRlIHRoZSBpbnRyaW5zaWMsIHNvIHRoYXQgaWYgbGl0ZXJhbFxuICAgICAgLy8gc3RyaW5ncyBhcmUgdXNlZCBpbiB7Rm46OkpvaW59IG9yIHNvbWV0aGluZywgdGhleSB3aWxsIGVuZCB1cFxuICAgICAgLy8gZXNjYXBlZCBpbiB0aGUgZmluYWwgSlNPTiBvdXRwdXQuXG4gICAgICBjb25zdCByZXNvbHZlZCA9IHJlc29sdmUob2JqKTtcblxuICAgICAgLy8gV2UgY2FuIGp1c3QgZGlyZWN0bHkgcmV0dXJuIHRoaXMgdmFsdWUsIHNpbmNlIHJlc29sdmUoKSB3aWxsIGJlIGNhbGxlZFxuICAgICAgLy8gb24gb3VyIHJldHVybiB2YWx1ZSBhbnl3YXkuXG4gICAgICByZXR1cm4gSlNPTi5zdHJpbmdpZnkoZGVlcFJlcGxhY2VJbnRyaW5zaWNzKHJlc29sdmVkKSk7XG4gICAgfSk7XG5cbiAgICAvKipcbiAgICAgKiBSZWN1cnNlIGludG8gYSBzdHJ1Y3R1cmUsIHJlcGxhY2UgYWxsIGludHJpbnNpY3Mgd2l0aCBJbnRyaW5zaWNUb2tlbnMuXG4gICAgICovXG4gICAgZnVuY3Rpb24gZGVlcFJlcGxhY2VJbnRyaW5zaWNzKHg6IGFueSk6IGFueSB7XG4gICAgICBpZiAoaXNJbnRyaW5zaWMoeCkpIHtcbiAgICAgICAgcmV0dXJuIHdyYXBJbnRyaW5zaWMoeCk7XG4gICAgICB9XG5cbiAgICAgIGlmIChBcnJheS5pc0FycmF5KHgpKSB7XG4gICAgICAgIHJldHVybiB4Lm1hcChkZWVwUmVwbGFjZUludHJpbnNpY3MpO1xuICAgICAgfVxuXG4gICAgICBpZiAodHlwZW9mIHggPT09ICdvYmplY3QnKSB7XG4gICAgICAgIGZvciAoY29uc3Qga2V5IG9mIE9iamVjdC5rZXlzKHgpKSB7XG4gICAgICAgICAgeFtrZXldID0gZGVlcFJlcGxhY2VJbnRyaW5zaWNzKHhba2V5XSk7XG4gICAgICAgIH1cbiAgICAgIH1cblxuICAgICAgcmV0dXJuIHg7XG4gICAgfVxuXG4gICAgZnVuY3Rpb24gd3JhcEludHJpbnNpYyhpbnRyaW5zaWM6IGFueSk6IEludHJpbnNpY1Rva2VuIHtcbiAgICAgIHJldHVybiBuZXcgSW50cmluc2ljVG9rZW4oKCkgPT4gZGVlcFF1b3RlU3RyaW5nc0ZvckpTT04oaW50cmluc2ljKSk7XG4gICAgfVxuICB9XG59XG5cbi8qKlxuICogVG9rZW4gdGhhdCBhbHNvIHN0cmluZ2lmaWVzIGluIHRoZSB0b0pTT04oKSBvcGVyYXRpb24uXG4gKi9cbmNsYXNzIEludHJpbnNpY1Rva2VuIGV4dGVuZHMgQ2xvdWRGb3JtYXRpb25Ub2tlbiB7XG4gIC8qKlxuICAgKiBTcGVjaWFsIGhhbmRsZXIgdGhhdCBnZXRzIGNhbGxlZCB3aGVuIEpTT04uc3RyaW5naWZ5KCkgaXMgdXNlZC5cbiAgICovXG4gIHB1YmxpYyB0b0pTT04oKSB7XG4gICAgcmV0dXJuIHRoaXMudG9TdHJpbmcoKTtcbiAgfVxufVxuXG4vKipcbiAqIERlZXAgZXNjYXBlIHN0cmluZ3MgZm9yIHVzZSBpbiBhIEpTT04gY29udGV4dFxuICovXG5mdW5jdGlvbiBkZWVwUXVvdGVTdHJpbmdzRm9ySlNPTih4OiBhbnkpOiBhbnkge1xuICBpZiAodHlwZW9mIHggPT09ICdzdHJpbmcnKSB7XG4gICAgLy8gV2hlbmV2ZXIgd2UgZXNjYXBlIGEgc3RyaW5nIHdlIHN0cmlwIG9mZiB0aGUgb3V0ZXJtb3N0IHF1b3Rlc1xuICAgIC8vIHNpbmNlIHdlJ3JlIGFscmVhZHkgaW4gYSBxdW90ZWQgY29udGV4dC5cbiAgICBjb25zdCBzdHJpbmdpZmllZCA9IEpTT04uc3RyaW5naWZ5KHgpO1xuICAgIHJldHVybiBzdHJpbmdpZmllZC5zdWJzdHJpbmcoMSwgc3RyaW5naWZpZWQubGVuZ3RoIC0gMSk7XG4gIH1cblxuICBpZiAoQXJyYXkuaXNBcnJheSh4KSkge1xuICAgIHJldHVybiB4Lm1hcChkZWVwUXVvdGVTdHJpbmdzRm9ySlNPTik7XG4gIH1cblxuICBpZiAodHlwZW9mIHggPT09ICdvYmplY3QnKSB7XG4gICAgZm9yIChjb25zdCBrZXkgb2YgT2JqZWN0LmtleXMoeCkpIHtcbiAgICAgIHhba2V5XSA9IGRlZXBRdW90ZVN0cmluZ3NGb3JKU09OKHhba2V5XSk7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIHg7XG59XG4iXX0=

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

exports.isIntrinsic = isIntrinsic;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xvdWRmb3JtYXRpb24tdG9rZW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJjbG91ZGZvcm1hdGlvbi10b2tlbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLDJDQUFnRDtBQUVoRDs7R0FFRztBQUNILE1BQWEsbUJBQW9CLFNBQVEsY0FBSztJQUNuQyxNQUFNLENBQUMsSUFBcUIsRUFBRSxLQUFzQjtRQUN2RCxNQUFNLEtBQUssR0FBRyxJQUFJLEtBQUssRUFBTyxDQUFDO1FBQy9CLElBQUksSUFBSSxLQUFLLFNBQVMsRUFBRTtZQUFFLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7U0FBRTtRQUM3QyxLQUFLLENBQUMsSUFBSSxDQUFDLGdCQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztRQUMxQixJQUFJLEtBQUssS0FBSyxTQUFTLEVBQUU7WUFBRSxLQUFLLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1NBQUU7UUFDL0MsT0FBTyxJQUFJLGFBQVEsQ0FBQyxHQUFHLEtBQUssQ0FBQyxDQUFDO0lBQ2xDLENBQUM7Q0FDSjtBQVJELGtEQVFDO0FBRUQsNkJBQWdDO0FBRWhDOztHQUVHO0FBQ0gsU0FBZ0IsV0FBVyxDQUFDLENBQU07SUFDOUIsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxJQUFJLElBQUksT0FBTyxDQUFDLEtBQUssUUFBUSxFQUFFO1FBQUUsT0FBTyxLQUFLLENBQUM7S0FBRTtJQUU5RSxNQUFNLElBQUksR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQzVCLElBQUksSUFBSSxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7UUFBRSxPQUFPLEtBQUssQ0FBQztLQUFFO0lBRXhDLE9BQU8sSUFBSSxDQUFDLENBQUMsQ0FBQyxLQUFLLEtBQUssSUFBSSxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0FBQzNELENBQUM7QUFQRCxrQ0FPQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHJlc29sdmUsIFRva2VuIH0gZnJvbSBcIi4uL2NvcmUvdG9rZW5zXCI7XG5cbi8qKlxuICogQmFzZSBjbGFzcyBmb3IgQ2xvdWRGb3JtYXRpb24gYnVpbHQtaW5zXG4gKi9cbmV4cG9ydCBjbGFzcyBDbG91ZEZvcm1hdGlvblRva2VuIGV4dGVuZHMgVG9rZW4ge1xuICAgIHB1YmxpYyBjb25jYXQobGVmdDogYW55IHwgdW5kZWZpbmVkLCByaWdodDogYW55IHwgdW5kZWZpbmVkKTogVG9rZW4ge1xuICAgICAgICBjb25zdCBwYXJ0cyA9IG5ldyBBcnJheTxhbnk+KCk7XG4gICAgICAgIGlmIChsZWZ0ICE9PSB1bmRlZmluZWQpIHsgcGFydHMucHVzaChsZWZ0KTsgfVxuICAgICAgICBwYXJ0cy5wdXNoKHJlc29sdmUodGhpcykpO1xuICAgICAgICBpZiAocmlnaHQgIT09IHVuZGVmaW5lZCkgeyBwYXJ0cy5wdXNoKHJpZ2h0KTsgfVxuICAgICAgICByZXR1cm4gbmV3IEZuQ29uY2F0KC4uLnBhcnRzKTtcbiAgICB9XG59XG5cbmltcG9ydCB7IEZuQ29uY2F0IH0gZnJvbSBcIi4vZm5cIjtcblxuLyoqXG4gKiBSZXR1cm4gd2hldGhlciB0aGUgZ2l2ZW4gdmFsdWUgcmVwcmVzZW50cyBhIENsb3VkRm9ybWF0aW9uIGludHJpbnNpY1xuICovXG5leHBvcnQgZnVuY3Rpb24gaXNJbnRyaW5zaWMoeDogYW55KSB7XG4gICAgaWYgKEFycmF5LmlzQXJyYXkoeCkgfHwgeCA9PT0gbnVsbCB8fCB0eXBlb2YgeCAhPT0gJ29iamVjdCcpIHsgcmV0dXJuIGZhbHNlOyB9XG5cbiAgICBjb25zdCBrZXlzID0gT2JqZWN0LmtleXMoeCk7XG4gICAgaWYgKGtleXMubGVuZ3RoICE9PSAxKSB7IHJldHVybiBmYWxzZTsgfVxuXG4gICAgcmV0dXJuIGtleXNbMF0gPT09ICdSZWYnIHx8IGtleXNbMF0uc3RhcnRzV2l0aCgnRm46OicpO1xufSJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xvdWRmb3JtYXRpb24tdG9rZW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJjbG91ZGZvcm1hdGlvbi10b2tlbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLDJDQUFnRDtBQUVoRDs7R0FFRztBQUNILE1BQWEsbUJBQW9CLFNBQVEsY0FBSztJQUNyQyxNQUFNLENBQUMsSUFBcUIsRUFBRSxLQUFzQjtRQUN6RCxNQUFNLEtBQUssR0FBRyxJQUFJLEtBQUssRUFBTyxDQUFDO1FBQy9CLElBQUksSUFBSSxLQUFLLFNBQVMsRUFBRTtZQUFFLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7U0FBRTtRQUM3QyxLQUFLLENBQUMsSUFBSSxDQUFDLGdCQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztRQUMxQixJQUFJLEtBQUssS0FBSyxTQUFTLEVBQUU7WUFBRSxLQUFLLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1NBQUU7UUFDL0MsT0FBTyxJQUFJLGFBQVEsQ0FBQyxHQUFHLEtBQUssQ0FBQyxDQUFDO0lBQ2hDLENBQUM7Q0FDRjtBQVJELGtEQVFDO0FBRUQsNkJBQWdDO0FBRWhDOztHQUVHO0FBQ0gsU0FBZ0IsV0FBVyxDQUFDLENBQU07SUFDaEMsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxJQUFJLElBQUksT0FBTyxDQUFDLEtBQUssUUFBUSxFQUFFO1FBQUUsT0FBTyxLQUFLLENBQUM7S0FBRTtJQUU5RSxNQUFNLElBQUksR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQzVCLElBQUksSUFBSSxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7UUFBRSxPQUFPLEtBQUssQ0FBQztLQUFFO0lBRXhDLE9BQU8sSUFBSSxDQUFDLENBQUMsQ0FBQyxLQUFLLEtBQUssSUFBSSxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0FBQ3pELENBQUM7QUFQRCxrQ0FPQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHJlc29sdmUsIFRva2VuIH0gZnJvbSBcIi4uL2NvcmUvdG9rZW5zXCI7XG5cbi8qKlxuICogQmFzZSBjbGFzcyBmb3IgQ2xvdWRGb3JtYXRpb24gYnVpbHQtaW5zXG4gKi9cbmV4cG9ydCBjbGFzcyBDbG91ZEZvcm1hdGlvblRva2VuIGV4dGVuZHMgVG9rZW4ge1xuICBwdWJsaWMgY29uY2F0KGxlZnQ6IGFueSB8IHVuZGVmaW5lZCwgcmlnaHQ6IGFueSB8IHVuZGVmaW5lZCk6IFRva2VuIHtcbiAgICBjb25zdCBwYXJ0cyA9IG5ldyBBcnJheTxhbnk+KCk7XG4gICAgaWYgKGxlZnQgIT09IHVuZGVmaW5lZCkgeyBwYXJ0cy5wdXNoKGxlZnQpOyB9XG4gICAgcGFydHMucHVzaChyZXNvbHZlKHRoaXMpKTtcbiAgICBpZiAocmlnaHQgIT09IHVuZGVmaW5lZCkgeyBwYXJ0cy5wdXNoKHJpZ2h0KTsgfVxuICAgIHJldHVybiBuZXcgRm5Db25jYXQoLi4ucGFydHMpO1xuICB9XG59XG5cbmltcG9ydCB7IEZuQ29uY2F0IH0gZnJvbSBcIi4vZm5cIjtcblxuLyoqXG4gKiBSZXR1cm4gd2hldGhlciB0aGUgZ2l2ZW4gdmFsdWUgcmVwcmVzZW50cyBhIENsb3VkRm9ybWF0aW9uIGludHJpbnNpY1xuICovXG5leHBvcnQgZnVuY3Rpb24gaXNJbnRyaW5zaWMoeDogYW55KSB7XG4gIGlmIChBcnJheS5pc0FycmF5KHgpIHx8IHggPT09IG51bGwgfHwgdHlwZW9mIHggIT09ICdvYmplY3QnKSB7IHJldHVybiBmYWxzZTsgfVxuXG4gIGNvbnN0IGtleXMgPSBPYmplY3Qua2V5cyh4KTtcbiAgaWYgKGtleXMubGVuZ3RoICE9PSAxKSB7IHJldHVybiBmYWxzZTsgfVxuXG4gIHJldHVybiBrZXlzWzBdID09PSAnUmVmJyB8fCBrZXlzWzBdLnN0YXJ0c1dpdGgoJ0ZuOjonKTtcbn1cbiJdfQ==

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

exports.Condition = Condition;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZGl0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiY29uZGl0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBRUEsbUNBQXdDO0FBTXhDOzs7R0FHRztBQUNILE1BQWEsU0FBVSxTQUFRLHFCQUFhO0lBTXhDOzs7T0FHRztJQUNILFlBQVksTUFBaUIsRUFBRSxJQUFZLEVBQUUsS0FBc0I7UUFDL0QsS0FBSyxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUNwQixJQUFJLENBQUMsVUFBVSxHQUFHLEtBQUssSUFBSSxLQUFLLENBQUMsVUFBVSxDQUFDO0lBQ2hELENBQUM7SUFFTSxnQkFBZ0I7UUFDbkIsT0FBTztZQUNILFVBQVUsRUFBRTtnQkFDUixDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsRUFBRSxJQUFJLENBQUMsVUFBVTthQUNwQztTQUNKLENBQUM7SUFDTixDQUFDO0NBQ0o7QUF0QkQsOEJBc0JDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSAnLi4vY29yZS9jb25zdHJ1Y3QnO1xuaW1wb3J0IHsgRm5Db25kaXRpb24gfSBmcm9tICcuL2ZuJztcbmltcG9ydCB7IFJlZmVyZW5jZWFibGUgfSBmcm9tICcuL3N0YWNrJztcblxuZXhwb3J0IGludGVyZmFjZSBDb25kaXRpb25Qcm9wcyB7XG4gICAgZXhwcmVzc2lvbj86IEZuQ29uZGl0aW9uO1xufVxuXG4vKipcbiAqIFJlcHJlc2VudHMgYSBDbG91ZEZvcm1hdGlvbiBjb25kaXRpb24sIGZvciByZXNvdXJjZXMgd2hpY2ggbXVzdCBiZSBjb25kaXRpb25hbGx5IGNyZWF0ZWQgYW5kXG4gKiB0aGUgZGV0ZXJtaW5hdGlvbiBtdXN0IGJlIG1hZGUgYXQgZGVwbG95IHRpbWUuXG4gKi9cbmV4cG9ydCBjbGFzcyBDb25kaXRpb24gZXh0ZW5kcyBSZWZlcmVuY2VhYmxlIHtcbiAgICAvKipcbiAgICAgKiBUaGUgY29uZGl0aW9uIHN0YXRlbWVudC5cbiAgICAgKi9cbiAgICBwdWJsaWMgZXhwcmVzc2lvbj86IEZuQ29uZGl0aW9uO1xuXG4gICAgLyoqXG4gICAgICogQnVpbGQgYSBuZXcgY29uZGl0aW9uLiBUaGUgY29uZGl0aW9uIG11c3QgYmUgY29uc3RydWN0ZWQgd2l0aCBhIGNvbmRpdGlvbiB0b2tlbixcbiAgICAgKiB0aGF0IHRoZSBjb25kaXRpb24gaXMgYmFzZWQgb24uXG4gICAgICovXG4gICAgY29uc3RydWN0b3IocGFyZW50OiBDb25zdHJ1Y3QsIG5hbWU6IHN0cmluZywgcHJvcHM/OiBDb25kaXRpb25Qcm9wcykge1xuICAgICAgICBzdXBlcihwYXJlbnQsIG5hbWUpO1xuICAgICAgICB0aGlzLmV4cHJlc3Npb24gPSBwcm9wcyAmJiBwcm9wcy5leHByZXNzaW9uO1xuICAgIH1cblxuICAgIHB1YmxpYyB0b0Nsb3VkRm9ybWF0aW9uKCk6IG9iamVjdCB7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICBDb25kaXRpb25zOiB7XG4gICAgICAgICAgICAgICAgW3RoaXMubG9naWNhbElkXTogdGhpcy5leHByZXNzaW9uXG4gICAgICAgICAgICB9XG4gICAgICAgIH07XG4gICAgfVxufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZGl0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiY29uZGl0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBRUEsbUNBQXdDO0FBTXhDOzs7R0FHRztBQUNILE1BQWEsU0FBVSxTQUFRLHFCQUFhO0lBTTFDOzs7T0FHRztJQUNILFlBQVksTUFBaUIsRUFBRSxJQUFZLEVBQUUsS0FBc0I7UUFDakUsS0FBSyxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUNwQixJQUFJLENBQUMsVUFBVSxHQUFHLEtBQUssSUFBSSxLQUFLLENBQUMsVUFBVSxDQUFDO0lBQzlDLENBQUM7SUFFTSxnQkFBZ0I7UUFDckIsT0FBTztZQUNMLFVBQVUsRUFBRTtnQkFDVixDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsRUFBRSxJQUFJLENBQUMsVUFBVTthQUNsQztTQUNGLENBQUM7SUFDSixDQUFDO0NBQ0Y7QUF0QkQsOEJBc0JDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSAnLi4vY29yZS9jb25zdHJ1Y3QnO1xuaW1wb3J0IHsgRm5Db25kaXRpb24gfSBmcm9tICcuL2ZuJztcbmltcG9ydCB7IFJlZmVyZW5jZWFibGUgfSBmcm9tICcuL3N0YWNrJztcblxuZXhwb3J0IGludGVyZmFjZSBDb25kaXRpb25Qcm9wcyB7XG4gIGV4cHJlc3Npb24/OiBGbkNvbmRpdGlvbjtcbn1cblxuLyoqXG4gKiBSZXByZXNlbnRzIGEgQ2xvdWRGb3JtYXRpb24gY29uZGl0aW9uLCBmb3IgcmVzb3VyY2VzIHdoaWNoIG11c3QgYmUgY29uZGl0aW9uYWxseSBjcmVhdGVkIGFuZFxuICogdGhlIGRldGVybWluYXRpb24gbXVzdCBiZSBtYWRlIGF0IGRlcGxveSB0aW1lLlxuICovXG5leHBvcnQgY2xhc3MgQ29uZGl0aW9uIGV4dGVuZHMgUmVmZXJlbmNlYWJsZSB7XG4gIC8qKlxuICAgKiBUaGUgY29uZGl0aW9uIHN0YXRlbWVudC5cbiAgICovXG4gIHB1YmxpYyBleHByZXNzaW9uPzogRm5Db25kaXRpb247XG5cbiAgLyoqXG4gICAqIEJ1aWxkIGEgbmV3IGNvbmRpdGlvbi4gVGhlIGNvbmRpdGlvbiBtdXN0IGJlIGNvbnN0cnVjdGVkIHdpdGggYSBjb25kaXRpb24gdG9rZW4sXG4gICAqIHRoYXQgdGhlIGNvbmRpdGlvbiBpcyBiYXNlZCBvbi5cbiAgICovXG4gIGNvbnN0cnVjdG9yKHBhcmVudDogQ29uc3RydWN0LCBuYW1lOiBzdHJpbmcsIHByb3BzPzogQ29uZGl0aW9uUHJvcHMpIHtcbiAgICBzdXBlcihwYXJlbnQsIG5hbWUpO1xuICAgIHRoaXMuZXhwcmVzc2lvbiA9IHByb3BzICYmIHByb3BzLmV4cHJlc3Npb247XG4gIH1cblxuICBwdWJsaWMgdG9DbG91ZEZvcm1hdGlvbigpOiBvYmplY3Qge1xuICAgIHJldHVybiB7XG4gICAgICBDb25kaXRpb25zOiB7XG4gICAgICAgIFt0aGlzLmxvZ2ljYWxJZF06IHRoaXMuZXhwcmVzc2lvblxuICAgICAgfVxuICAgIH07XG4gIH1cbn1cbiJdfQ==

@@ -44,5 +44,5 @@ import { CloudFormationToken } from './cloudformation-token';

* @param region The name of the region for which you want to get the Availability Zones.
* You can use the AWS::Region pseudo parameter to specify the region in
* which the stack is created. Specifying an empty string is equivalent to
* specifying AWS::Region.
* You can use the AWS::Region pseudo parameter to specify the region in
* which the stack is created. Specifying an empty string is equivalent to
* specifying AWS::Region.
*/

@@ -72,3 +72,3 @@ constructor(region?: string);

* @param delimiter The value you want to occur between fragments. The delimiter will occur between fragments only.
* It will not terminate the final value.
* It will not terminate the final value.
* @param listOfValues The list of values you want combined.

@@ -123,8 +123,8 @@ */

* @param body A string with variables that AWS CloudFormation substitutes with their
* associated values at runtime. Write variables as ${MyVarName}. Variables
* can be template parameter names, resource logical IDs, resource attributes,
* or a variable in a key-value map. If you specify only template parameter names,
* resource logical IDs, and resource attributes, don't specify a key-value map.
* associated values at runtime. Write variables as ${MyVarName}. Variables
* can be template parameter names, resource logical IDs, resource attributes,
* or a variable in a key-value map. If you specify only template parameter names,
* resource logical IDs, and resource attributes, don't specify a key-value map.
* @param variables The name of a variable that you included in the String parameter.
* The value that AWS CloudFormation substitutes for the associated variable name at runtime.
* The value that AWS CloudFormation substitutes for the associated variable name at runtime.
*/

@@ -154,3 +154,3 @@ constructor(body: string, variables?: {

* @param ipBlock The user-specified default Cidr address block.
* @param count The number of subnets' Cidr block wanted. Count can be 1 to 256.
* @param count The number of subnets' Cidr block wanted. Count can be 1 to 256.
* @param sizeMask The digit covered in the subnet.

@@ -281,4 +281,4 @@ */

* @param parameterType An AWS-specific parameter type, such as AWS::EC2::SecurityGroup::Id or
* AWS::EC2::VPC::Id. For more information, see Parameters in the AWS
* CloudFormation User Guide.
* AWS::EC2::VPC::Id. For more information, see Parameters in the AWS
* CloudFormation User Guide.
*/

@@ -285,0 +285,0 @@ constructor(parameterType: string);

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

* @param region The name of the region for which you want to get the Availability Zones.
* You can use the AWS::Region pseudo parameter to specify the region in
* which the stack is created. Specifying an empty string is equivalent to
* specifying AWS::Region.
* You can use the AWS::Region pseudo parameter to specify the region in
* which the stack is created. Specifying an empty string is equivalent to
* specifying AWS::Region.
*/

@@ -90,3 +90,3 @@ constructor(region) {

* @param delimiter The value you want to occur between fragments. The delimiter will occur between fragments only.
* It will not terminate the final value.
* It will not terminate the final value.
* @param listOfValues The list of values you want combined.

@@ -190,8 +190,8 @@ */

* @param body A string with variables that AWS CloudFormation substitutes with their
* associated values at runtime. Write variables as ${MyVarName}. Variables
* can be template parameter names, resource logical IDs, resource attributes,
* or a variable in a key-value map. If you specify only template parameter names,
* resource logical IDs, and resource attributes, don't specify a key-value map.
* associated values at runtime. Write variables as ${MyVarName}. Variables
* can be template parameter names, resource logical IDs, resource attributes,
* or a variable in a key-value map. If you specify only template parameter names,
* resource logical IDs, and resource attributes, don't specify a key-value map.
* @param variables The name of a variable that you included in the String parameter.
* The value that AWS CloudFormation substitutes for the associated variable name at runtime.
* The value that AWS CloudFormation substitutes for the associated variable name at runtime.
*/

@@ -225,3 +225,3 @@ constructor(body, variables) {

* @param ipBlock The user-specified default Cidr address block.
* @param count The number of subnets' Cidr block wanted. Count can be 1 to 256.
* @param count The number of subnets' Cidr block wanted. Count can be 1 to 256.
* @param sizeMask The digit covered in the subnet.

@@ -383,4 +383,4 @@ */

* @param parameterType An AWS-specific parameter type, such as AWS::EC2::SecurityGroup::Id or
* AWS::EC2::VPC::Id. For more information, see Parameters in the AWS
* CloudFormation User Guide.
* AWS::EC2::VPC::Id. For more information, see Parameters in the AWS
* CloudFormation User Guide.
*/

@@ -420,2 +420,2 @@ constructor(parameterType) {

exports.FnValueOfAll = FnValueOfAll;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fn.js","sourceRoot":"","sources":["fn.ts"],"names":[],"mappings":"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","sourcesContent":["import { CloudFormationToken, isIntrinsic } from './cloudformation-token';\n// tslint:disable:max-line-length\n\n/**\n * CloudFormation intrinsic functions.\n * http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/intrinsic-function-reference.html\n */\nexport class Fn extends CloudFormationToken {\n    constructor(name: string, value: any) {\n        super(() => ({ [name]: value }));\n    }\n}\n\n/**\n * The intrinsic function ``Fn::FindInMap`` returns the value corresponding to keys in a two-level\n * map that is declared in the Mappings section.\n */\nexport class FnFindInMap extends Fn {\n    /**\n     * Creates an ``Fn::FindInMap`` function.\n     * @param mapName The logical name of a mapping declared in the Mappings section that contains the keys and values.\n     * @param topLevelKey The top-level key name. Its value is a list of key-value pairs.\n     * @param secondLevelKey The second-level key name, which is set to one of the keys from the list assigned to TopLevelKey.\n     */\n    constructor(mapName: string, topLevelKey: any, secondLevelKey: any) {\n        super('Fn::FindInMap', [ mapName, topLevelKey, secondLevelKey ]);\n    }\n}\n\n/**\n * The ``Fn::GetAtt`` intrinsic function returns the value of an attribute from a resource in the template.\n */\nexport class FnGetAtt extends Fn {\n    /**\n     * Creates a ``Fn::GetAtt`` function.\n     * @param logicalNameOfResource The logical name (also called logical ID) of the resource that contains the attribute that you want.\n     * @param attributeName The name of the resource-specific attribute whose value you want. See the resource's reference page for details about the attributes available for that resource type.\n     */\n    constructor(logicalNameOfResource: string, attributeName: string) {\n        super('Fn::GetAtt', [ logicalNameOfResource, attributeName ]);\n    }\n}\n\n/**\n * The intrinsic function ``Fn::GetAZs`` returns an array that lists Availability Zones for a\n * specified region. Because customers have access to different Availability Zones, the intrinsic\n * function ``Fn::GetAZs`` enables template authors to write templates that adapt to the calling\n * user's access. That way you don't have to hard-code a full list of Availability Zones for a\n * specified region.\n */\nexport class FnGetAZs extends Fn {\n    /**\n     * Creates an ``Fn::GetAZs`` function.\n     * @param region The name of the region for which you want to get the Availability Zones.\n     *               You can use the AWS::Region pseudo parameter to specify the region in\n     *               which the stack is created. Specifying an empty string is equivalent to\n     *               specifying AWS::Region.\n     */\n    constructor(region?: string) {\n        super('Fn::GetAZs', region || '');\n    }\n}\n\n/**\n * The intrinsic function ``Fn::ImportValue`` returns the value of an output exported by another stack.\n * You typically use this function to create cross-stack references. In the following example\n * template snippets, Stack A exports VPC security group values and Stack B imports them.\n */\nexport class FnImportValue extends Fn {\n    /**\n     * Creates an ``Fn::ImportValue`` function.\n     * @param sharedValueToImport The stack output value that you want to import.\n     */\n    constructor(sharedValueToImport: string) {\n        super('Fn::ImportValue', sharedValueToImport);\n    }\n}\n\n/**\n * The intrinsic function ``Fn::Join`` appends a set of values into a single value, separated by\n * the specified delimiter. If a delimiter is the empty string, the set of values are concatenated\n * with no delimiter.\n */\nexport class FnJoin extends Fn {\n    /**\n     * Creates an ``Fn::Join`` function.\n     * @param delimiter The value you want to occur between fragments. The delimiter will occur between fragments only.\n     *                  It will not terminate the final value.\n     * @param listOfValues The list of values you want combined.\n     */\n    constructor(delimiter: string, listOfValues: any[]) {\n        if (listOfValues.length === 0) {\n            throw new Error(`FnJoin requires at least one value to be provided`);\n        }\n        super('Fn::Join', [ delimiter, listOfValues ]);\n    }\n}\n\n/**\n * Alias for ``FnJoin('', listOfValues)``.\n */\nexport class FnConcat extends FnJoin {\n    private readonly listOfValues: any[];\n\n    /**\n     * Creates an ``Fn::Join`` function with an empty delimiter.\n     * @param listOfValues The list of values to concatenate.\n     */\n    constructor(...listOfValues: any[]) {\n        // Optimization: if any of the input arguments is also a FnConcat,\n        // splice their list of values into the current FnConcat. 'instanceof'\n        // can fail, but we do not depend depend on this for correctness.\n        //\n        // Do the same for resolved intrinsics, so we can detect this\n        // happening both at Token as well as at CloudFormation level.\n\n        let i = 0;\n        while (i < listOfValues.length) {\n            const el = listOfValues[i];\n            if (el instanceof FnConcat) {\n                listOfValues.splice(i, 1, ...el.listOfValues);\n                i += el.listOfValues.length;\n            } else if (isConcatIntrinsic(el)) {\n                const values = concatIntrinsicValues(el);\n                listOfValues.splice(i, 1, ...values);\n                i += values;\n            } else {\n                i++;\n            }\n        }\n\n        super('', listOfValues);\n        this.listOfValues = listOfValues;\n    }\n}\n\n/**\n * Return whether the given object represents a CloudFormation intrinsic that is the result of a FnConcat resolution\n */\nfunction isConcatIntrinsic(x: any) {\n    return isIntrinsic(x) && Object.keys(x)[0] === 'Fn::Join' && x['Fn::Join'][0] === '';\n}\n\n/**\n * Return the concatted values of the concat intrinsic\n */\nfunction concatIntrinsicValues(x: any) {\n    return x['Fn::Join'][1];\n}\n\n/**\n * The intrinsic function ``Fn::Select`` returns a single object from a list of objects by index.\n */\nexport class FnSelect extends Fn {\n    /**\n     * Creates an ``Fn::Select`` function.\n     * @param index The index of the object to retrieve. This must be a value from zero to N-1, where N represents the number of elements in the array.\n     * @param array The list of objects to select from. This list must not be null, nor can it have null entries.\n     */\n    constructor(index: number, array: any) {\n        super('Fn::Select', [ index, array ]);\n    }\n}\n\n/**\n * To split a string into a list of string values so that you can select an element from the\n * resulting string list, use the ``Fn::Split`` intrinsic function. Specify the location of splits\n * with a delimiter, such as , (a comma). After you split a string, use the ``Fn::Select`` function\n * to pick a specific element.\n */\nexport class FnSplit extends Fn {\n    /**\n     * Create an ``Fn::Split`` function.\n     * @param delimiter A string value that determines where the source string is divided.\n     * @param source The string value that you want to split.\n     */\n    constructor(delimiter: string, source: any) {\n        super('Fn::Split', [ delimiter, source ]);\n    }\n}\n\n/**\n * The intrinsic function ``Fn::Sub`` substitutes variables in an input string with values that\n * you specify. In your templates, you can use this function to construct commands or outputs\n * that include values that aren't available until you create or update a stack.\n */\nexport class FnSub extends Fn {\n    /**\n     * Creates an ``Fn::Sub`` function.\n     * @param body A string with variables that AWS CloudFormation substitutes with their\n     *             associated values at runtime. Write variables as ${MyVarName}. Variables\n     *             can be template parameter names, resource logical IDs, resource attributes,\n     *             or a variable in a key-value map. If you specify only template parameter names,\n     *             resource logical IDs, and resource attributes, don't specify a key-value map.\n     * @param variables The name of a variable that you included in the String parameter.\n     *                  The value that AWS CloudFormation substitutes for the associated variable name at runtime.\n     */\n    constructor(body: string, variables?: { [key: string]: any }) {\n        super('Fn::Sub', variables ? [body, variables] : body);\n    }\n}\n\n/**\n * The intrinsic function ``Fn::Base64`` returns the Base64 representation of the input string.\n * This function is typically used to pass encoded data to Amazon EC2 instances by way of\n * the UserData property.\n */\nexport class FnBase64 extends Fn {\n\n    /**\n     * Creates an ``Fn::Base64`` function.\n     * @param data The string value you want to convert to Base64.\n     */\n    constructor(data: any) {\n        super('Fn::Base64', data);\n    }\n}\n\n/**\n * The intrinsic function ``Fn::Cidr`` returns the specified Cidr address block.\n */\nexport class FnCidr extends Fn {\n    /**\n     * Creates an ``Fn::Cidr`` function.\n     * @param ipBlock  The user-specified default Cidr address block.\n     * @param count    The number of subnets' Cidr block wanted. Count can be 1 to 256.\n     * @param sizeMask The digit covered in the subnet.\n     */\n    constructor(ipBlock: any, count: any, sizeMask?: any) {\n        if (count < 1 || count > 256) {\n            throw new Error(`Fn::Cidr's count attribute must be betwen 1 and 256, ${count} was provided.`);\n        }\n        super('Fn::Cidr', [ipBlock, count, sizeMask]);\n    }\n}\n\n/**\n * You can use intrinsic functions, such as ``Fn::If``, ``Fn::Equals``, and ``Fn::Not``, to conditionally\n * create stack resources. These conditions are evaluated based on input parameters that you\n * declare when you create or update a stack. After you define all your conditions, you can\n * associate them with resources or resource properties in the Resources and Outputs sections\n * of a template.\n *\n * You define all conditions in the Conditions section of a template except for ``Fn::If`` conditions.\n * You can use the ``Fn::If`` condition in the metadata attribute, update policy attribute, and property\n * values in the Resources section and Outputs sections of a template.\n *\n * You might use conditions when you want to reuse a template that can create resources in different\n * contexts, such as a test environment versus a production environment. In your template, you can\n * add an EnvironmentType input parameter, which accepts either prod or test as inputs. For the\n * production environment, you might include Amazon EC2 instances with certain capabilities;\n * however, for the test environment, you want to use less capabilities to save costs. With\n * conditions, you can define which resources are created and how they're configured for each\n * environment type.\n */\nexport class FnCondition extends Fn {\n\n}\n\n/**\n * Returns true if all the specified conditions evaluate to true, or returns false if any one\n *  of the conditions evaluates to false. ``Fn::And`` acts as an AND operator. The minimum number of\n * conditions that you can include is 2, and the maximum is 10.\n */\nexport class FnAnd extends FnCondition {\n    constructor(...condition: FnCondition[]) {\n        super('Fn::And', condition);\n    }\n}\n\n/**\n * Compares if two values are equal. Returns true if the two values are equal or false\n * if they aren't.\n */\nexport class FnEquals extends FnCondition {\n    /**\n     * Creates an ``Fn::Equals`` condition function.\n     * @param lhs A value of any type that you want to compare.\n     * @param rhs A value of any type that you want to compare.\n     */\n    constructor(lhs: any, rhs: any) {\n        super('Fn::Equals', [ lhs, rhs ]);\n    }\n}\n\n/**\n * Returns one value if the specified condition evaluates to true and another value if the\n * specified condition evaluates to false. Currently, AWS CloudFormation supports the ``Fn::If``\n * intrinsic function in the metadata attribute, update policy attribute, and property values\n * in the Resources section and Outputs sections of a template. You can use the AWS::NoValue\n * pseudo parameter as a return value to remove the corresponding property.\n */\nexport class FnIf extends FnCondition {\n    /**\n     * Creates an ``Fn::If`` condition function.\n     * @param condition A reference to a condition in the Conditions section. Use the condition's name to reference it.\n     * @param valueIfTrue A value to be returned if the specified condition evaluates to true.\n     * @param valueIfFalse A value to be returned if the specified condition evaluates to false.\n     */\n    constructor(condition: string, valueIfTrue: any, valueIfFalse: any) {\n        super('Fn::If', [ condition, valueIfTrue, valueIfFalse ]);\n    }\n}\n\n/**\n * Returns true for a condition that evaluates to false or returns false for a condition that evaluates to true.\n * ``Fn::Not`` acts as a NOT operator.\n */\nexport class FnNot extends FnCondition {\n    /**\n     * Creates an ``Fn::Not`` condition function.\n     * @param condition A condition such as ``Fn::Equals`` that evaluates to true or false.\n     */\n    constructor(condition: FnCondition) {\n        super('Fn::Not', [ condition ]);\n    }\n}\n\n/**\n * Returns true if any one of the specified conditions evaluate to true, or returns false if\n * all of the conditions evaluates to false. ``Fn::Or`` acts as an OR operator. The minimum number\n * of conditions that you can include is 2, and the maximum is 10.\n */\nexport class FnOr extends FnCondition {\n    /**\n     * Creates an ``Fn::Or`` condition function.\n     * @param condition A condition that evaluates to true or false.\n     */\n    constructor(...condition: FnCondition[]) {\n        super('Fn::Or', condition);\n    }\n}\n\n/**\n * Returns true if a specified string matches at least one value in a list of strings.\n */\nexport class FnContains extends FnCondition {\n    /**\n     * Creates an ``Fn::Contains`` function.\n     * @param listOfStrings A list of strings, such as \"A\", \"B\", \"C\".\n     * @param value A string, such as \"A\", that you want to compare against a list of strings.\n     */\n    constructor(listOfStrings: any, value: string) {\n        super('Fn::Contains', [ listOfStrings, value ]);\n    }\n}\n\n/**\n * Returns true if a specified string matches all values in a list.\n */\nexport class FnEachMemberEquals extends FnCondition {\n    /**\n     * Creates an ``Fn::EachMemberEquals`` function.\n     * @param listOfStrings A list of strings, such as \"A\", \"B\", \"C\".\n     * @param value A string, such as \"A\", that you want to compare against a list of strings.\n     */\n    constructor(listOfStrings: any, value: string) {\n        super('Fn::EachMemberEquals', [ listOfStrings, value ]);\n    }\n}\n\n/**\n * Returns true if each member in a list of strings matches at least one value in a second\n * list of strings.\n */\nexport class FnEachMemberIn extends FnCondition {\n    /**\n     * Creates an ``Fn::EachMemberIn`` function.\n     * @param stringsToCheck A list of strings, such as \"A\", \"B\", \"C\". AWS CloudFormation checks whether each member in the strings_to_check parameter is in the strings_to_match parameter.\n     * @param stringsToMatch A list of strings, such as \"A\", \"B\", \"C\". Each member in the strings_to_match parameter is compared against the members of the strings_to_check parameter.\n     */\n    constructor(stringsToCheck: any, stringsToMatch: any) {\n        super('Fn::EachMemberIn', [ [stringsToCheck], stringsToMatch ]);\n    }\n}\n\n/**\n * Returns all values for a specified parameter type.\n */\nexport class FnRefAll extends FnCondition {\n    /**\n     * Creates an ``Fn::RefAll`` function.\n     * @param parameterType An AWS-specific parameter type, such as AWS::EC2::SecurityGroup::Id or\n     *                      AWS::EC2::VPC::Id. For more information, see Parameters in the AWS\n     *                      CloudFormation User Guide.\n     */\n    constructor(parameterType: string) {\n        super('Fn::RefAll', parameterType);\n    }\n}\n\n/**\n * Returns an attribute value or list of values for a specific parameter and attribute.\n */\nexport class FnValueOf extends FnCondition {\n    /**\n     * Creates an ``Fn::ValueOf`` function.\n     * @param parameterOrLogicalId The name of a parameter for which you want to retrieve attribute values. The parameter must be declared in the Parameters section of the template.\n     * @param attribute The name of an attribute from which you want to retrieve a value.\n     */\n    constructor(parameterOrLogicalId: string, attribute: string) {\n        super('Fn::ValueOf', [ parameterOrLogicalId, attribute ]);\n    }\n}\n\n/**\n * Returns a list of all attribute values for a given parameter type and attribute.\n */\nexport class FnValueOfAll extends FnCondition {\n    /**\n     * Creates an ``Fn::ValueOfAll`` function.\n     * @param parameterType An AWS-specific parameter type, such as AWS::EC2::SecurityGroup::Id or AWS::EC2::VPC::Id. For more information, see Parameters in the AWS CloudFormation User Guide.\n     * @param attribute The name of an attribute from which you want to retrieve a value. For more information about attributes, see Supported Attributes.\n     */\n    constructor(parameterType: string, attribute: string) {\n        super('Fn::ValueOfAll', [ parameterType, attribute ]);\n    }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fn.js","sourceRoot":"","sources":["fn.ts"],"names":[],"mappings":"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","sourcesContent":["import { CloudFormationToken, isIntrinsic } from './cloudformation-token';\n// tslint:disable:max-line-length\n\n/**\n * CloudFormation intrinsic functions.\n * http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/intrinsic-function-reference.html\n */\nexport class Fn extends CloudFormationToken {\n  constructor(name: string, value: any) {\n    super(() => ({ [name]: value }));\n  }\n}\n\n/**\n * The intrinsic function ``Fn::FindInMap`` returns the value corresponding to keys in a two-level\n * map that is declared in the Mappings section.\n */\nexport class FnFindInMap extends Fn {\n  /**\n   * Creates an ``Fn::FindInMap`` function.\n   * @param mapName The logical name of a mapping declared in the Mappings section that contains the keys and values.\n   * @param topLevelKey The top-level key name. Its value is a list of key-value pairs.\n   * @param secondLevelKey The second-level key name, which is set to one of the keys from the list assigned to TopLevelKey.\n   */\n  constructor(mapName: string, topLevelKey: any, secondLevelKey: any) {\n    super('Fn::FindInMap', [ mapName, topLevelKey, secondLevelKey ]);\n  }\n}\n\n/**\n * The ``Fn::GetAtt`` intrinsic function returns the value of an attribute from a resource in the template.\n */\nexport class FnGetAtt extends Fn {\n  /**\n   * Creates a ``Fn::GetAtt`` function.\n   * @param logicalNameOfResource The logical name (also called logical ID) of the resource that contains the attribute that you want.\n   * @param attributeName The name of the resource-specific attribute whose value you want. See the resource's reference page for details about the attributes available for that resource type.\n   */\n  constructor(logicalNameOfResource: string, attributeName: string) {\n    super('Fn::GetAtt', [ logicalNameOfResource, attributeName ]);\n  }\n}\n\n/**\n * The intrinsic function ``Fn::GetAZs`` returns an array that lists Availability Zones for a\n * specified region. Because customers have access to different Availability Zones, the intrinsic\n * function ``Fn::GetAZs`` enables template authors to write templates that adapt to the calling\n * user's access. That way you don't have to hard-code a full list of Availability Zones for a\n * specified region.\n */\nexport class FnGetAZs extends Fn {\n  /**\n   * Creates an ``Fn::GetAZs`` function.\n   * @param region The name of the region for which you want to get the Availability Zones.\n   *         You can use the AWS::Region pseudo parameter to specify the region in\n   *         which the stack is created. Specifying an empty string is equivalent to\n   *         specifying AWS::Region.\n   */\n  constructor(region?: string) {\n    super('Fn::GetAZs', region || '');\n  }\n}\n\n/**\n * The intrinsic function ``Fn::ImportValue`` returns the value of an output exported by another stack.\n * You typically use this function to create cross-stack references. In the following example\n * template snippets, Stack A exports VPC security group values and Stack B imports them.\n */\nexport class FnImportValue extends Fn {\n  /**\n   * Creates an ``Fn::ImportValue`` function.\n   * @param sharedValueToImport The stack output value that you want to import.\n   */\n  constructor(sharedValueToImport: string) {\n    super('Fn::ImportValue', sharedValueToImport);\n  }\n}\n\n/**\n * The intrinsic function ``Fn::Join`` appends a set of values into a single value, separated by\n * the specified delimiter. If a delimiter is the empty string, the set of values are concatenated\n * with no delimiter.\n */\nexport class FnJoin extends Fn {\n  /**\n   * Creates an ``Fn::Join`` function.\n   * @param delimiter The value you want to occur between fragments. The delimiter will occur between fragments only.\n   *          It will not terminate the final value.\n   * @param listOfValues The list of values you want combined.\n   */\n  constructor(delimiter: string, listOfValues: any[]) {\n    if (listOfValues.length === 0) {\n      throw new Error(`FnJoin requires at least one value to be provided`);\n    }\n    super('Fn::Join', [ delimiter, listOfValues ]);\n  }\n}\n\n/**\n * Alias for ``FnJoin('', listOfValues)``.\n */\nexport class FnConcat extends FnJoin {\n  private readonly listOfValues: any[];\n\n  /**\n   * Creates an ``Fn::Join`` function with an empty delimiter.\n   * @param listOfValues The list of values to concatenate.\n   */\n  constructor(...listOfValues: any[]) {\n    // Optimization: if any of the input arguments is also a FnConcat,\n    // splice their list of values into the current FnConcat. 'instanceof'\n    // can fail, but we do not depend depend on this for correctness.\n    //\n    // Do the same for resolved intrinsics, so we can detect this\n    // happening both at Token as well as at CloudFormation level.\n\n    let i = 0;\n    while (i < listOfValues.length) {\n      const el = listOfValues[i];\n      if (el instanceof FnConcat) {\n        listOfValues.splice(i, 1, ...el.listOfValues);\n        i += el.listOfValues.length;\n      } else if (isConcatIntrinsic(el)) {\n        const values = concatIntrinsicValues(el);\n        listOfValues.splice(i, 1, ...values);\n        i += values;\n      } else {\n        i++;\n      }\n    }\n\n    super('', listOfValues);\n    this.listOfValues = listOfValues;\n  }\n}\n\n/**\n * Return whether the given object represents a CloudFormation intrinsic that is the result of a FnConcat resolution\n */\nfunction isConcatIntrinsic(x: any) {\n  return isIntrinsic(x) && Object.keys(x)[0] === 'Fn::Join' && x['Fn::Join'][0] === '';\n}\n\n/**\n * Return the concatted values of the concat intrinsic\n */\nfunction concatIntrinsicValues(x: any) {\n  return x['Fn::Join'][1];\n}\n\n/**\n * The intrinsic function ``Fn::Select`` returns a single object from a list of objects by index.\n */\nexport class FnSelect extends Fn {\n  /**\n   * Creates an ``Fn::Select`` function.\n   * @param index The index of the object to retrieve. This must be a value from zero to N-1, where N represents the number of elements in the array.\n   * @param array The list of objects to select from. This list must not be null, nor can it have null entries.\n   */\n  constructor(index: number, array: any) {\n    super('Fn::Select', [ index, array ]);\n  }\n}\n\n/**\n * To split a string into a list of string values so that you can select an element from the\n * resulting string list, use the ``Fn::Split`` intrinsic function. Specify the location of splits\n * with a delimiter, such as , (a comma). After you split a string, use the ``Fn::Select`` function\n * to pick a specific element.\n */\nexport class FnSplit extends Fn {\n  /**\n   * Create an ``Fn::Split`` function.\n   * @param delimiter A string value that determines where the source string is divided.\n   * @param source The string value that you want to split.\n   */\n  constructor(delimiter: string, source: any) {\n    super('Fn::Split', [ delimiter, source ]);\n  }\n}\n\n/**\n * The intrinsic function ``Fn::Sub`` substitutes variables in an input string with values that\n * you specify. In your templates, you can use this function to construct commands or outputs\n * that include values that aren't available until you create or update a stack.\n */\nexport class FnSub extends Fn {\n  /**\n   * Creates an ``Fn::Sub`` function.\n   * @param body A string with variables that AWS CloudFormation substitutes with their\n   *       associated values at runtime. Write variables as ${MyVarName}. Variables\n   *       can be template parameter names, resource logical IDs, resource attributes,\n   *       or a variable in a key-value map. If you specify only template parameter names,\n   *       resource logical IDs, and resource attributes, don't specify a key-value map.\n   * @param variables The name of a variable that you included in the String parameter.\n   *          The value that AWS CloudFormation substitutes for the associated variable name at runtime.\n   */\n  constructor(body: string, variables?: { [key: string]: any }) {\n    super('Fn::Sub', variables ? [body, variables] : body);\n  }\n}\n\n/**\n * The intrinsic function ``Fn::Base64`` returns the Base64 representation of the input string.\n * This function is typically used to pass encoded data to Amazon EC2 instances by way of\n * the UserData property.\n */\nexport class FnBase64 extends Fn {\n\n  /**\n   * Creates an ``Fn::Base64`` function.\n   * @param data The string value you want to convert to Base64.\n   */\n  constructor(data: any) {\n    super('Fn::Base64', data);\n  }\n}\n\n/**\n * The intrinsic function ``Fn::Cidr`` returns the specified Cidr address block.\n */\nexport class FnCidr extends Fn {\n  /**\n   * Creates an ``Fn::Cidr`` function.\n   * @param ipBlock  The user-specified default Cidr address block.\n   * @param count  The number of subnets' Cidr block wanted. Count can be 1 to 256.\n   * @param sizeMask The digit covered in the subnet.\n   */\n  constructor(ipBlock: any, count: any, sizeMask?: any) {\n    if (count < 1 || count > 256) {\n      throw new Error(`Fn::Cidr's count attribute must be betwen 1 and 256, ${count} was provided.`);\n    }\n    super('Fn::Cidr', [ipBlock, count, sizeMask]);\n  }\n}\n\n/**\n * You can use intrinsic functions, such as ``Fn::If``, ``Fn::Equals``, and ``Fn::Not``, to conditionally\n * create stack resources. These conditions are evaluated based on input parameters that you\n * declare when you create or update a stack. After you define all your conditions, you can\n * associate them with resources or resource properties in the Resources and Outputs sections\n * of a template.\n *\n * You define all conditions in the Conditions section of a template except for ``Fn::If`` conditions.\n * You can use the ``Fn::If`` condition in the metadata attribute, update policy attribute, and property\n * values in the Resources section and Outputs sections of a template.\n *\n * You might use conditions when you want to reuse a template that can create resources in different\n * contexts, such as a test environment versus a production environment. In your template, you can\n * add an EnvironmentType input parameter, which accepts either prod or test as inputs. For the\n * production environment, you might include Amazon EC2 instances with certain capabilities;\n * however, for the test environment, you want to use less capabilities to save costs. With\n * conditions, you can define which resources are created and how they're configured for each\n * environment type.\n */\nexport class FnCondition extends Fn {\n\n}\n\n/**\n * Returns true if all the specified conditions evaluate to true, or returns false if any one\n *  of the conditions evaluates to false. ``Fn::And`` acts as an AND operator. The minimum number of\n * conditions that you can include is 2, and the maximum is 10.\n */\nexport class FnAnd extends FnCondition {\n  constructor(...condition: FnCondition[]) {\n    super('Fn::And', condition);\n  }\n}\n\n/**\n * Compares if two values are equal. Returns true if the two values are equal or false\n * if they aren't.\n */\nexport class FnEquals extends FnCondition {\n  /**\n   * Creates an ``Fn::Equals`` condition function.\n   * @param lhs A value of any type that you want to compare.\n   * @param rhs A value of any type that you want to compare.\n   */\n  constructor(lhs: any, rhs: any) {\n    super('Fn::Equals', [ lhs, rhs ]);\n  }\n}\n\n/**\n * Returns one value if the specified condition evaluates to true and another value if the\n * specified condition evaluates to false. Currently, AWS CloudFormation supports the ``Fn::If``\n * intrinsic function in the metadata attribute, update policy attribute, and property values\n * in the Resources section and Outputs sections of a template. You can use the AWS::NoValue\n * pseudo parameter as a return value to remove the corresponding property.\n */\nexport class FnIf extends FnCondition {\n  /**\n   * Creates an ``Fn::If`` condition function.\n   * @param condition A reference to a condition in the Conditions section. Use the condition's name to reference it.\n   * @param valueIfTrue A value to be returned if the specified condition evaluates to true.\n   * @param valueIfFalse A value to be returned if the specified condition evaluates to false.\n   */\n  constructor(condition: string, valueIfTrue: any, valueIfFalse: any) {\n    super('Fn::If', [ condition, valueIfTrue, valueIfFalse ]);\n  }\n}\n\n/**\n * Returns true for a condition that evaluates to false or returns false for a condition that evaluates to true.\n * ``Fn::Not`` acts as a NOT operator.\n */\nexport class FnNot extends FnCondition {\n  /**\n   * Creates an ``Fn::Not`` condition function.\n   * @param condition A condition such as ``Fn::Equals`` that evaluates to true or false.\n   */\n  constructor(condition: FnCondition) {\n    super('Fn::Not', [ condition ]);\n  }\n}\n\n/**\n * Returns true if any one of the specified conditions evaluate to true, or returns false if\n * all of the conditions evaluates to false. ``Fn::Or`` acts as an OR operator. The minimum number\n * of conditions that you can include is 2, and the maximum is 10.\n */\nexport class FnOr extends FnCondition {\n  /**\n   * Creates an ``Fn::Or`` condition function.\n   * @param condition A condition that evaluates to true or false.\n   */\n  constructor(...condition: FnCondition[]) {\n    super('Fn::Or', condition);\n  }\n}\n\n/**\n * Returns true if a specified string matches at least one value in a list of strings.\n */\nexport class FnContains extends FnCondition {\n  /**\n   * Creates an ``Fn::Contains`` function.\n   * @param listOfStrings A list of strings, such as \"A\", \"B\", \"C\".\n   * @param value A string, such as \"A\", that you want to compare against a list of strings.\n   */\n  constructor(listOfStrings: any, value: string) {\n    super('Fn::Contains', [ listOfStrings, value ]);\n  }\n}\n\n/**\n * Returns true if a specified string matches all values in a list.\n */\nexport class FnEachMemberEquals extends FnCondition {\n  /**\n   * Creates an ``Fn::EachMemberEquals`` function.\n   * @param listOfStrings A list of strings, such as \"A\", \"B\", \"C\".\n   * @param value A string, such as \"A\", that you want to compare against a list of strings.\n   */\n  constructor(listOfStrings: any, value: string) {\n    super('Fn::EachMemberEquals', [ listOfStrings, value ]);\n  }\n}\n\n/**\n * Returns true if each member in a list of strings matches at least one value in a second\n * list of strings.\n */\nexport class FnEachMemberIn extends FnCondition {\n  /**\n   * Creates an ``Fn::EachMemberIn`` function.\n   * @param stringsToCheck A list of strings, such as \"A\", \"B\", \"C\". AWS CloudFormation checks whether each member in the strings_to_check parameter is in the strings_to_match parameter.\n   * @param stringsToMatch A list of strings, such as \"A\", \"B\", \"C\". Each member in the strings_to_match parameter is compared against the members of the strings_to_check parameter.\n   */\n  constructor(stringsToCheck: any, stringsToMatch: any) {\n    super('Fn::EachMemberIn', [ [stringsToCheck], stringsToMatch ]);\n  }\n}\n\n/**\n * Returns all values for a specified parameter type.\n */\nexport class FnRefAll extends FnCondition {\n  /**\n   * Creates an ``Fn::RefAll`` function.\n   * @param parameterType An AWS-specific parameter type, such as AWS::EC2::SecurityGroup::Id or\n   *            AWS::EC2::VPC::Id. For more information, see Parameters in the AWS\n   *            CloudFormation User Guide.\n   */\n  constructor(parameterType: string) {\n    super('Fn::RefAll', parameterType);\n  }\n}\n\n/**\n * Returns an attribute value or list of values for a specific parameter and attribute.\n */\nexport class FnValueOf extends FnCondition {\n  /**\n   * Creates an ``Fn::ValueOf`` function.\n   * @param parameterOrLogicalId The name of a parameter for which you want to retrieve attribute values. The parameter must be declared in the Parameters section of the template.\n   * @param attribute The name of an attribute from which you want to retrieve a value.\n   */\n  constructor(parameterOrLogicalId: string, attribute: string) {\n    super('Fn::ValueOf', [ parameterOrLogicalId, attribute ]);\n  }\n}\n\n/**\n * Returns a list of all attribute values for a given parameter type and attribute.\n */\nexport class FnValueOfAll extends FnCondition {\n  /**\n   * Creates an ``Fn::ValueOfAll`` function.\n   * @param parameterType An AWS-specific parameter type, such as AWS::EC2::SecurityGroup::Id or AWS::EC2::VPC::Id. For more information, see Parameters in the AWS CloudFormation User Guide.\n   * @param attribute The name of an attribute from which you want to retrieve a value. For more information about attributes, see Supported Attributes.\n   */\n  constructor(parameterType: string, attribute: string) {\n    super('Fn::ValueOfAll', [ parameterType, attribute ]);\n  }\n}\n"]}

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

exports.Include = Include;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5jbHVkZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImluY2x1ZGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFDQSxtQ0FBdUM7QUFTdkM7OztHQUdHO0FBQ0gsTUFBYSxPQUFRLFNBQVEsb0JBQVk7SUFNckM7Ozs7Ozs7T0FPRztJQUNILFlBQVksTUFBaUIsRUFBRSxJQUFZLEVBQUUsS0FBbUI7UUFDNUQsS0FBSyxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUNwQixJQUFJLENBQUMsUUFBUSxHQUFHLEtBQUssQ0FBQyxRQUFRLENBQUM7SUFDbkMsQ0FBQztJQUVNLGdCQUFnQjtRQUNuQixPQUFPLElBQUksQ0FBQyxRQUFRLENBQUM7SUFDekIsQ0FBQztDQUNKO0FBdEJELDBCQXNCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJy4uL2NvcmUvY29uc3RydWN0JztcbmltcG9ydCB7IFN0YWNrRWxlbWVudCB9IGZyb20gJy4vc3RhY2snO1xuXG5leHBvcnQgaW50ZXJmYWNlIEluY2x1ZGVQcm9wcyB7XG4gICAgLyoqXG4gICAgICogVGhlIENsb3VkRm9ybWF0aW9uIHRlbXBsYXRlIHRvIGluY2x1ZGUgaW4gdGhlIHN0YWNrIChhcyBpcykuXG4gICAgICovXG4gICAgdGVtcGxhdGU6IG9iamVjdDtcbn1cblxuLyoqXG4gKiBJbmNsdWRlcyBhIENsb3VkRm9ybWF0aW9uIHRlbXBsYXRlIGludG8gYSBzdGFjay4gQWxsIGVsZW1lbnRzIG9mIHRoZSB0ZW1wbGF0ZSB3aWxsIGJlIG1lcmdlZCBpbnRvXG4gKiB0aGUgY3VycmVudCBzdGFjaywgdG9nZXRoZXIgd2l0aCBhbnkgZWxlbWVudHMgY3JlYXRlZCBwcm9ncmFtbWF0aWNhbGx5LlxuICovXG5leHBvcnQgY2xhc3MgSW5jbHVkZSBleHRlbmRzIFN0YWNrRWxlbWVudCB7XG4gICAgLyoqXG4gICAgICogVGhlIGluY2x1ZGVkIHRlbXBsYXRlLlxuICAgICAqL1xuICAgIHB1YmxpYyByZWFkb25seSB0ZW1wbGF0ZTogb2JqZWN0O1xuXG4gICAgLyoqXG4gICAgICogQ3JlYXRlcyBhbiBhZG9wdGVkIHRlbXBsYXRlIGNvbnN0cnVjdC4gVGhlIHRlbXBsYXRlIHdpbGwgYmUgaW5jb3Jwb3JhdGVkIGludG8gdGhlIHN0YWNrIGFzLWlzIHdpdGggbm8gY2hhbmdlcyBhdCBhbGwuXG4gICAgICogVGhpcyBtZWFucyB0aGF0IGxvZ2ljYWwgSURzIG9mIGVudGl0aWVzIHdpdGhpbiB0aGlzIHRlbXBsYXRlIG1heSBjb25mbGljdCB3aXRoIGxvZ2ljYWwgSURzIG9mIGVudGl0aWVzIHRoYXQgYXJlIHBhcnQgb2YgdGhlXG4gICAgICogc3RhY2suXG4gICAgICogQHBhcmFtIHBhcmVudCBUaGUgcGFyZW50IGNvbnN0cnVjdCBvZiB0aGlzIHRlbXBsYXRlXG4gICAgICogQHBhcmFtIGlkIFRoZSBJRCBvZiB0aGlzIGNvbnN0cnVjdFxuICAgICAqIEBwYXJhbSB0ZW1wbGF0ZSBUaGUgdGVtcGxhdGUgdG8gYWRvcHQuXG4gICAgICovXG4gICAgY29uc3RydWN0b3IocGFyZW50OiBDb25zdHJ1Y3QsIG5hbWU6IHN0cmluZywgcHJvcHM6IEluY2x1ZGVQcm9wcykge1xuICAgICAgICBzdXBlcihwYXJlbnQsIG5hbWUpO1xuICAgICAgICB0aGlzLnRlbXBsYXRlID0gcHJvcHMudGVtcGxhdGU7XG4gICAgfVxuXG4gICAgcHVibGljIHRvQ2xvdWRGb3JtYXRpb24oKSB7XG4gICAgICAgIHJldHVybiB0aGlzLnRlbXBsYXRlO1xuICAgIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5jbHVkZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImluY2x1ZGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFDQSxtQ0FBdUM7QUFTdkM7OztHQUdHO0FBQ0gsTUFBYSxPQUFRLFNBQVEsb0JBQVk7SUFNdkM7Ozs7Ozs7T0FPRztJQUNILFlBQVksTUFBaUIsRUFBRSxJQUFZLEVBQUUsS0FBbUI7UUFDOUQsS0FBSyxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUNwQixJQUFJLENBQUMsUUFBUSxHQUFHLEtBQUssQ0FBQyxRQUFRLENBQUM7SUFDakMsQ0FBQztJQUVNLGdCQUFnQjtRQUNyQixPQUFPLElBQUksQ0FBQyxRQUFRLENBQUM7SUFDdkIsQ0FBQztDQUNGO0FBdEJELDBCQXNCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJy4uL2NvcmUvY29uc3RydWN0JztcbmltcG9ydCB7IFN0YWNrRWxlbWVudCB9IGZyb20gJy4vc3RhY2snO1xuXG5leHBvcnQgaW50ZXJmYWNlIEluY2x1ZGVQcm9wcyB7XG4gIC8qKlxuICAgKiBUaGUgQ2xvdWRGb3JtYXRpb24gdGVtcGxhdGUgdG8gaW5jbHVkZSBpbiB0aGUgc3RhY2sgKGFzIGlzKS5cbiAgICovXG4gIHRlbXBsYXRlOiBvYmplY3Q7XG59XG5cbi8qKlxuICogSW5jbHVkZXMgYSBDbG91ZEZvcm1hdGlvbiB0ZW1wbGF0ZSBpbnRvIGEgc3RhY2suIEFsbCBlbGVtZW50cyBvZiB0aGUgdGVtcGxhdGUgd2lsbCBiZSBtZXJnZWQgaW50b1xuICogdGhlIGN1cnJlbnQgc3RhY2ssIHRvZ2V0aGVyIHdpdGggYW55IGVsZW1lbnRzIGNyZWF0ZWQgcHJvZ3JhbW1hdGljYWxseS5cbiAqL1xuZXhwb3J0IGNsYXNzIEluY2x1ZGUgZXh0ZW5kcyBTdGFja0VsZW1lbnQge1xuICAvKipcbiAgICogVGhlIGluY2x1ZGVkIHRlbXBsYXRlLlxuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IHRlbXBsYXRlOiBvYmplY3Q7XG5cbiAgLyoqXG4gICAqIENyZWF0ZXMgYW4gYWRvcHRlZCB0ZW1wbGF0ZSBjb25zdHJ1Y3QuIFRoZSB0ZW1wbGF0ZSB3aWxsIGJlIGluY29ycG9yYXRlZCBpbnRvIHRoZSBzdGFjayBhcy1pcyB3aXRoIG5vIGNoYW5nZXMgYXQgYWxsLlxuICAgKiBUaGlzIG1lYW5zIHRoYXQgbG9naWNhbCBJRHMgb2YgZW50aXRpZXMgd2l0aGluIHRoaXMgdGVtcGxhdGUgbWF5IGNvbmZsaWN0IHdpdGggbG9naWNhbCBJRHMgb2YgZW50aXRpZXMgdGhhdCBhcmUgcGFydCBvZiB0aGVcbiAgICogc3RhY2suXG4gICAqIEBwYXJhbSBwYXJlbnQgVGhlIHBhcmVudCBjb25zdHJ1Y3Qgb2YgdGhpcyB0ZW1wbGF0ZVxuICAgKiBAcGFyYW0gaWQgVGhlIElEIG9mIHRoaXMgY29uc3RydWN0XG4gICAqIEBwYXJhbSB0ZW1wbGF0ZSBUaGUgdGVtcGxhdGUgdG8gYWRvcHQuXG4gICAqL1xuICBjb25zdHJ1Y3RvcihwYXJlbnQ6IENvbnN0cnVjdCwgbmFtZTogc3RyaW5nLCBwcm9wczogSW5jbHVkZVByb3BzKSB7XG4gICAgc3VwZXIocGFyZW50LCBuYW1lKTtcbiAgICB0aGlzLnRlbXBsYXRlID0gcHJvcHMudGVtcGxhdGU7XG4gIH1cblxuICBwdWJsaWMgdG9DbG91ZEZvcm1hdGlvbigpIHtcbiAgICByZXR1cm4gdGhpcy50ZW1wbGF0ZTtcbiAgfVxufVxuIl19

@@ -21,4 +21,4 @@ import { StackElement } from './stack';

*
* <path.join('')><md5(path.join('/')>
* "human" "hash"
* <path.join('')><md5(path.join('/')>
* "human" "hash"
*

@@ -25,0 +25,0 @@ * If the "human" part of the ID exceeds 240 characters, we simply trim it so

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

*
* <path.join('')><md5(path.join('/')>
* "human" "hash"
* <path.join('')><md5(path.join('/')>
* "human" "hash"
*

@@ -132,2 +132,2 @@ * If the "human" part of the ID exceeds 240 characters, we simply trim it so

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logical-id.js","sourceRoot":"","sources":["logical-id.ts"],"names":[],"mappings":";;AAAA,+CAAgD;AAGhD,MAAM,QAAQ,GAAG,GAAG,CAAC;AAYrB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmCG;AACH,MAAa,sBAAsB;IACxB,eAAe,CAAC,iBAA2B;QAC9C,OAAO,uBAAY,CAAC,iBAAiB,CAAC,CAAC;IAC3C,CAAC;CACJ;AAJD,wDAIC;AAED;;;;GAIG;AACH,MAAa,UAAU;IAgBnB,YAA6B,YAA+B;QAA/B,iBAAY,GAAZ,YAAY,CAAmB;QAf5D;;WAEG;QACc,YAAO,GAA4B,EAAE,CAAC;QAEvD;;;;;;;WAOG;QACc,YAAO,GAA2B,EAAE,CAAC;IAGtD,CAAC;IAED;;OAEG;IACI,aAAa,CAAC,KAAa,EAAE,KAAa;QAC7C,IAAI,KAAK,IAAI,IAAI,CAAC,OAAO,EAAE;YACvB,MAAM,IAAI,KAAK,CAAC,6CAA6C,KAAK,GAAG,CAAC,CAAC;SAC1E;QACD,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC;IAChC,CAAC;IAED;;OAEG;IACI,YAAY,CAAC,YAA0B;QAC1C,MAAM,IAAI,GAAG,YAAY,CAAC,SAAS,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;QAEpD,MAAM,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;QAC5D,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;QAC9C,iBAAiB,CAAC,OAAO,CAAC,CAAC;QAC3B,OAAO,OAAO,CAAC;IACnB,CAAC;IAED;;;;OAIG;IACI,uBAAuB;QAC1B,MAAM,IAAI,GAAG,IAAI,GAAG,EAAU,CAAC;QAC/B,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QAEvD,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE;YAClC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC;QACrC,CAAC,CAAC,CAAC;QAEH,IAAI,IAAI,CAAC,IAAI,KAAK,CAAC,EAAE;YACjB,MAAM,aAAa,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;YAChD,MAAM,IAAI,KAAK,CAAC,0EAA0E,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;SACzH;IACL,CAAC;IAED;;OAEG;IACK,WAAW,CAAC,KAAa;QAC7B,IAAI,KAAK,GAAG,KAAK,CAAC;QAClB,IAAI,KAAK,IAAI,IAAI,CAAC,OAAO,EAAE;YACvB,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;SAC/B;QAED,6EAA6E;QAC7E,IAAI,KAAK,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,KAAK,EAAE;YACxD,2CAA2C;YAC3C,MAAM,IAAI,KAAK,CAAC,wDAAwD,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,UAAU,KAAK,yBAAyB,KAAK,IAAI,CAAC,CAAC;SACjJ;QACD,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC;QAE5B,OAAO,KAAK,CAAC;IACjB,CAAC;CACJ;AA9ED,gCA8EC;AAED,MAAM,qBAAqB,GAAG,8BAA8B,CAAC;AAE7D;;GAEG;AACH,SAAS,iBAAiB,CAAC,SAAiB;IACxC,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE;QACxC,MAAM,IAAI,KAAK,CAAC,qDAAqD,qBAAqB,CAAC,QAAQ,EAAE,UAAU,SAAS,GAAG,CAAC,CAAC;KAChI;AACL,CAAC","sourcesContent":["import { makeUniqueId } from '../util/uniqueid';\nimport { StackElement } from './stack';\n\nconst PATH_SEP = '/';\n\n/**\n * Interface for classes that implementation logical ID assignment strategies\n */\nexport interface IAddressingScheme {\n    /**\n     * Return the logical ID for the given list of Construct names on the path.\n     */\n    allocateAddress(addressComponents: string[]): string;\n}\n\n/**\n * Renders a hashed ID for a resource.\n *\n * In order to make sure logical IDs are unique and stable, we hash the resource\n * construct tree path (i.e. toplevel/secondlevel/.../myresource) and add it as\n * a suffix to the path components joined without a separator (CloudFormation\n * IDs only allow alphanumeric characters).\n *\n * The result will be:\n *\n *     <path.join('')><md5(path.join('/')>\n *         \"human\"          \"hash\"\n *\n * If the \"human\" part of the ID exceeds 240 characters, we simply trim it so\n * the total ID doesn't exceed CloudFormation's 255 character limit.\n *\n * We only take 8 characters from the md5 hash (0.000005 chance of collision).\n *\n * Special cases:\n *\n * - If the path only contains a single component (i.e. it's a top-level\n *   resource), we won't add the hash to it. The hash is not needed for\n *   disamiguation and also, it allows for a more straightforward migration an\n *   existing CloudFormation template to a CDK stack without logical ID changes\n *   (or renames).\n * - For aesthetic reasons, if the last components of the path are the same\n *   (i.e. `L1/L2/Pipeline/Pipeline`), they will be de-duplicated to make the\n *   resulting human portion of the ID more pleasing: `L1L2Pipeline<HASH>`\n *   instead of `L1L2PipelinePipeline<HASH>`\n * - If a component is named \"Default\" it will be omitted from the path. This\n *   allows refactoring higher level abstractions around constructs without affecting\n *   the IDs of already deployed resources.\n * - If a component is named \"Resource\" it will be omitted from the user-visible\n *   path, but included in the hash. This reduces visual noise in the human readable\n *   part of the identifier.\n */\nexport class HashedAddressingScheme implements IAddressingScheme {\n    public allocateAddress(addressComponents: string[]): string {\n        return makeUniqueId(addressComponents);\n    }\n}\n\n/**\n * Class that keeps track of the logical IDs that are assigned to resources\n *\n * Supports renaming the generated IDs.\n */\nexport class LogicalIDs {\n    /**\n     * The rename table (old to new)\n     */\n    private readonly renames: {[old: string]: string} = {};\n\n    /**\n     * All assigned names (new to old, may be identical)\n     *\n     * This is used to ensure that:\n     *\n     * - No 2 resources end up with the same final logical ID, unless they were the same to begin with.\n     * - All renames have been used at the end of renaming.\n     */\n    private readonly reverse: {[id: string]: string} = {};\n\n    constructor(private readonly namingScheme: IAddressingScheme) {\n    }\n\n    /**\n     * Rename a logical ID from an old ID to a new ID\n     */\n    public renameLogical(oldId: string, newId: string) {\n        if (oldId in this.renames) {\n            throw new Error(`A rename has already been registered for '${oldId}'`);\n        }\n        this.renames[oldId] = newId;\n    }\n\n    /**\n     * Return the logical ID for the given stack element\n     */\n    public getLogicalId(stackElement: StackElement): string {\n        const path = stackElement.stackPath.split(PATH_SEP);\n\n        const generatedId = this.namingScheme.allocateAddress(path);\n        const finalId = this.applyRename(generatedId);\n        validateLogicalId(finalId);\n        return finalId;\n    }\n\n    /**\n     * Throw an error if not all renames have been used\n     *\n     * This is to assure that users didn't make typoes when registering renames.\n     */\n    public assertAllRenamesApplied() {\n        const keys = new Set<string>();\n        Object.keys(this.renames).forEach(keys.add.bind(keys));\n\n        Object.keys(this.reverse).map(newId => {\n            keys.delete(this.reverse[newId]);\n        });\n\n        if (keys.size !== 0) {\n            const unusedRenames = Array.from(keys.values());\n            throw new Error(`The following Logical IDs were attempted to be renamed, but not found: ${unusedRenames.join(', ')}`);\n        }\n    }\n\n    /**\n     * Return the renamed version of an ID, if applicable\n     */\n    private applyRename(oldId: string) {\n        let newId = oldId;\n        if (oldId in this.renames) {\n            newId = this.renames[oldId];\n        }\n\n        // If this newId has already been used, it must have been with the same oldId\n        if (newId in this.reverse && this.reverse[newId] !== oldId) {\n            // tslint:disable-next-line:max-line-length\n            throw new Error(`Two objects have been assigned the same Logical ID: '${this.reverse[newId]}' and '${oldId}' are now both named '${newId}'.`);\n        }\n        this.reverse[newId] = oldId;\n\n        return newId;\n    }\n}\n\nconst VALID_LOGICALID_REGEX = /^[A-Za-z][A-Za-z0-9]{1,254}$/;\n\n/**\n * Validate logical ID is valid for CloudFormation\n */\nfunction validateLogicalId(logicalId: string) {\n    if (!VALID_LOGICALID_REGEX.test(logicalId)) {\n        throw new Error(`Logical ID must adhere to the regular expression: ${VALID_LOGICALID_REGEX.toString()}, got '${logicalId}'`);\n    }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logical-id.js","sourceRoot":"","sources":["logical-id.ts"],"names":[],"mappings":"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","sourcesContent":["import { makeUniqueId } from '../util/uniqueid';\nimport { StackElement } from './stack';\n\nconst PATH_SEP = '/';\n\n/**\n * Interface for classes that implementation logical ID assignment strategies\n */\nexport interface IAddressingScheme {\n  /**\n   * Return the logical ID for the given list of Construct names on the path.\n   */\n  allocateAddress(addressComponents: string[]): string;\n}\n\n/**\n * Renders a hashed ID for a resource.\n *\n * In order to make sure logical IDs are unique and stable, we hash the resource\n * construct tree path (i.e. toplevel/secondlevel/.../myresource) and add it as\n * a suffix to the path components joined without a separator (CloudFormation\n * IDs only allow alphanumeric characters).\n *\n * The result will be:\n *\n *   <path.join('')><md5(path.join('/')>\n *     \"human\"      \"hash\"\n *\n * If the \"human\" part of the ID exceeds 240 characters, we simply trim it so\n * the total ID doesn't exceed CloudFormation's 255 character limit.\n *\n * We only take 8 characters from the md5 hash (0.000005 chance of collision).\n *\n * Special cases:\n *\n * - If the path only contains a single component (i.e. it's a top-level\n *   resource), we won't add the hash to it. The hash is not needed for\n *   disamiguation and also, it allows for a more straightforward migration an\n *   existing CloudFormation template to a CDK stack without logical ID changes\n *   (or renames).\n * - For aesthetic reasons, if the last components of the path are the same\n *   (i.e. `L1/L2/Pipeline/Pipeline`), they will be de-duplicated to make the\n *   resulting human portion of the ID more pleasing: `L1L2Pipeline<HASH>`\n *   instead of `L1L2PipelinePipeline<HASH>`\n * - If a component is named \"Default\" it will be omitted from the path. This\n *   allows refactoring higher level abstractions around constructs without affecting\n *   the IDs of already deployed resources.\n * - If a component is named \"Resource\" it will be omitted from the user-visible\n *   path, but included in the hash. This reduces visual noise in the human readable\n *   part of the identifier.\n */\nexport class HashedAddressingScheme implements IAddressingScheme {\n  public allocateAddress(addressComponents: string[]): string {\n    return makeUniqueId(addressComponents);\n  }\n}\n\n/**\n * Class that keeps track of the logical IDs that are assigned to resources\n *\n * Supports renaming the generated IDs.\n */\nexport class LogicalIDs {\n  /**\n   * The rename table (old to new)\n   */\n  private readonly renames: {[old: string]: string} = {};\n\n  /**\n   * All assigned names (new to old, may be identical)\n   *\n   * This is used to ensure that:\n   *\n   * - No 2 resources end up with the same final logical ID, unless they were the same to begin with.\n   * - All renames have been used at the end of renaming.\n   */\n  private readonly reverse: {[id: string]: string} = {};\n\n  constructor(private readonly namingScheme: IAddressingScheme) {\n  }\n\n  /**\n   * Rename a logical ID from an old ID to a new ID\n   */\n  public renameLogical(oldId: string, newId: string) {\n    if (oldId in this.renames) {\n      throw new Error(`A rename has already been registered for '${oldId}'`);\n    }\n    this.renames[oldId] = newId;\n  }\n\n  /**\n   * Return the logical ID for the given stack element\n   */\n  public getLogicalId(stackElement: StackElement): string {\n    const path = stackElement.stackPath.split(PATH_SEP);\n\n    const generatedId = this.namingScheme.allocateAddress(path);\n    const finalId = this.applyRename(generatedId);\n    validateLogicalId(finalId);\n    return finalId;\n  }\n\n  /**\n   * Throw an error if not all renames have been used\n   *\n   * This is to assure that users didn't make typoes when registering renames.\n   */\n  public assertAllRenamesApplied() {\n    const keys = new Set<string>();\n    Object.keys(this.renames).forEach(keys.add.bind(keys));\n\n    Object.keys(this.reverse).map(newId => {\n      keys.delete(this.reverse[newId]);\n    });\n\n    if (keys.size !== 0) {\n      const unusedRenames = Array.from(keys.values());\n      throw new Error(`The following Logical IDs were attempted to be renamed, but not found: ${unusedRenames.join(', ')}`);\n    }\n  }\n\n  /**\n   * Return the renamed version of an ID, if applicable\n   */\n  private applyRename(oldId: string) {\n    let newId = oldId;\n    if (oldId in this.renames) {\n      newId = this.renames[oldId];\n    }\n\n    // If this newId has already been used, it must have been with the same oldId\n    if (newId in this.reverse && this.reverse[newId] !== oldId) {\n      // tslint:disable-next-line:max-line-length\n      throw new Error(`Two objects have been assigned the same Logical ID: '${this.reverse[newId]}' and '${oldId}' are now both named '${newId}'.`);\n    }\n    this.reverse[newId] = oldId;\n\n    return newId;\n  }\n}\n\nconst VALID_LOGICALID_REGEX = /^[A-Za-z][A-Za-z0-9]{1,254}$/;\n\n/**\n * Validate logical ID is valid for CloudFormation\n */\nfunction validateLogicalId(logicalId: string) {\n  if (!VALID_LOGICALID_REGEX.test(logicalId)) {\n    throw new Error(`Logical ID must adhere to the regular expression: ${VALID_LOGICALID_REGEX.toString()}, got '${logicalId}'`);\n  }\n}\n"]}

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

exports.Mapping = Mapping;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFwcGluZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIm1hcHBpbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFDQSw2QkFBbUM7QUFDbkMsbUNBQXdDO0FBTXhDOztHQUVHO0FBQ0gsTUFBYSxPQUFRLFNBQVEscUJBQWE7SUFHdEMsWUFBWSxNQUFpQixFQUFFLElBQVksRUFBRSxLQUFtQjtRQUM1RCxLQUFLLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxDQUFDO1FBSGhCLFlBQU8sR0FBNEMsRUFBRyxDQUFDO1FBSTNELElBQUksQ0FBQyxPQUFPLEdBQUcsS0FBSyxDQUFDLE9BQU8sSUFBSSxFQUFHLENBQUM7SUFDeEMsQ0FBQztJQUVEOztPQUVHO0lBQ0ksUUFBUSxDQUFDLElBQVksRUFBRSxJQUFZLEVBQUUsS0FBVTtRQUNsRCxJQUFJLENBQUMsQ0FBQyxJQUFJLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxFQUFFO1lBQ3pCLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRyxDQUFDO1NBQzVCO1FBRUQsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxLQUFLLENBQUM7SUFDckMsQ0FBQztJQUVEOztPQUVHO0lBQ0ksU0FBUyxDQUFDLElBQVMsRUFBRSxJQUFTO1FBQ2pDLElBQUksQ0FBQyxDQUFDLElBQUksSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLEVBQUU7WUFDekIsTUFBTSxJQUFJLEtBQUssQ0FBQywwQ0FBMEMsSUFBSSxHQUFHLENBQUMsQ0FBQztTQUN0RTtRQUVELElBQUksQ0FBQyxDQUFDLElBQUksSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLEVBQUU7WUFDL0IsTUFBTSxJQUFJLEtBQUssQ0FBQyw2Q0FBNkMsSUFBSSxHQUFHLENBQUMsQ0FBQztTQUN6RTtRQUVELE9BQU8sSUFBSSxnQkFBVyxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQ3ZELENBQUM7SUFFTSxnQkFBZ0I7UUFDbkIsT0FBTztZQUNILFFBQVEsRUFBRTtnQkFDTixDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsRUFBRSxJQUFJLENBQUMsT0FBTzthQUNqQztTQUNKLENBQUM7SUFDTixDQUFDO0NBQ0o7QUF6Q0QsMEJBeUNDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSAnLi4vY29yZS9jb25zdHJ1Y3QnO1xuaW1wb3J0IHsgRm5GaW5kSW5NYXAgfSBmcm9tICcuL2ZuJztcbmltcG9ydCB7IFJlZmVyZW5jZWFibGUgfSBmcm9tICcuL3N0YWNrJztcblxuZXhwb3J0IGludGVyZmFjZSBNYXBwaW5nUHJvcHMge1xuICAgIG1hcHBpbmc/OiB7IFtrMTogc3RyaW5nXTogeyBbazI6IHN0cmluZ106IGFueSB9IH07XG59XG5cbi8qKlxuICogUmVwcmVzZW50cyBhIENsb3VkRm9ybWF0aW9uIG1hcHBpbmcuXG4gKi9cbmV4cG9ydCBjbGFzcyBNYXBwaW5nIGV4dGVuZHMgUmVmZXJlbmNlYWJsZSB7XG4gICAgcHJpdmF0ZSBtYXBwaW5nOiB7IFtrMTogc3RyaW5nXTogeyBbazI6IHN0cmluZ106IGFueSB9IH0gPSB7IH07XG5cbiAgICBjb25zdHJ1Y3RvcihwYXJlbnQ6IENvbnN0cnVjdCwgbmFtZTogc3RyaW5nLCBwcm9wczogTWFwcGluZ1Byb3BzKSB7XG4gICAgICAgIHN1cGVyKHBhcmVudCwgbmFtZSk7XG4gICAgICAgIHRoaXMubWFwcGluZyA9IHByb3BzLm1hcHBpbmcgfHwgeyB9O1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIFNldHMgYSB2YWx1ZSBpbiB0aGUgbWFwIGJhc2VkIG9uIHRoZSB0d28ga2V5cy5cbiAgICAgKi9cbiAgICBwdWJsaWMgc2V0VmFsdWUoa2V5MTogc3RyaW5nLCBrZXkyOiBzdHJpbmcsIHZhbHVlOiBhbnkpIHtcbiAgICAgICAgaWYgKCEoa2V5MSBpbiB0aGlzLm1hcHBpbmcpKSB7XG4gICAgICAgICAgICB0aGlzLm1hcHBpbmdba2V5MV0gPSB7IH07XG4gICAgICAgIH1cblxuICAgICAgICB0aGlzLm1hcHBpbmdba2V5MV1ba2V5Ml0gPSB2YWx1ZTtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBAcmV0dXJucyBBIHJlZmVyZW5jZSB0byBhIHZhbHVlIGluIHRoZSBtYXAgYmFzZWQgb24gdGhlIHR3byBrZXlzLlxuICAgICAqL1xuICAgIHB1YmxpYyBmaW5kSW5NYXAoa2V5MTogYW55LCBrZXkyOiBhbnkpIHtcbiAgICAgICAgaWYgKCEoa2V5MSBpbiB0aGlzLm1hcHBpbmcpKSB7XG4gICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYE1hcHBpbmcgZG9lc24ndCBjb250YWluIHRvcC1sZXZlbCBrZXkgJyR7a2V5MX0nYCk7XG4gICAgICAgIH1cblxuICAgICAgICBpZiAoIShrZXkyIGluIHRoaXMubWFwcGluZ1trZXkxXSkpIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcihgTWFwcGluZyBkb2Vzbid0IGNvbnRhaW4gc2Vjb25kLWxldmVsIGtleSAnJHtrZXkyfSdgKTtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiBuZXcgRm5GaW5kSW5NYXAodGhpcy5sb2dpY2FsSWQsIGtleTEsIGtleTIpO1xuICAgIH1cblxuICAgIHB1YmxpYyB0b0Nsb3VkRm9ybWF0aW9uKCk6IG9iamVjdCB7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICBNYXBwaW5nczoge1xuICAgICAgICAgICAgICAgIFt0aGlzLmxvZ2ljYWxJZF06IHRoaXMubWFwcGluZ1xuICAgICAgICAgICAgfVxuICAgICAgICB9O1xuICAgIH1cbn0iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFwcGluZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIm1hcHBpbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFDQSw2QkFBbUM7QUFDbkMsbUNBQXdDO0FBTXhDOztHQUVHO0FBQ0gsTUFBYSxPQUFRLFNBQVEscUJBQWE7SUFHeEMsWUFBWSxNQUFpQixFQUFFLElBQVksRUFBRSxLQUFtQjtRQUM5RCxLQUFLLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxDQUFDO1FBSGQsWUFBTyxHQUE0QyxFQUFHLENBQUM7UUFJN0QsSUFBSSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUMsT0FBTyxJQUFJLEVBQUcsQ0FBQztJQUN0QyxDQUFDO0lBRUQ7O09BRUc7SUFDSSxRQUFRLENBQUMsSUFBWSxFQUFFLElBQVksRUFBRSxLQUFVO1FBQ3BELElBQUksQ0FBQyxDQUFDLElBQUksSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLEVBQUU7WUFDM0IsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFHLENBQUM7U0FDMUI7UUFFRCxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLEtBQUssQ0FBQztJQUNuQyxDQUFDO0lBRUQ7O09BRUc7SUFDSSxTQUFTLENBQUMsSUFBUyxFQUFFLElBQVM7UUFDbkMsSUFBSSxDQUFDLENBQUMsSUFBSSxJQUFJLElBQUksQ0FBQyxPQUFPLENBQUMsRUFBRTtZQUMzQixNQUFNLElBQUksS0FBSyxDQUFDLDBDQUEwQyxJQUFJLEdBQUcsQ0FBQyxDQUFDO1NBQ3BFO1FBRUQsSUFBSSxDQUFDLENBQUMsSUFBSSxJQUFJLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsRUFBRTtZQUNqQyxNQUFNLElBQUksS0FBSyxDQUFDLDZDQUE2QyxJQUFJLEdBQUcsQ0FBQyxDQUFDO1NBQ3ZFO1FBRUQsT0FBTyxJQUFJLGdCQUFXLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDckQsQ0FBQztJQUVNLGdCQUFnQjtRQUNyQixPQUFPO1lBQ0wsUUFBUSxFQUFFO2dCQUNSLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxFQUFFLElBQUksQ0FBQyxPQUFPO2FBQy9CO1NBQ0YsQ0FBQztJQUNKLENBQUM7Q0FDRjtBQXpDRCwwQkF5Q0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICcuLi9jb3JlL2NvbnN0cnVjdCc7XG5pbXBvcnQgeyBGbkZpbmRJbk1hcCB9IGZyb20gJy4vZm4nO1xuaW1wb3J0IHsgUmVmZXJlbmNlYWJsZSB9IGZyb20gJy4vc3RhY2snO1xuXG5leHBvcnQgaW50ZXJmYWNlIE1hcHBpbmdQcm9wcyB7XG4gIG1hcHBpbmc/OiB7IFtrMTogc3RyaW5nXTogeyBbazI6IHN0cmluZ106IGFueSB9IH07XG59XG5cbi8qKlxuICogUmVwcmVzZW50cyBhIENsb3VkRm9ybWF0aW9uIG1hcHBpbmcuXG4gKi9cbmV4cG9ydCBjbGFzcyBNYXBwaW5nIGV4dGVuZHMgUmVmZXJlbmNlYWJsZSB7XG4gIHByaXZhdGUgbWFwcGluZzogeyBbazE6IHN0cmluZ106IHsgW2syOiBzdHJpbmddOiBhbnkgfSB9ID0geyB9O1xuXG4gIGNvbnN0cnVjdG9yKHBhcmVudDogQ29uc3RydWN0LCBuYW1lOiBzdHJpbmcsIHByb3BzOiBNYXBwaW5nUHJvcHMpIHtcbiAgICBzdXBlcihwYXJlbnQsIG5hbWUpO1xuICAgIHRoaXMubWFwcGluZyA9IHByb3BzLm1hcHBpbmcgfHwgeyB9O1xuICB9XG5cbiAgLyoqXG4gICAqIFNldHMgYSB2YWx1ZSBpbiB0aGUgbWFwIGJhc2VkIG9uIHRoZSB0d28ga2V5cy5cbiAgICovXG4gIHB1YmxpYyBzZXRWYWx1ZShrZXkxOiBzdHJpbmcsIGtleTI6IHN0cmluZywgdmFsdWU6IGFueSkge1xuICAgIGlmICghKGtleTEgaW4gdGhpcy5tYXBwaW5nKSkge1xuICAgICAgdGhpcy5tYXBwaW5nW2tleTFdID0geyB9O1xuICAgIH1cblxuICAgIHRoaXMubWFwcGluZ1trZXkxXVtrZXkyXSA9IHZhbHVlO1xuICB9XG5cbiAgLyoqXG4gICAqIEByZXR1cm5zIEEgcmVmZXJlbmNlIHRvIGEgdmFsdWUgaW4gdGhlIG1hcCBiYXNlZCBvbiB0aGUgdHdvIGtleXMuXG4gICAqL1xuICBwdWJsaWMgZmluZEluTWFwKGtleTE6IGFueSwga2V5MjogYW55KSB7XG4gICAgaWYgKCEoa2V5MSBpbiB0aGlzLm1hcHBpbmcpKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYE1hcHBpbmcgZG9lc24ndCBjb250YWluIHRvcC1sZXZlbCBrZXkgJyR7a2V5MX0nYCk7XG4gICAgfVxuXG4gICAgaWYgKCEoa2V5MiBpbiB0aGlzLm1hcHBpbmdba2V5MV0pKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYE1hcHBpbmcgZG9lc24ndCBjb250YWluIHNlY29uZC1sZXZlbCBrZXkgJyR7a2V5Mn0nYCk7XG4gICAgfVxuXG4gICAgcmV0dXJuIG5ldyBGbkZpbmRJbk1hcCh0aGlzLmxvZ2ljYWxJZCwga2V5MSwga2V5Mik7XG4gIH1cblxuICBwdWJsaWMgdG9DbG91ZEZvcm1hdGlvbigpOiBvYmplY3Qge1xuICAgIHJldHVybiB7XG4gICAgICBNYXBwaW5nczoge1xuICAgICAgICBbdGhpcy5sb2dpY2FsSWRdOiB0aGlzLm1hcHBpbmdcbiAgICAgIH1cbiAgICB9O1xuICB9XG59XG4iXX0=

@@ -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(): 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"]}
//# 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"]}

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

exports.Parameter = Parameter;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFyYW1ldGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsicGFyYW1ldGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBRUEsbUNBQTZDO0FBaUU3Qzs7OztHQUlHO0FBQ0gsTUFBYSxTQUFVLFNBQVEscUJBQWE7SUFReEM7Ozs7Ozs7T0FPRztJQUNILFlBQVksTUFBaUIsRUFBRSxJQUFZLEVBQUUsS0FBcUI7UUFDOUQsS0FBSyxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUNwQixJQUFJLENBQUMsVUFBVSxHQUFHLEtBQUssQ0FBQztRQUN4QixJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksV0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQy9CLENBQUM7SUFFTSxnQkFBZ0I7UUFDbkIsT0FBTztZQUNILFVBQVUsRUFBRTtnQkFDUixDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsRUFBRTtvQkFDZCxJQUFJLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJO29CQUMxQixPQUFPLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPO29CQUNoQyxjQUFjLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxjQUFjO29CQUM5QyxhQUFhLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhO29CQUM1QyxxQkFBcUIsRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLHFCQUFxQjtvQkFDNUQsV0FBVyxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsV0FBVztvQkFDeEMsU0FBUyxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsU0FBUztvQkFDcEMsUUFBUSxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUTtvQkFDbEMsU0FBUyxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsU0FBUztvQkFDcEMsUUFBUSxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUTtvQkFDbEMsTUFBTSxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsTUFBTTtpQkFDakM7YUFDSjtTQUNKLENBQUM7SUFDTixDQUFDO0lBRUQ7OztPQUdHO0lBQ0ksT0FBTztRQUNWLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQztJQUN0QixDQUFDO0NBQ0o7QUFqREQsOEJBaURDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSAnLi4vY29yZS9jb25zdHJ1Y3QnO1xuaW1wb3J0IHsgVG9rZW4gfSBmcm9tICcuLi9jb3JlL3Rva2Vucyc7XG5pbXBvcnQgeyBSZWYsIFJlZmVyZW5jZWFibGUgfSBmcm9tICcuL3N0YWNrJztcblxuZXhwb3J0IGludGVyZmFjZSBQYXJhbWV0ZXJQcm9wcyB7XG4gICAgLyoqXG4gICAgICogVGhlIGRhdGEgdHlwZSBmb3IgdGhlIHBhcmFtZXRlciAoRGF0YVR5cGUpLlxuICAgICAqL1xuICAgIHR5cGU6IHN0cmluZztcblxuICAgIC8qKlxuICAgICAqIEEgdmFsdWUgb2YgdGhlIGFwcHJvcHJpYXRlIHR5cGUgZm9yIHRoZSB0ZW1wbGF0ZSB0byB1c2UgaWYgbm8gdmFsdWUgaXMgc3BlY2lmaWVkXG4gICAgICogd2hlbiBhIHN0YWNrIGlzIGNyZWF0ZWQuIElmIHlvdSBkZWZpbmUgY29uc3RyYWludHMgZm9yIHRoZSBwYXJhbWV0ZXIsIHlvdSBtdXN0IHNwZWNpZnlcbiAgICAgKiBhIHZhbHVlIHRoYXQgYWRoZXJlcyB0byB0aG9zZSBjb25zdHJhaW50cy5cbiAgICAgKi9cbiAgICBkZWZhdWx0PzogYW55O1xuXG4gICAgLyoqXG4gICAgICogQSByZWd1bGFyIGV4cHJlc3Npb24gdGhhdCByZXByZXNlbnRzIHRoZSBwYXR0ZXJucyB0byBhbGxvdyBmb3IgU3RyaW5nIHR5cGVzLlxuICAgICAqL1xuICAgIGFsbG93ZWRQYXR0ZXJuPzogc3RyaW5nO1xuXG4gICAgLyoqXG4gICAgICogQW4gYXJyYXkgY29udGFpbmluZyB0aGUgbGlzdCBvZiB2YWx1ZXMgYWxsb3dlZCBmb3IgdGhlIHBhcmFtZXRlci5cbiAgICAgKi9cbiAgICBhbGxvd2VkVmFsdWVzPzogc3RyaW5nW107XG5cbiAgICAvKipcbiAgICAgKiBBIHN0cmluZyB0aGF0IGV4cGxhaW5zIGEgY29uc3RyYWludCB3aGVuIHRoZSBjb25zdHJhaW50IGlzIHZpb2xhdGVkLlxuICAgICAqIEZvciBleGFtcGxlLCB3aXRob3V0IGEgY29uc3RyYWludCBkZXNjcmlwdGlvbiwgYSBwYXJhbWV0ZXIgdGhhdCBoYXMgYW4gYWxsb3dlZFxuICAgICAqIHBhdHRlcm4gb2YgW0EtWmEtejAtOV0rIGRpc3BsYXlzIHRoZSBmb2xsb3dpbmcgZXJyb3IgbWVzc2FnZSB3aGVuIHRoZSB1c2VyIHNwZWNpZmllc1xuICAgICAqIGFuIGludmFsaWQgdmFsdWU6XG4gICAgICovXG4gICAgY29uc3RyYWludERlc2NyaXB0aW9uPzogc3RyaW5nO1xuXG4gICAgLyoqXG4gICAgICogQSBzdHJpbmcgb2YgdXAgdG8gNDAwMCBjaGFyYWN0ZXJzIHRoYXQgZGVzY3JpYmVzIHRoZSBwYXJhbWV0ZXIuXG4gICAgICovXG4gICAgZGVzY3JpcHRpb24/OiBzdHJpbmc7XG5cbiAgICAvKipcbiAgICAgKiBBbiBpbnRlZ2VyIHZhbHVlIHRoYXQgZGV0ZXJtaW5lcyB0aGUgbGFyZ2VzdCBudW1iZXIgb2YgY2hhcmFjdGVycyB5b3Ugd2FudCB0byBhbGxvdyBmb3IgU3RyaW5nIHR5cGVzLlxuICAgICAqL1xuICAgIG1heExlbmd0aD86IG51bWJlcjtcblxuICAgIC8qKlxuICAgICAqIEEgbnVtZXJpYyB2YWx1ZSB0aGF0IGRldGVybWluZXMgdGhlIGxhcmdlc3QgbnVtZXJpYyB2YWx1ZSB5b3Ugd2FudCB0byBhbGxvdyBmb3IgTnVtYmVyIHR5cGVzLlxuICAgICAqL1xuICAgIG1heFZhbHVlPzogbnVtYmVyO1xuXG4gICAgLyoqXG4gICAgICogQW4gaW50ZWdlciB2YWx1ZSB0aGF0IGRldGVybWluZXMgdGhlIHNtYWxsZXN0IG51bWJlciBvZiBjaGFyYWN0ZXJzIHlvdSB3YW50IHRvIGFsbG93IGZvciBTdHJpbmcgdHlwZXMuXG4gICAgICovXG4gICAgbWluTGVuZ3RoPzogbnVtYmVyO1xuXG4gICAgLyoqXG4gICAgICogQSBudW1lcmljIHZhbHVlIHRoYXQgZGV0ZXJtaW5lcyB0aGUgc21hbGxlc3QgbnVtZXJpYyB2YWx1ZSB5b3Ugd2FudCB0byBhbGxvdyBmb3IgTnVtYmVyIHR5cGVzLlxuICAgICAqL1xuICAgIG1pblZhbHVlPzogbnVtYmVyO1xuXG4gICAgLyoqXG4gICAgICogV2hldGhlciB0byBtYXNrIHRoZSBwYXJhbWV0ZXIgdmFsdWUgd2hlbiBhbnlvbmUgbWFrZXMgYSBjYWxsIHRoYXQgZGVzY3JpYmVzIHRoZSBzdGFjay5cbiAgICAgKiBJZiB5b3Ugc2V0IHRoZSB2YWx1ZSB0byBgYHRydWVgYCwgdGhlIHBhcmFtZXRlciB2YWx1ZSBpcyBtYXNrZWQgd2l0aCBhc3Rlcmlza3MgKGBgKioqKipgYCkuXG4gICAgICovXG4gICAgbm9FY2hvPzogYm9vbGVhbjtcbn1cblxuLyoqXG4gKiBVc2UgdGhlIG9wdGlvbmFsIFBhcmFtZXRlcnMgc2VjdGlvbiB0byBjdXN0b21pemUgeW91ciB0ZW1wbGF0ZXMuXG4gKiBQYXJhbWV0ZXJzIGVuYWJsZSB5b3UgdG8gaW5wdXQgY3VzdG9tIHZhbHVlcyB0byB5b3VyIHRlbXBsYXRlIGVhY2ggdGltZSB5b3UgY3JlYXRlIG9yXG4gKiB1cGRhdGUgYSBzdGFjay5cbiAqL1xuZXhwb3J0IGNsYXNzIFBhcmFtZXRlciBleHRlbmRzIFJlZmVyZW5jZWFibGUge1xuICAgIC8qKlxuICAgICAqIEEgdG9rZW4gdGhhdCByZXByZXNlbnRzIHRoZSBhY3R1YWwgdmFsdWUgb2YgdGhpcyBwYXJhbWV0ZXIuXG4gICAgICovXG4gICAgcHVibGljIHZhbHVlOiBUb2tlbjtcblxuICAgIHByaXZhdGUgcHJvcGVydGllczogUGFyYW1ldGVyUHJvcHM7XG5cbiAgICAvKipcbiAgICAgKiBDcmVhdGVzIGEgcGFyYW1ldGVyIGNvbnN0cnVjdC5cbiAgICAgKiBOb3RlIHRoYXQgdGhlIG5hbWUgKGxvZ2ljYWwgSUQpIG9mIHRoZSBwYXJhbWV0ZXIgd2lsbCBkZXJpdmUgZnJvbSBpdCdzIGBjb25hbWVgIGFuZCBsb2NhdGlvblxuICAgICAqIHdpdGhpbiB0aGUgc3RhY2suIFRoZXJlZm9yZSwgaXQgaXMgcmVjb21tZW5kZWQgdGhhdCBwYXJhbWV0ZXJzIGFyZSBkZWZpbmVkIGF0IHRoZSBzdGFjayBsZXZlbC5cbiAgICAgKlxuICAgICAqIEBwYXJhbSBwYXJlbnQgVGhlIHBhcmVudCBjb25zdHJ1Y3QuXG4gICAgICogQHBhcmFtIHByb3BzIFRoZSBwYXJhbWV0ZXIgcHJvcGVydGllcy5cbiAgICAgKi9cbiAgICBjb25zdHJ1Y3RvcihwYXJlbnQ6IENvbnN0cnVjdCwgbmFtZTogc3RyaW5nLCBwcm9wczogUGFyYW1ldGVyUHJvcHMpIHtcbiAgICAgICAgc3VwZXIocGFyZW50LCBuYW1lKTtcbiAgICAgICAgdGhpcy5wcm9wZXJ0aWVzID0gcHJvcHM7XG4gICAgICAgIHRoaXMudmFsdWUgPSBuZXcgUmVmKHRoaXMpO1xuICAgIH1cblxuICAgIHB1YmxpYyB0b0Nsb3VkRm9ybWF0aW9uKCk6IG9iamVjdCB7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICBQYXJhbWV0ZXJzOiB7XG4gICAgICAgICAgICAgICAgW3RoaXMubG9naWNhbElkXToge1xuICAgICAgICAgICAgICAgICAgICBUeXBlOiB0aGlzLnByb3BlcnRpZXMudHlwZSxcbiAgICAgICAgICAgICAgICAgICAgRGVmYXVsdDogdGhpcy5wcm9wZXJ0aWVzLmRlZmF1bHQsXG4gICAgICAgICAgICAgICAgICAgIEFsbG93ZWRQYXR0ZXJuOiB0aGlzLnByb3BlcnRpZXMuYWxsb3dlZFBhdHRlcm4sXG4gICAgICAgICAgICAgICAgICAgIEFsbG93ZWRWYWx1ZXM6IHRoaXMucHJvcGVydGllcy5hbGxvd2VkVmFsdWVzLFxuICAgICAgICAgICAgICAgICAgICBDb25zdHJhaW50RGVzY3JpcHRpb246IHRoaXMucHJvcGVydGllcy5jb25zdHJhaW50RGVzY3JpcHRpb24sXG4gICAgICAgICAgICAgICAgICAgIERlc2NyaXB0aW9uOiB0aGlzLnByb3BlcnRpZXMuZGVzY3JpcHRpb24sXG4gICAgICAgICAgICAgICAgICAgIE1heExlbmd0aDogdGhpcy5wcm9wZXJ0aWVzLm1heExlbmd0aCxcbiAgICAgICAgICAgICAgICAgICAgTWF4VmFsdWU6IHRoaXMucHJvcGVydGllcy5tYXhWYWx1ZSxcbiAgICAgICAgICAgICAgICAgICAgTWluTGVuZ3RoOiB0aGlzLnByb3BlcnRpZXMubWluTGVuZ3RoLFxuICAgICAgICAgICAgICAgICAgICBNaW5WYWx1ZTogdGhpcy5wcm9wZXJ0aWVzLm1pblZhbHVlLFxuICAgICAgICAgICAgICAgICAgICBOb0VjaG86IHRoaXMucHJvcGVydGllcy5ub0VjaG9cbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgIH07XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQWxsb3dzIHVzaW5nIHBhcmFtZXRlcnMgYXMgdG9rZW5zIHdpdGhvdXQgdGhlIG5lZWQgdG8gZGVyZWZlcmVuY2UgdGhlbS5cbiAgICAgKiBUaGlzIGltcGxpY2l0bHkgaW1wbGVtZW50cyBUb2tlbiwgdW50aWwgd2UgbWFrZSBpdCBhbiBpbnRlcmZhY2UuXG4gICAgICovXG4gICAgcHVibGljIHJlc29sdmUoKTogYW55IHtcbiAgICAgICAgcmV0dXJuIHRoaXMudmFsdWU7XG4gICAgfVxufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFyYW1ldGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsicGFyYW1ldGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBRUEsbUNBQTZDO0FBaUU3Qzs7OztHQUlHO0FBQ0gsTUFBYSxTQUFVLFNBQVEscUJBQWE7SUFRMUM7Ozs7Ozs7T0FPRztJQUNILFlBQVksTUFBaUIsRUFBRSxJQUFZLEVBQUUsS0FBcUI7UUFDaEUsS0FBSyxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUNwQixJQUFJLENBQUMsVUFBVSxHQUFHLEtBQUssQ0FBQztRQUN4QixJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksV0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQzdCLENBQUM7SUFFTSxnQkFBZ0I7UUFDckIsT0FBTztZQUNMLFVBQVUsRUFBRTtnQkFDVixDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsRUFBRTtvQkFDaEIsSUFBSSxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSTtvQkFDMUIsT0FBTyxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsT0FBTztvQkFDaEMsY0FBYyxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsY0FBYztvQkFDOUMsYUFBYSxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYTtvQkFDNUMscUJBQXFCLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxxQkFBcUI7b0JBQzVELFdBQVcsRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLFdBQVc7b0JBQ3hDLFNBQVMsRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLFNBQVM7b0JBQ3BDLFFBQVEsRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLFFBQVE7b0JBQ2xDLFNBQVMsRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLFNBQVM7b0JBQ3BDLFFBQVEsRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLFFBQVE7b0JBQ2xDLE1BQU0sRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLE1BQU07aUJBQy9CO2FBQ0Y7U0FDRixDQUFDO0lBQ0osQ0FBQztJQUVEOzs7T0FHRztJQUNJLE9BQU87UUFDWixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDcEIsQ0FBQztDQUNGO0FBakRELDhCQWlEQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJy4uL2NvcmUvY29uc3RydWN0JztcbmltcG9ydCB7IFRva2VuIH0gZnJvbSAnLi4vY29yZS90b2tlbnMnO1xuaW1wb3J0IHsgUmVmLCBSZWZlcmVuY2VhYmxlIH0gZnJvbSAnLi9zdGFjayc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGFyYW1ldGVyUHJvcHMge1xuICAvKipcbiAgICogVGhlIGRhdGEgdHlwZSBmb3IgdGhlIHBhcmFtZXRlciAoRGF0YVR5cGUpLlxuICAgKi9cbiAgdHlwZTogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBBIHZhbHVlIG9mIHRoZSBhcHByb3ByaWF0ZSB0eXBlIGZvciB0aGUgdGVtcGxhdGUgdG8gdXNlIGlmIG5vIHZhbHVlIGlzIHNwZWNpZmllZFxuICAgKiB3aGVuIGEgc3RhY2sgaXMgY3JlYXRlZC4gSWYgeW91IGRlZmluZSBjb25zdHJhaW50cyBmb3IgdGhlIHBhcmFtZXRlciwgeW91IG11c3Qgc3BlY2lmeVxuICAgKiBhIHZhbHVlIHRoYXQgYWRoZXJlcyB0byB0aG9zZSBjb25zdHJhaW50cy5cbiAgICovXG4gIGRlZmF1bHQ/OiBhbnk7XG5cbiAgLyoqXG4gICAqIEEgcmVndWxhciBleHByZXNzaW9uIHRoYXQgcmVwcmVzZW50cyB0aGUgcGF0dGVybnMgdG8gYWxsb3cgZm9yIFN0cmluZyB0eXBlcy5cbiAgICovXG4gIGFsbG93ZWRQYXR0ZXJuPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBBbiBhcnJheSBjb250YWluaW5nIHRoZSBsaXN0IG9mIHZhbHVlcyBhbGxvd2VkIGZvciB0aGUgcGFyYW1ldGVyLlxuICAgKi9cbiAgYWxsb3dlZFZhbHVlcz86IHN0cmluZ1tdO1xuXG4gIC8qKlxuICAgKiBBIHN0cmluZyB0aGF0IGV4cGxhaW5zIGEgY29uc3RyYWludCB3aGVuIHRoZSBjb25zdHJhaW50IGlzIHZpb2xhdGVkLlxuICAgKiBGb3IgZXhhbXBsZSwgd2l0aG91dCBhIGNvbnN0cmFpbnQgZGVzY3JpcHRpb24sIGEgcGFyYW1ldGVyIHRoYXQgaGFzIGFuIGFsbG93ZWRcbiAgICogcGF0dGVybiBvZiBbQS1aYS16MC05XSsgZGlzcGxheXMgdGhlIGZvbGxvd2luZyBlcnJvciBtZXNzYWdlIHdoZW4gdGhlIHVzZXIgc3BlY2lmaWVzXG4gICAqIGFuIGludmFsaWQgdmFsdWU6XG4gICAqL1xuICBjb25zdHJhaW50RGVzY3JpcHRpb24/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEEgc3RyaW5nIG9mIHVwIHRvIDQwMDAgY2hhcmFjdGVycyB0aGF0IGRlc2NyaWJlcyB0aGUgcGFyYW1ldGVyLlxuICAgKi9cbiAgZGVzY3JpcHRpb24/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEFuIGludGVnZXIgdmFsdWUgdGhhdCBkZXRlcm1pbmVzIHRoZSBsYXJnZXN0IG51bWJlciBvZiBjaGFyYWN0ZXJzIHlvdSB3YW50IHRvIGFsbG93IGZvciBTdHJpbmcgdHlwZXMuXG4gICAqL1xuICBtYXhMZW5ndGg/OiBudW1iZXI7XG5cbiAgLyoqXG4gICAqIEEgbnVtZXJpYyB2YWx1ZSB0aGF0IGRldGVybWluZXMgdGhlIGxhcmdlc3QgbnVtZXJpYyB2YWx1ZSB5b3Ugd2FudCB0byBhbGxvdyBmb3IgTnVtYmVyIHR5cGVzLlxuICAgKi9cbiAgbWF4VmFsdWU/OiBudW1iZXI7XG5cbiAgLyoqXG4gICAqIEFuIGludGVnZXIgdmFsdWUgdGhhdCBkZXRlcm1pbmVzIHRoZSBzbWFsbGVzdCBudW1iZXIgb2YgY2hhcmFjdGVycyB5b3Ugd2FudCB0byBhbGxvdyBmb3IgU3RyaW5nIHR5cGVzLlxuICAgKi9cbiAgbWluTGVuZ3RoPzogbnVtYmVyO1xuXG4gIC8qKlxuICAgKiBBIG51bWVyaWMgdmFsdWUgdGhhdCBkZXRlcm1pbmVzIHRoZSBzbWFsbGVzdCBudW1lcmljIHZhbHVlIHlvdSB3YW50IHRvIGFsbG93IGZvciBOdW1iZXIgdHlwZXMuXG4gICAqL1xuICBtaW5WYWx1ZT86IG51bWJlcjtcblxuICAvKipcbiAgICogV2hldGhlciB0byBtYXNrIHRoZSBwYXJhbWV0ZXIgdmFsdWUgd2hlbiBhbnlvbmUgbWFrZXMgYSBjYWxsIHRoYXQgZGVzY3JpYmVzIHRoZSBzdGFjay5cbiAgICogSWYgeW91IHNldCB0aGUgdmFsdWUgdG8gYGB0cnVlYGAsIHRoZSBwYXJhbWV0ZXIgdmFsdWUgaXMgbWFza2VkIHdpdGggYXN0ZXJpc2tzIChgYCoqKioqYGApLlxuICAgKi9cbiAgbm9FY2hvPzogYm9vbGVhbjtcbn1cblxuLyoqXG4gKiBVc2UgdGhlIG9wdGlvbmFsIFBhcmFtZXRlcnMgc2VjdGlvbiB0byBjdXN0b21pemUgeW91ciB0ZW1wbGF0ZXMuXG4gKiBQYXJhbWV0ZXJzIGVuYWJsZSB5b3UgdG8gaW5wdXQgY3VzdG9tIHZhbHVlcyB0byB5b3VyIHRlbXBsYXRlIGVhY2ggdGltZSB5b3UgY3JlYXRlIG9yXG4gKiB1cGRhdGUgYSBzdGFjay5cbiAqL1xuZXhwb3J0IGNsYXNzIFBhcmFtZXRlciBleHRlbmRzIFJlZmVyZW5jZWFibGUge1xuICAvKipcbiAgICogQSB0b2tlbiB0aGF0IHJlcHJlc2VudHMgdGhlIGFjdHVhbCB2YWx1ZSBvZiB0aGlzIHBhcmFtZXRlci5cbiAgICovXG4gIHB1YmxpYyB2YWx1ZTogVG9rZW47XG5cbiAgcHJpdmF0ZSBwcm9wZXJ0aWVzOiBQYXJhbWV0ZXJQcm9wcztcblxuICAvKipcbiAgICogQ3JlYXRlcyBhIHBhcmFtZXRlciBjb25zdHJ1Y3QuXG4gICAqIE5vdGUgdGhhdCB0aGUgbmFtZSAobG9naWNhbCBJRCkgb2YgdGhlIHBhcmFtZXRlciB3aWxsIGRlcml2ZSBmcm9tIGl0J3MgYGNvbmFtZWAgYW5kIGxvY2F0aW9uXG4gICAqIHdpdGhpbiB0aGUgc3RhY2suIFRoZXJlZm9yZSwgaXQgaXMgcmVjb21tZW5kZWQgdGhhdCBwYXJhbWV0ZXJzIGFyZSBkZWZpbmVkIGF0IHRoZSBzdGFjayBsZXZlbC5cbiAgICpcbiAgICogQHBhcmFtIHBhcmVudCBUaGUgcGFyZW50IGNvbnN0cnVjdC5cbiAgICogQHBhcmFtIHByb3BzIFRoZSBwYXJhbWV0ZXIgcHJvcGVydGllcy5cbiAgICovXG4gIGNvbnN0cnVjdG9yKHBhcmVudDogQ29uc3RydWN0LCBuYW1lOiBzdHJpbmcsIHByb3BzOiBQYXJhbWV0ZXJQcm9wcykge1xuICAgIHN1cGVyKHBhcmVudCwgbmFtZSk7XG4gICAgdGhpcy5wcm9wZXJ0aWVzID0gcHJvcHM7XG4gICAgdGhpcy52YWx1ZSA9IG5ldyBSZWYodGhpcyk7XG4gIH1cblxuICBwdWJsaWMgdG9DbG91ZEZvcm1hdGlvbigpOiBvYmplY3Qge1xuICAgIHJldHVybiB7XG4gICAgICBQYXJhbWV0ZXJzOiB7XG4gICAgICAgIFt0aGlzLmxvZ2ljYWxJZF06IHtcbiAgICAgICAgICBUeXBlOiB0aGlzLnByb3BlcnRpZXMudHlwZSxcbiAgICAgICAgICBEZWZhdWx0OiB0aGlzLnByb3BlcnRpZXMuZGVmYXVsdCxcbiAgICAgICAgICBBbGxvd2VkUGF0dGVybjogdGhpcy5wcm9wZXJ0aWVzLmFsbG93ZWRQYXR0ZXJuLFxuICAgICAgICAgIEFsbG93ZWRWYWx1ZXM6IHRoaXMucHJvcGVydGllcy5hbGxvd2VkVmFsdWVzLFxuICAgICAgICAgIENvbnN0cmFpbnREZXNjcmlwdGlvbjogdGhpcy5wcm9wZXJ0aWVzLmNvbnN0cmFpbnREZXNjcmlwdGlvbixcbiAgICAgICAgICBEZXNjcmlwdGlvbjogdGhpcy5wcm9wZXJ0aWVzLmRlc2NyaXB0aW9uLFxuICAgICAgICAgIE1heExlbmd0aDogdGhpcy5wcm9wZXJ0aWVzLm1heExlbmd0aCxcbiAgICAgICAgICBNYXhWYWx1ZTogdGhpcy5wcm9wZXJ0aWVzLm1heFZhbHVlLFxuICAgICAgICAgIE1pbkxlbmd0aDogdGhpcy5wcm9wZXJ0aWVzLm1pbkxlbmd0aCxcbiAgICAgICAgICBNaW5WYWx1ZTogdGhpcy5wcm9wZXJ0aWVzLm1pblZhbHVlLFxuICAgICAgICAgIE5vRWNobzogdGhpcy5wcm9wZXJ0aWVzLm5vRWNob1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfTtcbiAgfVxuXG4gIC8qKlxuICAgKiBBbGxvd3MgdXNpbmcgcGFyYW1ldGVycyBhcyB0b2tlbnMgd2l0aG91dCB0aGUgbmVlZCB0byBkZXJlZmVyZW5jZSB0aGVtLlxuICAgKiBUaGlzIGltcGxpY2l0bHkgaW1wbGVtZW50cyBUb2tlbiwgdW50aWwgd2UgbWFrZSBpdCBhbiBpbnRlcmZhY2UuXG4gICAqL1xuICBwdWJsaWMgcmVzb2x2ZSgpOiBhbnkge1xuICAgIHJldHVybiB0aGlzLnZhbHVlO1xuICB9XG59XG4iXX0=

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

})(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 { 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"]}
//# 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"]}

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

exports.AwsStackName = AwsStackName;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHNldWRvLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsicHNldWRvLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsaUVBQTZEO0FBRTdELE1BQWEsZUFBZ0IsU0FBUSwwQ0FBbUI7SUFDcEQsWUFBWSxJQUFZO1FBQ3BCLEtBQUssQ0FBQyxFQUFFLEdBQUcsRUFBRSxJQUFJLEVBQUUsRUFBRSxJQUFJLENBQUMsQ0FBQztJQUMvQixDQUFDO0NBQ0o7QUFKRCwwQ0FJQztBQUVELE1BQWEsWUFBYSxTQUFRLGVBQWU7SUFDN0M7UUFDSSxLQUFLLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztJQUM1QixDQUFDO0NBQ0o7QUFKRCxvQ0FJQztBQUVELE1BQWEsZUFBZ0IsU0FBUSxlQUFlO0lBQ2hEO1FBQ0ksS0FBSyxDQUFDLG1CQUFtQixDQUFDLENBQUM7SUFDL0IsQ0FBQztDQUNKO0FBSkQsMENBSUM7QUFFRCxNQUFhLFlBQWEsU0FBUSxlQUFlO0lBQzdDO1FBQ0ksS0FBSyxDQUFDLGdCQUFnQixDQUFDLENBQUM7SUFDNUIsQ0FBQztDQUNKO0FBSkQsb0NBSUM7QUFFRCxNQUFhLG1CQUFvQixTQUFRLGVBQWU7SUFDcEQ7UUFDSSxLQUFLLENBQUMsdUJBQXVCLENBQUMsQ0FBQztJQUNuQyxDQUFDO0NBQ0o7QUFKRCxrREFJQztBQUVELE1BQWEsVUFBVyxTQUFRLGVBQWU7SUFDM0M7UUFDSSxLQUFLLENBQUMsY0FBYyxDQUFDLENBQUM7SUFDMUIsQ0FBQztDQUNKO0FBSkQsZ0NBSUM7QUFFRCxNQUFhLFlBQWEsU0FBUSxlQUFlO0lBQzdDO1FBQ0ksS0FBSyxDQUFDLGdCQUFnQixDQUFDLENBQUM7SUFDNUIsQ0FBQztDQUNKO0FBSkQsb0NBSUM7QUFFRCxNQUFhLFNBQVUsU0FBUSxlQUFlO0lBQzFDO1FBQ0ksS0FBSyxDQUFDLGFBQWEsQ0FBQyxDQUFDO0lBQ3pCLENBQUM7Q0FDSjtBQUpELDhCQUlDO0FBRUQsTUFBYSxVQUFXLFNBQVEsZUFBZTtJQUMzQztRQUNJLEtBQUssQ0FBQyxjQUFjLENBQUMsQ0FBQztJQUMxQixDQUFDO0NBQ0o7QUFKRCxnQ0FJQztBQUVELE1BQWEsWUFBYSxTQUFRLGVBQWU7SUFDN0M7UUFDSSxLQUFLLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztJQUM1QixDQUFDO0NBQ0o7QUFKRCxvQ0FJQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENsb3VkRm9ybWF0aW9uVG9rZW4gfSBmcm9tICcuL2Nsb3VkZm9ybWF0aW9uLXRva2VuJztcblxuZXhwb3J0IGNsYXNzIFBzZXVkb1BhcmFtZXRlciBleHRlbmRzIENsb3VkRm9ybWF0aW9uVG9rZW4ge1xuICAgIGNvbnN0cnVjdG9yKG5hbWU6IHN0cmluZykge1xuICAgICAgICBzdXBlcih7IFJlZjogbmFtZSB9LCBuYW1lKTtcbiAgICB9XG59XG5cbmV4cG9ydCBjbGFzcyBBd3NBY2NvdW50SWQgZXh0ZW5kcyBQc2V1ZG9QYXJhbWV0ZXIge1xuICAgIGNvbnN0cnVjdG9yKCkge1xuICAgICAgICBzdXBlcignQVdTOjpBY2NvdW50SWQnKTtcbiAgICB9XG59XG5cbmV4cG9ydCBjbGFzcyBBd3NEb21haW5TdWZmaXggZXh0ZW5kcyBQc2V1ZG9QYXJhbWV0ZXIge1xuICAgIGNvbnN0cnVjdG9yKCkge1xuICAgICAgICBzdXBlcignQVdTOjpEb21haW5TdWZmaXgnKTtcbiAgICB9XG59XG5cbmV4cG9ydCBjbGFzcyBBd3NVUkxTdWZmaXggZXh0ZW5kcyBQc2V1ZG9QYXJhbWV0ZXIge1xuICAgIGNvbnN0cnVjdG9yKCkge1xuICAgICAgICBzdXBlcignQVdTOjpVUkxTdWZmaXgnKTtcbiAgICB9XG59XG5cbmV4cG9ydCBjbGFzcyBBd3NOb3RpZmljYXRpb25BUk5zIGV4dGVuZHMgUHNldWRvUGFyYW1ldGVyIHtcbiAgICBjb25zdHJ1Y3RvcigpIHtcbiAgICAgICAgc3VwZXIoJ0FXUzo6Tm90aWZpY2F0aW9uQVJOcycpO1xuICAgIH1cbn1cblxuZXhwb3J0IGNsYXNzIEF3c05vVmFsdWUgZXh0ZW5kcyBQc2V1ZG9QYXJhbWV0ZXIge1xuICAgIGNvbnN0cnVjdG9yKCkge1xuICAgICAgICBzdXBlcignQVdTOjpOb1ZhbHVlJyk7XG4gICAgfVxufVxuXG5leHBvcnQgY2xhc3MgQXdzUGFydGl0aW9uIGV4dGVuZHMgUHNldWRvUGFyYW1ldGVyIHtcbiAgICBjb25zdHJ1Y3RvcigpIHtcbiAgICAgICAgc3VwZXIoJ0FXUzo6UGFydGl0aW9uJyk7XG4gICAgfVxufVxuXG5leHBvcnQgY2xhc3MgQXdzUmVnaW9uIGV4dGVuZHMgUHNldWRvUGFyYW1ldGVyIHtcbiAgICBjb25zdHJ1Y3RvcigpIHtcbiAgICAgICAgc3VwZXIoJ0FXUzo6UmVnaW9uJyk7XG4gICAgfVxufVxuXG5leHBvcnQgY2xhc3MgQXdzU3RhY2tJZCBleHRlbmRzIFBzZXVkb1BhcmFtZXRlciB7XG4gICAgY29uc3RydWN0b3IoKSB7XG4gICAgICAgIHN1cGVyKCdBV1M6OlN0YWNrSWQnKTtcbiAgICB9XG59XG5cbmV4cG9ydCBjbGFzcyBBd3NTdGFja05hbWUgZXh0ZW5kcyBQc2V1ZG9QYXJhbWV0ZXIge1xuICAgIGNvbnN0cnVjdG9yKCkge1xuICAgICAgICBzdXBlcignQVdTOjpTdGFja05hbWUnKTtcbiAgICB9XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHNldWRvLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsicHNldWRvLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsaUVBQTZEO0FBRTdELE1BQWEsZUFBZ0IsU0FBUSwwQ0FBbUI7SUFDdEQsWUFBWSxJQUFZO1FBQ3RCLEtBQUssQ0FBQyxFQUFFLEdBQUcsRUFBRSxJQUFJLEVBQUUsRUFBRSxJQUFJLENBQUMsQ0FBQztJQUM3QixDQUFDO0NBQ0Y7QUFKRCwwQ0FJQztBQUVELE1BQWEsWUFBYSxTQUFRLGVBQWU7SUFDL0M7UUFDRSxLQUFLLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztJQUMxQixDQUFDO0NBQ0Y7QUFKRCxvQ0FJQztBQUVELE1BQWEsZUFBZ0IsU0FBUSxlQUFlO0lBQ2xEO1FBQ0UsS0FBSyxDQUFDLG1CQUFtQixDQUFDLENBQUM7SUFDN0IsQ0FBQztDQUNGO0FBSkQsMENBSUM7QUFFRCxNQUFhLFlBQWEsU0FBUSxlQUFlO0lBQy9DO1FBQ0UsS0FBSyxDQUFDLGdCQUFnQixDQUFDLENBQUM7SUFDMUIsQ0FBQztDQUNGO0FBSkQsb0NBSUM7QUFFRCxNQUFhLG1CQUFvQixTQUFRLGVBQWU7SUFDdEQ7UUFDRSxLQUFLLENBQUMsdUJBQXVCLENBQUMsQ0FBQztJQUNqQyxDQUFDO0NBQ0Y7QUFKRCxrREFJQztBQUVELE1BQWEsVUFBVyxTQUFRLGVBQWU7SUFDN0M7UUFDRSxLQUFLLENBQUMsY0FBYyxDQUFDLENBQUM7SUFDeEIsQ0FBQztDQUNGO0FBSkQsZ0NBSUM7QUFFRCxNQUFhLFlBQWEsU0FBUSxlQUFlO0lBQy9DO1FBQ0UsS0FBSyxDQUFDLGdCQUFnQixDQUFDLENBQUM7SUFDMUIsQ0FBQztDQUNGO0FBSkQsb0NBSUM7QUFFRCxNQUFhLFNBQVUsU0FBUSxlQUFlO0lBQzVDO1FBQ0UsS0FBSyxDQUFDLGFBQWEsQ0FBQyxDQUFDO0lBQ3ZCLENBQUM7Q0FDRjtBQUpELDhCQUlDO0FBRUQsTUFBYSxVQUFXLFNBQVEsZUFBZTtJQUM3QztRQUNFLEtBQUssQ0FBQyxjQUFjLENBQUMsQ0FBQztJQUN4QixDQUFDO0NBQ0Y7QUFKRCxnQ0FJQztBQUVELE1BQWEsWUFBYSxTQUFRLGVBQWU7SUFDL0M7UUFDRSxLQUFLLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztJQUMxQixDQUFDO0NBQ0Y7QUFKRCxvQ0FJQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENsb3VkRm9ybWF0aW9uVG9rZW4gfSBmcm9tICcuL2Nsb3VkZm9ybWF0aW9uLXRva2VuJztcblxuZXhwb3J0IGNsYXNzIFBzZXVkb1BhcmFtZXRlciBleHRlbmRzIENsb3VkRm9ybWF0aW9uVG9rZW4ge1xuICBjb25zdHJ1Y3RvcihuYW1lOiBzdHJpbmcpIHtcbiAgICBzdXBlcih7IFJlZjogbmFtZSB9LCBuYW1lKTtcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgQXdzQWNjb3VudElkIGV4dGVuZHMgUHNldWRvUGFyYW1ldGVyIHtcbiAgY29uc3RydWN0b3IoKSB7XG4gICAgc3VwZXIoJ0FXUzo6QWNjb3VudElkJyk7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIEF3c0RvbWFpblN1ZmZpeCBleHRlbmRzIFBzZXVkb1BhcmFtZXRlciB7XG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIHN1cGVyKCdBV1M6OkRvbWFpblN1ZmZpeCcpO1xuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBBd3NVUkxTdWZmaXggZXh0ZW5kcyBQc2V1ZG9QYXJhbWV0ZXIge1xuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcignQVdTOjpVUkxTdWZmaXgnKTtcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgQXdzTm90aWZpY2F0aW9uQVJOcyBleHRlbmRzIFBzZXVkb1BhcmFtZXRlciB7XG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIHN1cGVyKCdBV1M6Ok5vdGlmaWNhdGlvbkFSTnMnKTtcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgQXdzTm9WYWx1ZSBleHRlbmRzIFBzZXVkb1BhcmFtZXRlciB7XG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIHN1cGVyKCdBV1M6Ok5vVmFsdWUnKTtcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgQXdzUGFydGl0aW9uIGV4dGVuZHMgUHNldWRvUGFyYW1ldGVyIHtcbiAgY29uc3RydWN0b3IoKSB7XG4gICAgc3VwZXIoJ0FXUzo6UGFydGl0aW9uJyk7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIEF3c1JlZ2lvbiBleHRlbmRzIFBzZXVkb1BhcmFtZXRlciB7XG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIHN1cGVyKCdBV1M6OlJlZ2lvbicpO1xuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBBd3NTdGFja0lkIGV4dGVuZHMgUHNldWRvUGFyYW1ldGVyIHtcbiAgY29uc3RydWN0b3IoKSB7XG4gICAgc3VwZXIoJ0FXUzo6U3RhY2tJZCcpO1xuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBBd3NTdGFja05hbWUgZXh0ZW5kcyBQc2V1ZG9QYXJhbWV0ZXIge1xuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcignQVdTOjpTdGFja05hbWUnKTtcbiAgfVxufVxuIl19

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

exports.applyRemovalPolicy = applyRemovalPolicy;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVtb3ZhbC1wb2xpY3kuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJyZW1vdmFsLXBvbGljeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUNBLHVEQUFtRDtBQUVuRCxJQUFZLGFBa0JYO0FBbEJELFdBQVksYUFBYTtJQUNyQjs7O09BR0c7SUFDSCx1REFBVyxDQUFBO0lBRVg7OztPQUdHO0lBQ0gscURBQU0sQ0FBQTtJQUVOOzs7T0FHRztJQUNILHFEQUFNLENBQUE7QUFDVixDQUFDLEVBbEJXLGFBQWEsR0FBYixxQkFBYSxLQUFiLHFCQUFhLFFBa0J4QjtBQUVELFNBQWdCLGtCQUFrQixDQUFDLFFBQWtCLEVBQUUsYUFBd0M7SUFDM0YsSUFBSSxhQUFhLEtBQUssYUFBYSxDQUFDLE1BQU0sSUFBSSxhQUFhLEtBQUssYUFBYSxDQUFDLE1BQU0sRUFBRTtRQUNsRixRQUFRLENBQUMsT0FBTyxDQUFDLGNBQWMsR0FBRyxnQ0FBYyxDQUFDLE1BQU0sQ0FBQztLQUMzRDtJQUVELHlFQUF5RTtJQUN6RSwrQ0FBK0M7SUFDL0MsSUFBSSxhQUFhLEtBQUssYUFBYSxDQUFDLE1BQU0sRUFBRTtRQUN4QyxRQUFRLENBQUMsV0FBVyxDQUFDLG1CQUFtQixFQUFFLElBQUksQ0FBQyxDQUFDO0tBQ25EO0FBQ0wsQ0FBQztBQVZELGdEQVVDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUmVzb3VyY2UgfSBmcm9tICcuL3Jlc291cmNlJztcbmltcG9ydCB7IERlbGV0aW9uUG9saWN5IH0gZnJvbSAnLi9yZXNvdXJjZS1wb2xpY3knO1xuXG5leHBvcnQgZW51bSBSZW1vdmFsUG9saWN5IHtcbiAgICAvKipcbiAgICAgKiBUaGlzIGlzIHRoZSBkZWZhdWx0IHJlbW92YWwgcG9saWN5IGZvciBtb3N0IHJlc291cmNlcy4gSXQgbWVhbnMgdGhhdCB3aGVuIHRoZSByZXNvdXJjZVxuICAgICAqIGlzIHJlbW92ZWQgZnJvbSB0aGUgYXBwLCBpdCB3aWxsIGJlIHBoeXNpY2FsbHkgZGVzdHJveWVkLlxuICAgICAqL1xuICAgIERlc3Ryb3kgPSAwLFxuXG4gICAgLyoqXG4gICAgICogVGhpcyB1c2VzIHRoZSAnUmV0YWluJyBEZWxldGlvblBvbGljeSwgd2hpY2ggd2lsbCBjYXVzZSB0aGUgcmVzb3VyY2UgdG8gYmUgcmV0YWluZWRcbiAgICAgKiBpbiB0aGUgYWNjb3VudCwgYnV0IG9ycGhhbmVkIGZyb20gdGhlIHN0YWNrLlxuICAgICAqL1xuICAgIE9ycGhhbixcblxuICAgIC8qKlxuICAgICAqIFRoaXMgd2lsbCBhcHBseSB0aGUgJ1JldGFpbicgRGVsZXRpb25Qb2xpY3kgYW5kIGFsc28gYWRkIG1ldGFkYXRhIGZvciB0aGUgdG9vbGtpdFxuICAgICAqIHRvIGFwcGx5IGEgQ2xvdWRGb3JtYXRpb24gc3RhY2sgcG9saWN5IHdoaWNoIGZvcmJpZHMgdGhlIGRlbGV0aW9uIG9mIHJlc291cmNlLlxuICAgICAqL1xuICAgIEZvcmJpZFxufVxuXG5leHBvcnQgZnVuY3Rpb24gYXBwbHlSZW1vdmFsUG9saWN5KHJlc291cmNlOiBSZXNvdXJjZSwgcmVtb3ZhbFBvbGljeTogUmVtb3ZhbFBvbGljeSB8IHVuZGVmaW5lZCkge1xuICAgIGlmIChyZW1vdmFsUG9saWN5ID09PSBSZW1vdmFsUG9saWN5Lk9ycGhhbiB8fCByZW1vdmFsUG9saWN5ID09PSBSZW1vdmFsUG9saWN5LkZvcmJpZCkge1xuICAgICAgICByZXNvdXJjZS5vcHRpb25zLmRlbGV0aW9uUG9saWN5ID0gRGVsZXRpb25Qb2xpY3kuUmV0YWluO1xuICAgIH1cblxuICAgIC8vIGF0dGFjaCBtZXRhZGF0YSB0aGF0IHdpbGwgdGVsbCB0aGUgdG9vbGtpdCB0byBwcm90ZWN0IHRoaXMgcmVzb3VyY2UgYnlcbiAgICAvLyBhcHBseWluZyBhbiBhcHByb3ByaWF0ZSBzdGFjayB1cGRhdGUgcG9saWN5LlxuICAgIGlmIChyZW1vdmFsUG9saWN5ID09PSBSZW1vdmFsUG9saWN5LkZvcmJpZCkge1xuICAgICAgICByZXNvdXJjZS5hZGRNZXRhZGF0YSgnYXdzOmNkazpwcm90ZWN0ZWQnLCB0cnVlKTtcbiAgICB9XG59Il19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVtb3ZhbC1wb2xpY3kuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJyZW1vdmFsLXBvbGljeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUNBLHVEQUFtRDtBQUVuRCxJQUFZLGFBa0JYO0FBbEJELFdBQVksYUFBYTtJQUN2Qjs7O09BR0c7SUFDSCx1REFBVyxDQUFBO0lBRVg7OztPQUdHO0lBQ0gscURBQU0sQ0FBQTtJQUVOOzs7T0FHRztJQUNILHFEQUFNLENBQUE7QUFDUixDQUFDLEVBbEJXLGFBQWEsR0FBYixxQkFBYSxLQUFiLHFCQUFhLFFBa0J4QjtBQUVELFNBQWdCLGtCQUFrQixDQUFDLFFBQWtCLEVBQUUsYUFBd0M7SUFDN0YsSUFBSSxhQUFhLEtBQUssYUFBYSxDQUFDLE1BQU0sSUFBSSxhQUFhLEtBQUssYUFBYSxDQUFDLE1BQU0sRUFBRTtRQUNwRixRQUFRLENBQUMsT0FBTyxDQUFDLGNBQWMsR0FBRyxnQ0FBYyxDQUFDLE1BQU0sQ0FBQztLQUN6RDtJQUVELHlFQUF5RTtJQUN6RSwrQ0FBK0M7SUFDL0MsSUFBSSxhQUFhLEtBQUssYUFBYSxDQUFDLE1BQU0sRUFBRTtRQUMxQyxRQUFRLENBQUMsV0FBVyxDQUFDLG1CQUFtQixFQUFFLElBQUksQ0FBQyxDQUFDO0tBQ2pEO0FBQ0gsQ0FBQztBQVZELGdEQVVDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUmVzb3VyY2UgfSBmcm9tICcuL3Jlc291cmNlJztcbmltcG9ydCB7IERlbGV0aW9uUG9saWN5IH0gZnJvbSAnLi9yZXNvdXJjZS1wb2xpY3knO1xuXG5leHBvcnQgZW51bSBSZW1vdmFsUG9saWN5IHtcbiAgLyoqXG4gICAqIFRoaXMgaXMgdGhlIGRlZmF1bHQgcmVtb3ZhbCBwb2xpY3kgZm9yIG1vc3QgcmVzb3VyY2VzLiBJdCBtZWFucyB0aGF0IHdoZW4gdGhlIHJlc291cmNlXG4gICAqIGlzIHJlbW92ZWQgZnJvbSB0aGUgYXBwLCBpdCB3aWxsIGJlIHBoeXNpY2FsbHkgZGVzdHJveWVkLlxuICAgKi9cbiAgRGVzdHJveSA9IDAsXG5cbiAgLyoqXG4gICAqIFRoaXMgdXNlcyB0aGUgJ1JldGFpbicgRGVsZXRpb25Qb2xpY3ksIHdoaWNoIHdpbGwgY2F1c2UgdGhlIHJlc291cmNlIHRvIGJlIHJldGFpbmVkXG4gICAqIGluIHRoZSBhY2NvdW50LCBidXQgb3JwaGFuZWQgZnJvbSB0aGUgc3RhY2suXG4gICAqL1xuICBPcnBoYW4sXG5cbiAgLyoqXG4gICAqIFRoaXMgd2lsbCBhcHBseSB0aGUgJ1JldGFpbicgRGVsZXRpb25Qb2xpY3kgYW5kIGFsc28gYWRkIG1ldGFkYXRhIGZvciB0aGUgdG9vbGtpdFxuICAgKiB0byBhcHBseSBhIENsb3VkRm9ybWF0aW9uIHN0YWNrIHBvbGljeSB3aGljaCBmb3JiaWRzIHRoZSBkZWxldGlvbiBvZiByZXNvdXJjZS5cbiAgICovXG4gIEZvcmJpZFxufVxuXG5leHBvcnQgZnVuY3Rpb24gYXBwbHlSZW1vdmFsUG9saWN5KHJlc291cmNlOiBSZXNvdXJjZSwgcmVtb3ZhbFBvbGljeTogUmVtb3ZhbFBvbGljeSB8IHVuZGVmaW5lZCkge1xuICBpZiAocmVtb3ZhbFBvbGljeSA9PT0gUmVtb3ZhbFBvbGljeS5PcnBoYW4gfHwgcmVtb3ZhbFBvbGljeSA9PT0gUmVtb3ZhbFBvbGljeS5Gb3JiaWQpIHtcbiAgICByZXNvdXJjZS5vcHRpb25zLmRlbGV0aW9uUG9saWN5ID0gRGVsZXRpb25Qb2xpY3kuUmV0YWluO1xuICB9XG5cbiAgLy8gYXR0YWNoIG1ldGFkYXRhIHRoYXQgd2lsbCB0ZWxsIHRoZSB0b29sa2l0IHRvIHByb3RlY3QgdGhpcyByZXNvdXJjZSBieVxuICAvLyBhcHBseWluZyBhbiBhcHByb3ByaWF0ZSBzdGFjayB1cGRhdGUgcG9saWN5LlxuICBpZiAocmVtb3ZhbFBvbGljeSA9PT0gUmVtb3ZhbFBvbGljeS5Gb3JiaWQpIHtcbiAgICByZXNvdXJjZS5hZGRNZXRhZGF0YSgnYXdzOmNkazpwcm90ZWN0ZWQnLCB0cnVlKTtcbiAgfVxufVxuIl19

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

})(DeletionPolicy = exports.DeletionPolicy || (exports.DeletionPolicy = {}));
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resource-policy.js","sourceRoot":"","sources":["resource-policy.ts"],"names":[],"mappings":";;AAkEA;;;;;GAKG;AACH,IAAY,cAwBX;AAxBD,WAAY,cAAc;IACtB;;;;OAIG;IACH,mCAAiB,CAAA;IAEjB;;;;;OAKG;IACH,mCAAiB,CAAA;IAEjB;;;;;;OAMG;IACH,uCAAqB,CAAA;AACzB,CAAC,EAxBW,cAAc,GAAd,sBAAc,KAAd,sBAAc,QAwBzB","sourcesContent":["/**\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 * The creation policy is invoked only when AWS CloudFormation creates the associated resource. Currently, the only\n * AWS CloudFormation resources that support creation policies are AWS::AutoScaling::AutoScalingGroup, AWS::EC2::Instance,\n * and AWS::CloudFormation::WaitCondition.\n *\n * Use the CreationPolicy attribute when you want to wait on resource configuration actions before stack creation proceeds.\n * For example, if you install and configure software applications on an EC2 instance, you might want those applications to\n * be running before proceeding. In such cases, you can add a CreationPolicy attribute to the instance, and then send a success\n * signal to the instance after the applications are installed and configured. For a detailed example, see Deploying Applications\n * on Amazon EC2 with AWS CloudFormation.\n */\nexport interface CreationPolicy {\n    /**\n     * For an Auto Scaling group replacement update, specifies how many instances must signal success for the\n     * update to succeed.\n     */\n    autoScalingCreationPolicy?: AutoScalingCreationPolicy;\n\n    /**\n     * When AWS CloudFormation creates the associated resource, configures the number of required success signals and\n     * the length of time that AWS CloudFormation waits for those signals.\n     */\n    resourceSignal?: ResourceSignal;\n}\n\n/**\n * For an Auto Scaling group replacement update, specifies how many instances must signal success for the\n * update to succeed.\n */\nexport interface AutoScalingCreationPolicy {\n    /**\n     * Specifies the percentage of instances in an Auto Scaling replacement update that must signal success for the\n     * update to succeed. You can specify a value from 0 to 100. AWS CloudFormation rounds to the nearest tenth of a percent.\n     * For example, if you update five instances with a minimum successful percentage of 50, three instances must signal success.\n     * If an instance doesn't send a signal within the time specified by the Timeout property, AWS CloudFormation assumes that the\n     * instance wasn't created.\n     */\n    minSuccessfulInstancesPercent?: number;\n}\n\n/**\n * When AWS CloudFormation creates the associated resource, configures the number of required success signals and\n * the length of time that AWS CloudFormation waits for those signals.\n */\nexport interface ResourceSignal {\n\n    /**\n     * The number of success signals AWS CloudFormation must receive before it sets the resource status as CREATE_COMPLETE.\n     * If the resource receives a failure signal or doesn't receive the specified number of signals before the timeout period\n     * expires, the resource creation fails and AWS CloudFormation rolls the stack back.\n     */\n    count?: number;\n\n    /**\n     * The length of time that AWS CloudFormation waits for the number of signals that was specified in the Count property.\n     * The timeout period starts after AWS CloudFormation starts creating the resource, and the timeout expires no sooner\n     * than the time you specify but can occur shortly thereafter. The maximum time that you can specify is 12 hours.\n     */\n    timeout?: string;\n}\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 */\nexport enum DeletionPolicy {\n    /**\n     * AWS CloudFormation deletes the resource and all its content if applicable during stack deletion. You can add this\n     * deletion policy to any resource type. By default, if you don't specify a DeletionPolicy, AWS CloudFormation deletes\n     * your resources. However, be aware of the following considerations:\n     */\n    Delete = 'Delete',\n\n    /**\n     * AWS CloudFormation keeps the resource without deleting the resource or its contents when its stack is deleted.\n     * You can add this deletion policy to any resource type. Note that when AWS CloudFormation completes the stack deletion,\n     * the stack will be in Delete_Complete state; however, resources that are retained continue to exist and continue to incur\n     * applicable charges until you delete those resources.\n     */\n    Retain = 'Retain',\n\n    /**\n     * For resources that support snapshots (AWS::EC2::Volume, AWS::ElastiCache::CacheCluster, AWS::ElastiCache::ReplicationGroup,\n     * AWS::RDS::DBInstance, AWS::RDS::DBCluster, and AWS::Redshift::Cluster), AWS CloudFormation creates a snapshot for the\n     * resource before deleting it. Note that when AWS CloudFormation completes the stack deletion, the stack will be in the\n     * Delete_Complete state; however, the snapshots that are created with this policy continue to exist and continue to\n     * incur applicable charges until you delete those snapshots.\n     */\n    Snapshot = 'Snapshot',\n}\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 */\nexport interface UpdatePolicy {\n\n    /**\n     * Specifies whether an Auto Scaling group and the instances it contains are replaced during an update. During replacement,\n     * AWS CloudFormation retains the old group until it finishes creating the new one. If the update fails, AWS CloudFormation\n     * can roll back to the old Auto Scaling group and delete the new Auto Scaling group.\n     */\n    autoScalingReplacingUpdate?: AutoScalingReplacingUpdate;\n\n    /**\n     * To specify how AWS CloudFormation handles rolling updates for an Auto Scaling group, use the AutoScalingRollingUpdate\n     * policy. Rolling updates enable you to specify whether AWS CloudFormation updates instances that are in an Auto Scaling\n     * group in batches or all at once.\n     */\n    autoScalingRollingUpdate?: AutoScalingRollingUpdate;\n\n    /**\n     * To specify how AWS CloudFormation handles updates for the MinSize, MaxSize, and DesiredCapacity properties when\n     * the AWS::AutoScaling::AutoScalingGroup resource has an associated scheduled action, use the AutoScalingScheduledAction\n     * policy.\n     */\n    autoScalingScheduledAction?: AutoScalingScheduledAction;\n\n}\n\n/**\n * To specify how AWS CloudFormation handles rolling updates for an Auto Scaling group, use the AutoScalingRollingUpdate\n * policy. Rolling updates enable you to specify whether AWS CloudFormation updates instances that are in an Auto Scaling\n * group in batches or all at once.\n */\nexport interface AutoScalingRollingUpdate {\n\n    /**\n     * Specifies the maximum number of instances that AWS CloudFormation updates.\n     */\n    maxBatchSize?: number;\n\n    /**\n     * Specifies the minimum number of instances that must be in service within the Auto Scaling group while AWS\n     * CloudFormation updates old instances.\n     */\n    minInstancesInService?: number;\n\n    /**\n     * Specifies the percentage of instances in an Auto Scaling rolling update that must signal success for an update to succeed.\n     * You can specify a value from 0 to 100. AWS CloudFormation rounds to the nearest tenth of a percent. For example, if you\n     * update five instances with a minimum successful percentage of 50, three instances must signal success.\n     *\n     * If an instance doesn't send a signal within the time specified in the PauseTime property, AWS CloudFormation assumes\n     * that the instance wasn't updated.\n     *\n     * If you specify this property, you must also enable the WaitOnResourceSignals and PauseTime properties.\n     */\n    minSuccessfulInstancesPercent?: number;\n\n    /**\n     * The amount of time that AWS CloudFormation pauses after making a change to a batch of instances to give those instances\n     * time to start software applications. For example, you might need to specify PauseTime when scaling up the number of\n     * instances in an Auto Scaling group.\n     *\n     * If you enable the WaitOnResourceSignals property, PauseTime is the amount of time that AWS CloudFormation should wait\n     * for the Auto Scaling group to receive the required number of valid signals from added or replaced instances. If the\n     * PauseTime is exceeded before the Auto Scaling group receives the required number of signals, the update fails. For best\n     * results, specify a time period that gives your applications sufficient time to get started. If the update needs to be\n     * rolled back, a short PauseTime can cause the rollback to fail.\n     *\n     * Specify PauseTime in the ISO8601 duration format (in the format PT#H#M#S, where each # is the number of hours, minutes,\n     * and seconds, respectively). The maximum PauseTime is one hour (PT1H).\n     */\n    pauseTime?: string;\n\n    /**\n     * Specifies the Auto Scaling processes to suspend during a stack update. Suspending processes prevents Auto Scaling from\n     * interfering with a stack update. For example, you can suspend alarming so that Auto Scaling doesn't execute scaling\n     * policies associated with an alarm. For valid values, see the ScalingProcesses.member.N parameter for the SuspendProcesses\n     * action in the Auto Scaling API Reference.\n     */\n    suspendProcesses?: string[];\n\n    /**\n     * Specifies whether the Auto Scaling group waits on signals from new instances during an update. Use this property to\n     * ensure that instances have completed installing and configuring applications before the Auto Scaling group update proceeds.\n     * AWS CloudFormation suspends the update of an Auto Scaling group after new EC2 instances are launched into the group.\n     * AWS CloudFormation must receive a signal from each new instance within the specified PauseTime before continuing the update.\n     * To signal the Auto Scaling group, use the cfn-signal helper script or SignalResource API.\n     *\n     * To have instances wait for an Elastic Load Balancing health check before they signal success, add a health-check\n     * verification by using the cfn-init helper script. For an example, see the verify_instance_health command in the Auto Scaling\n     * rolling updates sample template.\n     */\n    waitOnResourceSignals?: boolean;\n}\n\n/**\n * Specifies whether an Auto Scaling group and the instances it contains are replaced during an update. During replacement,\n * AWS CloudFormation retains the old group until it finishes creating the new one. If the update fails, AWS CloudFormation\n * can roll back to the old Auto Scaling group and delete the new Auto Scaling group.\n *\n * While AWS CloudFormation creates the new group, it doesn't detach or attach any instances. After successfully creating\n * the new Auto Scaling group, AWS CloudFormation deletes the old Auto Scaling group during the cleanup process.\n *\n * When you set the WillReplace parameter, remember to specify a matching CreationPolicy. If the minimum number of\n * instances (specified by the MinSuccessfulInstancesPercent property) don't signal success within the Timeout period\n * (specified in the CreationPolicy policy), the replacement update fails and AWS CloudFormation rolls back to the old\n * Auto Scaling group.\n */\nexport interface AutoScalingReplacingUpdate {\n    willReplace?: boolean;\n}\n\n/**\n * With scheduled actions, the group size properties of an Auto Scaling group can change at any time. When you update a\n * stack with an Auto Scaling group and scheduled action, AWS CloudFormation always sets the group size property values of\n * your Auto Scaling group to the values that are defined in the AWS::AutoScaling::AutoScalingGroup resource of your template,\n * even if a scheduled action is in effect.\n *\n * If you do not want AWS CloudFormation to change any of the group size property values when you have a scheduled action in\n * effect, use the AutoScalingScheduledAction update policy to prevent AWS CloudFormation from changing the MinSize, MaxSize,\n * or DesiredCapacity properties unless you have modified these values in your template.\\\n */\nexport interface AutoScalingScheduledAction {\n    /*\n    * Specifies whether AWS CloudFormation ignores differences in group size properties between your current Auto Scaling\n    * group and the Auto Scaling group described in the AWS::AutoScaling::AutoScalingGroup resource of your template during\n    * a stack update. If you modify any of the group size property values in your template, AWS CloudFormation uses the modified\n    * values and updates your Auto Scaling group.\n    */\n    ignoreUnmodifiedGroupSizeProperties?: boolean;\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resource-policy.js","sourceRoot":"","sources":["resource-policy.ts"],"names":[],"mappings":";;AAkEA;;;;;GAKG;AACH,IAAY,cAwBX;AAxBD,WAAY,cAAc;IACxB;;;;OAIG;IACH,mCAAiB,CAAA;IAEjB;;;;;OAKG;IACH,mCAAiB,CAAA;IAEjB;;;;;;OAMG;IACH,uCAAqB,CAAA;AACvB,CAAC,EAxBW,cAAc,GAAd,sBAAc,KAAd,sBAAc,QAwBzB","sourcesContent":["/**\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 * The creation policy is invoked only when AWS CloudFormation creates the associated resource. Currently, the only\n * AWS CloudFormation resources that support creation policies are AWS::AutoScaling::AutoScalingGroup, AWS::EC2::Instance,\n * and AWS::CloudFormation::WaitCondition.\n *\n * Use the CreationPolicy attribute when you want to wait on resource configuration actions before stack creation proceeds.\n * For example, if you install and configure software applications on an EC2 instance, you might want those applications to\n * be running before proceeding. In such cases, you can add a CreationPolicy attribute to the instance, and then send a success\n * signal to the instance after the applications are installed and configured. For a detailed example, see Deploying Applications\n * on Amazon EC2 with AWS CloudFormation.\n */\nexport interface CreationPolicy {\n  /**\n   * For an Auto Scaling group replacement update, specifies how many instances must signal success for the\n   * update to succeed.\n   */\n  autoScalingCreationPolicy?: AutoScalingCreationPolicy;\n\n  /**\n   * When AWS CloudFormation creates the associated resource, configures the number of required success signals and\n   * the length of time that AWS CloudFormation waits for those signals.\n   */\n  resourceSignal?: ResourceSignal;\n}\n\n/**\n * For an Auto Scaling group replacement update, specifies how many instances must signal success for the\n * update to succeed.\n */\nexport interface AutoScalingCreationPolicy {\n  /**\n   * Specifies the percentage of instances in an Auto Scaling replacement update that must signal success for the\n   * update to succeed. You can specify a value from 0 to 100. AWS CloudFormation rounds to the nearest tenth of a percent.\n   * For example, if you update five instances with a minimum successful percentage of 50, three instances must signal success.\n   * If an instance doesn't send a signal within the time specified by the Timeout property, AWS CloudFormation assumes that the\n   * instance wasn't created.\n   */\n  minSuccessfulInstancesPercent?: number;\n}\n\n/**\n * When AWS CloudFormation creates the associated resource, configures the number of required success signals and\n * the length of time that AWS CloudFormation waits for those signals.\n */\nexport interface ResourceSignal {\n\n  /**\n   * The number of success signals AWS CloudFormation must receive before it sets the resource status as CREATE_COMPLETE.\n   * If the resource receives a failure signal or doesn't receive the specified number of signals before the timeout period\n   * expires, the resource creation fails and AWS CloudFormation rolls the stack back.\n   */\n  count?: number;\n\n  /**\n   * The length of time that AWS CloudFormation waits for the number of signals that was specified in the Count property.\n   * The timeout period starts after AWS CloudFormation starts creating the resource, and the timeout expires no sooner\n   * than the time you specify but can occur shortly thereafter. The maximum time that you can specify is 12 hours.\n   */\n  timeout?: string;\n}\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 */\nexport enum DeletionPolicy {\n  /**\n   * AWS CloudFormation deletes the resource and all its content if applicable during stack deletion. You can add this\n   * deletion policy to any resource type. By default, if you don't specify a DeletionPolicy, AWS CloudFormation deletes\n   * your resources. However, be aware of the following considerations:\n   */\n  Delete = 'Delete',\n\n  /**\n   * AWS CloudFormation keeps the resource without deleting the resource or its contents when its stack is deleted.\n   * You can add this deletion policy to any resource type. Note that when AWS CloudFormation completes the stack deletion,\n   * the stack will be in Delete_Complete state; however, resources that are retained continue to exist and continue to incur\n   * applicable charges until you delete those resources.\n   */\n  Retain = 'Retain',\n\n  /**\n   * For resources that support snapshots (AWS::EC2::Volume, AWS::ElastiCache::CacheCluster, AWS::ElastiCache::ReplicationGroup,\n   * AWS::RDS::DBInstance, AWS::RDS::DBCluster, and AWS::Redshift::Cluster), AWS CloudFormation creates a snapshot for the\n   * resource before deleting it. Note that when AWS CloudFormation completes the stack deletion, the stack will be in the\n   * Delete_Complete state; however, the snapshots that are created with this policy continue to exist and continue to\n   * incur applicable charges until you delete those snapshots.\n   */\n  Snapshot = 'Snapshot',\n}\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 */\nexport interface UpdatePolicy {\n\n  /**\n   * Specifies whether an Auto Scaling group and the instances it contains are replaced during an update. During replacement,\n   * AWS CloudFormation retains the old group until it finishes creating the new one. If the update fails, AWS CloudFormation\n   * can roll back to the old Auto Scaling group and delete the new Auto Scaling group.\n   */\n  autoScalingReplacingUpdate?: AutoScalingReplacingUpdate;\n\n  /**\n   * To specify how AWS CloudFormation handles rolling updates for an Auto Scaling group, use the AutoScalingRollingUpdate\n   * policy. Rolling updates enable you to specify whether AWS CloudFormation updates instances that are in an Auto Scaling\n   * group in batches or all at once.\n   */\n  autoScalingRollingUpdate?: AutoScalingRollingUpdate;\n\n  /**\n   * To specify how AWS CloudFormation handles updates for the MinSize, MaxSize, and DesiredCapacity properties when\n   * the AWS::AutoScaling::AutoScalingGroup resource has an associated scheduled action, use the AutoScalingScheduledAction\n   * policy.\n   */\n  autoScalingScheduledAction?: AutoScalingScheduledAction;\n\n}\n\n/**\n * To specify how AWS CloudFormation handles rolling updates for an Auto Scaling group, use the AutoScalingRollingUpdate\n * policy. Rolling updates enable you to specify whether AWS CloudFormation updates instances that are in an Auto Scaling\n * group in batches or all at once.\n */\nexport interface AutoScalingRollingUpdate {\n\n  /**\n   * Specifies the maximum number of instances that AWS CloudFormation updates.\n   */\n  maxBatchSize?: number;\n\n  /**\n   * Specifies the minimum number of instances that must be in service within the Auto Scaling group while AWS\n   * CloudFormation updates old instances.\n   */\n  minInstancesInService?: number;\n\n  /**\n   * Specifies the percentage of instances in an Auto Scaling rolling update that must signal success for an update to succeed.\n   * You can specify a value from 0 to 100. AWS CloudFormation rounds to the nearest tenth of a percent. For example, if you\n   * update five instances with a minimum successful percentage of 50, three instances must signal success.\n   *\n   * If an instance doesn't send a signal within the time specified in the PauseTime property, AWS CloudFormation assumes\n   * that the instance wasn't updated.\n   *\n   * If you specify this property, you must also enable the WaitOnResourceSignals and PauseTime properties.\n   */\n  minSuccessfulInstancesPercent?: number;\n\n  /**\n   * The amount of time that AWS CloudFormation pauses after making a change to a batch of instances to give those instances\n   * time to start software applications. For example, you might need to specify PauseTime when scaling up the number of\n   * instances in an Auto Scaling group.\n   *\n   * If you enable the WaitOnResourceSignals property, PauseTime is the amount of time that AWS CloudFormation should wait\n   * for the Auto Scaling group to receive the required number of valid signals from added or replaced instances. If the\n   * PauseTime is exceeded before the Auto Scaling group receives the required number of signals, the update fails. For best\n   * results, specify a time period that gives your applications sufficient time to get started. If the update needs to be\n   * rolled back, a short PauseTime can cause the rollback to fail.\n   *\n   * Specify PauseTime in the ISO8601 duration format (in the format PT#H#M#S, where each # is the number of hours, minutes,\n   * and seconds, respectively). The maximum PauseTime is one hour (PT1H).\n   */\n  pauseTime?: string;\n\n  /**\n   * Specifies the Auto Scaling processes to suspend during a stack update. Suspending processes prevents Auto Scaling from\n   * interfering with a stack update. For example, you can suspend alarming so that Auto Scaling doesn't execute scaling\n   * policies associated with an alarm. For valid values, see the ScalingProcesses.member.N parameter for the SuspendProcesses\n   * action in the Auto Scaling API Reference.\n   */\n  suspendProcesses?: string[];\n\n  /**\n   * Specifies whether the Auto Scaling group waits on signals from new instances during an update. Use this property to\n   * ensure that instances have completed installing and configuring applications before the Auto Scaling group update proceeds.\n   * AWS CloudFormation suspends the update of an Auto Scaling group after new EC2 instances are launched into the group.\n   * AWS CloudFormation must receive a signal from each new instance within the specified PauseTime before continuing the update.\n   * To signal the Auto Scaling group, use the cfn-signal helper script or SignalResource API.\n   *\n   * To have instances wait for an Elastic Load Balancing health check before they signal success, add a health-check\n   * verification by using the cfn-init helper script. For an example, see the verify_instance_health command in the Auto Scaling\n   * rolling updates sample template.\n   */\n  waitOnResourceSignals?: boolean;\n}\n\n/**\n * Specifies whether an Auto Scaling group and the instances it contains are replaced during an update. During replacement,\n * AWS CloudFormation retains the old group until it finishes creating the new one. If the update fails, AWS CloudFormation\n * can roll back to the old Auto Scaling group and delete the new Auto Scaling group.\n *\n * While AWS CloudFormation creates the new group, it doesn't detach or attach any instances. After successfully creating\n * the new Auto Scaling group, AWS CloudFormation deletes the old Auto Scaling group during the cleanup process.\n *\n * When you set the WillReplace parameter, remember to specify a matching CreationPolicy. If the minimum number of\n * instances (specified by the MinSuccessfulInstancesPercent property) don't signal success within the Timeout period\n * (specified in the CreationPolicy policy), the replacement update fails and AWS CloudFormation rolls back to the old\n * Auto Scaling group.\n */\nexport interface AutoScalingReplacingUpdate {\n  willReplace?: boolean;\n}\n\n/**\n * With scheduled actions, the group size properties of an Auto Scaling group can change at any time. When you update a\n * stack with an Auto Scaling group and scheduled action, AWS CloudFormation always sets the group size property values of\n * your Auto Scaling group to the values that are defined in the AWS::AutoScaling::AutoScalingGroup resource of your template,\n * even if a scheduled action is in effect.\n *\n * If you do not want AWS CloudFormation to change any of the group size property values when you have a scheduled action in\n * effect, use the AutoScalingScheduledAction update policy to prevent AWS CloudFormation from changing the MinSize, MaxSize,\n * or DesiredCapacity properties unless you have modified these values in your template.\\\n */\nexport interface AutoScalingScheduledAction {\n  /*\n  * Specifies whether AWS CloudFormation ignores differences in group size properties between your current Auto Scaling\n  * group and the Auto Scaling group described in the AWS::AutoScaling::AutoScalingGroup resource of your template during\n  * a stack update. If you modify any of the group size property values in your template, AWS CloudFormation uses the modified\n  * values and updates your Auto Scaling group.\n  */\n  ignoreUnmodifiedGroupSizeProperties?: boolean;\n}\n"]}

@@ -35,5 +35,22 @@ import { Construct } from '../core/construct';

/**
* AWS resource properties
* AWS resource property overrides.
*
* During synthesis, the method "renderProperties(this.overrides)" is called
* with this object, and merged on top of the output of
* "renderProperties(this.properties)".
*
* Derived classes should expose a strongly-typed version of this object as
* a public property called `propertyOverrides`.
*/
protected readonly untypedPropertyOverrides: any;
/**
* AWS resource properties.
*
* This object is rendered via a call to "renderProperties(this.properties)".
*/
protected readonly properties: any;
/**
* An object to be merged on top of the entire resource definition.
*/
private readonly rawOverrides;
private dependsOn;

@@ -58,6 +75,36 @@ /**

/**
* Adds an override to the synthesized CloudFormation resource. To add a
* property override, either use `addPropertyOverride` or prefix `path` with
* "Properties." (i.e. `Properties.TopicName`).
*
* @param path The path of the property, you can use dot notation to
* override values in complex types. Any intermdediate keys
* will be created as needed.
* @param value The value. Could be primitive or complex.
*/
addOverride(path: string, value: any): void;
/**
* Syntactic sugar for `addOverride(path, undefined)`.
* @param path The path of the value to delete
*/
addDeletionOverride(path: string): void;
/**
* Adds an override to a resource property.
*
* Syntactic sugar for `addOverride("Properties.<...>", value)`.
*
* @param propertyPath The path of the property
* @param value The value
*/
addPropertyOverride(propertyPath: string, value: any): void;
/**
* Adds an override that deletes the value of a property from the resource definition.
* @param propertyPath The path to the property.
*/
addPropertyDeletionOverride(propertyPath: string): void;
/**
* Emits CloudFormation for this resource.
*/
toCloudFormation(): object;
protected renderProperties(): {
protected renderProperties(properties: any): {
[key: string]: any;

@@ -102,1 +149,6 @@ };

}
/**
* Merges `source` into `target`, overriding any existing values.
* `null`s will cause a value to be deleted.
*/
export declare function deepMerge(target: any, source: any): any;

@@ -20,2 +20,17 @@ "use strict";

this.options = {};
/**
* AWS resource property overrides.
*
* During synthesis, the method "renderProperties(this.overrides)" is called
* with this object, and merged on top of the output of
* "renderProperties(this.properties)".
*
* Derived classes should expose a strongly-typed version of this object as
* a public property called `propertyOverrides`.
*/
this.untypedPropertyOverrides = {};
/**
* An object to be merged on top of the entire resource definition.
*/
this.rawOverrides = {};
this.dependsOn = new Array();

@@ -65,2 +80,53 @@ if (!props.type) {

/**
* Adds an override to the synthesized CloudFormation resource. To add a
* property override, either use `addPropertyOverride` or prefix `path` with
* "Properties." (i.e. `Properties.TopicName`).
*
* @param path The path of the property, you can use dot notation to
* override values in complex types. Any intermdediate keys
* will be created as needed.
* @param value The value. Could be primitive or complex.
*/
addOverride(path, value) {
const parts = path.split('.');
let curr = this.rawOverrides;
while (parts.length > 1) {
const key = parts.shift();
// if we can't recurse further or the previous value is not an
// object overwrite it with an object.
const isObject = curr[key] != null && typeof (curr[key]) === 'object' && !Array.isArray(curr[key]);
if (!isObject) {
curr[key] = {};
}
curr = curr[key];
}
const lastKey = parts.shift();
curr[lastKey] = value;
}
/**
* Syntactic sugar for `addOverride(path, undefined)`.
* @param path The path of the value to delete
*/
addDeletionOverride(path) {
this.addOverride(path, undefined);
}
/**
* Adds an override to a resource property.
*
* Syntactic sugar for `addOverride("Properties.<...>", value)`.
*
* @param propertyPath The path of the property
* @param value The value
*/
addPropertyOverride(propertyPath, value) {
this.addOverride(`Properties.${propertyPath}`, value);
}
/**
* Adds an override that deletes the value of a property from the resource definition.
* @param propertyPath The path to the property.
*/
addPropertyDeletionOverride(propertyPath) {
this.addPropertyOverride(propertyPath, undefined);
}
/**
* Emits CloudFormation for this resource.

@@ -70,7 +136,9 @@ */

try {
// merge property overrides onto properties and then render (and validate).
const properties = this.renderProperties(deepMerge(this.properties || {}, this.untypedPropertyOverrides));
return {
Resources: {
[this.logicalId]: {
[this.logicalId]: deepMerge({
Type: this.resourceType,
Properties: util_1.ignoreEmpty(this.renderProperties()),
Properties: util_1.ignoreEmpty(properties),
DependsOn: util_1.ignoreEmpty(this.renderDependsOn()),

@@ -82,3 +150,3 @@ CreationPolicy: util_1.capitalizePropertyNames(this.options.creationPolicy),

Condition: this.options.condition && this.options.condition.logicalId
}
}, this.rawOverrides)
}

@@ -91,5 +159,5 @@ };

// Adjust stack trace (make it look like node built it, too...)
const creationStack = ['--- resource created at ---', ...this.creationStackTrace].join('\n at ');
const creationStack = ['--- resource created at ---', ...this.creationStackTrace].join('\n at ');
const problemTrace = e.stack.substr(e.stack.indexOf(e.message) + e.message.length);
e.stack = `${e.message}\n ${creationStack}\n --- problem discovered at ---${problemTrace}`;
e.stack = `${e.message}\n ${creationStack}\n --- problem discovered at ---${problemTrace}`;
// Re-throw

@@ -99,5 +167,4 @@ throw e;

}
renderProperties() {
// FIXME: default implementation is not great, it should throw, but it avoids breaking all unit tests for now.
return this.properties;
renderProperties(properties) {
return properties;
}

@@ -128,2 +195,37 @@ renderDependsOn() {

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 { 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"]}
/**
* Merges `source` into `target`, overriding any existing values.
* `null`s will cause a value to be deleted.
*/
function deepMerge(target, source) {
if (typeof (source) !== 'object' || typeof (target) !== 'object') {
throw new Error(`Invalid usage. Both source (${JSON.stringify(source)}) and target (${JSON.stringify(target)}) must be objects`);
}
for (const key of Object.keys(source)) {
const value = source[key];
if (typeof (value) === 'object' && value != null && !Array.isArray(value)) {
// if the value at the target is not an object, override it with an
// object so we can continue the recursion
if (typeof (target[key]) !== 'object') {
target[key] = {};
}
deepMerge(target[key], value);
// if the result of the merge is an empty object, it's because the
// eventual value we assigned is `undefined`, and there are no
// sibling concrete values alongside, so we can delete this tree.
const output = target[key];
if (typeof (output) === 'object' && Object.keys(output).length === 0) {
delete target[key];
}
}
else if (value === undefined) {
delete target[key];
}
else {
target[key] = value;
}
}
return target;
}
exports.deepMerge = deepMerge;
//# 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 property overrides.\n   *\n   * During synthesis, the method \"renderProperties(this.overrides)\" is called\n   * with this object, and merged on top of the output of\n   * \"renderProperties(this.properties)\".\n   *\n   * Derived classes should expose a strongly-typed version of this object as\n   * a public property called `propertyOverrides`.\n   */\n  protected readonly untypedPropertyOverrides: any = { };\n\n  /**\n   * AWS resource properties.\n   *\n   * This object is rendered via a call to \"renderProperties(this.properties)\".\n   */\n  protected readonly properties: any;\n\n  /**\n   * An object to be merged on top of the entire resource definition.\n   */\n  private readonly rawOverrides: 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   * Adds an override to the synthesized CloudFormation resource. To add a\n   * property override, either use `addPropertyOverride` or prefix `path` with\n   * \"Properties.\" (i.e. `Properties.TopicName`).\n   *\n   * @param path  The path of the property, you can use dot notation to\n   *        override values in complex types. Any intermdediate keys\n   *        will be created as needed.\n   * @param value The value. Could be primitive or complex.\n   */\n  public addOverride(path: string, value: any) {\n    const parts = path.split('.');\n    let curr: any = this.rawOverrides;\n\n    while (parts.length > 1) {\n      const key = parts.shift()!;\n\n      // if we can't recurse further or the previous value is not an\n      // object overwrite it with an object.\n      const isObject = curr[key] != null && typeof(curr[key]) === 'object' && !Array.isArray(curr[key]);\n      if (!isObject) {\n        curr[key] = { };\n      }\n\n      curr = curr[key];\n    }\n\n    const lastKey = parts.shift()!;\n    curr[lastKey] = value;\n  }\n\n  /**\n   * Syntactic sugar for `addOverride(path, undefined)`.\n   * @param path The path of the value to delete\n   */\n  public addDeletionOverride(path: string) {\n    this.addOverride(path, undefined);\n  }\n\n  /**\n   * Adds an override to a resource property.\n   *\n   * Syntactic sugar for `addOverride(\"Properties.<...>\", value)`.\n   *\n   * @param propertyPath The path of the property\n   * @param value The value\n   */\n  public addPropertyOverride(propertyPath: string, value: any) {\n    this.addOverride(`Properties.${propertyPath}`, value);\n  }\n\n  /**\n   * Adds an override that deletes the value of a property from the resource definition.\n   * @param propertyPath The path to the property.\n   */\n  public addPropertyDeletionOverride(propertyPath: string) {\n    this.addPropertyOverride(propertyPath, undefined);\n  }\n\n  /**\n   * Emits CloudFormation for this resource.\n   */\n  public toCloudFormation(): object {\n    try {\n      // merge property overrides onto properties and then render (and validate).\n      const properties = this.renderProperties(deepMerge(this.properties || { }, this.untypedPropertyOverrides));\n\n      return {\n        Resources: {\n          [this.logicalId]: deepMerge({\n            Type: this.resourceType,\n            Properties: ignoreEmpty(properties),\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          }, this.rawOverrides)\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(properties: any): { [key: string]: any } {\n    return 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\n/**\n * Merges `source` into `target`, overriding any existing values.\n * `null`s will cause a value to be deleted.\n */\nexport function deepMerge(target: any, source: any) {\n  if (typeof(source) !== 'object' || typeof(target) !== 'object') {\n    throw new Error(`Invalid usage. Both source (${JSON.stringify(source)}) and target (${JSON.stringify(target)}) must be objects`);\n  }\n\n  for (const key of Object.keys(source)) {\n    const value = source[key];\n    if (typeof(value) === 'object' && value != null && !Array.isArray(value)) {\n      // if the value at the target is not an object, override it with an\n      // object so we can continue the recursion\n      if (typeof(target[key]) !== 'object') {\n        target[key] = { };\n      }\n\n      deepMerge(target[key], value);\n\n      // if the result of the merge is an empty object, it's because the\n      // eventual value we assigned is `undefined`, and there are no\n      // sibling concrete values alongside, so we can delete this tree.\n      const output = target[key];\n      if (typeof(output) === 'object' && Object.keys(output).length === 0) {\n        delete target[key];\n      }\n    } else if (value === undefined) {\n      delete target[key];\n    } else {\n      target[key] = value;\n    }\n  }\n\n  return target;\n}\n"]}

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

exports.Rule = Rule;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInJ1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFDQSx1Q0FBdUQ7QUFFdkQsbUNBQXdDO0FBb0N4Qzs7Ozs7Ozs7Ozs7Ozs7R0FjRztBQUNILE1BQWEsSUFBSyxTQUFRLHFCQUFhO0lBWW5DOzs7O09BSUc7SUFDSCxZQUFZLE1BQWlCLEVBQUUsSUFBWSxFQUFFLEtBQWlCO1FBQzFELEtBQUssQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFFcEIsSUFBSSxDQUFDLGFBQWEsR0FBRyxLQUFLLElBQUksS0FBSyxDQUFDLGFBQWEsQ0FBQztRQUNsRCxJQUFJLENBQUMsVUFBVSxHQUFHLEtBQUssSUFBSSxLQUFLLENBQUMsVUFBVSxDQUFDO0lBQ2hELENBQUM7SUFFRDs7OztPQUlHO0lBQ0ksWUFBWSxDQUFDLFNBQXNCLEVBQUUsV0FBbUI7UUFDM0QsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUU7WUFDbEIsSUFBSSxDQUFDLFVBQVUsR0FBRyxFQUFFLENBQUM7U0FDeEI7UUFFRCxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQztZQUNqQixNQUFNLEVBQUUsU0FBUztZQUNqQixpQkFBaUIsRUFBRSxXQUFXO1NBQ2pDLENBQUMsQ0FBQztJQUNQLENBQUM7SUFFTSxnQkFBZ0I7UUFDbkIsT0FBTztZQUNILEtBQUssRUFBRTtnQkFDSCxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsRUFBRTtvQkFDZCxhQUFhLEVBQUUsSUFBSSxDQUFDLGFBQWE7b0JBQ2pDLFVBQVUsRUFBRSw4QkFBdUIsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDO2lCQUN2RDthQUNKO1NBQ0osQ0FBQztJQUNOLENBQUM7Q0FDSjtBQWxERCxvQkFrREMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICcuLi9jb3JlL2NvbnN0cnVjdCc7XG5pbXBvcnQgeyBjYXBpdGFsaXplUHJvcGVydHlOYW1lcyB9IGZyb20gJy4uL2NvcmUvdXRpbCc7XG5pbXBvcnQgeyBGbkNvbmRpdGlvbiB9IGZyb20gJy4vZm4nO1xuaW1wb3J0IHsgUmVmZXJlbmNlYWJsZSB9IGZyb20gJy4vc3RhY2snO1xuXG4vKipcbiAqIEEgcnVsZSBjYW4gaW5jbHVkZSBhIFJ1bGVDb25kaXRpb24gcHJvcGVydHkgYW5kIG11c3QgaW5jbHVkZSBhbiBBc3NlcnRpb25zIHByb3BlcnR5LlxuICogRm9yIGVhY2ggcnVsZSwgeW91IGNhbiBkZWZpbmUgb25seSBvbmUgcnVsZSBjb25kaXRpb247IHlvdSBjYW4gZGVmaW5lIG9uZSBvciBtb3JlIGFzc2VydHMgd2l0aGluIHRoZSBBc3NlcnRpb25zIHByb3BlcnR5LlxuICogWW91IGRlZmluZSBhIHJ1bGUgY29uZGl0aW9uIGFuZCBhc3NlcnRpb25zIGJ5IHVzaW5nIHJ1bGUtc3BlY2lmaWMgaW50cmluc2ljIGZ1bmN0aW9ucy5cbiAqXG4gKiBZb3UgY2FuIHVzZSB0aGUgZm9sbG93aW5nIHJ1bGUtc3BlY2lmaWMgaW50cmluc2ljIGZ1bmN0aW9ucyB0byBkZWZpbmUgcnVsZSBjb25kaXRpb25zIGFuZCBhc3NlcnRpb25zOlxuICpcbiAqICBGbjo6QW5kXG4gKiAgRm46OkNvbnRhaW5zXG4gKiAgRm46OkVhY2hNZW1iZXJFcXVhbHNcbiAqICBGbjo6RWFjaE1lbWJlckluXG4gKiAgRm46OkVxdWFsc1xuICogIEZuOjpJZlxuICogIEZuOjpOb3RcbiAqICBGbjo6T3JcbiAqICBGbjo6UmVmQWxsXG4gKiAgRm46OlZhbHVlT2ZcbiAqICBGbjo6VmFsdWVPZkFsbFxuICpcbiAqIGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9zZXJ2aWNlY2F0YWxvZy9sYXRlc3QvYWRtaW5ndWlkZS9yZWZlcmVuY2UtdGVtcGxhdGVfY29uc3RyYWludF9ydWxlcy5odG1sXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUnVsZVByb3BzIHtcbiAgICAvKipcbiAgICAgKiBJZiB0aGUgcnVsZSBjb25kaXRpb24gZXZhbHVhdGVzIHRvIGZhbHNlLCB0aGUgcnVsZSBkb2Vzbid0IHRha2UgZWZmZWN0LlxuICAgICAqIElmIHRoZSBmdW5jdGlvbiBpbiB0aGUgcnVsZSBjb25kaXRpb24gZXZhbHVhdGVzIHRvIHRydWUsIGV4cHJlc3Npb25zIGluIGVhY2ggYXNzZXJ0IGFyZSBldmFsdWF0ZWQgYW5kIGFwcGxpZWQuXG4gICAgICovXG4gICAgcnVsZUNvbmRpdGlvbj86IEZuQ29uZGl0aW9uO1xuXG4gICAgLyoqXG4gICAgICogQXNzZXJ0aW9ucyB3aGljaCBkZWZpbmUgdGhlIHJ1bGUuXG4gICAgICovXG4gICAgYXNzZXJ0aW9ucz86IFJ1bGVBc3NlcnRpb25bXTtcbn1cblxuLyoqXG4gKiBUaGUgUnVsZXMgdGhhdCBkZWZpbmUgdGVtcGxhdGUgY29uc3RyYWludHMgaW4gYW4gQVdTIFNlcnZpY2UgQ2F0YWxvZyBwb3J0Zm9saW8gZGVzY3JpYmUgd2hlblxuICogZW5kIHVzZXJzIGNhbiB1c2UgdGhlIHRlbXBsYXRlIGFuZCB3aGljaCB2YWx1ZXMgdGhleSBjYW4gc3BlY2lmeSBmb3IgcGFyYW1ldGVycyB0aGF0IGFyZSBkZWNsYXJlZFxuICogaW4gdGhlIEFXUyBDbG91ZEZvcm1hdGlvbiB0ZW1wbGF0ZSB1c2VkIHRvIGNyZWF0ZSB0aGUgcHJvZHVjdCB0aGV5IGFyZSBhdHRlbXB0aW5nIHRvIHVzZS4gUnVsZXNcbiAqIGFyZSB1c2VmdWwgZm9yIHByZXZlbnRpbmcgZW5kIHVzZXJzIGZyb20gaW5hZHZlcnRlbnRseSBzcGVjaWZ5aW5nIGFuIGluY29ycmVjdCB2YWx1ZS5cbiAqIEZvciBleGFtcGxlLCB5b3UgY2FuIGFkZCBhIHJ1bGUgdG8gdmVyaWZ5IHdoZXRoZXIgZW5kIHVzZXJzIHNwZWNpZmllZCBhIHZhbGlkIHN1Ym5ldCBpbiBhXG4gKiBnaXZlbiBWUEMgb3IgdXNlZCBtMS5zbWFsbCBpbnN0YW5jZSB0eXBlcyBmb3IgdGVzdCBlbnZpcm9ubWVudHMuIEFXUyBDbG91ZEZvcm1hdGlvbiB1c2VzXG4gKiBydWxlcyB0byB2YWxpZGF0ZSBwYXJhbWV0ZXIgdmFsdWVzIGJlZm9yZSBpdCBjcmVhdGVzIHRoZSByZXNvdXJjZXMgZm9yIHRoZSBwcm9kdWN0LlxuICpcbiAqIEEgcnVsZSBjYW4gaW5jbHVkZSBhIFJ1bGVDb25kaXRpb24gcHJvcGVydHkgYW5kIG11c3QgaW5jbHVkZSBhbiBBc3NlcnRpb25zIHByb3BlcnR5LlxuICogRm9yIGVhY2ggcnVsZSwgeW91IGNhbiBkZWZpbmUgb25seSBvbmUgcnVsZSBjb25kaXRpb247IHlvdSBjYW4gZGVmaW5lIG9uZSBvciBtb3JlIGFzc2VydHMgd2l0aGluIHRoZSBBc3NlcnRpb25zIHByb3BlcnR5LlxuICogWW91IGRlZmluZSBhIHJ1bGUgY29uZGl0aW9uIGFuZCBhc3NlcnRpb25zIGJ5IHVzaW5nIHJ1bGUtc3BlY2lmaWMgaW50cmluc2ljIGZ1bmN0aW9ucy5cbiAqXG4gKiBAbGluayBodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vc2VydmljZWNhdGFsb2cvbGF0ZXN0L2FkbWluZ3VpZGUvcmVmZXJlbmNlLXRlbXBsYXRlX2NvbnN0cmFpbnRfcnVsZXMuaHRtbFxuICovXG5leHBvcnQgY2xhc3MgUnVsZSBleHRlbmRzIFJlZmVyZW5jZWFibGUge1xuICAgIC8qKlxuICAgICAqIElmIHRoZSBydWxlIGNvbmRpdGlvbiBldmFsdWF0ZXMgdG8gZmFsc2UsIHRoZSBydWxlIGRvZXNuJ3QgdGFrZSBlZmZlY3QuXG4gICAgICogSWYgdGhlIGZ1bmN0aW9uIGluIHRoZSBydWxlIGNvbmRpdGlvbiBldmFsdWF0ZXMgdG8gdHJ1ZSwgZXhwcmVzc2lvbnMgaW4gZWFjaCBhc3NlcnQgYXJlIGV2YWx1YXRlZCBhbmQgYXBwbGllZC5cbiAgICAgKi9cbiAgICBwdWJsaWMgcnVsZUNvbmRpdGlvbj86IEZuQ29uZGl0aW9uO1xuXG4gICAgLyoqXG4gICAgICogQXNzZXJ0aW9ucyB3aGljaCBkZWZpbmUgdGhlIHJ1bGUuXG4gICAgICovXG4gICAgcHVibGljIGFzc2VydGlvbnM/OiBSdWxlQXNzZXJ0aW9uW107XG5cbiAgICAvKipcbiAgICAgKiBDcmVhdGVzIGFuZCBhZGRzIGEgcnVsZS5cbiAgICAgKiBAcGFyYW0gcGFyZW50IFRoZSBwYXJlbnQgY29uc3RydWN0LlxuICAgICAqIEBwYXJhbSBwcm9wcyBUaGUgcnVsZSBwcm9wcy5cbiAgICAgKi9cbiAgICBjb25zdHJ1Y3RvcihwYXJlbnQ6IENvbnN0cnVjdCwgbmFtZTogc3RyaW5nLCBwcm9wcz86IFJ1bGVQcm9wcykge1xuICAgICAgICBzdXBlcihwYXJlbnQsIG5hbWUpO1xuXG4gICAgICAgIHRoaXMucnVsZUNvbmRpdGlvbiA9IHByb3BzICYmIHByb3BzLnJ1bGVDb25kaXRpb247XG4gICAgICAgIHRoaXMuYXNzZXJ0aW9ucyA9IHByb3BzICYmIHByb3BzLmFzc2VydGlvbnM7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQWRkcyBhbiBhc3NlcnRpb24gdG8gdGhlIHJ1bGUuXG4gICAgICogQHBhcmFtIGNvbmRpdGlvbiBUaGUgZXhwcmVzc2lvbiB0byBldmFsdWF0aW9uLlxuICAgICAqIEBwYXJhbSBkZXNjcmlwdGlvbiBUaGUgZGVzY3JpcHRpb24gb2YgdGhlIGFzc2VydGlvbi5cbiAgICAgKi9cbiAgICBwdWJsaWMgYWRkQXNzZXJ0aW9uKGNvbmRpdGlvbjogRm5Db25kaXRpb24sIGRlc2NyaXB0aW9uOiBzdHJpbmcpIHtcbiAgICAgICAgaWYgKCF0aGlzLmFzc2VydGlvbnMpIHtcbiAgICAgICAgICAgIHRoaXMuYXNzZXJ0aW9ucyA9IFtdO1xuICAgICAgICB9XG5cbiAgICAgICAgdGhpcy5hc3NlcnRpb25zLnB1c2goe1xuICAgICAgICAgICAgYXNzZXJ0OiBjb25kaXRpb24sXG4gICAgICAgICAgICBhc3NlcnREZXNjcmlwdGlvbjogZGVzY3JpcHRpb25cbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgcHVibGljIHRvQ2xvdWRGb3JtYXRpb24oKTogb2JqZWN0IHtcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgIFJ1bGVzOiB7XG4gICAgICAgICAgICAgICAgW3RoaXMubG9naWNhbElkXToge1xuICAgICAgICAgICAgICAgICAgICBSdWxlQ29uZGl0aW9uOiB0aGlzLnJ1bGVDb25kaXRpb24sXG4gICAgICAgICAgICAgICAgICAgIEFzc2VydGlvbnM6IGNhcGl0YWxpemVQcm9wZXJ0eU5hbWVzKHRoaXMuYXNzZXJ0aW9ucylcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgIH07XG4gICAgfVxufVxuXG4vKipcbiAqIEEgcnVsZSBhc3NlcnRpb24uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUnVsZUFzc2VydGlvbiB7XG4gICAgLyoqXG4gICAgICogVGhlIGFzc2VydGlvbi5cbiAgICAgKi9cbiAgICBhc3NlcnQ6IEZuQ29uZGl0aW9uO1xuXG4gICAgLyoqXG4gICAgICogVGhlIGFzc2VydGlvbiBkZXNjcmlwdGlvbi5cbiAgICAgKi9cbiAgICBhc3NlcnREZXNjcmlwdGlvbjogc3RyaW5nO1xufSJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInJ1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFDQSx1Q0FBdUQ7QUFFdkQsbUNBQXdDO0FBb0N4Qzs7Ozs7Ozs7Ozs7Ozs7R0FjRztBQUNILE1BQWEsSUFBSyxTQUFRLHFCQUFhO0lBWXJDOzs7O09BSUc7SUFDSCxZQUFZLE1BQWlCLEVBQUUsSUFBWSxFQUFFLEtBQWlCO1FBQzVELEtBQUssQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFFcEIsSUFBSSxDQUFDLGFBQWEsR0FBRyxLQUFLLElBQUksS0FBSyxDQUFDLGFBQWEsQ0FBQztRQUNsRCxJQUFJLENBQUMsVUFBVSxHQUFHLEtBQUssSUFBSSxLQUFLLENBQUMsVUFBVSxDQUFDO0lBQzlDLENBQUM7SUFFRDs7OztPQUlHO0lBQ0ksWUFBWSxDQUFDLFNBQXNCLEVBQUUsV0FBbUI7UUFDN0QsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUU7WUFDcEIsSUFBSSxDQUFDLFVBQVUsR0FBRyxFQUFFLENBQUM7U0FDdEI7UUFFRCxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQztZQUNuQixNQUFNLEVBQUUsU0FBUztZQUNqQixpQkFBaUIsRUFBRSxXQUFXO1NBQy9CLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFTSxnQkFBZ0I7UUFDckIsT0FBTztZQUNMLEtBQUssRUFBRTtnQkFDTCxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsRUFBRTtvQkFDaEIsYUFBYSxFQUFFLElBQUksQ0FBQyxhQUFhO29CQUNqQyxVQUFVLEVBQUUsOEJBQXVCLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQztpQkFDckQ7YUFDRjtTQUNGLENBQUM7SUFDSixDQUFDO0NBQ0Y7QUFsREQsb0JBa0RDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSAnLi4vY29yZS9jb25zdHJ1Y3QnO1xuaW1wb3J0IHsgY2FwaXRhbGl6ZVByb3BlcnR5TmFtZXMgfSBmcm9tICcuLi9jb3JlL3V0aWwnO1xuaW1wb3J0IHsgRm5Db25kaXRpb24gfSBmcm9tICcuL2ZuJztcbmltcG9ydCB7IFJlZmVyZW5jZWFibGUgfSBmcm9tICcuL3N0YWNrJztcblxuLyoqXG4gKiBBIHJ1bGUgY2FuIGluY2x1ZGUgYSBSdWxlQ29uZGl0aW9uIHByb3BlcnR5IGFuZCBtdXN0IGluY2x1ZGUgYW4gQXNzZXJ0aW9ucyBwcm9wZXJ0eS5cbiAqIEZvciBlYWNoIHJ1bGUsIHlvdSBjYW4gZGVmaW5lIG9ubHkgb25lIHJ1bGUgY29uZGl0aW9uOyB5b3UgY2FuIGRlZmluZSBvbmUgb3IgbW9yZSBhc3NlcnRzIHdpdGhpbiB0aGUgQXNzZXJ0aW9ucyBwcm9wZXJ0eS5cbiAqIFlvdSBkZWZpbmUgYSBydWxlIGNvbmRpdGlvbiBhbmQgYXNzZXJ0aW9ucyBieSB1c2luZyBydWxlLXNwZWNpZmljIGludHJpbnNpYyBmdW5jdGlvbnMuXG4gKlxuICogWW91IGNhbiB1c2UgdGhlIGZvbGxvd2luZyBydWxlLXNwZWNpZmljIGludHJpbnNpYyBmdW5jdGlvbnMgdG8gZGVmaW5lIHJ1bGUgY29uZGl0aW9ucyBhbmQgYXNzZXJ0aW9uczpcbiAqXG4gKiAgRm46OkFuZFxuICogIEZuOjpDb250YWluc1xuICogIEZuOjpFYWNoTWVtYmVyRXF1YWxzXG4gKiAgRm46OkVhY2hNZW1iZXJJblxuICogIEZuOjpFcXVhbHNcbiAqICBGbjo6SWZcbiAqICBGbjo6Tm90XG4gKiAgRm46Ok9yXG4gKiAgRm46OlJlZkFsbFxuICogIEZuOjpWYWx1ZU9mXG4gKiAgRm46OlZhbHVlT2ZBbGxcbiAqXG4gKiBodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vc2VydmljZWNhdGFsb2cvbGF0ZXN0L2FkbWluZ3VpZGUvcmVmZXJlbmNlLXRlbXBsYXRlX2NvbnN0cmFpbnRfcnVsZXMuaHRtbFxuICovXG5leHBvcnQgaW50ZXJmYWNlIFJ1bGVQcm9wcyB7XG4gIC8qKlxuICAgKiBJZiB0aGUgcnVsZSBjb25kaXRpb24gZXZhbHVhdGVzIHRvIGZhbHNlLCB0aGUgcnVsZSBkb2Vzbid0IHRha2UgZWZmZWN0LlxuICAgKiBJZiB0aGUgZnVuY3Rpb24gaW4gdGhlIHJ1bGUgY29uZGl0aW9uIGV2YWx1YXRlcyB0byB0cnVlLCBleHByZXNzaW9ucyBpbiBlYWNoIGFzc2VydCBhcmUgZXZhbHVhdGVkIGFuZCBhcHBsaWVkLlxuICAgKi9cbiAgcnVsZUNvbmRpdGlvbj86IEZuQ29uZGl0aW9uO1xuXG4gIC8qKlxuICAgKiBBc3NlcnRpb25zIHdoaWNoIGRlZmluZSB0aGUgcnVsZS5cbiAgICovXG4gIGFzc2VydGlvbnM/OiBSdWxlQXNzZXJ0aW9uW107XG59XG5cbi8qKlxuICogVGhlIFJ1bGVzIHRoYXQgZGVmaW5lIHRlbXBsYXRlIGNvbnN0cmFpbnRzIGluIGFuIEFXUyBTZXJ2aWNlIENhdGFsb2cgcG9ydGZvbGlvIGRlc2NyaWJlIHdoZW5cbiAqIGVuZCB1c2VycyBjYW4gdXNlIHRoZSB0ZW1wbGF0ZSBhbmQgd2hpY2ggdmFsdWVzIHRoZXkgY2FuIHNwZWNpZnkgZm9yIHBhcmFtZXRlcnMgdGhhdCBhcmUgZGVjbGFyZWRcbiAqIGluIHRoZSBBV1MgQ2xvdWRGb3JtYXRpb24gdGVtcGxhdGUgdXNlZCB0byBjcmVhdGUgdGhlIHByb2R1Y3QgdGhleSBhcmUgYXR0ZW1wdGluZyB0byB1c2UuIFJ1bGVzXG4gKiBhcmUgdXNlZnVsIGZvciBwcmV2ZW50aW5nIGVuZCB1c2VycyBmcm9tIGluYWR2ZXJ0ZW50bHkgc3BlY2lmeWluZyBhbiBpbmNvcnJlY3QgdmFsdWUuXG4gKiBGb3IgZXhhbXBsZSwgeW91IGNhbiBhZGQgYSBydWxlIHRvIHZlcmlmeSB3aGV0aGVyIGVuZCB1c2VycyBzcGVjaWZpZWQgYSB2YWxpZCBzdWJuZXQgaW4gYVxuICogZ2l2ZW4gVlBDIG9yIHVzZWQgbTEuc21hbGwgaW5zdGFuY2UgdHlwZXMgZm9yIHRlc3QgZW52aXJvbm1lbnRzLiBBV1MgQ2xvdWRGb3JtYXRpb24gdXNlc1xuICogcnVsZXMgdG8gdmFsaWRhdGUgcGFyYW1ldGVyIHZhbHVlcyBiZWZvcmUgaXQgY3JlYXRlcyB0aGUgcmVzb3VyY2VzIGZvciB0aGUgcHJvZHVjdC5cbiAqXG4gKiBBIHJ1bGUgY2FuIGluY2x1ZGUgYSBSdWxlQ29uZGl0aW9uIHByb3BlcnR5IGFuZCBtdXN0IGluY2x1ZGUgYW4gQXNzZXJ0aW9ucyBwcm9wZXJ0eS5cbiAqIEZvciBlYWNoIHJ1bGUsIHlvdSBjYW4gZGVmaW5lIG9ubHkgb25lIHJ1bGUgY29uZGl0aW9uOyB5b3UgY2FuIGRlZmluZSBvbmUgb3IgbW9yZSBhc3NlcnRzIHdpdGhpbiB0aGUgQXNzZXJ0aW9ucyBwcm9wZXJ0eS5cbiAqIFlvdSBkZWZpbmUgYSBydWxlIGNvbmRpdGlvbiBhbmQgYXNzZXJ0aW9ucyBieSB1c2luZyBydWxlLXNwZWNpZmljIGludHJpbnNpYyBmdW5jdGlvbnMuXG4gKlxuICogQGxpbmsgaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL3NlcnZpY2VjYXRhbG9nL2xhdGVzdC9hZG1pbmd1aWRlL3JlZmVyZW5jZS10ZW1wbGF0ZV9jb25zdHJhaW50X3J1bGVzLmh0bWxcbiAqL1xuZXhwb3J0IGNsYXNzIFJ1bGUgZXh0ZW5kcyBSZWZlcmVuY2VhYmxlIHtcbiAgLyoqXG4gICAqIElmIHRoZSBydWxlIGNvbmRpdGlvbiBldmFsdWF0ZXMgdG8gZmFsc2UsIHRoZSBydWxlIGRvZXNuJ3QgdGFrZSBlZmZlY3QuXG4gICAqIElmIHRoZSBmdW5jdGlvbiBpbiB0aGUgcnVsZSBjb25kaXRpb24gZXZhbHVhdGVzIHRvIHRydWUsIGV4cHJlc3Npb25zIGluIGVhY2ggYXNzZXJ0IGFyZSBldmFsdWF0ZWQgYW5kIGFwcGxpZWQuXG4gICAqL1xuICBwdWJsaWMgcnVsZUNvbmRpdGlvbj86IEZuQ29uZGl0aW9uO1xuXG4gIC8qKlxuICAgKiBBc3NlcnRpb25zIHdoaWNoIGRlZmluZSB0aGUgcnVsZS5cbiAgICovXG4gIHB1YmxpYyBhc3NlcnRpb25zPzogUnVsZUFzc2VydGlvbltdO1xuXG4gIC8qKlxuICAgKiBDcmVhdGVzIGFuZCBhZGRzIGEgcnVsZS5cbiAgICogQHBhcmFtIHBhcmVudCBUaGUgcGFyZW50IGNvbnN0cnVjdC5cbiAgICogQHBhcmFtIHByb3BzIFRoZSBydWxlIHByb3BzLlxuICAgKi9cbiAgY29uc3RydWN0b3IocGFyZW50OiBDb25zdHJ1Y3QsIG5hbWU6IHN0cmluZywgcHJvcHM/OiBSdWxlUHJvcHMpIHtcbiAgICBzdXBlcihwYXJlbnQsIG5hbWUpO1xuXG4gICAgdGhpcy5ydWxlQ29uZGl0aW9uID0gcHJvcHMgJiYgcHJvcHMucnVsZUNvbmRpdGlvbjtcbiAgICB0aGlzLmFzc2VydGlvbnMgPSBwcm9wcyAmJiBwcm9wcy5hc3NlcnRpb25zO1xuICB9XG5cbiAgLyoqXG4gICAqIEFkZHMgYW4gYXNzZXJ0aW9uIHRvIHRoZSBydWxlLlxuICAgKiBAcGFyYW0gY29uZGl0aW9uIFRoZSBleHByZXNzaW9uIHRvIGV2YWx1YXRpb24uXG4gICAqIEBwYXJhbSBkZXNjcmlwdGlvbiBUaGUgZGVzY3JpcHRpb24gb2YgdGhlIGFzc2VydGlvbi5cbiAgICovXG4gIHB1YmxpYyBhZGRBc3NlcnRpb24oY29uZGl0aW9uOiBGbkNvbmRpdGlvbiwgZGVzY3JpcHRpb246IHN0cmluZykge1xuICAgIGlmICghdGhpcy5hc3NlcnRpb25zKSB7XG4gICAgICB0aGlzLmFzc2VydGlvbnMgPSBbXTtcbiAgICB9XG5cbiAgICB0aGlzLmFzc2VydGlvbnMucHVzaCh7XG4gICAgICBhc3NlcnQ6IGNvbmRpdGlvbixcbiAgICAgIGFzc2VydERlc2NyaXB0aW9uOiBkZXNjcmlwdGlvblxuICAgIH0pO1xuICB9XG5cbiAgcHVibGljIHRvQ2xvdWRGb3JtYXRpb24oKTogb2JqZWN0IHtcbiAgICByZXR1cm4ge1xuICAgICAgUnVsZXM6IHtcbiAgICAgICAgW3RoaXMubG9naWNhbElkXToge1xuICAgICAgICAgIFJ1bGVDb25kaXRpb246IHRoaXMucnVsZUNvbmRpdGlvbixcbiAgICAgICAgICBBc3NlcnRpb25zOiBjYXBpdGFsaXplUHJvcGVydHlOYW1lcyh0aGlzLmFzc2VydGlvbnMpXG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9O1xuICB9XG59XG5cbi8qKlxuICogQSBydWxlIGFzc2VydGlvbi5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBSdWxlQXNzZXJ0aW9uIHtcbiAgLyoqXG4gICAqIFRoZSBhc3NlcnRpb24uXG4gICAqL1xuICBhc3NlcnQ6IEZuQ29uZGl0aW9uO1xuXG4gIC8qKlxuICAgKiBUaGUgYXNzZXJ0aW9uIGRlc2NyaXB0aW9uLlxuICAgKi9cbiAgYXNzZXJ0RGVzY3JpcHRpb246IHN0cmluZztcbn1cbiJdfQ==

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

exports.SecretParameter = SecretParameter;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VjcmV0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsic2VjcmV0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsaURBQThDO0FBQzlDLDJDQUF1QztBQUN2QywyQ0FBd0M7QUFFeEM7Ozs7Ozs7OztHQVNHO0FBQ0gsTUFBYSxNQUFPLFNBQVEsY0FBSztDQUFJO0FBQXJDLHdCQUFxQztBQTJDckM7Ozs7Ozs7Ozs7OztHQVlHO0FBQ0gsTUFBYSxlQUFnQixTQUFRLHFCQUFTO0lBTTFDLFlBQVksTUFBaUIsRUFBRSxJQUFZLEVBQUUsS0FBa0I7UUFDM0QsS0FBSyxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUVwQixNQUFNLEtBQUssR0FBRyxJQUFJLHFCQUFTLENBQUMsSUFBSSxFQUFFLFdBQVcsRUFBRTtZQUMzQyxJQUFJLEVBQUUsb0NBQW9DO1lBQzFDLE9BQU8sRUFBRSxLQUFLLENBQUMsWUFBWTtZQUMzQixXQUFXLEVBQUUsS0FBSyxDQUFDLFdBQVc7WUFDOUIsY0FBYyxFQUFFLEtBQUssQ0FBQyxjQUFjO1lBQ3BDLGFBQWEsRUFBRSxLQUFLLENBQUMsYUFBYTtZQUNsQyxxQkFBcUIsRUFBRSxLQUFLLENBQUMscUJBQXFCO1lBQ2xELFNBQVMsRUFBRSxLQUFLLENBQUMsU0FBUztZQUMxQixTQUFTLEVBQUUsS0FBSyxDQUFDLFNBQVM7WUFDMUIsTUFBTSxFQUFFLElBQUk7U0FDZixDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksTUFBTSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUN2QyxDQUFDO0NBQ0o7QUF2QkQsMENBdUJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSAnLi4vY29yZS9jb25zdHJ1Y3QnO1xuaW1wb3J0IHsgVG9rZW4gfSBmcm9tICcuLi9jb3JlL3Rva2Vucyc7XG5pbXBvcnQgeyBQYXJhbWV0ZXIgfSBmcm9tICcuL3BhcmFtZXRlcic7XG5cbi8qKlxuICogQSB0b2tlbiB0aGF0IHJlcHJlc2VudHMgYSB2YWx1ZSB0aGF0J3MgZXhwZWN0ZWQgdG8gYmUgYSBzZWNyZXQsIGxpa2VcbiAqIHBhc3N3b3JkcyBhbmQga2V5cy5cbiAqXG4gKiBJdCBpcyByZWNvbW1lbmRlZCB0byB1c2UgdGhlIGBTZWNyZXRQYXJhbWV0ZXJgIGNvbnN0cnVjdCBpbiBvcmRlciB0byBpbXBvcnRcbiAqIHNlY3JldCB2YWx1ZXMgZnJvbSB0aGUgU1NNIFBhcmFtZXRlciBTdG9yZSBpbnN0ZWFkIG9mIHN0b3JpbmcgdGhlbSBpbiB5b3VyXG4gKiBjb2RlLlxuICpcbiAqIEhvd2V2ZXIsIHlvdSBjYW4gYWxzbyBqdXN0IHBhc3MgaW4gdmFsdWVzLCBsaWtlIGFueSBvdGhlciB0b2tlbjogYG5ldyBTZWNyZXQoJ2JsYScpYFxuICovXG5leHBvcnQgY2xhc3MgU2VjcmV0IGV4dGVuZHMgVG9rZW4geyB9XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2VjcmV0UHJvcHMge1xuICAgIC8qKlxuICAgICAqIFRoZSBuYW1lIG9mIHRoZSBTU00gcGFyYW1ldGVyIHdoZXJlIHRoZSBzZWNyZXQgdmFsdWUgaXMgc3RvcmVkLlxuICAgICAqL1xuICAgIHNzbVBhcmFtZXRlcjogc3RyaW5nO1xuXG4gICAgLyoqXG4gICAgICogQSBzdHJpbmcgb2YgdXAgdG8gNDAwMCBjaGFyYWN0ZXJzIHRoYXQgZGVzY3JpYmVzIHRoZSBwYXJhbWV0ZXIuXG4gICAgICogQGRlZmF1bHQgTm8gZGVzY3JpcHRpb25cbiAgICAgKi9cbiAgICBkZXNjcmlwdGlvbj86IHN0cmluZztcblxuICAgIC8qKlxuICAgICAqIEEgcmVndWxhciBleHByZXNzaW9uIHRoYXQgcmVwcmVzZW50cyB0aGUgcGF0dGVybnMgdG8gYWxsb3cgZm9yIFN0cmluZyB0eXBlcy5cbiAgICAgKi9cbiAgICBhbGxvd2VkUGF0dGVybj86IHN0cmluZztcblxuICAgIC8qKlxuICAgICAqIEFuIGFycmF5IGNvbnRhaW5pbmcgdGhlIGxpc3Qgb2YgdmFsdWVzIGFsbG93ZWQgZm9yIHRoZSBwYXJhbWV0ZXIuXG4gICAgICovXG4gICAgYWxsb3dlZFZhbHVlcz86IHN0cmluZ1tdO1xuXG4gICAgLyoqXG4gICAgICogQSBzdHJpbmcgdGhhdCBleHBsYWlucyBhIGNvbnN0cmFpbnQgd2hlbiB0aGUgY29uc3RyYWludCBpcyB2aW9sYXRlZC5cbiAgICAgKiBGb3IgZXhhbXBsZSwgd2l0aG91dCBhIGNvbnN0cmFpbnQgZGVzY3JpcHRpb24sIGEgcGFyYW1ldGVyIHRoYXQgaGFzIGFuIGFsbG93ZWRcbiAgICAgKiBwYXR0ZXJuIG9mIFtBLVphLXowLTldKyBkaXNwbGF5cyB0aGUgZm9sbG93aW5nIGVycm9yIG1lc3NhZ2Ugd2hlbiB0aGUgdXNlciBzcGVjaWZpZXNcbiAgICAgKiBhbiBpbnZhbGlkIHZhbHVlOlxuICAgICAqL1xuICAgIGNvbnN0cmFpbnREZXNjcmlwdGlvbj86IHN0cmluZztcblxuICAgIC8qKlxuICAgICAqIEFuIGludGVnZXIgdmFsdWUgdGhhdCBkZXRlcm1pbmVzIHRoZSBsYXJnZXN0IG51bWJlciBvZiBjaGFyYWN0ZXJzIHlvdSB3YW50IHRvIGFsbG93IGZvciBTdHJpbmcgdHlwZXMuXG4gICAgICovXG4gICAgbWF4TGVuZ3RoPzogbnVtYmVyO1xuXG4gICAgLyoqXG4gICAgICogQW4gaW50ZWdlciB2YWx1ZSB0aGF0IGRldGVybWluZXMgdGhlIHNtYWxsZXN0IG51bWJlciBvZiBjaGFyYWN0ZXJzIHlvdSB3YW50IHRvIGFsbG93IGZvciBTdHJpbmcgdHlwZXMuXG4gICAgICovXG4gICAgbWluTGVuZ3RoPzogbnVtYmVyO1xufVxuXG4vKipcbiAqIERlZmluZXMgYSBzZWNyZXQgdmFsdWUgcmVzb2x2ZWQgZnJvbSB0aGUgU3lzdGVtcyBNYW5hZ2VyIChTU00pIFBhcmFtZXRlclxuICogU3RvcmUgZHVyaW5nIGRlcGxveW1lbnQuIFRoaXMgaXMgdXNlZnVsIGZvciByZWZlcmVuY2luZyB2YWx1ZXMgdGhhdCB5b3UgZG9cbiAqIG5vdCB3aXNoIHRvIGluY2x1ZGUgaW4geW91ciBjb2RlIGJhc2UsIHN1Y2ggYXMgc2VjcmV0cywgcGFzc3dvcmRzIGFuZCBrZXlzLlxuICpcbiAqIFRoaXMgY29uc3RydWN0IHdpbGwgYWRkIGEgQ2xvdWRGb3JtYXRpb24gcGFyYW1ldGVyIHRvIHlvdXIgdGVtcGxhdGUgYm91bmQgdG9cbiAqIGFuIFNTTSBwYXJhbWV0ZXIgKG9mIHR5cGUgXCJBV1M6OlNTTTo6UGFyYW1ldGVyOjpWYWx1ZTxTdHJpbmc+XCIpLiBEZXBsb3ltZW50XG4gKiB3aWxsIGZhaWwgaWYgdGhlIHZhbHVlIGRvZXNuJ3QgZXhpc3QgaW4gdGhlIHRhcmdldCBlbnZpcm9ubWVudC5cbiAqXG4gKiBJbXBvcnRhbnQ6IEZvciB2YWx1ZXMgb3RoZXIgdGhhbiBzZWNyZXRzLCBwcmVmZXIgdG8gdXNlIHRoZVxuICogYFNTTVBhcmFtZXRlclByb3ZpZGVyYCB3aGljaCByZXNvbHZlcyBTU00gcGFyYW1ldGVyIGluIGRlc2lnbi10aW1lLCBhbmRcbiAqIGVuc3VyZXMgdGhhdCBzdGFjayBkZXBsb3ltZW50cyBhcmUgZGV0ZXJtaW5pc3RpYy5cbiAqL1xuZXhwb3J0IGNsYXNzIFNlY3JldFBhcmFtZXRlciBleHRlbmRzIENvbnN0cnVjdCB7XG4gICAgLyoqXG4gICAgICogVGhlIHZhbHVlIG9mIHRoZSBzZWNyZXQgcGFyYW1ldGVyLlxuICAgICAqL1xuICAgIHB1YmxpYyB2YWx1ZTogU2VjcmV0O1xuXG4gICAgY29uc3RydWN0b3IocGFyZW50OiBDb25zdHJ1Y3QsIG5hbWU6IHN0cmluZywgcHJvcHM6IFNlY3JldFByb3BzKSB7XG4gICAgICAgIHN1cGVyKHBhcmVudCwgbmFtZSk7XG5cbiAgICAgICAgY29uc3QgcGFyYW0gPSBuZXcgUGFyYW1ldGVyKHRoaXMsICdQYXJhbWV0ZXInLCB7XG4gICAgICAgICAgICB0eXBlOiAnQVdTOjpTU006OlBhcmFtZXRlcjo6VmFsdWU8U3RyaW5nPicsXG4gICAgICAgICAgICBkZWZhdWx0OiBwcm9wcy5zc21QYXJhbWV0ZXIsXG4gICAgICAgICAgICBkZXNjcmlwdGlvbjogcHJvcHMuZGVzY3JpcHRpb24sXG4gICAgICAgICAgICBhbGxvd2VkUGF0dGVybjogcHJvcHMuYWxsb3dlZFBhdHRlcm4sXG4gICAgICAgICAgICBhbGxvd2VkVmFsdWVzOiBwcm9wcy5hbGxvd2VkVmFsdWVzLFxuICAgICAgICAgICAgY29uc3RyYWludERlc2NyaXB0aW9uOiBwcm9wcy5jb25zdHJhaW50RGVzY3JpcHRpb24sXG4gICAgICAgICAgICBtYXhMZW5ndGg6IHByb3BzLm1heExlbmd0aCxcbiAgICAgICAgICAgIG1pbkxlbmd0aDogcHJvcHMubWluTGVuZ3RoLFxuICAgICAgICAgICAgbm9FY2hvOiB0cnVlLFxuICAgICAgICB9KTtcblxuICAgICAgICB0aGlzLnZhbHVlID0gbmV3IFNlY3JldChwYXJhbS5yZWYpO1xuICAgIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VjcmV0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsic2VjcmV0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsaURBQThDO0FBQzlDLDJDQUF1QztBQUN2QywyQ0FBd0M7QUFFeEM7Ozs7Ozs7OztHQVNHO0FBQ0gsTUFBYSxNQUFPLFNBQVEsY0FBSztDQUFJO0FBQXJDLHdCQUFxQztBQTJDckM7Ozs7Ozs7Ozs7OztHQVlHO0FBQ0gsTUFBYSxlQUFnQixTQUFRLHFCQUFTO0lBTTVDLFlBQVksTUFBaUIsRUFBRSxJQUFZLEVBQUUsS0FBa0I7UUFDN0QsS0FBSyxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUVwQixNQUFNLEtBQUssR0FBRyxJQUFJLHFCQUFTLENBQUMsSUFBSSxFQUFFLFdBQVcsRUFBRTtZQUM3QyxJQUFJLEVBQUUsb0NBQW9DO1lBQzFDLE9BQU8sRUFBRSxLQUFLLENBQUMsWUFBWTtZQUMzQixXQUFXLEVBQUUsS0FBSyxDQUFDLFdBQVc7WUFDOUIsY0FBYyxFQUFFLEtBQUssQ0FBQyxjQUFjO1lBQ3BDLGFBQWEsRUFBRSxLQUFLLENBQUMsYUFBYTtZQUNsQyxxQkFBcUIsRUFBRSxLQUFLLENBQUMscUJBQXFCO1lBQ2xELFNBQVMsRUFBRSxLQUFLLENBQUMsU0FBUztZQUMxQixTQUFTLEVBQUUsS0FBSyxDQUFDLFNBQVM7WUFDMUIsTUFBTSxFQUFFLElBQUk7U0FDYixDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksTUFBTSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNyQyxDQUFDO0NBQ0Y7QUF2QkQsMENBdUJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSAnLi4vY29yZS9jb25zdHJ1Y3QnO1xuaW1wb3J0IHsgVG9rZW4gfSBmcm9tICcuLi9jb3JlL3Rva2Vucyc7XG5pbXBvcnQgeyBQYXJhbWV0ZXIgfSBmcm9tICcuL3BhcmFtZXRlcic7XG5cbi8qKlxuICogQSB0b2tlbiB0aGF0IHJlcHJlc2VudHMgYSB2YWx1ZSB0aGF0J3MgZXhwZWN0ZWQgdG8gYmUgYSBzZWNyZXQsIGxpa2VcbiAqIHBhc3N3b3JkcyBhbmQga2V5cy5cbiAqXG4gKiBJdCBpcyByZWNvbW1lbmRlZCB0byB1c2UgdGhlIGBTZWNyZXRQYXJhbWV0ZXJgIGNvbnN0cnVjdCBpbiBvcmRlciB0byBpbXBvcnRcbiAqIHNlY3JldCB2YWx1ZXMgZnJvbSB0aGUgU1NNIFBhcmFtZXRlciBTdG9yZSBpbnN0ZWFkIG9mIHN0b3JpbmcgdGhlbSBpbiB5b3VyXG4gKiBjb2RlLlxuICpcbiAqIEhvd2V2ZXIsIHlvdSBjYW4gYWxzbyBqdXN0IHBhc3MgaW4gdmFsdWVzLCBsaWtlIGFueSBvdGhlciB0b2tlbjogYG5ldyBTZWNyZXQoJ2JsYScpYFxuICovXG5leHBvcnQgY2xhc3MgU2VjcmV0IGV4dGVuZHMgVG9rZW4geyB9XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2VjcmV0UHJvcHMge1xuICAvKipcbiAgICogVGhlIG5hbWUgb2YgdGhlIFNTTSBwYXJhbWV0ZXIgd2hlcmUgdGhlIHNlY3JldCB2YWx1ZSBpcyBzdG9yZWQuXG4gICAqL1xuICBzc21QYXJhbWV0ZXI6IHN0cmluZztcblxuICAvKipcbiAgICogQSBzdHJpbmcgb2YgdXAgdG8gNDAwMCBjaGFyYWN0ZXJzIHRoYXQgZGVzY3JpYmVzIHRoZSBwYXJhbWV0ZXIuXG4gICAqIEBkZWZhdWx0IE5vIGRlc2NyaXB0aW9uXG4gICAqL1xuICBkZXNjcmlwdGlvbj86IHN0cmluZztcblxuICAvKipcbiAgICogQSByZWd1bGFyIGV4cHJlc3Npb24gdGhhdCByZXByZXNlbnRzIHRoZSBwYXR0ZXJucyB0byBhbGxvdyBmb3IgU3RyaW5nIHR5cGVzLlxuICAgKi9cbiAgYWxsb3dlZFBhdHRlcm4/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEFuIGFycmF5IGNvbnRhaW5pbmcgdGhlIGxpc3Qgb2YgdmFsdWVzIGFsbG93ZWQgZm9yIHRoZSBwYXJhbWV0ZXIuXG4gICAqL1xuICBhbGxvd2VkVmFsdWVzPzogc3RyaW5nW107XG5cbiAgLyoqXG4gICAqIEEgc3RyaW5nIHRoYXQgZXhwbGFpbnMgYSBjb25zdHJhaW50IHdoZW4gdGhlIGNvbnN0cmFpbnQgaXMgdmlvbGF0ZWQuXG4gICAqIEZvciBleGFtcGxlLCB3aXRob3V0IGEgY29uc3RyYWludCBkZXNjcmlwdGlvbiwgYSBwYXJhbWV0ZXIgdGhhdCBoYXMgYW4gYWxsb3dlZFxuICAgKiBwYXR0ZXJuIG9mIFtBLVphLXowLTldKyBkaXNwbGF5cyB0aGUgZm9sbG93aW5nIGVycm9yIG1lc3NhZ2Ugd2hlbiB0aGUgdXNlciBzcGVjaWZpZXNcbiAgICogYW4gaW52YWxpZCB2YWx1ZTpcbiAgICovXG4gIGNvbnN0cmFpbnREZXNjcmlwdGlvbj86IHN0cmluZztcblxuICAvKipcbiAgICogQW4gaW50ZWdlciB2YWx1ZSB0aGF0IGRldGVybWluZXMgdGhlIGxhcmdlc3QgbnVtYmVyIG9mIGNoYXJhY3RlcnMgeW91IHdhbnQgdG8gYWxsb3cgZm9yIFN0cmluZyB0eXBlcy5cbiAgICovXG4gIG1heExlbmd0aD86IG51bWJlcjtcblxuICAvKipcbiAgICogQW4gaW50ZWdlciB2YWx1ZSB0aGF0IGRldGVybWluZXMgdGhlIHNtYWxsZXN0IG51bWJlciBvZiBjaGFyYWN0ZXJzIHlvdSB3YW50IHRvIGFsbG93IGZvciBTdHJpbmcgdHlwZXMuXG4gICAqL1xuICBtaW5MZW5ndGg/OiBudW1iZXI7XG59XG5cbi8qKlxuICogRGVmaW5lcyBhIHNlY3JldCB2YWx1ZSByZXNvbHZlZCBmcm9tIHRoZSBTeXN0ZW1zIE1hbmFnZXIgKFNTTSkgUGFyYW1ldGVyXG4gKiBTdG9yZSBkdXJpbmcgZGVwbG95bWVudC4gVGhpcyBpcyB1c2VmdWwgZm9yIHJlZmVyZW5jaW5nIHZhbHVlcyB0aGF0IHlvdSBkb1xuICogbm90IHdpc2ggdG8gaW5jbHVkZSBpbiB5b3VyIGNvZGUgYmFzZSwgc3VjaCBhcyBzZWNyZXRzLCBwYXNzd29yZHMgYW5kIGtleXMuXG4gKlxuICogVGhpcyBjb25zdHJ1Y3Qgd2lsbCBhZGQgYSBDbG91ZEZvcm1hdGlvbiBwYXJhbWV0ZXIgdG8geW91ciB0ZW1wbGF0ZSBib3VuZCB0b1xuICogYW4gU1NNIHBhcmFtZXRlciAob2YgdHlwZSBcIkFXUzo6U1NNOjpQYXJhbWV0ZXI6OlZhbHVlPFN0cmluZz5cIikuIERlcGxveW1lbnRcbiAqIHdpbGwgZmFpbCBpZiB0aGUgdmFsdWUgZG9lc24ndCBleGlzdCBpbiB0aGUgdGFyZ2V0IGVudmlyb25tZW50LlxuICpcbiAqIEltcG9ydGFudDogRm9yIHZhbHVlcyBvdGhlciB0aGFuIHNlY3JldHMsIHByZWZlciB0byB1c2UgdGhlXG4gKiBgU1NNUGFyYW1ldGVyUHJvdmlkZXJgIHdoaWNoIHJlc29sdmVzIFNTTSBwYXJhbWV0ZXIgaW4gZGVzaWduLXRpbWUsIGFuZFxuICogZW5zdXJlcyB0aGF0IHN0YWNrIGRlcGxveW1lbnRzIGFyZSBkZXRlcm1pbmlzdGljLlxuICovXG5leHBvcnQgY2xhc3MgU2VjcmV0UGFyYW1ldGVyIGV4dGVuZHMgQ29uc3RydWN0IHtcbiAgLyoqXG4gICAqIFRoZSB2YWx1ZSBvZiB0aGUgc2VjcmV0IHBhcmFtZXRlci5cbiAgICovXG4gIHB1YmxpYyB2YWx1ZTogU2VjcmV0O1xuXG4gIGNvbnN0cnVjdG9yKHBhcmVudDogQ29uc3RydWN0LCBuYW1lOiBzdHJpbmcsIHByb3BzOiBTZWNyZXRQcm9wcykge1xuICAgIHN1cGVyKHBhcmVudCwgbmFtZSk7XG5cbiAgICBjb25zdCBwYXJhbSA9IG5ldyBQYXJhbWV0ZXIodGhpcywgJ1BhcmFtZXRlcicsIHtcbiAgICAgIHR5cGU6ICdBV1M6OlNTTTo6UGFyYW1ldGVyOjpWYWx1ZTxTdHJpbmc+JyxcbiAgICAgIGRlZmF1bHQ6IHByb3BzLnNzbVBhcmFtZXRlcixcbiAgICAgIGRlc2NyaXB0aW9uOiBwcm9wcy5kZXNjcmlwdGlvbixcbiAgICAgIGFsbG93ZWRQYXR0ZXJuOiBwcm9wcy5hbGxvd2VkUGF0dGVybixcbiAgICAgIGFsbG93ZWRWYWx1ZXM6IHByb3BzLmFsbG93ZWRWYWx1ZXMsXG4gICAgICBjb25zdHJhaW50RGVzY3JpcHRpb246IHByb3BzLmNvbnN0cmFpbnREZXNjcmlwdGlvbixcbiAgICAgIG1heExlbmd0aDogcHJvcHMubWF4TGVuZ3RoLFxuICAgICAgbWluTGVuZ3RoOiBwcm9wcy5taW5MZW5ndGgsXG4gICAgICBub0VjaG86IHRydWUsXG4gICAgfSk7XG5cbiAgICB0aGlzLnZhbHVlID0gbmV3IFNlY3JldChwYXJhbS5yZWYpO1xuICB9XG59XG4iXX0=

@@ -158,4 +158,4 @@ import cxapi = require('@aws-cdk/cx-api');

* @returns the stack trace of the point where this Resource was created from, sourced
* from the +metadata+ entry typed +aws:cdk:logicalId+, and with the bottom-most
* node +internal+ entries filtered.
* from the +metadata+ entry typed +aws:cdk:logicalId+, and with the bottom-most
* node +internal+ entries filtered.
*/

@@ -174,9 +174,9 @@ readonly creationStackTrace: string[];

* {
* Resources: {
* [this.logicalId]: {
* Type: this.resourceType,
* Properties: this.props,
* Condition: this.condition
* }
* Resources: {
* [this.logicalId]: {
* Type: this.resourceType,
* Properties: this.props,
* Condition: this.condition
* }
* }
* }

@@ -183,0 +183,0 @@ */

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

* @returns the stack trace of the point where this Resource was created from, sourced
* from the +metadata+ entry typed +aws:cdk:logicalId+, and with the bottom-most
* node +internal+ entries filtered.
* from the +metadata+ entry typed +aws:cdk:logicalId+, and with the bottom-most
* node +internal+ entries filtered.
*/

@@ -315,2 +315,2 @@ get creationStackTrace() {

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(): 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}"]}
//# 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}\n"]}
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsidGFnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaW5rIGh0dHA6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0Nsb3VkRm9ybWF0aW9uL2xhdGVzdC9Vc2VyR3VpZGUvYXdzLXByb3BlcnRpZXMtcmVzb3VyY2UtdGFncy5odG1sXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgVGFnIHtcbiAgICAvKipcbiAgICAgKiBAbGluayBodHRwOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BV1NDbG91ZEZvcm1hdGlvbi9sYXRlc3QvVXNlckd1aWRlL2F3cy1wcm9wZXJ0aWVzLXJlc291cmNlLXRhZ3MuaHRtbCNjZm4tcmVzb3VyY2UtdGFncy1rZXlcbiAgICAgKi9cbiAgICBrZXk6IHN0cmluZztcblxuICAgIC8qKlxuICAgICAqIEBsaW5rIGh0dHA6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0Nsb3VkRm9ybWF0aW9uL2xhdGVzdC9Vc2VyR3VpZGUvYXdzLXByb3BlcnRpZXMtcmVzb3VyY2UtdGFncy5odG1sI2Nmbi1yZXNvdXJjZS10YWdzLXZhbHVlXG4gICAgICovXG4gICAgdmFsdWU6IHN0cmluZztcbn0iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsidGFnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaW5rIGh0dHA6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0Nsb3VkRm9ybWF0aW9uL2xhdGVzdC9Vc2VyR3VpZGUvYXdzLXByb3BlcnRpZXMtcmVzb3VyY2UtdGFncy5odG1sXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgVGFnIHtcbiAgLyoqXG4gICAqIEBsaW5rIGh0dHA6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0Nsb3VkRm9ybWF0aW9uL2xhdGVzdC9Vc2VyR3VpZGUvYXdzLXByb3BlcnRpZXMtcmVzb3VyY2UtdGFncy5odG1sI2Nmbi1yZXNvdXJjZS10YWdzLWtleVxuICAgKi9cbiAga2V5OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEBsaW5rIGh0dHA6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0Nsb3VkRm9ybWF0aW9uL2xhdGVzdC9Vc2VyR3VpZGUvYXdzLXByb3BlcnRpZXMtcmVzb3VyY2UtdGFncy5odG1sI2Nmbi1yZXNvdXJjZS10YWdzLXZhbHVlXG4gICAqL1xuICB2YWx1ZTogc3RyaW5nO1xufVxuIl19

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

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context.js","sourceRoot":"","sources":["context.ts"],"names":[],"mappings":"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","sourcesContent":["import { Stack } from './cloudformation/stack';\nimport { Construct } from './core/construct';\n\nconst AVAILABILITY_ZONES_PROVIDER = 'availability-zones';\nconst SSM_PARAMETER_PROVIDER = 'ssm';\n\n/**\n * Base class for the model side of context providers\n *\n * Instances of this class communicate with context provider plugins in the 'cdk\n * toolkit' via context variables (input), outputting specialized queries for\n * more context variables (output).\n *\n * ContextProvider needs access to a Construct to hook into the context mechanism.\n */\nexport class ContextProvider {\n\n    private readonly stack: Stack;\n\n    constructor(private context: Construct) {\n        this.stack = Stack.find(context);\n    }\n\n    /**\n     * Read a provider value, verifying it's a string\n     * @param provider The name of the context provider\n     * @param scope The scope (e.g. account/region) for the value\n     * @param args Any arguments\n     * @param defaultValue The value to return if there is no value defined for this context key\n     */\n    public getStringValue(\n        provider: string,\n        scope: undefined | string[],\n        args: string[],\n        defaultValue: string): string {\n        // if scope is undefined, this is probably a test mode, so we just\n        // return the default value\n        if (!scope) {\n            this.context.addError(formatMissingScopeError(provider, args));\n            return defaultValue;\n        }\n        const key = colonQuote([provider].concat(scope).concat(args)).join(':');\n        const value = this.context.getContext(key);\n        if (value != null) {\n            if (typeof value !== 'string') {\n                throw new TypeError(`Expected context parameter '${key}' to be a string, but got '${value}'`);\n            }\n            return value;\n        }\n\n        this.stack.reportMissingContext(key, { provider, scope, args });\n        return defaultValue;\n    }\n\n    /**\n     * Read a provider value, verifying it's a list\n     * @param provider The name of the context provider\n     * @param scope The scope (e.g. account/region) for the value\n     * @param args Any arguments\n     * @param defaultValue The value to return if there is no value defined for this context key\n     */\n    public getStringListValue(\n        provider: string,\n        scope: undefined | string[],\n        args: string[],\n        defaultValue: string[]): string[] {\n        // if scope is undefined, this is probably a test mode, so we just\n        // return the default value and report an error so this in not accidentally used\n        // in the toolkit\n        if (!scope) {\n            // tslint:disable-next-line:max-line-length\n            this.context.addError(formatMissingScopeError(provider, args));\n            return defaultValue;\n        }\n\n        const key = colonQuote([provider].concat(scope).concat(args)).join(':');\n        const value = this.context.getContext(key);\n\n        if (value != null) {\n            if (!value.map) {\n                throw new Error(`Context value '${key}' is supposed to be a list, got '${value}'`);\n            }\n            return value;\n        }\n\n        this.stack.reportMissingContext(key, { provider, scope, args });\n        return defaultValue;\n    }\n\n    /**\n     * Helper function to wrap up account and region into a scope tuple\n     */\n    public accountRegionScope(providerDescription: string): undefined | string[] {\n        const stack = Stack.find(this.context);\n        if (!stack) {\n            throw new Error(`${providerDescription}: construct must be in a stack`);\n        }\n\n        const account = stack.env.account;\n        const region = stack.env.region;\n\n        if (account == null || region == null) {\n            return undefined;\n        }\n\n        return [account, region];\n    }\n}\n\n/**\n * Quote colons in all strings so that we can undo the quoting at a later point\n *\n * We'll use $ as a quoting character, for no particularly good reason other\n * than that \\ is going to lead to quoting hell when the keys are stored in JSON.\n */\nfunction colonQuote(xs: string[]): string[] {\n    return xs.map(x => x.replace('$', '$$').replace(':', '$:'));\n}\n\n/**\n * Context provider that will return the availability zones for the current account and region\n */\nexport class AvailabilityZoneProvider {\n    private provider: ContextProvider;\n\n    constructor(context: Construct) {\n        this.provider = new ContextProvider(context);\n    }\n\n    /**\n     * Return the list of AZs for the current account and region\n     */\n    public get availabilityZones(): string[] {\n        return this.provider.getStringListValue(AVAILABILITY_ZONES_PROVIDER,\n                                                this.provider.accountRegionScope('AvailabilityZoneProvider'),\n                                                [],\n                                                ['dummy1a', 'dummy1b', 'dummy1c']);\n    }\n}\n\n/**\n * Context provider that will read values from the SSM parameter store in the indicated account and region\n */\nexport class SSMParameterProvider {\n    private provider: ContextProvider;\n\n    constructor(context: Construct) {\n        this.provider = new ContextProvider(context);\n    }\n\n    /**\n     * Return the SSM parameter string with the indicated key\n     */\n    public getString(parameterName: string): any {\n        const scope = this.provider.accountRegionScope('SSMParameterProvider');\n        return this.provider.getStringValue(SSM_PARAMETER_PROVIDER, scope, [parameterName], 'dummy');\n    }\n}\n\nfunction formatMissingScopeError(provider: string, args: string[]) {\n    let s = `Cannot determine scope for context provider ${provider}`;\n    if (args.length > 0) {\n        s += JSON.stringify(args);\n    }\n    s += '.';\n    s += '\\n';\n    s += 'This usually happens when AWS credentials are not available and the default account/region cannot be determined.';\n    return s;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context.js","sourceRoot":"","sources":["context.ts"],"names":[],"mappings":"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","sourcesContent":["import { Stack } from './cloudformation/stack';\nimport { Construct } from './core/construct';\n\nconst AVAILABILITY_ZONES_PROVIDER = 'availability-zones';\nconst SSM_PARAMETER_PROVIDER = 'ssm';\n\n/**\n * Base class for the model side of context providers\n *\n * Instances of this class communicate with context provider plugins in the 'cdk\n * toolkit' via context variables (input), outputting specialized queries for\n * more context variables (output).\n *\n * ContextProvider needs access to a Construct to hook into the context mechanism.\n */\nexport class ContextProvider {\n\n  private readonly stack: Stack;\n\n  constructor(private context: Construct) {\n    this.stack = Stack.find(context);\n  }\n\n  /**\n   * Read a provider value, verifying it's a string\n   * @param provider The name of the context provider\n   * @param scope The scope (e.g. account/region) for the value\n   * @param args Any arguments\n   * @param defaultValue The value to return if there is no value defined for this context key\n   */\n  public getStringValue(\n    provider: string,\n    scope: undefined | string[],\n    args: string[],\n    defaultValue: string): string {\n    // if scope is undefined, this is probably a test mode, so we just\n    // return the default value\n    if (!scope) {\n      this.context.addError(formatMissingScopeError(provider, args));\n      return defaultValue;\n    }\n    const key = colonQuote([provider].concat(scope).concat(args)).join(':');\n    const value = this.context.getContext(key);\n    if (value != null) {\n      if (typeof value !== 'string') {\n        throw new TypeError(`Expected context parameter '${key}' to be a string, but got '${value}'`);\n      }\n      return value;\n    }\n\n    this.stack.reportMissingContext(key, { provider, scope, args });\n    return defaultValue;\n  }\n\n  /**\n   * Read a provider value, verifying it's a list\n   * @param provider The name of the context provider\n   * @param scope The scope (e.g. account/region) for the value\n   * @param args Any arguments\n   * @param defaultValue The value to return if there is no value defined for this context key\n   */\n  public getStringListValue(\n    provider: string,\n    scope: undefined | string[],\n    args: string[],\n    defaultValue: string[]): string[] {\n    // if scope is undefined, this is probably a test mode, so we just\n    // return the default value and report an error so this in not accidentally used\n    // in the toolkit\n    if (!scope) {\n      // tslint:disable-next-line:max-line-length\n      this.context.addError(formatMissingScopeError(provider, args));\n      return defaultValue;\n    }\n\n    const key = colonQuote([provider].concat(scope).concat(args)).join(':');\n    const value = this.context.getContext(key);\n\n    if (value != null) {\n      if (!value.map) {\n        throw new Error(`Context value '${key}' is supposed to be a list, got '${value}'`);\n      }\n      return value;\n    }\n\n    this.stack.reportMissingContext(key, { provider, scope, args });\n    return defaultValue;\n  }\n\n  /**\n   * Helper function to wrap up account and region into a scope tuple\n   */\n  public accountRegionScope(providerDescription: string): undefined | string[] {\n    const stack = Stack.find(this.context);\n    if (!stack) {\n      throw new Error(`${providerDescription}: construct must be in a stack`);\n    }\n\n    const account = stack.env.account;\n    const region = stack.env.region;\n\n    if (account == null || region == null) {\n      return undefined;\n    }\n\n    return [account, region];\n  }\n}\n\n/**\n * Quote colons in all strings so that we can undo the quoting at a later point\n *\n * We'll use $ as a quoting character, for no particularly good reason other\n * than that \\ is going to lead to quoting hell when the keys are stored in JSON.\n */\nfunction colonQuote(xs: string[]): string[] {\n  return xs.map(x => x.replace('$', '$$').replace(':', '$:'));\n}\n\n/**\n * Context provider that will return the availability zones for the current account and region\n */\nexport class AvailabilityZoneProvider {\n  private provider: ContextProvider;\n\n  constructor(context: Construct) {\n    this.provider = new ContextProvider(context);\n  }\n\n  /**\n   * Return the list of AZs for the current account and region\n   */\n  public get availabilityZones(): string[] {\n    return this.provider.getStringListValue(AVAILABILITY_ZONES_PROVIDER,\n                        this.provider.accountRegionScope('AvailabilityZoneProvider'),\n                        [],\n                        ['dummy1a', 'dummy1b', 'dummy1c']);\n  }\n}\n\n/**\n * Context provider that will read values from the SSM parameter store in the indicated account and region\n */\nexport class SSMParameterProvider {\n  private provider: ContextProvider;\n\n  constructor(context: Construct) {\n    this.provider = new ContextProvider(context);\n  }\n\n  /**\n   * Return the SSM parameter string with the indicated key\n   */\n  public getString(parameterName: string): any {\n    const scope = this.provider.accountRegionScope('SSMParameterProvider');\n    return this.provider.getStringValue(SSM_PARAMETER_PROVIDER, scope, [parameterName], 'dummy');\n  }\n}\n\nfunction formatMissingScopeError(provider: string, args: string[]) {\n  let s = `Cannot determine scope for context provider ${provider}`;\n  if (args.length > 0) {\n    s += JSON.stringify(args);\n  }\n  s += '.';\n  s += '\\n';\n  s += 'This usually happens when AWS credentials are not available and the default account/region cannot be determined.';\n  return s;\n}\n"]}

@@ -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    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"]}
//# 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"]}

@@ -10,5 +10,5 @@ import { Construct } from './construct';

* For example:
* <Foo p1='a' p2={2}/>
* <Foo p1='a' p2={2}/>
* will produce this code:
* jsx.create(Foo, { p1: 'a', p2: 2 }, []);
* jsx.create(Foo, { p1: 'a', p2: 2 }, []);
*

@@ -15,0 +15,0 @@ * This function will not actually create any objects, but rather just return a tree of

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

* For example:
* <Foo p1='a' p2={2}/>
* <Foo p1='a' p2={2}/>
* will produce this code:
* jsx.create(Foo, { p1: 'a', p2: 2 }, []);
* jsx.create(Foo, { p1: 'a', p2: 2 }, []);
*

@@ -55,2 +55,2 @@ * This function will not actually create any objects, but rather just return a tree of

})(jsx = exports.jsx || (exports.jsx = {}));
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoianN4LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsianN4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsMkNBQXdDO0FBSXhDLElBQWlCLEdBQUcsQ0FrRG5CO0FBbERELFdBQWlCLEdBQUc7SUFFaEI7Ozs7Ozs7Ozs7Ozs7Ozs7T0FnQkc7SUFDSCxTQUFnQixNQUFNLENBQUMsSUFBMEIsRUFBRSxLQUFVLEVBQUUsR0FBRyxRQUF1QjtRQUNyRixJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxZQUFZLHFCQUFTLENBQUMsRUFBRTtZQUN4QyxNQUFNLElBQUksS0FBSyxDQUFDLHdDQUF3QyxHQUFHLElBQUksQ0FBQyxDQUFDO1NBQ3BFO1FBRUQsT0FBTztZQUNILElBQUksRUFBRSxLQUFLLEVBQUUsS0FBSyxJQUFJLEVBQUUsRUFBRSxRQUFRO1NBQ3JDLENBQUM7SUFDTixDQUFDO0lBUmUsVUFBTSxTQVFyQixDQUFBO0lBRUQ7Ozs7OztPQU1HO0lBQ0gsU0FBZ0IsU0FBUyxDQUFDLElBQWlCLEVBQUUsTUFBa0I7UUFDM0QsTUFBTSxFQUFFLEdBQUcsQ0FBQyxJQUFJLENBQUMsS0FBSyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQy9DLE1BQU0sSUFBSSxHQUFHLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsRUFBRSxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLGNBQWM7UUFDbEUsY0FBYyxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDcEMsT0FBTyxJQUFJLENBQUM7SUFDaEIsQ0FBQztJQUxlLGFBQVMsWUFLeEIsQ0FBQTtJQUVELFNBQVMsY0FBYyxDQUFDLE1BQWlCLEVBQUUsUUFBZTtRQUN0RCxLQUFLLE1BQU0sS0FBSyxJQUFJLFFBQVEsRUFBRTtZQUMxQixNQUFNLEVBQUUsR0FBRyxDQUFDLEtBQUssQ0FBQyxLQUFLLElBQUksS0FBSyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDakQsTUFBTSxRQUFRLEdBQUcsSUFBSSxLQUFLLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxFQUFFLEVBQUUsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ3pELGNBQWMsQ0FBQyxRQUFRLEVBQUUsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1NBQzVDO0lBQ0wsQ0FBQztBQUNMLENBQUMsRUFsRGdCLEdBQUcsR0FBSCxXQUFHLEtBQUgsV0FBRyxRQWtEbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICcuL2NvbnN0cnVjdCc7XG5cbmV4cG9ydCB0eXBlIENvbnN0cnVjdENvbnN0cnVjdG9yID0geyBuZXcgKC4uLmFyZ3M6IGFueVtdKTogQ29uc3RydWN0IH07XG5cbmV4cG9ydCBuYW1lc3BhY2UganN4IHtcblxuICAgIC8qKlxuICAgICAqIFRoZSBKU1ggZmFjdG9yeSBmdW5jdGlvbi4gVGhpcyBpcyB3aGF0IFR5cGVTY3JpcHQgY29udmVydHMgYSBKU1ggc3RhdGVtZW50IHRvLlxuICAgICAqXG4gICAgICogRm9yIGV4YW1wbGU6XG4gICAgICogICAgICA8Rm9vIHAxPSdhJyBwMj17Mn0vPlxuICAgICAqIHdpbGwgcHJvZHVjZSB0aGlzIGNvZGU6XG4gICAgICogICAgICBqc3guY3JlYXRlKEZvbywgeyBwMTogJ2EnLCBwMjogMiB9LCBbXSk7XG4gICAgICpcbiAgICAgKiBUaGlzIGZ1bmN0aW9uIHdpbGwgbm90IGFjdHVhbGx5IGNyZWF0ZSBhbnkgb2JqZWN0cywgYnV0IHJhdGhlciBqdXN0IHJldHVybiBhIHRyZWUgb2ZcbiAgICAgKiBlbGVtZW50IGluZm9ybWF0aW9uIGZvciBsYXRlciBjb25zdW1wdGlvbiBieSBqc3guY29uc3RydWN0KHRyZWUpLCB3aGljaCBjYW4gYmUgdXNlZFxuICAgICAqIHRvIG1hdGVyaWFsaXplIGFuIGFjdHVhbCBjb25zdHJ1Y3QgdHJlZSBmcm9tLlxuICAgICAqXG4gICAgICogQHBhcmFtIHR5cGUgVGhlIGNsYXNzXG4gICAgICogQHBhcmFtIHByb3BzIFByb3BlcnR5IGhhc2hcbiAgICAgKiBAcGFyYW0gY2hpbGRyZW4gQXJyYXkgb2YgY2hpbGRyZW5cbiAgICAgKiBAcmV0dXJucyBlbGVtZW50IHRyZWVcbiAgICAgKi9cbiAgICBleHBvcnQgZnVuY3Rpb24gY3JlYXRlKHR5cGU6IENvbnN0cnVjdENvbnN0cnVjdG9yLCBwcm9wczogYW55LCAuLi5jaGlsZHJlbjogSlNYLkVsZW1lbnRbXSk6IEpTWC5FbGVtZW50IHtcbiAgICAgICAgaWYgKCEodHlwZS5wcm90b3R5cGUgaW5zdGFuY2VvZiBDb25zdHJ1Y3QpKSB7XG4gICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ0FsbCBub2RlcyBtdXN0IGRlcml2ZSBmcm9tIENvbnN0cnVjdDogJyArIHR5cGUpO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgIHR5cGUsIHByb3BzOiBwcm9wcyB8fCB7fSwgY2hpbGRyZW5cbiAgICAgICAgfTtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBDb252ZXJ0cyBhIEpTWCB0cmVlIHRvIGEgY29uc3RydWN0IHRyZWUuXG4gICAgICogQ3JlYXRlcyBhbGwgY29uc3RydWN0IG9iamVjdHMgYW5kIGFzc29jaWF0ZSB0aGVtIHRvZ2V0aGVyIGFzIGNoaWxkcmVuLlxuICAgICAqIEBwYXJhbSB0cmVlIFRoZSBKU1ggdHJlZVxuICAgICAqIEBwYXJhbSBwYXJlbnQgT3B0aW9uYWwgcGFyZW50IGZvciB0aGUgY29uc3RydWN0IHRyZWVcbiAgICAgKiBAcmV0dXJucyBBIENvbnN0cnVjdCBvYmplY3RcbiAgICAgKi9cbiAgICBleHBvcnQgZnVuY3Rpb24gY29uc3RydWN0KHRyZWU6IEpTWC5FbGVtZW50LCBwYXJlbnQ/OiBDb25zdHJ1Y3QpOiBDb25zdHJ1Y3Qge1xuICAgICAgICBjb25zdCBpZCA9ICh0cmVlLnByb3BzICYmIHRyZWUucHJvcHMuaWQpIHx8ICcnO1xuICAgICAgICBjb25zdCByb290ID0gbmV3IHRyZWUudHlwZShwYXJlbnQsIGlkLCB0cmVlLnByb3BzKTsgLy8gY3JlYXRlIHJvb3RcbiAgICAgICAgY3JlYXRlQ2hpbGRyZW4ocm9vdCwgdHJlZS5jaGlsZHJlbik7XG4gICAgICAgIHJldHVybiByb290O1xuICAgIH1cblxuICAgIGZ1bmN0aW9uIGNyZWF0ZUNoaWxkcmVuKHBhcmVudDogQ29uc3RydWN0LCBjaGlsZHJlbjogYW55W10pIHtcbiAgICAgICAgZm9yIChjb25zdCBjaGlsZCBvZiBjaGlsZHJlbikge1xuICAgICAgICAgICAgY29uc3QgaWQgPSAoY2hpbGQucHJvcHMgJiYgY2hpbGQucHJvcHMuaWQpIHx8ICcnO1xuICAgICAgICAgICAgY29uc3QgY2hpbGRPYmogPSBuZXcgY2hpbGQudHlwZShwYXJlbnQsIGlkLCBjaGlsZC5wcm9wcyk7XG4gICAgICAgICAgICBjcmVhdGVDaGlsZHJlbihjaGlsZE9iaiwgY2hpbGQuY2hpbGRyZW4pO1xuICAgICAgICB9XG4gICAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gICAgbmFtZXNwYWNlIEpTWCB7XG4gICAgICAgIC8qKlxuICAgICAgICAgKiBEZWNsYXJlIEpTWC5FbGVtZW50IHRvIGJlIHRoZSBsYXp5IHNwZWNpZmljYXRpb24gb2YgYSBDb25zdHJ1Y3RcbiAgICAgICAgICovXG4gICAgICAgIGV4cG9ydCBpbnRlcmZhY2UgRWxlbWVudCB7XG4gICAgICAgICAgICB0eXBlOiBDb25zdHJ1Y3RDb25zdHJ1Y3RvcjtcblxuICAgICAgICAgICAgcHJvcHM6IGFueTtcblxuICAgICAgICAgICAgY2hpbGRyZW46IEpTWC5FbGVtZW50W107XG4gICAgICAgIH1cblxuICAgICAgICBpbnRlcmZhY2UgRWxlbWVudEF0dHJpYnV0ZXNQcm9wZXJ0eSB7XG4gICAgICAgICAgICAvLyBQcm9wZXJ0eSBvZiB0aGUgb2JqZWN0IHRoYXQgVFNDIHdpbGwgdXNlIHRvIHNlZSB0aGUgYWxsb3dhYmxlXG4gICAgICAgICAgICAvLyBwYXJhbWV0ZXJzIGZvciBldmVyeSB0eXBlLlxuICAgICAgICAgICAganN4UHJvcHM6IGFueTtcbiAgICAgICAgfVxuXG4gICAgICAgIGludGVyZmFjZSBJbnRyaW5zaWNBdHRyaWJ1dGVzIHtcbiAgICAgICAgICAgIC8vIFByb3BlcnRpZXMgdXNlZCBieSB0aGUgZnJhbWV3b3JrLCBub3QgYnkgdGhlIGluZGl2aWR1YWwgY2xhc3Nlcy5cbiAgICAgICAgICAgIGlkOiBzdHJpbmc7XG4gICAgICAgIH1cbiAgICB9XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoianN4LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsianN4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsMkNBQXdDO0FBSXhDLElBQWlCLEdBQUcsQ0FrRG5CO0FBbERELFdBQWlCLEdBQUc7SUFFbEI7Ozs7Ozs7Ozs7Ozs7Ozs7T0FnQkc7SUFDSCxTQUFnQixNQUFNLENBQUMsSUFBMEIsRUFBRSxLQUFVLEVBQUUsR0FBRyxRQUF1QjtRQUN2RixJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxZQUFZLHFCQUFTLENBQUMsRUFBRTtZQUMxQyxNQUFNLElBQUksS0FBSyxDQUFDLHdDQUF3QyxHQUFHLElBQUksQ0FBQyxDQUFDO1NBQ2xFO1FBRUQsT0FBTztZQUNMLElBQUksRUFBRSxLQUFLLEVBQUUsS0FBSyxJQUFJLEVBQUUsRUFBRSxRQUFRO1NBQ25DLENBQUM7SUFDSixDQUFDO0lBUmUsVUFBTSxTQVFyQixDQUFBO0lBRUQ7Ozs7OztPQU1HO0lBQ0gsU0FBZ0IsU0FBUyxDQUFDLElBQWlCLEVBQUUsTUFBa0I7UUFDN0QsTUFBTSxFQUFFLEdBQUcsQ0FBQyxJQUFJLENBQUMsS0FBSyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQy9DLE1BQU0sSUFBSSxHQUFHLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsRUFBRSxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLGNBQWM7UUFDbEUsY0FBYyxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDcEMsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBTGUsYUFBUyxZQUt4QixDQUFBO0lBRUQsU0FBUyxjQUFjLENBQUMsTUFBaUIsRUFBRSxRQUFlO1FBQ3hELEtBQUssTUFBTSxLQUFLLElBQUksUUFBUSxFQUFFO1lBQzVCLE1BQU0sRUFBRSxHQUFHLENBQUMsS0FBSyxDQUFDLEtBQUssSUFBSSxLQUFLLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUNqRCxNQUFNLFFBQVEsR0FBRyxJQUFJLEtBQUssQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLEVBQUUsRUFBRSxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDekQsY0FBYyxDQUFDLFFBQVEsRUFBRSxLQUFLLENBQUMsUUFBUSxDQUFDLENBQUM7U0FDMUM7SUFDSCxDQUFDO0FBQ0gsQ0FBQyxFQWxEZ0IsR0FBRyxHQUFILFdBQUcsS0FBSCxXQUFHLFFBa0RuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJy4vY29uc3RydWN0JztcblxuZXhwb3J0IHR5cGUgQ29uc3RydWN0Q29uc3RydWN0b3IgPSB7IG5ldyAoLi4uYXJnczogYW55W10pOiBDb25zdHJ1Y3QgfTtcblxuZXhwb3J0IG5hbWVzcGFjZSBqc3gge1xuXG4gIC8qKlxuICAgKiBUaGUgSlNYIGZhY3RvcnkgZnVuY3Rpb24uIFRoaXMgaXMgd2hhdCBUeXBlU2NyaXB0IGNvbnZlcnRzIGEgSlNYIHN0YXRlbWVudCB0by5cbiAgICpcbiAgICogRm9yIGV4YW1wbGU6XG4gICAqICAgIDxGb28gcDE9J2EnIHAyPXsyfS8+XG4gICAqIHdpbGwgcHJvZHVjZSB0aGlzIGNvZGU6XG4gICAqICAgIGpzeC5jcmVhdGUoRm9vLCB7IHAxOiAnYScsIHAyOiAyIH0sIFtdKTtcbiAgICpcbiAgICogVGhpcyBmdW5jdGlvbiB3aWxsIG5vdCBhY3R1YWxseSBjcmVhdGUgYW55IG9iamVjdHMsIGJ1dCByYXRoZXIganVzdCByZXR1cm4gYSB0cmVlIG9mXG4gICAqIGVsZW1lbnQgaW5mb3JtYXRpb24gZm9yIGxhdGVyIGNvbnN1bXB0aW9uIGJ5IGpzeC5jb25zdHJ1Y3QodHJlZSksIHdoaWNoIGNhbiBiZSB1c2VkXG4gICAqIHRvIG1hdGVyaWFsaXplIGFuIGFjdHVhbCBjb25zdHJ1Y3QgdHJlZSBmcm9tLlxuICAgKlxuICAgKiBAcGFyYW0gdHlwZSBUaGUgY2xhc3NcbiAgICogQHBhcmFtIHByb3BzIFByb3BlcnR5IGhhc2hcbiAgICogQHBhcmFtIGNoaWxkcmVuIEFycmF5IG9mIGNoaWxkcmVuXG4gICAqIEByZXR1cm5zIGVsZW1lbnQgdHJlZVxuICAgKi9cbiAgZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZSh0eXBlOiBDb25zdHJ1Y3RDb25zdHJ1Y3RvciwgcHJvcHM6IGFueSwgLi4uY2hpbGRyZW46IEpTWC5FbGVtZW50W10pOiBKU1guRWxlbWVudCB7XG4gICAgaWYgKCEodHlwZS5wcm90b3R5cGUgaW5zdGFuY2VvZiBDb25zdHJ1Y3QpKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ0FsbCBub2RlcyBtdXN0IGRlcml2ZSBmcm9tIENvbnN0cnVjdDogJyArIHR5cGUpO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICB0eXBlLCBwcm9wczogcHJvcHMgfHwge30sIGNoaWxkcmVuXG4gICAgfTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDb252ZXJ0cyBhIEpTWCB0cmVlIHRvIGEgY29uc3RydWN0IHRyZWUuXG4gICAqIENyZWF0ZXMgYWxsIGNvbnN0cnVjdCBvYmplY3RzIGFuZCBhc3NvY2lhdGUgdGhlbSB0b2dldGhlciBhcyBjaGlsZHJlbi5cbiAgICogQHBhcmFtIHRyZWUgVGhlIEpTWCB0cmVlXG4gICAqIEBwYXJhbSBwYXJlbnQgT3B0aW9uYWwgcGFyZW50IGZvciB0aGUgY29uc3RydWN0IHRyZWVcbiAgICogQHJldHVybnMgQSBDb25zdHJ1Y3Qgb2JqZWN0XG4gICAqL1xuICBleHBvcnQgZnVuY3Rpb24gY29uc3RydWN0KHRyZWU6IEpTWC5FbGVtZW50LCBwYXJlbnQ/OiBDb25zdHJ1Y3QpOiBDb25zdHJ1Y3Qge1xuICAgIGNvbnN0IGlkID0gKHRyZWUucHJvcHMgJiYgdHJlZS5wcm9wcy5pZCkgfHwgJyc7XG4gICAgY29uc3Qgcm9vdCA9IG5ldyB0cmVlLnR5cGUocGFyZW50LCBpZCwgdHJlZS5wcm9wcyk7IC8vIGNyZWF0ZSByb290XG4gICAgY3JlYXRlQ2hpbGRyZW4ocm9vdCwgdHJlZS5jaGlsZHJlbik7XG4gICAgcmV0dXJuIHJvb3Q7XG4gIH1cblxuICBmdW5jdGlvbiBjcmVhdGVDaGlsZHJlbihwYXJlbnQ6IENvbnN0cnVjdCwgY2hpbGRyZW46IGFueVtdKSB7XG4gICAgZm9yIChjb25zdCBjaGlsZCBvZiBjaGlsZHJlbikge1xuICAgICAgY29uc3QgaWQgPSAoY2hpbGQucHJvcHMgJiYgY2hpbGQucHJvcHMuaWQpIHx8ICcnO1xuICAgICAgY29uc3QgY2hpbGRPYmogPSBuZXcgY2hpbGQudHlwZShwYXJlbnQsIGlkLCBjaGlsZC5wcm9wcyk7XG4gICAgICBjcmVhdGVDaGlsZHJlbihjaGlsZE9iaiwgY2hpbGQuY2hpbGRyZW4pO1xuICAgIH1cbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIG5hbWVzcGFjZSBKU1gge1xuICAgIC8qKlxuICAgICAqIERlY2xhcmUgSlNYLkVsZW1lbnQgdG8gYmUgdGhlIGxhenkgc3BlY2lmaWNhdGlvbiBvZiBhIENvbnN0cnVjdFxuICAgICAqL1xuICAgIGV4cG9ydCBpbnRlcmZhY2UgRWxlbWVudCB7XG4gICAgICB0eXBlOiBDb25zdHJ1Y3RDb25zdHJ1Y3RvcjtcblxuICAgICAgcHJvcHM6IGFueTtcblxuICAgICAgY2hpbGRyZW46IEpTWC5FbGVtZW50W107XG4gICAgfVxuXG4gICAgaW50ZXJmYWNlIEVsZW1lbnRBdHRyaWJ1dGVzUHJvcGVydHkge1xuICAgICAgLy8gUHJvcGVydHkgb2YgdGhlIG9iamVjdCB0aGF0IFRTQyB3aWxsIHVzZSB0byBzZWUgdGhlIGFsbG93YWJsZVxuICAgICAgLy8gcGFyYW1ldGVycyBmb3IgZXZlcnkgdHlwZS5cbiAgICAgIGpzeFByb3BzOiBhbnk7XG4gICAgfVxuXG4gICAgaW50ZXJmYWNlIEludHJpbnNpY0F0dHJpYnV0ZXMge1xuICAgICAgLy8gUHJvcGVydGllcyB1c2VkIGJ5IHRoZSBmcmFtZXdvcmssIG5vdCBieSB0aGUgaW5kaXZpZHVhbCBjbGFzc2VzLlxuICAgICAgaWQ6IHN0cmluZztcbiAgICB9XG4gIH1cbn1cbiJdfQ==

@@ -39,2 +39,23 @@ import { Construct } from './construct';

/**
* This is the interface for arguments to `tagFormatResolve` to enable extensions
*/
export interface TagGroups {
/**
* Tags that overwrite ancestor tags
*/
stickyTags: Tags;
/**
* Tags that are overwritten by ancestor tags
*/
nonStickyTags: Tags;
/**
* Tags with propagate true not from an ancestor
*/
propagateTags: Tags;
/**
* Tags that are propagated from ancestors
*/
ancestorTags: Tags;
}
/**
* Properties for removing tags

@@ -51,2 +72,11 @@ */

/**
* Properties for Tag Manager
*/
export interface TagManagerProps {
/**
* Initial tags to set on the tag manager using TAG_DEFAULTS
*/
initialTags?: Tags;
}
/**
* TagManager facilitates a common implementation of tagging for Constructs.

@@ -95,3 +125,3 @@ *

private readonly blockedTags;
constructor(parent: Construct, initialTags?: Tags);
constructor(parent: Construct, props?: TagManagerProps);
/**

@@ -113,4 +143,13 @@ * Converts the `tags` to a Token for use in lazy evaluation

* @param key The key of the tag to remove
* @param props The `RemoveProps` for the tag
*/
removeTag(key: string, props?: RemoveProps): void;
/**
* Handles returning the tags in the desired format
*
* This function can be overridden to support another tag format. This was
* specifically designed to enable AutoScalingGroup Tags that have an
* additional CloudFormation key for `PropagateAtLaunch`
*/
protected tagFormatResolve(tagGroups: TagGroups): any;
}

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

class TagManager extends tokens_1.Token {
constructor(parent, initialTags = {}) {
constructor(parent, props = {}) {
super();

@@ -52,2 +52,3 @@ this.parent = parent;

this.blockedTags = [];
const initialTags = props.initialTags || {};
for (const key of Object.keys(initialTags)) {

@@ -71,2 +72,4 @@ const tag = {

resolve() {
// need this for scoping
const blockedTags = this.blockedTags;
function filterTags(_tags, filter = {}) {

@@ -91,2 +94,5 @@ const filteredTags = {};

});
for (const key of blockedTags) {
delete filteredTags[key];
}
return filteredTags;

@@ -102,13 +108,18 @@ }

}
for (const key of blockedTags) {
delete parentTags[key];
}
return parentTags;
}
const propOverwrite = filterTags(this._tags, { sticky: false });
const nonOverwrite = filterTags(this._tags, { sticky: true });
const nonStickyTags = filterTags(this._tags, { sticky: false });
const stickyTags = filterTags(this._tags, { sticky: true });
const ancestors = this.parent.ancestors();
ancestors.push(this.parent);
const tags = Object.assign({}, propOverwrite, propagatedTags(ancestors), nonOverwrite);
for (const key of this.blockedTags) {
delete tags[key];
}
return Object.keys(tags).map(key => ({ key, value: tags[key] }));
const ancestorTags = propagatedTags(ancestors);
const propagateTags = filterTags(this._tags, { propagate: true });
return this.tagFormatResolve({
ancestorTags,
nonStickyTags,
stickyTags,
propagateTags,
});
}

@@ -139,2 +150,3 @@ /**

* @param key The key of the tag to remove
* @param props The `RemoveProps` for the tag
*/

@@ -147,2 +159,16 @@ removeTag(key, props = { blockPropagate: true }) {

}
/**
* Handles returning the tags in the desired format
*
* This function can be overridden to support another tag format. This was
* specifically designed to enable AutoScalingGroup Tags that have an
* additional CloudFormation key for `PropagateAtLaunch`
*/
tagFormatResolve(tagGroups) {
const tags = Object.assign({}, tagGroups.nonStickyTags, tagGroups.ancestorTags, tagGroups.stickyTags);
for (const key of this.blockedTags) {
delete tags[key];
}
return Object.keys(tags).map(key => ({ key, value: tags[key] }));
}
}

@@ -155,2 +181,2 @@ TagManager.DEFAULT_TAG_PROPS = {

exports.TagManager = TagManager;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tag-manager.js","sourceRoot":"","sources":["tag-manager.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct } from './construct';\nimport { Token } from './tokens';\n\n/**\n * ITaggable indicates a entity manages tags via the `tags` property\n */\nexport interface ITaggable {\n    readonly tags: TagManager,\n}\n\n/**\n * Properties Tags is a dictionary of tags as strings\n */\nexport type Tags = { [key: string]: string };\n\n/**\n * An object of tags with value and properties\n *\n * This is used internally but not exported\n */\ninterface FullTags {\n    [key: string]: {value: string, props?: TagProps};\n}\n\n/**\n * Properties for a tag\n */\nexport interface TagProps {\n    /**\n     * If true all child taggable `Constructs` will receive this tag\n     *\n     * @default true\n     */\n    propagate?: boolean;\n\n    /**\n     * If set propagated tags from parents will not overwrite the tag\n     *\n     * @default true\n     */\n    sticky?: boolean;\n\n    /**\n     * If set this tag will overwrite existing tags\n     *\n     * @default true\n     */\n    overwrite?: boolean;\n}\n\n/**\n * Properties for removing tags\n */\nexport interface RemoveProps {\n    /**\n     * If true prevent this tag form being set via propagation\n     *\n     * @default true\n     */\n    blockPropagate?: boolean;\n}\n\n/**\n * TagManager facilitates a common implementation of tagging for Constructs.\n *\n * Each construct that wants to support tags should implement the `ITaggable`\n * interface and properly pass tags to the `Resources` (Cloudformation) elements\n * the `Construct` creates. The `TagManager` extends `Token` the object can be\n * passed directly to `Resources` that support tag properties.\n *\n * There are a few standard use cases the `TagManager` supports for managing\n * tags across the resources in your stack.\n *\n * Propagation: If you tag a resource and it has children, by default those tags\n * will be propagated to the children. This is controlled by\n * `TagProps.propagate`.\n *\n * Default a tag unless an ancestor has a value: There are situations where a\n * construct author might want to set a tag value, but choose to take a parents\n * value. For example, you might default `{Key: \"Compliance\", Value: \"None\"}`,\n * but if a parent has `{Key: \"Compliance\", Value: \"PCI\"}` allow that parent to\n * override your tag. This is can be done by setting `TagProps.sticky` to false.\n * The default behavior is that child tags have precedence and `TagProps.sticky`\n * defaults to true to reflect this.\n *\n * Overwrite: Construct authors have the need to set a tag, but only if one was\n * not provided by the consumer. The most common example is the `Name` tag.\n * Overwrite is for this purpose and is controlled by `TagProps.overwrite`. The\n * default is `true`.\n *\n * Removing Tags: Tags can be removed from the local manager via `removeTag`. If\n * a parent also has a tag with the same name then it can be propagated to the\n * child (after removal). The user can control this `RemoveProps.blockPropagate`. By default\n * this is `true` and prevents a parent tag from propagating to the child after\n * the `removeTag` is invoked. However, if user wants the parent tag to\n * propagate, if it is provided by a parent this can be set to `false`.\n */\nexport class TagManager extends Token {\n\n    /**\n     * Checks if the object implements the `ITaggable` interface\n     */\n    public static isTaggable(taggable: ITaggable | any): taggable is ITaggable {\n        return ((taggable as ITaggable).tags !== undefined);\n    }\n\n    private static readonly DEFAULT_TAG_PROPS: TagProps = {\n        propagate: true,\n        sticky: true,\n        overwrite: true\n    };\n\n    /*\n     * Internally tags will have properties set\n     */\n    private readonly _tags: FullTags = {};\n\n    /*\n     * Tags that will be removed during `tags` method\n     */\n    private readonly blockedTags: string[] = [];\n\n    constructor(private readonly parent: Construct, initialTags: Tags  = {}) {\n        super();\n        for (const key of Object.keys(initialTags)) {\n            const tag = {\n                value: initialTags[key],\n                props: TagManager.DEFAULT_TAG_PROPS,\n            };\n            this._tags[key] = tag;\n        }\n    }\n\n    /**\n     * Converts the `tags` to a Token for use in lazy evaluation\n     */\n    public resolve(): any {\n        function filterTags(_tags: FullTags, filter: TagProps = {}): Tags {\n            const filteredTags: Tags = {};\n            Object.keys(_tags).map( key => {\n                let filterResult = true;\n                const props: TagProps = _tags[key].props || {};\n                if (filter.propagate !== undefined) {\n                    filterResult = filterResult && (filter.propagate === props.propagate);\n                }\n                if (filter.sticky !== undefined) {\n                    filterResult = filterResult &&\n                        (filter.sticky === props.sticky);\n                }\n                if (filter.overwrite !== undefined) {\n                    filterResult = filterResult && (filter.overwrite === props.overwrite);\n                }\n                if (filterResult) {\n                    filteredTags[key] = _tags[key].value;\n                }\n            });\n            return filteredTags;\n        }\n\n        function propagatedTags(tagProviders: Construct[]): Tags {\n            const parentTags: Tags = {};\n            for (const ancestor of tagProviders) {\n                if (TagManager.isTaggable(ancestor)) {\n                    const tagsFrom = filterTags(ancestor.tags._tags, {propagate: true});\n                    Object.assign(parentTags, tagsFrom);\n                }\n            }\n            return parentTags;\n        }\n\n        const propOverwrite = filterTags(this._tags, {sticky: false});\n        const nonOverwrite = filterTags(this._tags, {sticky: true});\n        const ancestors = this.parent.ancestors();\n        ancestors.push(this.parent);\n        const tags = {...propOverwrite, ...propagatedTags(ancestors), ...nonOverwrite};\n        for (const key of this.blockedTags) { delete tags[key]; }\n\n        return Object.keys(tags).map( key => ({key, value: tags[key]}));\n    }\n\n    /**\n     * Adds the specified tag to the array of tags\n     *\n     * @param key The key value of the tag\n     * @param value The value value of the tag\n     * @param props A `TagProps` object for the tag @default `TagManager.DEFAULT_TAG_PROPS`\n     */\n    public setTag(key: string, value: string, tagProps: TagProps = {}): void {\n        const props = {...TagManager.DEFAULT_TAG_PROPS, ...tagProps};\n        if (!props.overwrite) {\n            this._tags[key] = this._tags[key] || {value, props};\n        } else {\n            this._tags[key] = {value, props};\n        }\n        const index = this.blockedTags.indexOf(key);\n        if (index > -1) {\n            this.blockedTags.splice(index, 1);\n        }\n    }\n\n    /**\n     * Removes the specified tag from the array if it exists\n     *\n     * @param key The key of the tag to remove\n     */\n    public removeTag(key: string, props: RemoveProps = {blockPropagate: true}): void {\n        if (props.blockPropagate) {\n            this.blockedTags.push(key);\n        }\n        delete this._tags[key];\n    }\n\n    /**\n     * Retrieve all propagated tags from all ancestors\n     *\n     * This retrieves tags from parents but not local tags\n     */\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tag-manager.js","sourceRoot":"","sources":["tag-manager.ts"],"names":[],"mappings":";;AACA,qCAAiC;AAgGjC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAkCG;AACH,MAAa,UAAW,SAAQ,cAAK;IAyBnC,YAA6B,MAAiB,EAAE,QAA0B,EAAE;QAC1E,KAAK,EAAE,CAAC;QADmB,WAAM,GAAN,MAAM,CAAW;QAV9C;;WAEG;QACc,UAAK,GAAa,EAAE,CAAC;QAEtC;;WAEG;QACc,gBAAW,GAAa,EAAE,CAAC;QAK1C,MAAM,WAAW,GAAG,KAAK,CAAC,WAAW,IAAI,EAAE,CAAC;QAC5C,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE;YAC1C,MAAM,GAAG,GAAG;gBACV,KAAK,EAAE,WAAW,CAAC,GAAG,CAAC;gBACvB,KAAK,EAAE,UAAU,CAAC,iBAAiB;aACpC,CAAC;YACF,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC;SACvB;IACH,CAAC;IAlCD;;OAEG;IACI,MAAM,CAAC,UAAU,CAAC,QAAyB;QAChD,OAAO,CAAE,QAAsB,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC;IACtD,CAAC;IA+BD;;OAEG;IACI,OAAO;QACZ,wBAAwB;QACxB,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;QACrC,SAAS,UAAU,CAAC,KAAe,EAAE,SAAmB,EAAE;YACxD,MAAM,YAAY,GAAS,EAAE,CAAC;YAC9B,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,CAAE,GAAG,CAAC,EAAE;gBAC5B,IAAI,YAAY,GAAG,IAAI,CAAC;gBACxB,MAAM,KAAK,GAAa,KAAK,CAAC,GAAG,CAAC,CAAC,KAAK,IAAI,EAAE,CAAC;gBAC/C,IAAI,MAAM,CAAC,SAAS,KAAK,SAAS,EAAE;oBAClC,YAAY,GAAG,YAAY,IAAI,CAAC,MAAM,CAAC,SAAS,KAAK,KAAK,CAAC,SAAS,CAAC,CAAC;iBACvE;gBACD,IAAI,MAAM,CAAC,MAAM,KAAK,SAAS,EAAE;oBAC/B,YAAY,GAAG,YAAY;wBACzB,CAAC,MAAM,CAAC,MAAM,KAAK,KAAK,CAAC,MAAM,CAAC,CAAC;iBACpC;gBACD,IAAI,MAAM,CAAC,SAAS,KAAK,SAAS,EAAE;oBAClC,YAAY,GAAG,YAAY,IAAI,CAAC,MAAM,CAAC,SAAS,KAAK,KAAK,CAAC,SAAS,CAAC,CAAC;iBACvE;gBACD,IAAI,YAAY,EAAE;oBAChB,YAAY,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC;iBACtC;YACH,CAAC,CAAC,CAAC;YACH,KAAK,MAAM,GAAG,IAAI,WAAW,EAAE;gBAAE,OAAO,YAAY,CAAC,GAAG,CAAC,CAAC;aAAE;YAC5D,OAAO,YAAY,CAAC;QACtB,CAAC;QAED,SAAS,cAAc,CAAC,YAAyB;YAC/C,MAAM,UAAU,GAAS,EAAE,CAAC;YAC5B,KAAK,MAAM,QAAQ,IAAI,YAAY,EAAE;gBACnC,IAAI,UAAU,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE;oBACnC,MAAM,QAAQ,GAAG,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,EAAE,EAAC,SAAS,EAAE,IAAI,EAAC,CAAC,CAAC;oBACpE,MAAM,CAAC,MAAM,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC;iBACrC;aACF;YACD,KAAK,MAAM,GAAG,IAAI,WAAW,EAAE;gBAAE,OAAO,UAAU,CAAC,GAAG,CAAC,CAAC;aAAE;YAC1D,OAAO,UAAU,CAAC;QACpB,CAAC;QAED,MAAM,aAAa,GAAG,UAAU,CAAC,IAAI,CAAC,KAAK,EAAE,EAAC,MAAM,EAAE,KAAK,EAAC,CAAC,CAAC;QAC9D,MAAM,UAAU,GAAG,UAAU,CAAC,IAAI,CAAC,KAAK,EAAE,EAAC,MAAM,EAAE,IAAI,EAAC,CAAC,CAAC;QAC1D,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC;QAC1C,MAAM,YAAY,GAAG,cAAc,CAAC,SAAS,CAAC,CAAC;QAC/C,MAAM,aAAa,GAAG,UAAU,CAAC,IAAI,CAAC,KAAK,EAAE,EAAC,SAAS,EAAE,IAAI,EAAC,CAAC,CAAC;QAChE,OAAO,IAAI,CAAC,gBAAgB,CAAE;YAC5B,YAAY;YACZ,aAAa;YACb,UAAU;YACV,aAAa;SACd,CAAC,CAAC;IACL,CAAC;IAED;;;;;;OAMG;IACI,MAAM,CAAC,GAAW,EAAE,KAAa,EAAE,WAAqB,EAAE;QAC/D,MAAM,KAAK,qBAAO,UAAU,CAAC,iBAAiB,EAAK,QAAQ,CAAC,CAAC;QAC7D,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE;YACpB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,EAAC,KAAK,EAAE,KAAK,EAAC,CAAC;SACrD;aAAM;YACL,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAC,KAAK,EAAE,KAAK,EAAC,CAAC;SAClC;QACD,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QAC5C,IAAI,KAAK,GAAG,CAAC,CAAC,EAAE;YACd,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;SACnC;IACH,CAAC;IAED;;;;;OAKG;IACI,SAAS,CAAC,GAAW,EAAE,QAAqB,EAAC,cAAc,EAAE,IAAI,EAAC;QACvE,IAAI,KAAK,CAAC,cAAc,EAAE;YACxB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;SAC5B;QACD,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IACzB,CAAC;IAED;;;;;;OAMG;IACO,gBAAgB,CAAC,SAAoB;QAC7C,MAAM,IAAI,qBAAO,SAAS,CAAC,aAAa,EAAK,SAAS,CAAC,YAAY,EAAK,SAAS,CAAC,UAAU,CAAC,CAAC;QAC9F,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,WAAW,EAAE;YAAE,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC;SAAE;QACzD,OAAO,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAE,GAAG,CAAC,EAAE,CAAC,CAAC,EAAC,GAAG,EAAE,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,EAAC,CAAC,CAAC,CAAC;IAClE,CAAC;;AA/HuB,4BAAiB,GAAa;IACpD,SAAS,EAAE,IAAI;IACf,MAAM,EAAE,IAAI;IACZ,SAAS,EAAE,IAAI;CAChB,CAAC;AAbJ,gCAyIC","sourcesContent":["import { Construct } from './construct';\nimport { Token } from './tokens';\n\n/**\n * ITaggable indicates a entity manages tags via the `tags` property\n */\nexport interface ITaggable {\n  readonly tags: TagManager,\n}\n\n/**\n * Properties Tags is a dictionary of tags as strings\n */\nexport type Tags = { [key: string]: string };\n\n/**\n * An object of tags with value and properties\n *\n * This is used internally but not exported\n */\ninterface FullTags {\n  [key: string]: {value: string, props?: TagProps};\n}\n\n/**\n * Properties for a tag\n */\nexport interface TagProps {\n  /**\n   * If true all child taggable `Constructs` will receive this tag\n   *\n   * @default true\n   */\n  propagate?: boolean;\n\n  /**\n   * If set propagated tags from parents will not overwrite the tag\n   *\n   * @default true\n   */\n  sticky?: boolean;\n\n  /**\n   * If set this tag will overwrite existing tags\n   *\n   * @default true\n   */\n  overwrite?: boolean;\n}\n\n/**\n * This is the interface for arguments to `tagFormatResolve` to enable extensions\n */\nexport interface TagGroups {\n  /**\n   * Tags that overwrite ancestor tags\n   */\n  stickyTags: Tags;\n\n  /**\n   * Tags that are overwritten by ancestor tags\n   */\n  nonStickyTags: Tags;\n\n  /**\n   * Tags with propagate true not from an ancestor\n   */\n  propagateTags: Tags;\n\n  /**\n   * Tags that are propagated from ancestors\n   */\n  ancestorTags: Tags;\n}\n\n/**\n * Properties for removing tags\n */\nexport interface RemoveProps {\n  /**\n   * If true prevent this tag form being set via propagation\n   *\n   * @default true\n   */\n  blockPropagate?: boolean;\n}\n\n/**\n * Properties for Tag Manager\n */\nexport interface TagManagerProps {\n  /**\n   * Initial tags to set on the tag manager using TAG_DEFAULTS\n   */\n  initialTags?: Tags;\n}\n\n/**\n * TagManager facilitates a common implementation of tagging for Constructs.\n *\n * Each construct that wants to support tags should implement the `ITaggable`\n * interface and properly pass tags to the `Resources` (Cloudformation) elements\n * the `Construct` creates. The `TagManager` extends `Token` the object can be\n * passed directly to `Resources` that support tag properties.\n *\n * There are a few standard use cases the `TagManager` supports for managing\n * tags across the resources in your stack.\n *\n * Propagation: If you tag a resource and it has children, by default those tags\n * will be propagated to the children. This is controlled by\n * `TagProps.propagate`.\n *\n * Default a tag unless an ancestor has a value: There are situations where a\n * construct author might want to set a tag value, but choose to take a parents\n * value. For example, you might default `{Key: \"Compliance\", Value: \"None\"}`,\n * but if a parent has `{Key: \"Compliance\", Value: \"PCI\"}` allow that parent to\n * override your tag. This is can be done by setting `TagProps.sticky` to false.\n * The default behavior is that child tags have precedence and `TagProps.sticky`\n * defaults to true to reflect this.\n *\n * Overwrite: Construct authors have the need to set a tag, but only if one was\n * not provided by the consumer. The most common example is the `Name` tag.\n * Overwrite is for this purpose and is controlled by `TagProps.overwrite`. The\n * default is `true`.\n *\n * Removing Tags: Tags can be removed from the local manager via `removeTag`. If\n * a parent also has a tag with the same name then it can be propagated to the\n * child (after removal). The user can control this `RemoveProps.blockPropagate`. By default\n * this is `true` and prevents a parent tag from propagating to the child after\n * the `removeTag` is invoked. However, if user wants the parent tag to\n * propagate, if it is provided by a parent this can be set to `false`.\n */\nexport class TagManager extends Token {\n\n  /**\n   * Checks if the object implements the `ITaggable` interface\n   */\n  public static isTaggable(taggable: ITaggable | any): taggable is ITaggable {\n    return ((taggable as ITaggable).tags !== undefined);\n  }\n\n  private static readonly DEFAULT_TAG_PROPS: TagProps = {\n    propagate: true,\n    sticky: true,\n    overwrite: true\n  };\n\n  /*\n   * Internally tags will have properties set\n   */\n  private readonly _tags: FullTags = {};\n\n  /*\n   * Tags that will be removed during `tags` method\n   */\n  private readonly blockedTags: string[] = [];\n\n  constructor(private readonly parent: Construct, props: TagManagerProps  = {}) {\n    super();\n\n    const initialTags = props.initialTags || {};\n    for (const key of Object.keys(initialTags)) {\n      const tag = {\n        value: initialTags[key],\n        props: TagManager.DEFAULT_TAG_PROPS,\n      };\n      this._tags[key] = tag;\n    }\n  }\n\n  /**\n   * Converts the `tags` to a Token for use in lazy evaluation\n   */\n  public resolve(): any {\n    // need this for scoping\n    const blockedTags = this.blockedTags;\n    function filterTags(_tags: FullTags, filter: TagProps = {}): Tags {\n      const filteredTags: Tags = {};\n      Object.keys(_tags).map( key => {\n        let filterResult = true;\n        const props: TagProps = _tags[key].props || {};\n        if (filter.propagate !== undefined) {\n          filterResult = filterResult && (filter.propagate === props.propagate);\n        }\n        if (filter.sticky !== undefined) {\n          filterResult = filterResult &&\n            (filter.sticky === props.sticky);\n        }\n        if (filter.overwrite !== undefined) {\n          filterResult = filterResult && (filter.overwrite === props.overwrite);\n        }\n        if (filterResult) {\n          filteredTags[key] = _tags[key].value;\n        }\n      });\n      for (const key of blockedTags) { delete filteredTags[key]; }\n      return filteredTags;\n    }\n\n    function propagatedTags(tagProviders: Construct[]): Tags {\n      const parentTags: Tags = {};\n      for (const ancestor of tagProviders) {\n        if (TagManager.isTaggable(ancestor)) {\n          const tagsFrom = filterTags(ancestor.tags._tags, {propagate: true});\n          Object.assign(parentTags, tagsFrom);\n        }\n      }\n      for (const key of blockedTags) { delete parentTags[key]; }\n      return parentTags;\n    }\n\n    const nonStickyTags = filterTags(this._tags, {sticky: false});\n    const stickyTags = filterTags(this._tags, {sticky: true});\n    const ancestors = this.parent.ancestors();\n    const ancestorTags = propagatedTags(ancestors);\n    const propagateTags = filterTags(this._tags, {propagate: true});\n    return this.tagFormatResolve( {\n      ancestorTags,\n      nonStickyTags,\n      stickyTags,\n      propagateTags,\n    });\n  }\n\n  /**\n   * Adds the specified tag to the array of tags\n   *\n   * @param key The key value of the tag\n   * @param value The value value of the tag\n   * @param props A `TagProps` object for the tag @default `TagManager.DEFAULT_TAG_PROPS`\n   */\n  public setTag(key: string, value: string, tagProps: TagProps = {}): void {\n    const props = {...TagManager.DEFAULT_TAG_PROPS, ...tagProps};\n    if (!props.overwrite) {\n      this._tags[key] = this._tags[key] || {value, props};\n    } else {\n      this._tags[key] = {value, props};\n    }\n    const index = this.blockedTags.indexOf(key);\n    if (index > -1) {\n      this.blockedTags.splice(index, 1);\n    }\n  }\n\n  /**\n   * Removes the specified tag from the array if it exists\n   *\n   * @param key The key of the tag to remove\n   * @param props The `RemoveProps` for the tag\n   */\n  public removeTag(key: string, props: RemoveProps = {blockPropagate: true}): void {\n    if (props.blockPropagate) {\n      this.blockedTags.push(key);\n    }\n    delete this._tags[key];\n  }\n\n  /**\n   * Handles returning the tags in the desired format\n   *\n   * This function can be overridden to support another tag format. This was\n   * specifically designed to enable AutoScalingGroup Tags that have an\n   * additional CloudFormation key for `PropagateAtLaunch`\n   */\n  protected tagFormatResolve(tagGroups: TagGroups): any {\n    const tags = {...tagGroups.nonStickyTags, ...tagGroups.ancestorTags, ...tagGroups.stickyTags};\n    for (const key of this.blockedTags) { delete tags[key]; }\n    return Object.keys(tags).map( key => ({key, value: tags[key]}));\n  }\n}\n"]}

@@ -29,3 +29,3 @@ /**

*
* "embedded in a larger string is ${Token[DISPLAY_NAME.123]}"
* "embedded in a larger string is ${Token[DISPLAY_NAME.123]}"
*

@@ -32,0 +32,0 @@ * This value is used as a hint to humans what the meaning of the Token is,

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

*
* "embedded in a larger string is ${Token[DISPLAY_NAME.123]}"
* "embedded in a larger string is ${Token[DISPLAY_NAME.123]}"
*

@@ -363,2 +363,2 @@ * This value is used as a hint to humans what the meaning of the Token is,

}
//# 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}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tokens.js","sourceRoot":"","sources":["tokens.ts"],"names":[],"mappings":";;AAAA,2CAAwC;AAExC;;;GAGG;AACU,QAAA,cAAc,GAAG,SAAS,CAAC;AAExC;;;;;;;;;GASG;AACH,MAAa,KAAK;IAGhB;;;;;;;;;;;;;;;;;;OAkBG;IACH,YAA6B,eAAqB,EAAmB,WAAoB;QAA5D,oBAAe,GAAf,eAAe,CAAM;QAAmB,gBAAW,GAAX,WAAW,CAAS;IACzF,CAAC;IAED;;OAEG;IACI,OAAO;QACZ,IAAI,KAAK,GAAG,IAAI,CAAC,eAAe,CAAC;QACjC,IAAI,OAAM,CAAC,KAAK,CAAC,KAAK,UAAU,EAAE;YAChC,KAAK,GAAG,KAAK,EAAE,CAAC;SACjB;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;;;;;;;;;OAUG;IACI,QAAQ;QACb,MAAM,SAAS,GAAG,OAAO,IAAI,CAAC,eAAe,CAAC;QAC9C,iEAAiE;QACjE,uBAAuB;QACvB,IAAI,SAAS,KAAK,QAAQ,IAAI,SAAS,KAAK,QAAQ,IAAI,SAAS,KAAK,SAAS,EAAE;YAC/E,OAAO,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC;SACxC;QAED,IAAI,IAAI,CAAC,QAAQ,KAAK,SAAS,EAAE;YAC/B,IAAI,CAAC,QAAQ,GAAG,gBAAgB,CAAC,QAAQ,CAAC,IAAI,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;SACnE;QACD,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAED;;;;;OAKG;IACI,MAAM;QACX,2CAA2C;QAC3C,MAAM,IAAI,KAAK,CAAC,6HAA6H,CAAC,CAAC;IACjJ,CAAC;IAED;;;;;OAKG;IACI,MAAM,CAAC,IAAqB,EAAE,KAAsB;QACzD,MAAM,KAAK,GAAG,CAAC,IAAI,EAAE,OAAO,CAAC,IAAI,CAAC,EAAE,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC;QACxE,OAAO,IAAI,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;IACpD,CAAC;CACF;AAnFD,sBAmFC;AAED;;;;GAIG;AACH,SAAgB,UAAU,CAAC,GAAQ;IACjC,IAAI,OAAM,CAAC,GAAG,CAAC,KAAK,QAAQ,EAAE;QAC5B,OAAO,gBAAgB,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC;KACvD;SAAM;QACL,OAAO,OAAM,CAAC,GAAG,CAAC,sBAAc,CAAC,CAAC,KAAK,UAAU,CAAC;KACnD;AACH,CAAC;AAND,gCAMC;AAED;;;;;;GAMG;AACH,SAAgB,OAAO,CAAC,GAAQ,EAAE,MAAiB;IACjD,MAAM,IAAI,GAAG,MAAM,IAAI,EAAG,CAAC;IAC3B,MAAM,QAAQ,GAAG,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAEtC,uDAAuD;IACvD,IAAI,IAAI,CAAC,MAAM,GAAG,GAAG,EAAE;QACrB,MAAM,IAAI,KAAK,CAAC,+DAA+D,GAAG,QAAQ,CAAC,CAAC;KAC7F;IAED,EAAE;IACF,YAAY;IACZ,EAAE;IAEF,IAAI,OAAM,CAAC,GAAG,CAAC,KAAK,WAAW,EAAE;QAC/B,OAAO,SAAS,CAAC;KAClB;IAED,EAAE;IACF,OAAO;IACP,EAAE;IAEF,IAAI,GAAG,KAAK,IAAI,EAAE;QAChB,OAAO,IAAI,CAAC;KACb;IAED,EAAE;IACF,wDAAwD;IACxD,EAAE;IAEF,IAAI,OAAM,CAAC,GAAG,CAAC,KAAK,UAAU,EAAE;QAC9B,MAAM,IAAI,KAAK,CAAC,4FAA4F,QAAQ,aAAa,GAAG,EAAE,CAAC,CAAC;KACzI;IAED,EAAE;IACF,sDAAsD;IACtD,EAAE;IACF,IAAI,OAAM,CAAC,GAAG,CAAC,KAAK,QAAQ,EAAE;QAC5B,OAAO,gBAAgB,CAAC,cAAc,CAAC,GAAa,CAAC,CAAC;KACvD;IAED,EAAE;IACF,qBAAqB;IACrB,EAAE;IAEF,IAAI,OAAM,CAAC,GAAG,CAAC,KAAK,QAAQ,IAAI,GAAG,YAAY,IAAI,EAAE;QACnD,OAAO,GAAG,CAAC;KACZ;IAED,EAAE;IACF,gEAAgE;IAChE,EAAE;IAEF,IAAI,UAAU,CAAC,GAAG,CAAC,EAAE;QACnB,MAAM,KAAK,GAAG,GAAG,CAAC,sBAAc,CAAC,EAAE,CAAC;QACpC,OAAO,OAAO,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;KAC7B;IAED,EAAE;IACF,wEAAwE;IACxE,EAAE;IAEF,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;QACtB,MAAM,GAAG,GAAG,GAAG;aACZ,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;aACpD,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,OAAM,CAAC,CAAC,CAAC,KAAK,WAAW,CAAC,CAAC;QAE1C,OAAO,GAAG,CAAC;KACZ;IAED,EAAE;IACF,oCAAoC;IACpC,EAAE;IAEF,4EAA4E;IAC5E,8EAA8E;IAC9E,qCAAqC;IACrC,IAAI,GAAG,YAAY,qBAAS,EAAE;QAC5B,MAAM,IAAI,KAAK,CAAC,qCAAqC,GAAG,QAAQ,CAAC,CAAC;KACnE;IAED,MAAM,MAAM,GAAQ,EAAG,CAAC;IACxB,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE;QAClC,MAAM,WAAW,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;QACjC,IAAI,OAAM,CAAC,WAAW,CAAC,KAAK,QAAQ,EAAE;YACpC,MAAM,IAAI,KAAK,CAAC,YAAY,GAAG,0BAA0B,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,qCAAqC,CAAC,CAAC;SAC5H;QAED,MAAM,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;QAElD,iBAAiB;QACjB,IAAI,OAAM,CAAC,KAAK,CAAC,KAAK,WAAW,EAAE;YACjC,SAAS;SACV;QAED,MAAM,CAAC,WAAW,CAAC,GAAG,KAAK,CAAC;KAC7B;IAED,OAAO,MAAM,CAAC;AAChB,CAAC;AAlGD,0BAkGC;AAED;;;;;;;;GAQG;AACH,MAAM,cAAc;IAGlB;QACE,MAAM,IAAI,GAAG,MAAa,CAAC;QAC3B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,IAAI,EAAE,CAAC;IAChE,CAAC;IAED;;;;;;;;;;OAUG;IACI,QAAQ,CAAC,KAAY,EAAE,kBAA2B;QACvD,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC;QAClD,MAAM,cAAc,GAAG,kBAAkB,IAAI,OAAO,CAAC;QAErD,MAAM,GAAG,GAAG,GAAG,cAAc,IAAI,OAAO,EAAE,CAAC;QAC3C,IAAI,IAAI,MAAM,CAAC,KAAK,eAAe,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE;YACjD,MAAM,IAAI,KAAK,CAAC,+CAA+C,GAAG,EAAE,CAAC,CAAC;SACvE;QAED,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;QAC3B,OAAO,GAAG,kBAAkB,GAAG,GAAG,GAAG,gBAAgB,EAAE,CAAC;IAC1D,CAAC;IAED;;OAEG;IACI,iBAAiB,CAAC,CAAS;QAChC,OAAO,IAAI,WAAW,CAAC,CAAC,EAAE,kBAAkB,EAAE,IAAI,eAAe,IAAI,EAAE,gBAAgB,CAAC,CAAC;IAC3F,CAAC;IAED;;OAEG;IACI,cAAc,CAAC,CAAS;QAC7B,MAAM,GAAG,GAAG,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC;QACtC,MAAM,SAAS,GAAG,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QACzD,OAAO,SAAS,CAAC,IAAI,EAAE,CAAC;IAC1B,CAAC;IAED;;OAEG;IACI,WAAW,CAAC,GAAW;QAC5B,IAAI,CAAC,CAAC,GAAG,IAAI,IAAI,CAAC,QAAQ,CAAC,EAAE;YAC3B,MAAM,IAAI,KAAK,CAAC,2BAA2B,GAAG,EAAE,CAAC,CAAC;SACnD;QAED,OAAO,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;IAC5B,CAAC;CACF;AAED,MAAM,kBAAkB,GAAG,UAAU,CAAC;AACtC,MAAM,gBAAgB,GAAG,IAAI,CAAC;AAC9B,MAAM,eAAe,GAAG,eAAe,CAAC;AAExC;;GAEG;AACH,MAAM,gBAAgB,GAAG,IAAI,cAAc,EAAE,CAAC;AAoB9C;;GAEG;AACH,MAAM,WAAW;IAGf,YACmB,GAAW,EACX,WAAmB,EACnB,SAAiB,EACjB,SAAiB;QAHjB,QAAG,GAAH,GAAG,CAAQ;QACX,gBAAW,GAAX,WAAW,CAAQ;QACnB,cAAS,GAAT,SAAS,CAAQ;QACjB,cAAS,GAAT,SAAS,CAAQ;QAClC,IAAI,CAAC,OAAO,GAAG,GAAG,UAAU,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,IAAI,CAAC,SAAS,IAAI,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC;IACnG,CAAC;IAED;;OAEG;IACI,KAAK,CAAC,MAA6B;QACxC,MAAM,EAAE,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;QACzC,MAAM,GAAG,GAAG,IAAI,oBAAoB,EAAE,CAAC;QAEvC,IAAI,IAAI,GAAG,CAAC,CAAC;QACb,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC1B,OAAO,CAAC,EAAE;YACR,IAAI,CAAC,CAAC,KAAK,GAAG,IAAI,EAAE;gBAClB,GAAG,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;aAClD;YAED,GAAG,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAE3B,IAAI,GAAG,EAAE,CAAC,SAAS,CAAC;YACpB,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;SACvB;QAED,IAAI,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE;YAC1B,GAAG,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC;SACzC;QAED,OAAO,GAAG,CAAC;IACb,CAAC;IAED;;OAEG;IACI,IAAI;QACT,MAAM,EAAE,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;QACzC,OAAO,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC3B,CAAC;CACF;AAWD;;GAEG;AACH,MAAM,oBAAoB;IAA1B;QACmB,cAAS,GAAG,IAAI,KAAK,EAAY,CAAC;IA4CrD,CAAC;IA1CQ,MAAM;QACX,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;IAChF,CAAC;IAEM,SAAS,CAAC,GAAW;QAC1B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,GAAG,EAAE,CAAC,CAAC;IAC/C,CAAC;IAEM,QAAQ,CAAC,KAAY;QAC1B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;IAChD,CAAC;IAED;;;;OAIG;IACI,IAAI;QACT,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE;YAAE,OAAO,EAAE,CAAC;SAAE;QAC/C,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE;YAAE,OAAO,eAAe,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;SAAE;QAE/E,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;QAEhC,IAAI,CAAC,CAAC;QACN,IAAI,KAAY,CAAC;QAEjB,IAAI,KAAK,CAAC,IAAI,KAAK,OAAO,EAAE;YAC1B,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC;YACpB,CAAC,GAAG,CAAC,CAAC;SACP;aAAM;YACL,qCAAqC;YACrC,KAAK,GAAI,IAAI,CAAC,SAAS,CAAC,CAAC,CAAmB,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;YAChF,CAAC,GAAG,CAAC,CAAC;SACP;QAED,OAAO,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE;YAChC,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,SAAS,EAAE,eAAe,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACpE,CAAC,EAAE,CAAC;SACL;QAED,OAAO,OAAO,CAAC,KAAK,CAAC,CAAC;IACxB,CAAC;CACF;AAED;;GAEG;AACH,SAAS,eAAe,CAAC,QAAkB;IACzC,OAAO,QAAQ,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;AAC7E,CAAC;AAED;;GAEG;AACH,SAAS,UAAU,CAAC,CAAS;IAC3B,OAAO,CAAC,CAAC,OAAO,CAAC,sBAAsB,EAAE,MAAM,CAAC,CAAC;AACnD,CAAC","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}\n"]}

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

exports.ignoreEmpty = ignoreEmpty;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInV0aWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxxQ0FBbUM7QUFFbkM7OztHQUdHO0FBQ0gsU0FBZ0IsdUJBQXVCLENBQUMsR0FBUTtJQUM1QyxHQUFHLEdBQUcsZ0JBQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUVuQixJQUFJLE9BQU0sQ0FBQyxHQUFHLENBQUMsS0FBSyxRQUFRLEVBQUU7UUFDMUIsT0FBTyxHQUFHLENBQUM7S0FDZDtJQUVELElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRTtRQUNwQixPQUFPLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0tBQ25EO0lBRUQsTUFBTSxNQUFNLEdBQVEsRUFBRyxDQUFDO0lBQ3hCLEtBQUssTUFBTSxHQUFHLElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRTtRQUNoQyxNQUFNLEtBQUssR0FBRyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUM7UUFFdkIsTUFBTSxLQUFLLEdBQUcsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUMxQyxNQUFNLE1BQU0sR0FBRyxLQUFLLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNwQyxNQUFNLENBQUMsTUFBTSxDQUFDLEdBQUcsdUJBQXVCLENBQUMsS0FBSyxDQUFDLENBQUM7S0FDbkQ7SUFFRCxPQUFPLE1BQU0sQ0FBQztBQUNsQixDQUFDO0FBckJELDBEQXFCQztBQUVEOztHQUVHO0FBQ0gsU0FBZ0IsV0FBVyxDQUFDLENBQU07SUFDOUIsQ0FBQyxHQUFHLGdCQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyw4REFBOEQ7SUFFOUUsaUJBQWlCO0lBQ2pCLElBQUksQ0FBQyxJQUFJLElBQUksRUFBRTtRQUNYLE9BQU8sQ0FBQyxDQUFDO0tBQ1o7SUFFRCxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7UUFDcEMsT0FBTyxTQUFTLENBQUM7S0FDcEI7SUFFRCxJQUFJLE9BQU0sQ0FBQyxDQUFDLENBQUMsS0FBSyxRQUFRLElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFO1FBQ3ZELE9BQU8sU0FBUyxDQUFDO0tBQ3BCO0lBRUQsT0FBTyxDQUFDLENBQUM7QUFDYixDQUFDO0FBakJELGtDQWlCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHJlc29sdmUgfSBmcm9tICcuL3Rva2Vucyc7XG5cbi8qKlxuICogR2l2ZW4gYW4gb2JqZWN0LCBjb252ZXJ0cyBhbGwga2V5cyB0byBQYXNjYWxDYXNlIGdpdmVuIHRoZXkgYXJlIGN1cnJlbnRseSBpbiBjYW1lbCBjYXNlLlxuICogQHBhcmFtIG9iaiBUaGUgb2JqZWN0LlxuICovXG5leHBvcnQgZnVuY3Rpb24gY2FwaXRhbGl6ZVByb3BlcnR5TmFtZXMob2JqOiBhbnkpOiBhbnkge1xuICAgIG9iaiA9IHJlc29sdmUob2JqKTtcblxuICAgIGlmICh0eXBlb2Yob2JqKSAhPT0gJ29iamVjdCcpIHtcbiAgICAgICAgcmV0dXJuIG9iajtcbiAgICB9XG5cbiAgICBpZiAoQXJyYXkuaXNBcnJheShvYmopKSB7XG4gICAgICAgIHJldHVybiBvYmoubWFwKHggPT4gY2FwaXRhbGl6ZVByb3BlcnR5TmFtZXMoeCkpO1xuICAgIH1cblxuICAgIGNvbnN0IG5ld09iajogYW55ID0geyB9O1xuICAgIGZvciAoY29uc3Qga2V5IG9mIE9iamVjdC5rZXlzKG9iaikpIHtcbiAgICAgICAgY29uc3QgdmFsdWUgPSBvYmpba2V5XTtcblxuICAgICAgICBjb25zdCBmaXJzdCA9IGtleS5jaGFyQXQoMCkudG9VcHBlckNhc2UoKTtcbiAgICAgICAgY29uc3QgbmV3S2V5ID0gZmlyc3QgKyBrZXkuc2xpY2UoMSk7XG4gICAgICAgIG5ld09ialtuZXdLZXldID0gY2FwaXRhbGl6ZVByb3BlcnR5TmFtZXModmFsdWUpO1xuICAgIH1cblxuICAgIHJldHVybiBuZXdPYmo7XG59XG5cbi8qKlxuICogVHVybnMgZW1wdHkgYXJyYXlzL29iamVjdHMgdG8gdW5kZWZpbmVkIChhZnRlciBldmFsdWF0aW5nIHRva2VucykuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBpZ25vcmVFbXB0eShvOiBhbnkpOiBhbnkge1xuICAgIG8gPSByZXNvbHZlKG8pOyAvLyBmaXJzdCByZXNvbHZlIHRva2VucywgaW4gY2FzZSB0aGV5IGV2YWx1YXRlIHRvICd1bmRlZmluZWQnLlxuXG4gICAgLy8gdW5kZWZpbmVkL251bGxcbiAgICBpZiAobyA9PSBudWxsKSB7XG4gICAgICAgIHJldHVybiBvO1xuICAgIH1cblxuICAgIGlmIChBcnJheS5pc0FycmF5KG8pICYmIG8ubGVuZ3RoID09PSAwKSB7XG4gICAgICAgIHJldHVybiB1bmRlZmluZWQ7XG4gICAgfVxuXG4gICAgaWYgKHR5cGVvZihvKSA9PT0gJ29iamVjdCcgJiYgT2JqZWN0LmtleXMobykubGVuZ3RoID09PSAwKSB7XG4gICAgICAgIHJldHVybiB1bmRlZmluZWQ7XG4gICAgfVxuXG4gICAgcmV0dXJuIG87XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInV0aWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxxQ0FBbUM7QUFFbkM7OztHQUdHO0FBQ0gsU0FBZ0IsdUJBQXVCLENBQUMsR0FBUTtJQUM5QyxHQUFHLEdBQUcsZ0JBQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUVuQixJQUFJLE9BQU0sQ0FBQyxHQUFHLENBQUMsS0FBSyxRQUFRLEVBQUU7UUFDNUIsT0FBTyxHQUFHLENBQUM7S0FDWjtJQUVELElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRTtRQUN0QixPQUFPLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0tBQ2pEO0lBRUQsTUFBTSxNQUFNLEdBQVEsRUFBRyxDQUFDO0lBQ3hCLEtBQUssTUFBTSxHQUFHLElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRTtRQUNsQyxNQUFNLEtBQUssR0FBRyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUM7UUFFdkIsTUFBTSxLQUFLLEdBQUcsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUMxQyxNQUFNLE1BQU0sR0FBRyxLQUFLLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNwQyxNQUFNLENBQUMsTUFBTSxDQUFDLEdBQUcsdUJBQXVCLENBQUMsS0FBSyxDQUFDLENBQUM7S0FDakQ7SUFFRCxPQUFPLE1BQU0sQ0FBQztBQUNoQixDQUFDO0FBckJELDBEQXFCQztBQUVEOztHQUVHO0FBQ0gsU0FBZ0IsV0FBVyxDQUFDLENBQU07SUFDaEMsQ0FBQyxHQUFHLGdCQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyw4REFBOEQ7SUFFOUUsaUJBQWlCO0lBQ2pCLElBQUksQ0FBQyxJQUFJLElBQUksRUFBRTtRQUNiLE9BQU8sQ0FBQyxDQUFDO0tBQ1Y7SUFFRCxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7UUFDdEMsT0FBTyxTQUFTLENBQUM7S0FDbEI7SUFFRCxJQUFJLE9BQU0sQ0FBQyxDQUFDLENBQUMsS0FBSyxRQUFRLElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFO1FBQ3pELE9BQU8sU0FBUyxDQUFDO0tBQ2xCO0lBRUQsT0FBTyxDQUFDLENBQUM7QUFDWCxDQUFDO0FBakJELGtDQWlCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHJlc29sdmUgfSBmcm9tICcuL3Rva2Vucyc7XG5cbi8qKlxuICogR2l2ZW4gYW4gb2JqZWN0LCBjb252ZXJ0cyBhbGwga2V5cyB0byBQYXNjYWxDYXNlIGdpdmVuIHRoZXkgYXJlIGN1cnJlbnRseSBpbiBjYW1lbCBjYXNlLlxuICogQHBhcmFtIG9iaiBUaGUgb2JqZWN0LlxuICovXG5leHBvcnQgZnVuY3Rpb24gY2FwaXRhbGl6ZVByb3BlcnR5TmFtZXMob2JqOiBhbnkpOiBhbnkge1xuICBvYmogPSByZXNvbHZlKG9iaik7XG5cbiAgaWYgKHR5cGVvZihvYmopICE9PSAnb2JqZWN0Jykge1xuICAgIHJldHVybiBvYmo7XG4gIH1cblxuICBpZiAoQXJyYXkuaXNBcnJheShvYmopKSB7XG4gICAgcmV0dXJuIG9iai5tYXAoeCA9PiBjYXBpdGFsaXplUHJvcGVydHlOYW1lcyh4KSk7XG4gIH1cblxuICBjb25zdCBuZXdPYmo6IGFueSA9IHsgfTtcbiAgZm9yIChjb25zdCBrZXkgb2YgT2JqZWN0LmtleXMob2JqKSkge1xuICAgIGNvbnN0IHZhbHVlID0gb2JqW2tleV07XG5cbiAgICBjb25zdCBmaXJzdCA9IGtleS5jaGFyQXQoMCkudG9VcHBlckNhc2UoKTtcbiAgICBjb25zdCBuZXdLZXkgPSBmaXJzdCArIGtleS5zbGljZSgxKTtcbiAgICBuZXdPYmpbbmV3S2V5XSA9IGNhcGl0YWxpemVQcm9wZXJ0eU5hbWVzKHZhbHVlKTtcbiAgfVxuXG4gIHJldHVybiBuZXdPYmo7XG59XG5cbi8qKlxuICogVHVybnMgZW1wdHkgYXJyYXlzL29iamVjdHMgdG8gdW5kZWZpbmVkIChhZnRlciBldmFsdWF0aW5nIHRva2VucykuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBpZ25vcmVFbXB0eShvOiBhbnkpOiBhbnkge1xuICBvID0gcmVzb2x2ZShvKTsgLy8gZmlyc3QgcmVzb2x2ZSB0b2tlbnMsIGluIGNhc2UgdGhleSBldmFsdWF0ZSB0byAndW5kZWZpbmVkJy5cblxuICAvLyB1bmRlZmluZWQvbnVsbFxuICBpZiAobyA9PSBudWxsKSB7XG4gICAgcmV0dXJuIG87XG4gIH1cblxuICBpZiAoQXJyYXkuaXNBcnJheShvKSAmJiBvLmxlbmd0aCA9PT0gMCkge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICBpZiAodHlwZW9mKG8pID09PSAnb2JqZWN0JyAmJiBPYmplY3Qua2V5cyhvKS5sZW5ndGggPT09IDApIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgcmV0dXJuIG87XG59XG4iXX0=
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW52aXJvbm1lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJlbnZpcm9ubWVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBUaGUgZGVwbG95bWVudCBlbnZpcm9ubWVudCBmb3IgYSBzdGFjay5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBFbnZpcm9ubWVudCB7XG4gICAgLyoqXG4gICAgICogVGhlIEFXUyBhY2NvdW50IElEIGZvciB0aGlzIGVudmlyb25tZW50LlxuICAgICAqIElmIG5vdCBzcGVjaWZpZWQsIHRoZSBjb250ZXh0IHBhcmFtZXRlciBgZGVmYXVsdC1hY2NvdW50YCBpcyB1c2VkLlxuICAgICAqL1xuICAgIGFjY291bnQ/OiBzdHJpbmc7XG5cbiAgICAvKipcbiAgICAgKiBUaGUgQVdTIHJlZ2lvbiBmb3IgdGhpcyBlbnZpcm9ubWVudC5cbiAgICAgKiBJZiBub3Qgc3BlY2lmaWVkLCB0aGUgY29udGV4dCBwYXJhbWV0ZXIgYGRlZmF1bHQtcmVnaW9uYCBpcyB1c2VkLlxuICAgICAqL1xuICAgIHJlZ2lvbj86IHN0cmluZztcbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW52aXJvbm1lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJlbnZpcm9ubWVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBUaGUgZGVwbG95bWVudCBlbnZpcm9ubWVudCBmb3IgYSBzdGFjay5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBFbnZpcm9ubWVudCB7XG4gIC8qKlxuICAgKiBUaGUgQVdTIGFjY291bnQgSUQgZm9yIHRoaXMgZW52aXJvbm1lbnQuXG4gICAqIElmIG5vdCBzcGVjaWZpZWQsIHRoZSBjb250ZXh0IHBhcmFtZXRlciBgZGVmYXVsdC1hY2NvdW50YCBpcyB1c2VkLlxuICAgKi9cbiAgYWNjb3VudD86IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIEFXUyByZWdpb24gZm9yIHRoaXMgZW52aXJvbm1lbnQuXG4gICAqIElmIG5vdCBzcGVjaWZpZWQsIHRoZSBjb250ZXh0IHBhcmFtZXRlciBgZGVmYXVsdC1yZWdpb25gIGlzIHVzZWQuXG4gICAqL1xuICByZWdpb24/OiBzdHJpbmc7XG59XG4iXX0=

@@ -109,4 +109,4 @@ import { Construct } from './core/construct';

*
* @param props the property bag from which a property is required.
* @param name the name of the required property.
* @param props the property bag from which a property is required.
* @param name the name of the required property.
* @param typeName the name of the construct type that requires the property

@@ -127,11 +127,11 @@ *

*
* Properties not correct for 'FunctionProps'
* codeUri: not one of the possible types
* either: properties not correct for 'S3LocationProperty'
* bucket: required but missing
* key: required but missing
* version: required but missing
* or: '3' should be a 'string'
* Properties not correct for 'FunctionProps'
* codeUri: not one of the possible types
* either: properties not correct for 'S3LocationProperty'
* bucket: required but missing
* key: required but missing
* version: required but missing
* or: '3' should be a 'string'
*
*/
export declare function unionValidator(...validators: Validator[]): Validator;

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

const childMessages = this.results.errorTreeList();
return this.errorMessage + (childMessages.length ? `\n ${childMessages.replace(/\n/g, '\n ')}` : '');
return this.errorMessage + (childMessages.length ? `\n ${childMessages.replace(/\n/g, '\n ')}` : '');
}

@@ -310,4 +310,4 @@ /**

*
* @param props the property bag from which a property is required.
* @param name the name of the required property.
* @param props the property bag from which a property is required.
* @param name the name of the required property.
* @param typeName the name of the construct type that requires the property

@@ -334,9 +334,9 @@ *

*
* Properties not correct for 'FunctionProps'
* codeUri: not one of the possible types
* either: properties not correct for 'S3LocationProperty'
* bucket: required but missing
* key: required but missing
* version: required but missing
* or: '3' should be a 'string'
* Properties not correct for 'FunctionProps'
* codeUri: not one of the possible types
* either: properties not correct for 'S3LocationProperty'
* bucket: required but missing
* key: required but missing
* version: required but missing
* or: '3' should be a 'string'
*

@@ -376,2 +376,2 @@ */

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"runtime.js","sourceRoot":"","sources":["runtime.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct } from './core/construct';\n\n// ----------------------------------------------------------------------\n// PROPERTY MAPPERS\n//\n// These are used while converting generated classes/property bags to CloudFormation property objects\n//\n// We use identity mappers for the primitive types. These don't do anything but are there to make the code\n// generation work out nicely (so the code generator doesn't need to emit different code for primitive\n// vs. complex types).\nexport type Mapper = (x: any) => any;\n\nfunction identity(x: any) {\n    return x;\n}\n\nexport const stringToCloudFormation: Mapper = identity;\nexport const booleanToCloudFormation: Mapper = identity;\nexport const objectToCloudFormation: Mapper = identity;\nexport const numberToCloudFormation: Mapper = identity;\n\n/**\n * The date needs to be formatted as an ISO date in UTC\n *\n * Some usage sites require a date, some require a timestamp. We'll\n * always output a timestamp and hope the parser on the other end\n * is smart enough to ignore the time part... (?)\n */\nexport function dateToCloudFormation(x?: Date): any {\n    if (!x) {\n        return undefined;\n    }\n\n    // tslint:disable-next-line:max-line-length\n    return `${x.getUTCFullYear()}-${pad(x.getUTCMonth() + 1)}-${pad(x.getUTCDate())}T${pad(x.getUTCHours())}:${pad(x.getUTCMinutes())}:${pad(x.getUTCSeconds())}`;\n}\n\n/**\n * Pad a number to 2 decimal places\n */\nfunction pad(x: number) {\n    if (x < 10) {\n        return \"0\" + x.toString();\n    }\n    return x.toString();\n}\n\n/**\n * Turn a tag object into the proper CloudFormation representation\n */\nexport function tagToCloudFormation(x: any): any {\n    return {\n        Key: x.key,\n        Value: x.value\n    };\n}\n\nexport function listMapper(elementMapper: Mapper): Mapper {\n    return (x: any) => {\n        if (!canInspect(x)) { return x; }\n        return x.map(elementMapper);\n    };\n}\n\nexport function hashMapper(elementMapper: Mapper): Mapper {\n    return (x: any) => {\n        if (!canInspect(x)) { return x; }\n\n        const ret: any = {};\n\n        Object.keys(x).forEach((key) => {\n            ret[key] = elementMapper(x[key]);\n        });\n\n        return ret;\n    };\n}\n\n/**\n * Return a union mapper\n *\n * Takes a list of validators and a list of mappers, which should correspond pairwise.\n *\n * The mapper of the first successful validator will be called.\n */\nexport function unionMapper(validators: Validator[], mappers: Mapper[]): Mapper {\n    if (validators.length !== mappers.length) {\n        throw Error('Not the same amount of validators and mappers passed to unionMapper()');\n    }\n\n    return (x: any) => {\n        if (!canInspect(x)) { return x; }\n\n        for (let i = 0; i < validators.length; i++) {\n            if (validators[i](x).isSuccess) {\n                return mappers[i](x);\n            }\n        }\n\n        // Should not be possible because the union must have passed validation before this function\n        // will be called, but catch it anyway.\n        throw new TypeError('No validators matched in the union()');\n    };\n}\n\n// ----------------------------------------------------------------------\n// VALIDATORS\n//\n// These are used while checking that supplied property bags match the expected schema\n//\n// We have a couple of datatypes that model validation errors and collections of validation\n// errors (together forming a tree of errors so that we can trace validation errors through\n// an object graph), and validators.\n//\n// Validators are simply functions that take a value and return a validation results. Then\n// we have some combinators to turn primitive validators into more complex validators.\n//\n\n/**\n * Representation of validation results\n *\n * Models a tree of validation errors so that we have as much information as possible\n * about the failure that occurred.\n */\nexport class ValidationResult {\n    constructor(readonly errorMessage: string = '', readonly results: ValidationResults = new ValidationResults()) {\n    }\n\n    public get isSuccess(): boolean {\n        return !this.errorMessage && this.results.isSuccess;\n    }\n\n    /**\n     * Turn a failed validation into an exception\n     */\n    public assertSuccess() {\n        if (!this.isSuccess) {\n            let message = this.errorTree();\n            // The first letter will be lowercase, so uppercase it for a nicer error message\n            message = message.substr(0, 1).toUpperCase() + message.substr(1);\n            throw new TypeError(message);\n        }\n    }\n\n    /**\n     * Return a string rendering of the tree of validation failures\n     */\n    public errorTree(): string {\n        const childMessages = this.results.errorTreeList();\n        return this.errorMessage + (childMessages.length ? `\\n    ${childMessages.replace(/\\n/g, '\\n    ')}` : '');\n    }\n\n    /**\n     * Wrap this result with an error message, if it concerns an error\n     */\n    public prefix(message: string): ValidationResult {\n        if (this.isSuccess) { return this; }\n        return new ValidationResult(`${message}: ${this.errorMessage}`, this.results);\n    }\n}\n\n/**\n * A collection of validation results\n */\nexport class ValidationResults {\n    constructor(public results: ValidationResult[] = []) {\n    }\n\n    public collect(result: ValidationResult) {\n        // Only collect failures\n        if (!result.isSuccess) {\n            this.results.push(result);\n        }\n    }\n\n    public get isSuccess(): boolean {\n        return this.results.every(x => x.isSuccess);\n    }\n\n    public errorTreeList(): string {\n        return this.results.map(child => child.errorTree()).join('\\n');\n    }\n\n    /**\n     * Wrap up all validation results into a single tree node\n     *\n     * If there are failures in the collection, add a message, otherwise\n     * return a success.\n     */\n    public wrap(message: string): ValidationResult {\n        if (this.isSuccess) { return VALIDATION_SUCCESS; }\n        return new ValidationResult(message, this);\n    }\n}\n\n// Singleton object to save on allocations\nexport const VALIDATION_SUCCESS = new ValidationResult();\n\nexport type Validator = (x: any) => ValidationResult;\n\n/**\n * Return whether this object can be validated at all\n *\n * True unless it's undefined or a CloudFormation intrinsic\n */\nexport function canInspect(x: any) {\n    // Note: using weak equality on purpose, we also want to catch undefined\n    return (x != null && !isCloudFormationIntrinsic(x));\n}\n\n// CloudFormation validators for primitive types\nexport function validateString(x: any): ValidationResult {\n    if (canInspect(x) && typeof x !== 'string') {\n        return new ValidationResult(`${JSON.stringify(x)} should be a string`);\n    }\n    return VALIDATION_SUCCESS;\n}\n\nexport function validateNumber(x: any): ValidationResult {\n    if (canInspect(x) && typeof x !== 'number') {\n        return new ValidationResult(`${JSON.stringify(x)} should be a number`);\n    }\n    return VALIDATION_SUCCESS;\n}\n\nexport function validateBoolean(x: any): ValidationResult {\n    if (canInspect(x) && typeof x !== 'boolean') {\n        return new ValidationResult(`${JSON.stringify(x)} should be a boolean`);\n    }\n    return VALIDATION_SUCCESS;\n}\n\nexport function validateDate(x: any): ValidationResult {\n    if (canInspect(x) && !(x instanceof Date)) {\n        return new ValidationResult(`${JSON.stringify(x)} should be a Date`);\n    }\n\n    if (x !== undefined && isNaN(x.getTime())) {\n        return new ValidationResult('got an unparseable Date');\n    }\n\n    return VALIDATION_SUCCESS;\n}\n\nexport function validateObject(x: any): ValidationResult {\n    if (canInspect(x) && typeof x !== 'object') {\n        return new ValidationResult(`${JSON.stringify(x)} should be an 'object'`);\n    }\n    return VALIDATION_SUCCESS;\n}\n\nexport function validateTag(x: any): ValidationResult {\n    if (!canInspect(x)) { return VALIDATION_SUCCESS; }\n\n    if (x.key == null || x.value == null) {\n        return new ValidationResult(`${JSON.stringify(x)} should have a 'key' and a 'value' property`);\n    }\n\n    return VALIDATION_SUCCESS;\n}\n\n/**\n * Return a list validator based on the given element validator\n */\nexport function listValidator(elementValidator: Validator): Validator {\n    return (x: any) => {\n        if (!canInspect(x)) { return VALIDATION_SUCCESS; }\n\n        if (!x.forEach) {\n            return new ValidationResult(`${JSON.stringify(x)} should be a list`);\n        }\n\n        for (let i = 0; i < x.length; i++) {\n            const element = x[i];\n            const result = elementValidator(element);\n            if (!result.isSuccess) { return result.prefix(`element ${i}`); }\n        }\n\n        return VALIDATION_SUCCESS;\n    };\n}\n\n/**\n * Return a hash validator based on the given element validator\n */\nexport function hashValidator(elementValidator: Validator): Validator {\n    return (x: any) => {\n        if (!canInspect(x)) { return VALIDATION_SUCCESS; }\n\n        for (const key of Object.keys(x)) {\n            const result = elementValidator(x[key]);\n            if (!result.isSuccess) { return result.prefix(`element '${key}'`); }\n        }\n\n        return VALIDATION_SUCCESS;\n    };\n}\n\n/**\n * Decorate a validator with a message clarifying the property the failure is for.\n */\nexport function propertyValidator(propName: string, validator: Validator): Validator {\n    return (x: any) => {\n        return validator(x).prefix(propName);\n    };\n}\n\n/**\n * Return a validator that will fail if the passed property is not present\n *\n * Does not distinguish between the property actually not being present, vs being present but 'null'\n * or 'undefined' (courtesy of JavaScript), which is generally the behavior that we want.\n *\n * Empty strings are considered \"present\"--don't know if this agrees with how CloudFormation looks\n * at the world.\n */\nexport function requiredValidator(x: any) {\n    if (x == null) {\n        return new ValidationResult(`required but missing`);\n    }\n    return VALIDATION_SUCCESS;\n}\n\n/**\n * Require a property from a property bag.\n *\n * @param props    the property bag from which a property is required.\n * @param name     the name of the required property.\n * @param typeName the name of the construct type that requires the property\n *\n * @returns the value of ``props[name]``\n *\n * @throws if the property ``name`` is not present in ``props``.\n */\nexport function requireProperty(props: { [name: string]: any }, name: string, context: Construct): any {\n    if (!(name in props)) {\n        throw new Error(`${context.toString()} is missing required property: ${name}`);\n    }\n    const value = props[name];\n    // Possibly add type-checking here...\n    return value;\n}\n\n/**\n * Validates if any of the given validators matches\n *\n * We add either/or words to the front of the error mesages so that they read\n * more nicely. Example:\n *\n *     Properties not correct for 'FunctionProps'\n *         codeUri: not one of the possible types\n *             either: properties not correct for 'S3LocationProperty'\n *                 bucket: required but missing\n *                 key: required but missing\n *                 version: required but missing\n *             or: '3' should be a 'string'\n *\n */\nexport function unionValidator(...validators: Validator[]): Validator {\n    return (x: any) => {\n        const results = new ValidationResults();\n        let eitherOr = 'either';\n\n        for (const validator of validators) {\n            const result = validator(x);\n            if (result.isSuccess) { return result; }\n            results.collect(result.prefix(eitherOr));\n            eitherOr = 'or';\n        }\n        return results.wrap('not one of the possible types');\n    };\n}\n\n/**\n * Return whether the indicated value represents a CloudFormation intrinsic.\n *\n * CloudFormation instrinsics are modeled as objects with a single key, which\n * look like: { \"Fn::GetAtt\": [...] } or similar.\n */\nfunction isCloudFormationIntrinsic(x: any) {\n    if (!(typeof x === 'object')) { return false; }\n    const keys = Object.keys(x);\n    if (keys.length !== 1) { return false; }\n\n    return keys[0] === 'Ref' || keys[0].substr(0, 4) === 'Fn::';\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"runtime.js","sourceRoot":"","sources":["runtime.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct } from './core/construct';\n\n// ----------------------------------------------------------------------\n// PROPERTY MAPPERS\n//\n// These are used while converting generated classes/property bags to CloudFormation property objects\n//\n// We use identity mappers for the primitive types. These don't do anything but are there to make the code\n// generation work out nicely (so the code generator doesn't need to emit different code for primitive\n// vs. complex types).\nexport type Mapper = (x: any) => any;\n\nfunction identity(x: any) {\n  return x;\n}\n\nexport const stringToCloudFormation: Mapper = identity;\nexport const booleanToCloudFormation: Mapper = identity;\nexport const objectToCloudFormation: Mapper = identity;\nexport const numberToCloudFormation: Mapper = identity;\n\n/**\n * The date needs to be formatted as an ISO date in UTC\n *\n * Some usage sites require a date, some require a timestamp. We'll\n * always output a timestamp and hope the parser on the other end\n * is smart enough to ignore the time part... (?)\n */\nexport function dateToCloudFormation(x?: Date): any {\n  if (!x) {\n    return undefined;\n  }\n\n  // tslint:disable-next-line:max-line-length\n  return `${x.getUTCFullYear()}-${pad(x.getUTCMonth() + 1)}-${pad(x.getUTCDate())}T${pad(x.getUTCHours())}:${pad(x.getUTCMinutes())}:${pad(x.getUTCSeconds())}`;\n}\n\n/**\n * Pad a number to 2 decimal places\n */\nfunction pad(x: number) {\n  if (x < 10) {\n    return \"0\" + x.toString();\n  }\n  return x.toString();\n}\n\n/**\n * Turn a tag object into the proper CloudFormation representation\n */\nexport function tagToCloudFormation(x: any): any {\n  return {\n    Key: x.key,\n    Value: x.value\n  };\n}\n\nexport function listMapper(elementMapper: Mapper): Mapper {\n  return (x: any) => {\n    if (!canInspect(x)) { return x; }\n    return x.map(elementMapper);\n  };\n}\n\nexport function hashMapper(elementMapper: Mapper): Mapper {\n  return (x: any) => {\n    if (!canInspect(x)) { return x; }\n\n    const ret: any = {};\n\n    Object.keys(x).forEach((key) => {\n      ret[key] = elementMapper(x[key]);\n    });\n\n    return ret;\n  };\n}\n\n/**\n * Return a union mapper\n *\n * Takes a list of validators and a list of mappers, which should correspond pairwise.\n *\n * The mapper of the first successful validator will be called.\n */\nexport function unionMapper(validators: Validator[], mappers: Mapper[]): Mapper {\n  if (validators.length !== mappers.length) {\n    throw Error('Not the same amount of validators and mappers passed to unionMapper()');\n  }\n\n  return (x: any) => {\n    if (!canInspect(x)) { return x; }\n\n    for (let i = 0; i < validators.length; i++) {\n      if (validators[i](x).isSuccess) {\n        return mappers[i](x);\n      }\n    }\n\n    // Should not be possible because the union must have passed validation before this function\n    // will be called, but catch it anyway.\n    throw new TypeError('No validators matched in the union()');\n  };\n}\n\n// ----------------------------------------------------------------------\n// VALIDATORS\n//\n// These are used while checking that supplied property bags match the expected schema\n//\n// We have a couple of datatypes that model validation errors and collections of validation\n// errors (together forming a tree of errors so that we can trace validation errors through\n// an object graph), and validators.\n//\n// Validators are simply functions that take a value and return a validation results. Then\n// we have some combinators to turn primitive validators into more complex validators.\n//\n\n/**\n * Representation of validation results\n *\n * Models a tree of validation errors so that we have as much information as possible\n * about the failure that occurred.\n */\nexport class ValidationResult {\n  constructor(readonly errorMessage: string = '', readonly results: ValidationResults = new ValidationResults()) {\n  }\n\n  public get isSuccess(): boolean {\n    return !this.errorMessage && this.results.isSuccess;\n  }\n\n  /**\n   * Turn a failed validation into an exception\n   */\n  public assertSuccess() {\n    if (!this.isSuccess) {\n      let message = this.errorTree();\n      // The first letter will be lowercase, so uppercase it for a nicer error message\n      message = message.substr(0, 1).toUpperCase() + message.substr(1);\n      throw new TypeError(message);\n    }\n  }\n\n  /**\n   * Return a string rendering of the tree of validation failures\n   */\n  public errorTree(): string {\n    const childMessages = this.results.errorTreeList();\n    return this.errorMessage + (childMessages.length ? `\\n  ${childMessages.replace(/\\n/g, '\\n  ')}` : '');\n  }\n\n  /**\n   * Wrap this result with an error message, if it concerns an error\n   */\n  public prefix(message: string): ValidationResult {\n    if (this.isSuccess) { return this; }\n    return new ValidationResult(`${message}: ${this.errorMessage}`, this.results);\n  }\n}\n\n/**\n * A collection of validation results\n */\nexport class ValidationResults {\n  constructor(public results: ValidationResult[] = []) {\n  }\n\n  public collect(result: ValidationResult) {\n    // Only collect failures\n    if (!result.isSuccess) {\n      this.results.push(result);\n    }\n  }\n\n  public get isSuccess(): boolean {\n    return this.results.every(x => x.isSuccess);\n  }\n\n  public errorTreeList(): string {\n    return this.results.map(child => child.errorTree()).join('\\n');\n  }\n\n  /**\n   * Wrap up all validation results into a single tree node\n   *\n   * If there are failures in the collection, add a message, otherwise\n   * return a success.\n   */\n  public wrap(message: string): ValidationResult {\n    if (this.isSuccess) { return VALIDATION_SUCCESS; }\n    return new ValidationResult(message, this);\n  }\n}\n\n// Singleton object to save on allocations\nexport const VALIDATION_SUCCESS = new ValidationResult();\n\nexport type Validator = (x: any) => ValidationResult;\n\n/**\n * Return whether this object can be validated at all\n *\n * True unless it's undefined or a CloudFormation intrinsic\n */\nexport function canInspect(x: any) {\n  // Note: using weak equality on purpose, we also want to catch undefined\n  return (x != null && !isCloudFormationIntrinsic(x));\n}\n\n// CloudFormation validators for primitive types\nexport function validateString(x: any): ValidationResult {\n  if (canInspect(x) && typeof x !== 'string') {\n    return new ValidationResult(`${JSON.stringify(x)} should be a string`);\n  }\n  return VALIDATION_SUCCESS;\n}\n\nexport function validateNumber(x: any): ValidationResult {\n  if (canInspect(x) && typeof x !== 'number') {\n    return new ValidationResult(`${JSON.stringify(x)} should be a number`);\n  }\n  return VALIDATION_SUCCESS;\n}\n\nexport function validateBoolean(x: any): ValidationResult {\n  if (canInspect(x) && typeof x !== 'boolean') {\n    return new ValidationResult(`${JSON.stringify(x)} should be a boolean`);\n  }\n  return VALIDATION_SUCCESS;\n}\n\nexport function validateDate(x: any): ValidationResult {\n  if (canInspect(x) && !(x instanceof Date)) {\n    return new ValidationResult(`${JSON.stringify(x)} should be a Date`);\n  }\n\n  if (x !== undefined && isNaN(x.getTime())) {\n    return new ValidationResult('got an unparseable Date');\n  }\n\n  return VALIDATION_SUCCESS;\n}\n\nexport function validateObject(x: any): ValidationResult {\n  if (canInspect(x) && typeof x !== 'object') {\n    return new ValidationResult(`${JSON.stringify(x)} should be an 'object'`);\n  }\n  return VALIDATION_SUCCESS;\n}\n\nexport function validateTag(x: any): ValidationResult {\n  if (!canInspect(x)) { return VALIDATION_SUCCESS; }\n\n  if (x.key == null || x.value == null) {\n    return new ValidationResult(`${JSON.stringify(x)} should have a 'key' and a 'value' property`);\n  }\n\n  return VALIDATION_SUCCESS;\n}\n\n/**\n * Return a list validator based on the given element validator\n */\nexport function listValidator(elementValidator: Validator): Validator {\n  return (x: any) => {\n    if (!canInspect(x)) { return VALIDATION_SUCCESS; }\n\n    if (!x.forEach) {\n      return new ValidationResult(`${JSON.stringify(x)} should be a list`);\n    }\n\n    for (let i = 0; i < x.length; i++) {\n      const element = x[i];\n      const result = elementValidator(element);\n      if (!result.isSuccess) { return result.prefix(`element ${i}`); }\n    }\n\n    return VALIDATION_SUCCESS;\n  };\n}\n\n/**\n * Return a hash validator based on the given element validator\n */\nexport function hashValidator(elementValidator: Validator): Validator {\n  return (x: any) => {\n    if (!canInspect(x)) { return VALIDATION_SUCCESS; }\n\n    for (const key of Object.keys(x)) {\n      const result = elementValidator(x[key]);\n      if (!result.isSuccess) { return result.prefix(`element '${key}'`); }\n    }\n\n    return VALIDATION_SUCCESS;\n  };\n}\n\n/**\n * Decorate a validator with a message clarifying the property the failure is for.\n */\nexport function propertyValidator(propName: string, validator: Validator): Validator {\n  return (x: any) => {\n    return validator(x).prefix(propName);\n  };\n}\n\n/**\n * Return a validator that will fail if the passed property is not present\n *\n * Does not distinguish between the property actually not being present, vs being present but 'null'\n * or 'undefined' (courtesy of JavaScript), which is generally the behavior that we want.\n *\n * Empty strings are considered \"present\"--don't know if this agrees with how CloudFormation looks\n * at the world.\n */\nexport function requiredValidator(x: any) {\n  if (x == null) {\n    return new ValidationResult(`required but missing`);\n  }\n  return VALIDATION_SUCCESS;\n}\n\n/**\n * Require a property from a property bag.\n *\n * @param props  the property bag from which a property is required.\n * @param name   the name of the required property.\n * @param typeName the name of the construct type that requires the property\n *\n * @returns the value of ``props[name]``\n *\n * @throws if the property ``name`` is not present in ``props``.\n */\nexport function requireProperty(props: { [name: string]: any }, name: string, context: Construct): any {\n  if (!(name in props)) {\n    throw new Error(`${context.toString()} is missing required property: ${name}`);\n  }\n  const value = props[name];\n  // Possibly add type-checking here...\n  return value;\n}\n\n/**\n * Validates if any of the given validators matches\n *\n * We add either/or words to the front of the error mesages so that they read\n * more nicely. Example:\n *\n *   Properties not correct for 'FunctionProps'\n *     codeUri: not one of the possible types\n *       either: properties not correct for 'S3LocationProperty'\n *         bucket: required but missing\n *         key: required but missing\n *         version: required but missing\n *       or: '3' should be a 'string'\n *\n */\nexport function unionValidator(...validators: Validator[]): Validator {\n  return (x: any) => {\n    const results = new ValidationResults();\n    let eitherOr = 'either';\n\n    for (const validator of validators) {\n      const result = validator(x);\n      if (result.isSuccess) { return result; }\n      results.collect(result.prefix(eitherOr));\n      eitherOr = 'or';\n    }\n    return results.wrap('not one of the possible types');\n  };\n}\n\n/**\n * Return whether the indicated value represents a CloudFormation intrinsic.\n *\n * CloudFormation instrinsics are modeled as objects with a single key, which\n * look like: { \"Fn::GetAtt\": [...] } or similar.\n */\nfunction isCloudFormationIntrinsic(x: any) {\n  if (!(typeof x === 'object')) { return false; }\n  const keys = Object.keys(x);\n  if (keys.length !== 1) { return false; }\n\n  return keys[0] === 'Ref' || keys[0].substr(0, 4) === 'Fn::';\n}\n"]}

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

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5pcXVlaWQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJ1bmlxdWVpZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLDJDQUEyQztBQUMzQyxpQ0FBa0M7QUFFbEM7Ozs7O0dBS0c7QUFDSCxNQUFNLG9CQUFvQixHQUFHLFVBQVUsQ0FBQztBQUV4Qzs7R0FFRztBQUNILE1BQU0sU0FBUyxHQUFHLFNBQVMsQ0FBQztBQUU1QixNQUFNLFFBQVEsR0FBRyxHQUFHLENBQUM7QUFFckIsTUFBTSxRQUFRLEdBQUcsQ0FBQyxDQUFDO0FBQ25CLE1BQU0sYUFBYSxHQUFHLEdBQUcsQ0FBQyxDQUFDLG9CQUFvQjtBQUUvQzs7Ozs7Ozs7R0FRRztBQUNILFNBQWdCLFlBQVksQ0FBQyxVQUFvQjtJQUM3QyxVQUFVLEdBQUcsVUFBVSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsS0FBSyxTQUFTLENBQUMsQ0FBQztJQUVyRCxJQUFJLFVBQVUsQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFO1FBQ3pCLE1BQU0sSUFBSSxLQUFLLENBQUMsZ0VBQWdFLENBQUMsQ0FBQztLQUNyRjtJQUVELDJFQUEyRTtJQUMzRSwyRUFBMkU7SUFDM0UsZ0NBQWdDO0lBQ2hDLElBQUksVUFBVSxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7UUFDekIsT0FBTyxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUM7S0FDeEI7SUFFRCxNQUFNLElBQUksR0FBRyxRQUFRLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDbEMsTUFBTSxLQUFLLEdBQUcsV0FBVyxDQUFDLFVBQVUsQ0FBQztTQUNoQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEtBQUssb0JBQW9CLENBQUM7U0FDdkMsR0FBRyxDQUFDLHFCQUFxQixDQUFDO1NBQzFCLElBQUksQ0FBQyxFQUFFLENBQUM7U0FDUixLQUFLLENBQUMsQ0FBQyxFQUFFLGFBQWEsQ0FBQyxDQUFDO0lBRTdCLE9BQU8sS0FBSyxHQUFHLElBQUksQ0FBQztBQUN4QixDQUFDO0FBdEJELG9DQXNCQztBQUVEOzs7O0dBSUc7QUFDSCxTQUFTLFFBQVEsQ0FBQyxJQUFjO0lBQzVCLE1BQU0sR0FBRyxHQUFHLE1BQU0sQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDL0UsT0FBTyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxRQUFRLENBQUMsQ0FBQyxXQUFXLEVBQUUsQ0FBQztBQUNoRCxDQUFDO0FBRUQ7O0dBRUc7QUFDSCxTQUFTLHFCQUFxQixDQUFDLENBQVM7SUFDcEMsT0FBTyxDQUFDLENBQUMsT0FBTyxDQUFDLGVBQWUsRUFBRSxFQUFFLENBQUMsQ0FBQztBQUMxQyxDQUFDO0FBRUQ7Ozs7O0dBS0c7QUFDSCxTQUFTLFdBQVcsQ0FBQyxJQUFjO0lBQy9CLE1BQU0sR0FBRyxHQUFHLElBQUksS0FBSyxFQUFVLENBQUM7SUFFaEMsS0FBSyxNQUFNLFNBQVMsSUFBSSxJQUFJLEVBQUU7UUFDMUIsSUFBSSxHQUFHLENBQUMsTUFBTSxLQUFLLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsRUFBRTtZQUM5RCxHQUFHLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1NBQ3ZCO0tBQ0o7SUFFRCxPQUFPLEdBQUcsQ0FBQztBQUNmLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyB0c2xpbnQ6ZGlzYWJsZS1uZXh0LWxpbmU6bm8tdmFyLXJlcXVpcmVzXG5pbXBvcnQgY3J5cHRvID0gcmVxdWlyZSgnY3J5cHRvJyk7XG5cbi8qKlxuICogUmVzb3VyY2VzIHdpdGggdGhpcyBJRCBhcmUgaGlkZGVuIGZyb20gaHVtYW5zXG4gKlxuICogVGhleSBkbyBub3QgYXBwZWFyIGluIHRoZSBodW1hbi1yZWFkYWJsZSBwYXJ0IG9mIHRoZSBsb2dpY2FsIElELFxuICogYnV0IHRoZXkgYXJlIGluY2x1ZGVkIGluIHRoZSBoYXNoIGNhbGN1bGF0aW9uLlxuICovXG5jb25zdCBISURERU5fRlJPTV9IVU1BTl9JRCA9ICdSZXNvdXJjZSc7XG5cbi8qKlxuICogUmVzb3VyY2VzIHdpdGggdGhpcyBJRCBhcmUgY29tcGxldGUgaGlkZGVuIGZyb20gdGhlIGxvZ2ljYWwgSUQgY2FsY3VsYXRpb24uXG4gKi9cbmNvbnN0IEhJRERFTl9JRCA9ICdEZWZhdWx0JztcblxuY29uc3QgUEFUSF9TRVAgPSAnLyc7XG5cbmNvbnN0IEhBU0hfTEVOID0gODtcbmNvbnN0IE1BWF9IVU1BTl9MRU4gPSAyNDA7IC8vIG1heCBJRCBsZW4gaXMgMjU1XG5cbi8qKlxuICogQ2FsY3VsYXRlcyBhIHVuaXF1ZSBJRCBmb3IgYSBzZXQgb2YgdGV4dHVhbCBjb21wb25lbnRzLlxuICpcbiAqIFRoaXMgaXMgZG9uZSBieSBjYWxjdWxhdGluZyBhIGhhc2ggb24gdGhlIGZ1bGwgcGF0aCBhbmQgdXNpbmcgaXQgYXMgYSBzdWZmaXhcbiAqIG9mIGEgbGVuZ3RoLWxpbWl0ZWQgXCJodW1hblwiIHJlbmRpdGlvbiBvZiB0aGUgcGF0aCBjb21wb25lbnRzLlxuICpcbiAqIEBwYXJhbSBjb21wb25lbnRzIFRoZSBwYXRoIGNvbXBvbmVudHNcbiAqIEByZXR1cm5zIGEgdW5pcXVlIGFscGhhLW51bWVyaWMgaWRlbnRpZmllciB3aXRoIGEgbWF4aW11bSBsZW5ndGggb2YgMjU1XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBtYWtlVW5pcXVlSWQoY29tcG9uZW50czogc3RyaW5nW10pIHtcbiAgICBjb21wb25lbnRzID0gY29tcG9uZW50cy5maWx0ZXIoeCA9PiB4ICE9PSBISURERU5fSUQpO1xuXG4gICAgaWYgKGNvbXBvbmVudHMubGVuZ3RoID09PSAwKSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcignVW5hYmxlIHRvIGNhbGN1bGF0ZSBhIHVuaXF1ZSBpZCBmb3IgYW4gZW1wdHkgc2V0IG9mIGNvbXBvbmVudHMnKTtcbiAgICB9XG5cbiAgICAvLyB0b3AtbGV2ZWwgcmVzb3VyY2VzIHdpbGwgc2ltcGx5IHVzZSB0aGUgYG5hbWVgIGFzLWlzIGluIG9yZGVyIHRvIHN1cHBvcnRcbiAgICAvLyB0cmFuc3BhcmVudCBtaWdyYXRpb24gb2YgY2xvdWRmb3JtYXRpb24gdGVtcGxhdGVzIHRvIHRoZSBDREsgd2l0aG91dCB0aGVcbiAgICAvLyBuZWVkIHRvIHJlbmFtZSBhbGwgcmVzb3VyY2VzLlxuICAgIGlmIChjb21wb25lbnRzLmxlbmd0aCA9PT0gMSkge1xuICAgICAgICByZXR1cm4gY29tcG9uZW50c1swXTtcbiAgICB9XG5cbiAgICBjb25zdCBoYXNoID0gcGF0aEhhc2goY29tcG9uZW50cyk7XG4gICAgY29uc3QgaHVtYW4gPSByZW1vdmVEdXBlcyhjb21wb25lbnRzKVxuICAgICAgICAuZmlsdGVyKHggPT4geCAhPT0gSElEREVOX0ZST01fSFVNQU5fSUQpXG4gICAgICAgIC5tYXAocmVtb3ZlTm9uQWxwaGFudW1lcmljKVxuICAgICAgICAuam9pbignJylcbiAgICAgICAgLnNsaWNlKDAsIE1BWF9IVU1BTl9MRU4pO1xuXG4gICAgcmV0dXJuIGh1bWFuICsgaGFzaDtcbn1cblxuLyoqXG4gKiBUYWtlIGEgaGFzaCBvZiB0aGUgZ2l2ZW4gcGF0aC5cbiAqXG4gKiBUaGUgaGFzaCBpcyBsaW1pdGVkIGluIHNpemUuXG4gKi9cbmZ1bmN0aW9uIHBhdGhIYXNoKHBhdGg6IHN0cmluZ1tdKTogc3RyaW5nIHtcbiAgICBjb25zdCBtZDUgPSBjcnlwdG8uY3JlYXRlSGFzaCgnbWQ1JykudXBkYXRlKHBhdGguam9pbihQQVRIX1NFUCkpLmRpZ2VzdChcImhleFwiKTtcbiAgICByZXR1cm4gbWQ1LnNsaWNlKDAsIEhBU0hfTEVOKS50b1VwcGVyQ2FzZSgpO1xufVxuXG4vKipcbiAqIFJlbW92ZXMgYWxsIG5vbi1hbHBoYW51bWVyaWMgY2hhcmFjdGVycyBpbiBhIHN0cmluZy5cbiAqL1xuZnVuY3Rpb24gcmVtb3ZlTm9uQWxwaGFudW1lcmljKHM6IHN0cmluZykge1xuICAgIHJldHVybiBzLnJlcGxhY2UoL1teQS1aYS16MC05XS9nLCAnJyk7XG59XG5cbi8qKlxuICogUmVtb3ZlIGR1cGxpY2F0ZSBcInRlcm1zXCIgZnJvbSB0aGUgcGF0aCBsaXN0XG4gKlxuICogSWYgdGhlIHByZXZpb3VzIHBhdGggY29tcG9uZW50IG5hbWUgZW5kcyB3aXRoIHRoaXMgY29tcG9uZW50IG5hbWUsIHNraXAgdGhlXG4gKiBjdXJyZW50IGNvbXBvbmVudC5cbiAqL1xuZnVuY3Rpb24gcmVtb3ZlRHVwZXMocGF0aDogc3RyaW5nW10pOiBzdHJpbmdbXSB7XG4gICAgY29uc3QgcmV0ID0gbmV3IEFycmF5PHN0cmluZz4oKTtcblxuICAgIGZvciAoY29uc3QgY29tcG9uZW50IG9mIHBhdGgpIHtcbiAgICAgICAgaWYgKHJldC5sZW5ndGggPT09IDAgfHwgIXJldFtyZXQubGVuZ3RoIC0gMV0uZW5kc1dpdGgoY29tcG9uZW50KSkge1xuICAgICAgICAgICAgcmV0LnB1c2goY29tcG9uZW50KTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiByZXQ7XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5pcXVlaWQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJ1bmlxdWVpZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLDJDQUEyQztBQUMzQyxpQ0FBa0M7QUFFbEM7Ozs7O0dBS0c7QUFDSCxNQUFNLG9CQUFvQixHQUFHLFVBQVUsQ0FBQztBQUV4Qzs7R0FFRztBQUNILE1BQU0sU0FBUyxHQUFHLFNBQVMsQ0FBQztBQUU1QixNQUFNLFFBQVEsR0FBRyxHQUFHLENBQUM7QUFFckIsTUFBTSxRQUFRLEdBQUcsQ0FBQyxDQUFDO0FBQ25CLE1BQU0sYUFBYSxHQUFHLEdBQUcsQ0FBQyxDQUFDLG9CQUFvQjtBQUUvQzs7Ozs7Ozs7R0FRRztBQUNILFNBQWdCLFlBQVksQ0FBQyxVQUFvQjtJQUMvQyxVQUFVLEdBQUcsVUFBVSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsS0FBSyxTQUFTLENBQUMsQ0FBQztJQUVyRCxJQUFJLFVBQVUsQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFO1FBQzNCLE1BQU0sSUFBSSxLQUFLLENBQUMsZ0VBQWdFLENBQUMsQ0FBQztLQUNuRjtJQUVELDJFQUEyRTtJQUMzRSwyRUFBMkU7SUFDM0UsZ0NBQWdDO0lBQ2hDLElBQUksVUFBVSxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7UUFDM0IsT0FBTyxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUM7S0FDdEI7SUFFRCxNQUFNLElBQUksR0FBRyxRQUFRLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDbEMsTUFBTSxLQUFLLEdBQUcsV0FBVyxDQUFDLFVBQVUsQ0FBQztTQUNsQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEtBQUssb0JBQW9CLENBQUM7U0FDdkMsR0FBRyxDQUFDLHFCQUFxQixDQUFDO1NBQzFCLElBQUksQ0FBQyxFQUFFLENBQUM7U0FDUixLQUFLLENBQUMsQ0FBQyxFQUFFLGFBQWEsQ0FBQyxDQUFDO0lBRTNCLE9BQU8sS0FBSyxHQUFHLElBQUksQ0FBQztBQUN0QixDQUFDO0FBdEJELG9DQXNCQztBQUVEOzs7O0dBSUc7QUFDSCxTQUFTLFFBQVEsQ0FBQyxJQUFjO0lBQzlCLE1BQU0sR0FBRyxHQUFHLE1BQU0sQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDL0UsT0FBTyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxRQUFRLENBQUMsQ0FBQyxXQUFXLEVBQUUsQ0FBQztBQUM5QyxDQUFDO0FBRUQ7O0dBRUc7QUFDSCxTQUFTLHFCQUFxQixDQUFDLENBQVM7SUFDdEMsT0FBTyxDQUFDLENBQUMsT0FBTyxDQUFDLGVBQWUsRUFBRSxFQUFFLENBQUMsQ0FBQztBQUN4QyxDQUFDO0FBRUQ7Ozs7O0dBS0c7QUFDSCxTQUFTLFdBQVcsQ0FBQyxJQUFjO0lBQ2pDLE1BQU0sR0FBRyxHQUFHLElBQUksS0FBSyxFQUFVLENBQUM7SUFFaEMsS0FBSyxNQUFNLFNBQVMsSUFBSSxJQUFJLEVBQUU7UUFDNUIsSUFBSSxHQUFHLENBQUMsTUFBTSxLQUFLLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsRUFBRTtZQUNoRSxHQUFHLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1NBQ3JCO0tBQ0Y7SUFFRCxPQUFPLEdBQUcsQ0FBQztBQUNiLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyB0c2xpbnQ6ZGlzYWJsZS1uZXh0LWxpbmU6bm8tdmFyLXJlcXVpcmVzXG5pbXBvcnQgY3J5cHRvID0gcmVxdWlyZSgnY3J5cHRvJyk7XG5cbi8qKlxuICogUmVzb3VyY2VzIHdpdGggdGhpcyBJRCBhcmUgaGlkZGVuIGZyb20gaHVtYW5zXG4gKlxuICogVGhleSBkbyBub3QgYXBwZWFyIGluIHRoZSBodW1hbi1yZWFkYWJsZSBwYXJ0IG9mIHRoZSBsb2dpY2FsIElELFxuICogYnV0IHRoZXkgYXJlIGluY2x1ZGVkIGluIHRoZSBoYXNoIGNhbGN1bGF0aW9uLlxuICovXG5jb25zdCBISURERU5fRlJPTV9IVU1BTl9JRCA9ICdSZXNvdXJjZSc7XG5cbi8qKlxuICogUmVzb3VyY2VzIHdpdGggdGhpcyBJRCBhcmUgY29tcGxldGUgaGlkZGVuIGZyb20gdGhlIGxvZ2ljYWwgSUQgY2FsY3VsYXRpb24uXG4gKi9cbmNvbnN0IEhJRERFTl9JRCA9ICdEZWZhdWx0JztcblxuY29uc3QgUEFUSF9TRVAgPSAnLyc7XG5cbmNvbnN0IEhBU0hfTEVOID0gODtcbmNvbnN0IE1BWF9IVU1BTl9MRU4gPSAyNDA7IC8vIG1heCBJRCBsZW4gaXMgMjU1XG5cbi8qKlxuICogQ2FsY3VsYXRlcyBhIHVuaXF1ZSBJRCBmb3IgYSBzZXQgb2YgdGV4dHVhbCBjb21wb25lbnRzLlxuICpcbiAqIFRoaXMgaXMgZG9uZSBieSBjYWxjdWxhdGluZyBhIGhhc2ggb24gdGhlIGZ1bGwgcGF0aCBhbmQgdXNpbmcgaXQgYXMgYSBzdWZmaXhcbiAqIG9mIGEgbGVuZ3RoLWxpbWl0ZWQgXCJodW1hblwiIHJlbmRpdGlvbiBvZiB0aGUgcGF0aCBjb21wb25lbnRzLlxuICpcbiAqIEBwYXJhbSBjb21wb25lbnRzIFRoZSBwYXRoIGNvbXBvbmVudHNcbiAqIEByZXR1cm5zIGEgdW5pcXVlIGFscGhhLW51bWVyaWMgaWRlbnRpZmllciB3aXRoIGEgbWF4aW11bSBsZW5ndGggb2YgMjU1XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBtYWtlVW5pcXVlSWQoY29tcG9uZW50czogc3RyaW5nW10pIHtcbiAgY29tcG9uZW50cyA9IGNvbXBvbmVudHMuZmlsdGVyKHggPT4geCAhPT0gSElEREVOX0lEKTtcblxuICBpZiAoY29tcG9uZW50cy5sZW5ndGggPT09IDApIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ1VuYWJsZSB0byBjYWxjdWxhdGUgYSB1bmlxdWUgaWQgZm9yIGFuIGVtcHR5IHNldCBvZiBjb21wb25lbnRzJyk7XG4gIH1cblxuICAvLyB0b3AtbGV2ZWwgcmVzb3VyY2VzIHdpbGwgc2ltcGx5IHVzZSB0aGUgYG5hbWVgIGFzLWlzIGluIG9yZGVyIHRvIHN1cHBvcnRcbiAgLy8gdHJhbnNwYXJlbnQgbWlncmF0aW9uIG9mIGNsb3VkZm9ybWF0aW9uIHRlbXBsYXRlcyB0byB0aGUgQ0RLIHdpdGhvdXQgdGhlXG4gIC8vIG5lZWQgdG8gcmVuYW1lIGFsbCByZXNvdXJjZXMuXG4gIGlmIChjb21wb25lbnRzLmxlbmd0aCA9PT0gMSkge1xuICAgIHJldHVybiBjb21wb25lbnRzWzBdO1xuICB9XG5cbiAgY29uc3QgaGFzaCA9IHBhdGhIYXNoKGNvbXBvbmVudHMpO1xuICBjb25zdCBodW1hbiA9IHJlbW92ZUR1cGVzKGNvbXBvbmVudHMpXG4gICAgLmZpbHRlcih4ID0+IHggIT09IEhJRERFTl9GUk9NX0hVTUFOX0lEKVxuICAgIC5tYXAocmVtb3ZlTm9uQWxwaGFudW1lcmljKVxuICAgIC5qb2luKCcnKVxuICAgIC5zbGljZSgwLCBNQVhfSFVNQU5fTEVOKTtcblxuICByZXR1cm4gaHVtYW4gKyBoYXNoO1xufVxuXG4vKipcbiAqIFRha2UgYSBoYXNoIG9mIHRoZSBnaXZlbiBwYXRoLlxuICpcbiAqIFRoZSBoYXNoIGlzIGxpbWl0ZWQgaW4gc2l6ZS5cbiAqL1xuZnVuY3Rpb24gcGF0aEhhc2gocGF0aDogc3RyaW5nW10pOiBzdHJpbmcge1xuICBjb25zdCBtZDUgPSBjcnlwdG8uY3JlYXRlSGFzaCgnbWQ1JykudXBkYXRlKHBhdGguam9pbihQQVRIX1NFUCkpLmRpZ2VzdChcImhleFwiKTtcbiAgcmV0dXJuIG1kNS5zbGljZSgwLCBIQVNIX0xFTikudG9VcHBlckNhc2UoKTtcbn1cblxuLyoqXG4gKiBSZW1vdmVzIGFsbCBub24tYWxwaGFudW1lcmljIGNoYXJhY3RlcnMgaW4gYSBzdHJpbmcuXG4gKi9cbmZ1bmN0aW9uIHJlbW92ZU5vbkFscGhhbnVtZXJpYyhzOiBzdHJpbmcpIHtcbiAgcmV0dXJuIHMucmVwbGFjZSgvW15BLVphLXowLTldL2csICcnKTtcbn1cblxuLyoqXG4gKiBSZW1vdmUgZHVwbGljYXRlIFwidGVybXNcIiBmcm9tIHRoZSBwYXRoIGxpc3RcbiAqXG4gKiBJZiB0aGUgcHJldmlvdXMgcGF0aCBjb21wb25lbnQgbmFtZSBlbmRzIHdpdGggdGhpcyBjb21wb25lbnQgbmFtZSwgc2tpcCB0aGVcbiAqIGN1cnJlbnQgY29tcG9uZW50LlxuICovXG5mdW5jdGlvbiByZW1vdmVEdXBlcyhwYXRoOiBzdHJpbmdbXSk6IHN0cmluZ1tdIHtcbiAgY29uc3QgcmV0ID0gbmV3IEFycmF5PHN0cmluZz4oKTtcblxuICBmb3IgKGNvbnN0IGNvbXBvbmVudCBvZiBwYXRoKSB7XG4gICAgaWYgKHJldC5sZW5ndGggPT09IDAgfHwgIXJldFtyZXQubGVuZ3RoIC0gMV0uZW5kc1dpdGgoY29tcG9uZW50KSkge1xuICAgICAgcmV0LnB1c2goY29tcG9uZW50KTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4gcmV0O1xufVxuIl19

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

{
"name": "@aws-cdk/cdk",
"version": "0.9.2",
"version": "0.10.0",
"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.2",
"cfn2ts": "^0.9.2",
"pkglint": "^0.9.2"
"cdk-build-tools": "^0.10.0",
"cfn2ts": "^0.10.0",
"pkglint": "^0.10.0"
},
"dependencies": {
"@aws-cdk/cx-api": "^0.9.2",
"@aws-cdk/cx-api": "^0.10.0",
"js-base64": "^2.4.5",

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

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

exports.evaluateCFN = evaluateCFN;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZhbHVhdGUtY2ZuLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiZXZhbHVhdGUtY2ZuLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUE7Ozs7R0FJRztBQUNILFNBQWdCLFdBQVcsQ0FBQyxNQUFXLEVBQUUsVUFBbUMsRUFBRTtJQUMxRSxNQUFNLFVBQVUsR0FBUTtRQUNwQixVQUFVLENBQUMsU0FBaUIsRUFBRSxJQUFjO1lBQ3hDLE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDOUMsQ0FBQztRQUVELEtBQUssQ0FBQyxTQUFpQjtZQUNuQixJQUFJLENBQUMsQ0FBQyxTQUFTLElBQUksT0FBTyxDQUFDLEVBQUU7Z0JBQ3pCLE1BQU0sSUFBSSxLQUFLLENBQUMsOEJBQThCLFNBQVMsdUJBQXVCLENBQUMsQ0FBQzthQUNuRjtZQUNELE9BQU8sT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQzlCLENBQUM7UUFFRCxZQUFZLENBQUMsU0FBaUIsRUFBRSxhQUFxQjtZQUNqRCxNQUFNLEdBQUcsR0FBRyxHQUFHLFNBQVMsSUFBSSxhQUFhLEVBQUUsQ0FBQztZQUM1QyxJQUFJLENBQUMsQ0FBQyxHQUFHLElBQUksT0FBTyxDQUFDLEVBQUU7Z0JBQ25CLE1BQU0sSUFBSSxLQUFLLENBQUMscUNBQXFDLFNBQVMsSUFBSSxhQUFhLHVCQUF1QixDQUFDLENBQUM7YUFDM0c7WUFDRCxPQUFPLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUN4QixDQUFDO0tBQ0osQ0FBQztJQUVGLE9BQU8sUUFBUSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBRXhCLFNBQVMsUUFBUSxDQUFDLEdBQVE7UUFDdEIsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUFFO1lBQ3BCLE9BQU8sR0FBRyxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsQ0FBQztTQUM1QjtRQUVELElBQUksT0FBTyxHQUFHLEtBQUssUUFBUSxFQUFFO1lBQ3pCLE1BQU0sSUFBSSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7WUFDOUIsSUFBSSxJQUFJLENBQUMsTUFBTSxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLElBQUksSUFBSSxDQUFDLENBQUMsQ0FBQyxLQUFLLEtBQUssQ0FBQyxFQUFFO2dCQUN4RSxPQUFPLGlCQUFpQixDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQzthQUNuRDtZQUVELE1BQU0sR0FBRyxHQUF5QixFQUFFLENBQUM7WUFDckMsS0FBSyxNQUFNLEdBQUcsSUFBSSxJQUFJLEVBQUU7Z0JBQ3BCLEdBQUcsQ0FBQyxHQUFHLENBQUMsR0FBRyxXQUFXLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7YUFDcEM7WUFDRCxPQUFPLEdBQUcsQ0FBQztTQUNkO1FBRUQsT0FBTyxHQUFHLENBQUM7SUFDZixDQUFDO0lBRUQsU0FBUyxpQkFBaUIsQ0FBQyxJQUFZLEVBQUUsSUFBUztRQUM5QyxJQUFJLENBQUMsQ0FBQyxJQUFJLElBQUksVUFBVSxDQUFDLEVBQUU7WUFDdkIsTUFBTSxJQUFJLEtBQUssQ0FBQyxhQUFhLElBQUkscUJBQXFCLENBQUMsQ0FBQztTQUMzRDtRQUVELElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxFQUFFO1lBQ3RCLElBQUksR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO1NBQ2pCO1FBRUQsT0FBTyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUMsS0FBSyxDQUFDLFVBQVUsRUFBRSxJQUFJLENBQUMsQ0FBQztJQUNwRCxDQUFDO0FBQ0wsQ0FBQztBQXhERCxrQ0F3REMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFNpbXBsZSBmdW5jdGlvbiB0byBldmFsdWF0ZSBDbG91ZEZvcm1hdGlvbiBpbnRyaW5zaWNzLlxuICpcbiAqIE5vdGUgdGhhdCB0aGlzIGZ1bmN0aW9uIGlzIG5vdCBwcm9kdWN0aW9uIHF1YWxpdHksIGl0IGV4aXN0cyB0byBzdXBwb3J0IHRlc3RzLlxuICovXG5leHBvcnQgZnVuY3Rpb24gZXZhbHVhdGVDRk4ob2JqZWN0OiBhbnksIGNvbnRleHQ6IHtba2V5OiBzdHJpbmddOiBzdHJpbmd9ID0ge30pOiBhbnkge1xuICAgIGNvbnN0IGludHJpbnNpY3M6IGFueSA9IHtcbiAgICAgICAgJ0ZuOjpKb2luJyhzZXBhcmF0b3I6IHN0cmluZywgYXJnczogc3RyaW5nW10pIHtcbiAgICAgICAgICAgIHJldHVybiBhcmdzLm1hcChldmFsdWF0ZSkuam9pbihzZXBhcmF0b3IpO1xuICAgICAgICB9LFxuXG4gICAgICAgICdSZWYnKGxvZ2ljYWxJZDogc3RyaW5nKSB7XG4gICAgICAgICAgICBpZiAoIShsb2dpY2FsSWQgaW4gY29udGV4dCkpIHtcbiAgICAgICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYFRyeWluZyB0byBldmFsdWF0ZSBSZWYgb2YgJyR7bG9naWNhbElkfScgYnV0IG5vdCBpbiBjb250ZXh0IWApO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgcmV0dXJuIGNvbnRleHRbbG9naWNhbElkXTtcbiAgICAgICAgfSxcblxuICAgICAgICAnRm46OkdldEF0dCcobG9naWNhbElkOiBzdHJpbmcsIGF0dHJpYnV0ZU5hbWU6IHN0cmluZykge1xuICAgICAgICAgICAgY29uc3Qga2V5ID0gYCR7bG9naWNhbElkfS4ke2F0dHJpYnV0ZU5hbWV9YDtcbiAgICAgICAgICAgIGlmICghKGtleSBpbiBjb250ZXh0KSkge1xuICAgICAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcihgVHJ5aW5nIHRvIGV2YWx1YXRlIEZuOjpHZXRBdHQgb2YgJyR7bG9naWNhbElkfS4ke2F0dHJpYnV0ZU5hbWV9JyBidXQgbm90IGluIGNvbnRleHQhYCk7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICByZXR1cm4gY29udGV4dFtrZXldO1xuICAgICAgICB9XG4gICAgfTtcblxuICAgIHJldHVybiBldmFsdWF0ZShvYmplY3QpO1xuXG4gICAgZnVuY3Rpb24gZXZhbHVhdGUob2JqOiBhbnkpOiBhbnkge1xuICAgICAgICBpZiAoQXJyYXkuaXNBcnJheShvYmopKSB7XG4gICAgICAgICAgICByZXR1cm4gb2JqLm1hcChldmFsdWF0ZSk7XG4gICAgICAgIH1cblxuICAgICAgICBpZiAodHlwZW9mIG9iaiA9PT0gJ29iamVjdCcpIHtcbiAgICAgICAgICAgIGNvbnN0IGtleXMgPSBPYmplY3Qua2V5cyhvYmopO1xuICAgICAgICAgICAgaWYgKGtleXMubGVuZ3RoID09PSAxICYmIChrZXlzWzBdLnN0YXJ0c1dpdGgoJ0ZuOjonKSB8fCBrZXlzWzBdID09PSAnUmVmJykpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gZXZhbHVhdGVJbnRyaW5zaWMoa2V5c1swXSwgb2JqW2tleXNbMF1dKTtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgY29uc3QgcmV0OiB7W2tleTogc3RyaW5nXTogYW55fSA9IHt9O1xuICAgICAgICAgICAgZm9yIChjb25zdCBrZXkgb2Yga2V5cykge1xuICAgICAgICAgICAgICAgIHJldFtrZXldID0gZXZhbHVhdGVDRk4ob2JqW2tleV0pO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgcmV0dXJuIHJldDtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiBvYmo7XG4gICAgfVxuXG4gICAgZnVuY3Rpb24gZXZhbHVhdGVJbnRyaW5zaWMobmFtZTogc3RyaW5nLCBhcmdzOiBhbnkpIHtcbiAgICAgICAgaWYgKCEobmFtZSBpbiBpbnRyaW5zaWNzKSkge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBJbnRyaW5zaWMgJHtuYW1lfSBub3Qgc3VwcG9ydGVkIGhlcmVgKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmICghQXJyYXkuaXNBcnJheShhcmdzKSkge1xuICAgICAgICAgICAgYXJncyA9IFthcmdzXTtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiBpbnRyaW5zaWNzW25hbWVdLmFwcGx5KGludHJpbnNpY3MsIGFyZ3MpO1xuICAgIH1cbn0iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZhbHVhdGUtY2ZuLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiZXZhbHVhdGUtY2ZuLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUE7Ozs7R0FJRztBQUNILFNBQWdCLFdBQVcsQ0FBQyxNQUFXLEVBQUUsVUFBbUMsRUFBRTtJQUM1RSxNQUFNLFVBQVUsR0FBUTtRQUN0QixVQUFVLENBQUMsU0FBaUIsRUFBRSxJQUFjO1lBQzFDLE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDNUMsQ0FBQztRQUVELEtBQUssQ0FBQyxTQUFpQjtZQUNyQixJQUFJLENBQUMsQ0FBQyxTQUFTLElBQUksT0FBTyxDQUFDLEVBQUU7Z0JBQzNCLE1BQU0sSUFBSSxLQUFLLENBQUMsOEJBQThCLFNBQVMsdUJBQXVCLENBQUMsQ0FBQzthQUNqRjtZQUNELE9BQU8sT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQzVCLENBQUM7UUFFRCxZQUFZLENBQUMsU0FBaUIsRUFBRSxhQUFxQjtZQUNuRCxNQUFNLEdBQUcsR0FBRyxHQUFHLFNBQVMsSUFBSSxhQUFhLEVBQUUsQ0FBQztZQUM1QyxJQUFJLENBQUMsQ0FBQyxHQUFHLElBQUksT0FBTyxDQUFDLEVBQUU7Z0JBQ3JCLE1BQU0sSUFBSSxLQUFLLENBQUMscUNBQXFDLFNBQVMsSUFBSSxhQUFhLHVCQUF1QixDQUFDLENBQUM7YUFDekc7WUFDRCxPQUFPLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUN0QixDQUFDO0tBQ0YsQ0FBQztJQUVGLE9BQU8sUUFBUSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBRXhCLFNBQVMsUUFBUSxDQUFDLEdBQVE7UUFDeEIsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUFFO1lBQ3RCLE9BQU8sR0FBRyxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsQ0FBQztTQUMxQjtRQUVELElBQUksT0FBTyxHQUFHLEtBQUssUUFBUSxFQUFFO1lBQzNCLE1BQU0sSUFBSSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7WUFDOUIsSUFBSSxJQUFJLENBQUMsTUFBTSxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLElBQUksSUFBSSxDQUFDLENBQUMsQ0FBQyxLQUFLLEtBQUssQ0FBQyxFQUFFO2dCQUMxRSxPQUFPLGlCQUFpQixDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQzthQUNqRDtZQUVELE1BQU0sR0FBRyxHQUF5QixFQUFFLENBQUM7WUFDckMsS0FBSyxNQUFNLEdBQUcsSUFBSSxJQUFJLEVBQUU7Z0JBQ3RCLEdBQUcsQ0FBQyxHQUFHLENBQUMsR0FBRyxXQUFXLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7YUFDbEM7WUFDRCxPQUFPLEdBQUcsQ0FBQztTQUNaO1FBRUQsT0FBTyxHQUFHLENBQUM7SUFDYixDQUFDO0lBRUQsU0FBUyxpQkFBaUIsQ0FBQyxJQUFZLEVBQUUsSUFBUztRQUNoRCxJQUFJLENBQUMsQ0FBQyxJQUFJLElBQUksVUFBVSxDQUFDLEVBQUU7WUFDekIsTUFBTSxJQUFJLEtBQUssQ0FBQyxhQUFhLElBQUkscUJBQXFCLENBQUMsQ0FBQztTQUN6RDtRQUVELElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxFQUFFO1lBQ3hCLElBQUksR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO1NBQ2Y7UUFFRCxPQUFPLFVBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxLQUFLLENBQUMsVUFBVSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQ2xELENBQUM7QUFDSCxDQUFDO0FBeERELGtDQXdEQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogU2ltcGxlIGZ1bmN0aW9uIHRvIGV2YWx1YXRlIENsb3VkRm9ybWF0aW9uIGludHJpbnNpY3MuXG4gKlxuICogTm90ZSB0aGF0IHRoaXMgZnVuY3Rpb24gaXMgbm90IHByb2R1Y3Rpb24gcXVhbGl0eSwgaXQgZXhpc3RzIHRvIHN1cHBvcnQgdGVzdHMuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBldmFsdWF0ZUNGTihvYmplY3Q6IGFueSwgY29udGV4dDoge1trZXk6IHN0cmluZ106IHN0cmluZ30gPSB7fSk6IGFueSB7XG4gIGNvbnN0IGludHJpbnNpY3M6IGFueSA9IHtcbiAgICAnRm46OkpvaW4nKHNlcGFyYXRvcjogc3RyaW5nLCBhcmdzOiBzdHJpbmdbXSkge1xuICAgICAgcmV0dXJuIGFyZ3MubWFwKGV2YWx1YXRlKS5qb2luKHNlcGFyYXRvcik7XG4gICAgfSxcblxuICAgICdSZWYnKGxvZ2ljYWxJZDogc3RyaW5nKSB7XG4gICAgICBpZiAoIShsb2dpY2FsSWQgaW4gY29udGV4dCkpIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBUcnlpbmcgdG8gZXZhbHVhdGUgUmVmIG9mICcke2xvZ2ljYWxJZH0nIGJ1dCBub3QgaW4gY29udGV4dCFgKTtcbiAgICAgIH1cbiAgICAgIHJldHVybiBjb250ZXh0W2xvZ2ljYWxJZF07XG4gICAgfSxcblxuICAgICdGbjo6R2V0QXR0Jyhsb2dpY2FsSWQ6IHN0cmluZywgYXR0cmlidXRlTmFtZTogc3RyaW5nKSB7XG4gICAgICBjb25zdCBrZXkgPSBgJHtsb2dpY2FsSWR9LiR7YXR0cmlidXRlTmFtZX1gO1xuICAgICAgaWYgKCEoa2V5IGluIGNvbnRleHQpKSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcihgVHJ5aW5nIHRvIGV2YWx1YXRlIEZuOjpHZXRBdHQgb2YgJyR7bG9naWNhbElkfS4ke2F0dHJpYnV0ZU5hbWV9JyBidXQgbm90IGluIGNvbnRleHQhYCk7XG4gICAgICB9XG4gICAgICByZXR1cm4gY29udGV4dFtrZXldO1xuICAgIH1cbiAgfTtcblxuICByZXR1cm4gZXZhbHVhdGUob2JqZWN0KTtcblxuICBmdW5jdGlvbiBldmFsdWF0ZShvYmo6IGFueSk6IGFueSB7XG4gICAgaWYgKEFycmF5LmlzQXJyYXkob2JqKSkge1xuICAgICAgcmV0dXJuIG9iai5tYXAoZXZhbHVhdGUpO1xuICAgIH1cblxuICAgIGlmICh0eXBlb2Ygb2JqID09PSAnb2JqZWN0Jykge1xuICAgICAgY29uc3Qga2V5cyA9IE9iamVjdC5rZXlzKG9iaik7XG4gICAgICBpZiAoa2V5cy5sZW5ndGggPT09IDEgJiYgKGtleXNbMF0uc3RhcnRzV2l0aCgnRm46OicpIHx8IGtleXNbMF0gPT09ICdSZWYnKSkge1xuICAgICAgICByZXR1cm4gZXZhbHVhdGVJbnRyaW5zaWMoa2V5c1swXSwgb2JqW2tleXNbMF1dKTtcbiAgICAgIH1cblxuICAgICAgY29uc3QgcmV0OiB7W2tleTogc3RyaW5nXTogYW55fSA9IHt9O1xuICAgICAgZm9yIChjb25zdCBrZXkgb2Yga2V5cykge1xuICAgICAgICByZXRba2V5XSA9IGV2YWx1YXRlQ0ZOKG9ialtrZXldKTtcbiAgICAgIH1cbiAgICAgIHJldHVybiByZXQ7XG4gICAgfVxuXG4gICAgcmV0dXJuIG9iajtcbiAgfVxuXG4gIGZ1bmN0aW9uIGV2YWx1YXRlSW50cmluc2ljKG5hbWU6IHN0cmluZywgYXJnczogYW55KSB7XG4gICAgaWYgKCEobmFtZSBpbiBpbnRyaW5zaWNzKSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBJbnRyaW5zaWMgJHtuYW1lfSBub3Qgc3VwcG9ydGVkIGhlcmVgKTtcbiAgICB9XG5cbiAgICBpZiAoIUFycmF5LmlzQXJyYXkoYXJncykpIHtcbiAgICAgIGFyZ3MgPSBbYXJnc107XG4gICAgfVxuXG4gICAgcmV0dXJuIGludHJpbnNpY3NbbmFtZV0uYXBwbHkoaW50cmluc2ljcywgYXJncyk7XG4gIH1cbn1cbiJdfQ==

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

};
//# 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};"]}
//# 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};\n"]}

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

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.cloudformation-json.js","sourceRoot":"","sources":["test.cloudformation-json.ts"],"names":[],"mappings":"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","sourcesContent":["import { Test } from 'nodeunit';\nimport { CloudFormationJSON, CloudFormationToken, FnConcat, resolve, Token } from '../../lib';\nimport { evaluateCFN } from './evaluate-cfn';\n\nexport = {\n    'plain JSON.stringify() on a Token fails'(test: Test) {\n        // GIVEN\n        const token = new Token(() => 'value');\n\n        // WHEN\n        test.throws(() => {\n            JSON.stringify({ token });\n        });\n\n        test.done();\n    },\n\n    'string tokens can be JSONified and JSONification can be reversed'(test: Test) {\n        for (const token of tokensThatResolveTo('woof woof')) {\n            // GIVEN\n            const fido = { name: 'Fido', speaks: token };\n\n            // WHEN\n            const resolved = resolve(CloudFormationJSON.stringify(fido));\n\n            // THEN\n            test.deepEqual(evaluateCFN(resolved), '{\"name\":\"Fido\",\"speaks\":\"woof woof\"}');\n        }\n\n        test.done();\n    },\n\n    'string tokens can be embedded while being JSONified'(test: Test) {\n        for (const token of tokensThatResolveTo('woof woof')) {\n            // GIVEN\n            const fido = { name: 'Fido', speaks: `deep ${token}` };\n\n            // WHEN\n            const resolved = resolve(CloudFormationJSON.stringify(fido));\n\n            // THEN\n            test.deepEqual(evaluateCFN(resolved), '{\"name\":\"Fido\",\"speaks\":\"deep woof woof\"}');\n        }\n\n        test.done();\n    },\n\n    'integer Tokens behave correctly in stringification and JSONification'(test: Test) {\n        // GIVEN\n        const num = new Token(() => 1);\n        const embedded = `the number is ${num}`;\n\n        // WHEN\n        test.equal(evaluateCFN(resolve(embedded)), \"the number is 1\");\n        test.equal(evaluateCFN(resolve(CloudFormationJSON.stringify({ embedded }))), \"{\\\"embedded\\\":\\\"the number is 1\\\"}\");\n        test.equal(evaluateCFN(resolve(CloudFormationJSON.stringify({ num }))), \"{\\\"num\\\":1}\");\n\n        test.done();\n    },\n\n    'tokens in strings survive additional TokenJSON.stringification()'(test: Test) {\n        // GIVEN\n        for (const token of tokensThatResolveTo('pong!')) {\n            // WHEN\n            const stringified = CloudFormationJSON.stringify(`ping? ${token}`);\n\n            // THEN\n            test.equal(evaluateCFN(resolve(stringified)), '\"ping? pong!\"');\n        }\n\n        test.done();\n    },\n\n    'intrinsic Tokens embed correctly in JSONification'(test: Test) {\n        // GIVEN\n        const bucketName = new CloudFormationToken({ Ref: 'MyBucket' });\n\n        // WHEN\n        const resolved = resolve(CloudFormationJSON.stringify({ theBucket: bucketName }));\n\n        // THEN\n        const context = {MyBucket: 'TheName'};\n        test.equal(evaluateCFN(resolved, context), '{\"theBucket\":\"TheName\"}');\n\n        test.done();\n    },\n\n    'embedded string literals in intrinsics are escaped when calling TokenJSON.stringify()'(test: Test) {\n        // WHEN\n        const token = new FnConcat('Hello', 'This\\nIs', 'Very \"cool\"');\n\n        // WHEN\n        const resolved = resolve(CloudFormationJSON.stringify({\n            literal: 'I can also \"contain\" quotes',\n            token\n        }));\n\n        // THEN\n        const expected = '{\"literal\":\"I can also \\\\\"contain\\\\\" quotes\",\"token\":\"HelloThis\\\\nIsVery \\\\\"cool\\\\\"\"}';\n        test.equal(evaluateCFN(resolved), expected);\n\n        test.done();\n    },\n\n    'Tokens in Tokens are handled correctly'(test: Test) {\n        // GIVEN\n        const bucketName = new CloudFormationToken({ Ref: 'MyBucket' });\n        const combinedName = new FnConcat('The bucket name is ', bucketName);\n\n        // WHEN\n        const resolved = resolve(CloudFormationJSON.stringify({ theBucket: combinedName }));\n\n        // THEN\n        const context = {MyBucket: 'TheName'};\n        test.equal(evaluateCFN(resolved, context), '{\"theBucket\":\"The bucket name is TheName\"}');\n\n        test.done();\n    },\n\n    'Doubly nested strings evaluate correctly in JSON context'(test: Test) {\n        // WHEN\n        const fidoSays = new Token(() => 'woof');\n\n        // WHEN\n        const resolved = resolve(CloudFormationJSON.stringify({\n            information: `Did you know that Fido says: ${fidoSays}`\n        }));\n\n        // THEN\n        test.deepEqual(evaluateCFN(resolved), '{\"information\":\"Did you know that Fido says: woof\"}');\n\n        test.done();\n    },\n\n    'Doubly nested intrinsics evaluate correctly in JSON context'(test: Test) {\n        // WHEN\n        const fidoSays = new CloudFormationToken(() => ({ Ref: 'Something' }));\n\n        // WHEN\n        const resolved = resolve(CloudFormationJSON.stringify({\n            information: `Did you know that Fido says: ${fidoSays}`\n        }));\n\n        // THEN\n        const context = {Something: 'woof woof'};\n        test.deepEqual(evaluateCFN(resolved, context), '{\"information\":\"Did you know that Fido says: woof woof\"}');\n\n        test.done();\n    },\n\n    'Quoted strings in embedded JSON context are escaped'(test: Test) {\n        // WHEN\n        const fidoSays = new Token(() => '\"woof\"');\n\n        // WHEN\n        const resolved = resolve(CloudFormationJSON.stringify({\n            information: `Did you know that Fido says: ${fidoSays}`\n        }));\n\n        // THEN\n        test.deepEqual(evaluateCFN(resolved), '{\"information\":\"Did you know that Fido says: \\\\\"woof\\\\\"\"}');\n\n        test.done();\n    },\n};\n\n/**\n * Return two Tokens, one of which evaluates to a Token directly, one which evaluates to it lazily\n */\nfunction tokensThatResolveTo(value: any): Token[] {\n    return [\n        new Token(value),\n        new Token(() => value)\n    ];\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.cloudformation-json.js","sourceRoot":"","sources":["test.cloudformation-json.ts"],"names":[],"mappings":"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","sourcesContent":["import { Test } from 'nodeunit';\nimport { CloudFormationJSON, CloudFormationToken, FnConcat, resolve, Token } from '../../lib';\nimport { evaluateCFN } from './evaluate-cfn';\n\nexport = {\n  'plain JSON.stringify() on a Token fails'(test: Test) {\n    // GIVEN\n    const token = new Token(() => 'value');\n\n    // WHEN\n    test.throws(() => {\n      JSON.stringify({ token });\n    });\n\n    test.done();\n  },\n\n  'string tokens can be JSONified and JSONification can be reversed'(test: Test) {\n    for (const token of tokensThatResolveTo('woof woof')) {\n      // GIVEN\n      const fido = { name: 'Fido', speaks: token };\n\n      // WHEN\n      const resolved = resolve(CloudFormationJSON.stringify(fido));\n\n      // THEN\n      test.deepEqual(evaluateCFN(resolved), '{\"name\":\"Fido\",\"speaks\":\"woof woof\"}');\n    }\n\n    test.done();\n  },\n\n  'string tokens can be embedded while being JSONified'(test: Test) {\n    for (const token of tokensThatResolveTo('woof woof')) {\n      // GIVEN\n      const fido = { name: 'Fido', speaks: `deep ${token}` };\n\n      // WHEN\n      const resolved = resolve(CloudFormationJSON.stringify(fido));\n\n      // THEN\n      test.deepEqual(evaluateCFN(resolved), '{\"name\":\"Fido\",\"speaks\":\"deep woof woof\"}');\n    }\n\n    test.done();\n  },\n\n  'integer Tokens behave correctly in stringification and JSONification'(test: Test) {\n    // GIVEN\n    const num = new Token(() => 1);\n    const embedded = `the number is ${num}`;\n\n    // WHEN\n    test.equal(evaluateCFN(resolve(embedded)), \"the number is 1\");\n    test.equal(evaluateCFN(resolve(CloudFormationJSON.stringify({ embedded }))), \"{\\\"embedded\\\":\\\"the number is 1\\\"}\");\n    test.equal(evaluateCFN(resolve(CloudFormationJSON.stringify({ num }))), \"{\\\"num\\\":1}\");\n\n    test.done();\n  },\n\n  'tokens in strings survive additional TokenJSON.stringification()'(test: Test) {\n    // GIVEN\n    for (const token of tokensThatResolveTo('pong!')) {\n      // WHEN\n      const stringified = CloudFormationJSON.stringify(`ping? ${token}`);\n\n      // THEN\n      test.equal(evaluateCFN(resolve(stringified)), '\"ping? pong!\"');\n    }\n\n    test.done();\n  },\n\n  'intrinsic Tokens embed correctly in JSONification'(test: Test) {\n    // GIVEN\n    const bucketName = new CloudFormationToken({ Ref: 'MyBucket' });\n\n    // WHEN\n    const resolved = resolve(CloudFormationJSON.stringify({ theBucket: bucketName }));\n\n    // THEN\n    const context = {MyBucket: 'TheName'};\n    test.equal(evaluateCFN(resolved, context), '{\"theBucket\":\"TheName\"}');\n\n    test.done();\n  },\n\n  'embedded string literals in intrinsics are escaped when calling TokenJSON.stringify()'(test: Test) {\n    // WHEN\n    const token = new FnConcat('Hello', 'This\\nIs', 'Very \"cool\"');\n\n    // WHEN\n    const resolved = resolve(CloudFormationJSON.stringify({\n      literal: 'I can also \"contain\" quotes',\n      token\n    }));\n\n    // THEN\n    const expected = '{\"literal\":\"I can also \\\\\"contain\\\\\" quotes\",\"token\":\"HelloThis\\\\nIsVery \\\\\"cool\\\\\"\"}';\n    test.equal(evaluateCFN(resolved), expected);\n\n    test.done();\n  },\n\n  'Tokens in Tokens are handled correctly'(test: Test) {\n    // GIVEN\n    const bucketName = new CloudFormationToken({ Ref: 'MyBucket' });\n    const combinedName = new FnConcat('The bucket name is ', bucketName);\n\n    // WHEN\n    const resolved = resolve(CloudFormationJSON.stringify({ theBucket: combinedName }));\n\n    // THEN\n    const context = {MyBucket: 'TheName'};\n    test.equal(evaluateCFN(resolved, context), '{\"theBucket\":\"The bucket name is TheName\"}');\n\n    test.done();\n  },\n\n  'Doubly nested strings evaluate correctly in JSON context'(test: Test) {\n    // WHEN\n    const fidoSays = new Token(() => 'woof');\n\n    // WHEN\n    const resolved = resolve(CloudFormationJSON.stringify({\n      information: `Did you know that Fido says: ${fidoSays}`\n    }));\n\n    // THEN\n    test.deepEqual(evaluateCFN(resolved), '{\"information\":\"Did you know that Fido says: woof\"}');\n\n    test.done();\n  },\n\n  'Doubly nested intrinsics evaluate correctly in JSON context'(test: Test) {\n    // WHEN\n    const fidoSays = new CloudFormationToken(() => ({ Ref: 'Something' }));\n\n    // WHEN\n    const resolved = resolve(CloudFormationJSON.stringify({\n      information: `Did you know that Fido says: ${fidoSays}`\n    }));\n\n    // THEN\n    const context = {Something: 'woof woof'};\n    test.deepEqual(evaluateCFN(resolved, context), '{\"information\":\"Did you know that Fido says: woof woof\"}');\n\n    test.done();\n  },\n\n  'Quoted strings in embedded JSON context are escaped'(test: Test) {\n    // WHEN\n    const fidoSays = new Token(() => '\"woof\"');\n\n    // WHEN\n    const resolved = resolve(CloudFormationJSON.stringify({\n      information: `Did you know that Fido says: ${fidoSays}`\n    }));\n\n    // THEN\n    test.deepEqual(evaluateCFN(resolved), '{\"information\":\"Did you know that Fido says: \\\\\"woof\\\\\"\"}');\n\n    test.done();\n  },\n};\n\n/**\n * Return two Tokens, one of which evaluates to a Token directly, one which evaluates to it lazily\n */\nfunction tokensThatResolveTo(value: any): Token[] {\n  return [\n    new Token(value),\n    new Token(() => value)\n  ];\n}\n"]}

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

});
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5mbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInRlc3QuZm4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLHFDQUFzQztBQUN0QyxrREFBbUQ7QUFFbkQsaUJBQVMsUUFBUSxDQUFDLFFBQVEsQ0FBQztJQUN2QixVQUFVLEVBQUU7UUFDUix5Q0FBeUMsQ0FBQyxJQUFtQjtZQUN6RCxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksRUFBRSxDQUFDLE1BQU0sQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQztZQUMxQyxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDaEIsQ0FBQztLQUNKO0NBQ0osQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IG5vZGV1bml0ID0gcmVxdWlyZSgnbm9kZXVuaXQnKTtcbmltcG9ydCBmbiA9IHJlcXVpcmUoJy4uLy4uL2xpYi9jbG91ZGZvcm1hdGlvbi9mbicpO1xuXG5leHBvcnQgPSBub2RldW5pdC50ZXN0Q2FzZSh7XG4gICAgJ0ZuOjpKb2luJzoge1xuICAgICAgICAncmVqZWN0cyBlbXB0eSBsaXN0IG9mIGFyZ3VtZW50cyB0byBqb2luJyh0ZXN0OiBub2RldW5pdC5UZXN0KSB7XG4gICAgICAgICAgICB0ZXN0LnRocm93cygoKSA9PiBuZXcgZm4uRm5Kb2luKCcuJywgW10pKTtcbiAgICAgICAgICAgIHRlc3QuZG9uZSgpO1xuICAgICAgICB9XG4gICAgfVxufSk7XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5mbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInRlc3QuZm4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLHFDQUFzQztBQUN0QyxrREFBbUQ7QUFFbkQsaUJBQVMsUUFBUSxDQUFDLFFBQVEsQ0FBQztJQUN6QixVQUFVLEVBQUU7UUFDVix5Q0FBeUMsQ0FBQyxJQUFtQjtZQUMzRCxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksRUFBRSxDQUFDLE1BQU0sQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQztZQUMxQyxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDZCxDQUFDO0tBQ0Y7Q0FDRixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgbm9kZXVuaXQgPSByZXF1aXJlKCdub2RldW5pdCcpO1xuaW1wb3J0IGZuID0gcmVxdWlyZSgnLi4vLi4vbGliL2Nsb3VkZm9ybWF0aW9uL2ZuJyk7XG5cbmV4cG9ydCA9IG5vZGV1bml0LnRlc3RDYXNlKHtcbiAgJ0ZuOjpKb2luJzoge1xuICAgICdyZWplY3RzIGVtcHR5IGxpc3Qgb2YgYXJndW1lbnRzIHRvIGpvaW4nKHRlc3Q6IG5vZGV1bml0LlRlc3QpIHtcbiAgICAgIHRlc3QudGhyb3dzKCgpID0+IG5ldyBmbi5GbkpvaW4oJy4nLCBbXSkpO1xuICAgICAgdGVzdC5kb25lKCk7XG4gICAgfVxuICB9XG59KTtcbiJdfQ==

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

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.include.js","sourceRoot":"","sources":["test.include.ts"],"names":[],"mappings":"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","sourcesContent":["import { Test } from 'nodeunit';\nimport { Include, Output, Parameter, Resource, Stack } from '../../lib';\n\nexport = {\n    'the Include construct can be used to embed an existing template as-is into a stack'(test: Test) {\n        const stack = new Stack();\n\n        new Include(stack, 'T1', { template: clone(template) });\n\n        test.deepEqual(stack.toCloudFormation(), {\n            Parameters: { MyParam: { Type: 'String', Default: 'Hello' } },\n            Resources: {\n                MyResource1: { Type: 'ResourceType1', Properties: { P1: 1, P2: 2 } },\n                MyResource2: { Type: 'ResourceType2' } } });\n\n        test.done();\n    },\n\n    'included templates can co-exist with elements created programmatically'(test: Test) {\n        const stack = new Stack();\n\n        new Include(stack, 'T1', { template: clone(template) });\n        new Resource(stack, 'MyResource3', { type: 'ResourceType3', properties: { P3: 'Hello' } });\n        new Output(stack, 'MyOutput', { description: 'Out!', disableExport: true });\n        new Parameter(stack, 'MyParam2', { type: 'Integer' });\n\n        test.deepEqual(stack.toCloudFormation(), {\n            Parameters: {\n                MyParam: { Type: 'String', Default: 'Hello' },\n                MyParam2: { Type: 'Integer' } },\n            Resources: {\n                MyResource1: { Type: 'ResourceType1', Properties: { P1: 1, P2: 2 } },\n                MyResource2: { Type: 'ResourceType2' },\n                MyResource3: { Type: 'ResourceType3', Properties: { P3: 'Hello' } } },\n           Outputs: {\n               MyOutput: { Description: 'Out!' } } });\n\n        test.done();\n    },\n\n    'exception is thrown in construction if an entity from an included template has the same id as a programmatic entity'(test: Test) {\n        const stack = new Stack();\n\n        new Include(stack, 'T1', { template });\n        new Resource(stack, 'MyResource3', { type: 'ResourceType3', properties: { P3: 'Hello' } });\n        new Output(stack, 'MyOutput', { description: 'Out!' });\n        new Parameter(stack, 'MyParam', { type: 'Integer' }); // duplicate!\n\n        test.throws(() => stack.toCloudFormation());\n        test.done();\n    },\n};\n\nconst template = {\n    Parameters: {\n        MyParam: {\n            Type: 'String',\n            Default: 'Hello'\n        }\n    },\n    Resources: {\n        MyResource1: {\n            Type: 'ResourceType1',\n            Properties: {\n                P1: 1,\n                P2: 2,\n            }\n        },\n        MyResource2: {\n            Type: 'ResourceType2'\n        }\n    }\n};\n\n/**\n * @param obj an object to clone\n * @returns a deep clone of ``obj`.\n */\nfunction clone(obj: any): any {\n    switch (typeof obj) {\n    case 'object':\n        if (Array.isArray(obj)) {\n            return obj.map(elt => clone(elt));\n        } else {\n            const cloned: any = {};\n            for (const key of Object.keys(obj)) {\n                cloned[key] = clone(obj[key]);\n            }\n            return cloned;\n        }\n    default:\n        return obj;\n    }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5pbmNsdWRlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsidGVzdC5pbmNsdWRlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFDQSxtQ0FBd0U7QUFvRHhFLE1BQU0sUUFBUSxHQUFHO0lBQ2YsVUFBVSxFQUFFO1FBQ1YsT0FBTyxFQUFFO1lBQ1AsSUFBSSxFQUFFLFFBQVE7WUFDZCxPQUFPLEVBQUUsT0FBTztTQUNqQjtLQUNGO0lBQ0QsU0FBUyxFQUFFO1FBQ1QsV0FBVyxFQUFFO1lBQ1gsSUFBSSxFQUFFLGVBQWU7WUFDckIsVUFBVSxFQUFFO2dCQUNWLEVBQUUsRUFBRSxDQUFDO2dCQUNMLEVBQUUsRUFBRSxDQUFDO2FBQ047U0FDRjtRQUNELFdBQVcsRUFBRTtZQUNYLElBQUksRUFBRSxlQUFlO1NBQ3RCO0tBQ0Y7Q0FDRixDQUFDO0FBRUY7OztHQUdHO0FBQ0gsU0FBUyxLQUFLLENBQUMsR0FBUTtJQUNyQixRQUFRLE9BQU8sR0FBRyxFQUFFO1FBQ3BCLEtBQUssUUFBUTtZQUNYLElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRTtnQkFDdEIsT0FBTyxHQUFHLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7YUFDbkM7aUJBQU07Z0JBQ0wsTUFBTSxNQUFNLEdBQVEsRUFBRSxDQUFDO2dCQUN2QixLQUFLLE1BQU0sR0FBRyxJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUU7b0JBQ2xDLE1BQU0sQ0FBQyxHQUFHLENBQUMsR0FBRyxLQUFLLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7aUJBQy9CO2dCQUNELE9BQU8sTUFBTSxDQUFDO2FBQ2Y7UUFDSDtZQUNFLE9BQU8sR0FBRyxDQUFDO0tBQ1o7QUFDSCxDQUFDO0FBMUZELGlCQUFTO0lBQ1Asb0ZBQW9GLENBQUMsSUFBVTtRQUM3RixNQUFNLEtB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QUssRUFBRSxTQUFTLEVBQUUsRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLENBQUMsQ0FBQyxDQUFDLGFBQWE7UUFFbkUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLEVBQUUsQ0FBQyxLQUFLLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxDQUFDO1FBQzVDLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNkLENBQUM7Q0FDRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGVzdCB9IGZyb20gJ25vZGV1bml0JztcbmltcG9ydCB7IEluY2x1ZGUsIE91dHB1dCwgUGFyYW1ldGVyLCBSZXNvdXJjZSwgU3RhY2sgfSBmcm9tICcuLi8uLi9saWInO1xuXG5leHBvcnQgPSB7XG4gICd0aGUgSW5jbHVkZSBjb25zdHJ1Y3QgY2FuIGJlIHVzZWQgdG8gZW1iZWQgYW4gZXhpc3RpbmcgdGVtcGxhdGUgYXMtaXMgaW50byBhIHN0YWNrJyh0ZXN0OiBUZXN0KSB7XG4gICAgY29uc3Qgc3RhY2sgPSBuZXcgU3RhY2soKTtcblxuICAgIG5ldyBJbmNsdWRlKHN0YWNrLCAnVDEnLCB7IHRlbXBsYXRlOiBjbG9uZSh0ZW1wbGF0ZSkgfSk7XG5cbiAgICB0ZXN0LmRlZXBFcXVhbChzdGFjay50b0Nsb3VkRm9ybWF0aW9uKCksIHtcbiAgICAgIFBhcmFtZXRlcnM6IHsgTXlQYXJhbTogeyBUeXBlOiAnU3RyaW5nJywgRGVmYXVsdDogJ0hlbGxvJyB9IH0sXG4gICAgICBSZXNvdXJjZXM6IHtcbiAgICAgICAgTXlSZXNvdXJjZTE6IHsgVHlwZTogJ1Jlc291cmNlVHlwZTEnLCBQcm9wZXJ0aWVzOiB7IFAxOiAxLCBQMjogMiB9IH0sXG4gICAgICAgIE15UmVzb3VyY2UyOiB7IFR5cGU6ICdSZXNvdXJjZVR5cGUyJyB9IH0gfSk7XG5cbiAgICB0ZXN0LmRvbmUoKTtcbiAgfSxcblxuICAnaW5jbHVkZWQgdGVtcGxhdGVzIGNhbiBjby1leGlzdCB3aXRoIGVsZW1lbnRzIGNyZWF0ZWQgcHJvZ3JhbW1hdGljYWxseScodGVzdDogVGVzdCkge1xuICAgIGNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKCk7XG5cbiAgICBuZXcgSW5jbHVkZShzdGFjaywgJ1QxJywgeyB0ZW1wbGF0ZTogY2xvbmUodGVtcGxhdGUpIH0pO1xuICAgIG5ldyBSZXNvdXJjZShzdGFjaywgJ015UmVzb3VyY2UzJywgeyB0eXBlOiAnUmVzb3VyY2VUeXBlMycsIHByb3BlcnRpZXM6IHsgUDM6ICdIZWxsbycgfSB9KTtcbiAgICBuZXcgT3V0cHV0KHN0YWNrLCAnTXlPdXRwdXQnLCB7IGRlc2NyaXB0aW9uOiAnT3V0IScsIGRpc2FibGVFeHBvcnQ6IHRydWUgfSk7XG4gICAgbmV3IFBhcmFtZXRlcihzdGFjaywgJ015UGFyYW0yJywgeyB0eXBlOiAnSW50ZWdlcicgfSk7XG5cbiAgICB0ZXN0LmRlZXBFcXVhbChzdGFjay50b0Nsb3VkRm9ybWF0aW9uKCksIHtcbiAgICAgIFBhcmFtZXRlcnM6IHtcbiAgICAgICAgTXlQYXJhbTogeyBUeXBlOiAnU3RyaW5nJywgRGVmYXVsdDogJ0hlbGxvJyB9LFxuICAgICAgICBNeVBhcmFtMjogeyBUeXBlOiAnSW50ZWdlcicgfSB9LFxuICAgICAgUmVzb3VyY2VzOiB7XG4gICAgICAgIE15UmVzb3VyY2UxOiB7IFR5cGU6ICdSZXNvdXJjZVR5cGUxJywgUHJvcGVydGllczogeyBQMTogMSwgUDI6IDIgfSB9LFxuICAgICAgICBNeVJlc291cmNlMjogeyBUeXBlOiAnUmVzb3VyY2VUeXBlMicgfSxcbiAgICAgICAgTXlSZXNvdXJjZTM6IHsgVHlwZTogJ1Jlc291cmNlVHlwZTMnLCBQcm9wZXJ0aWVzOiB7IFAzOiAnSGVsbG8nIH0gfSB9LFxuICAgICAgIE91dHB1dHM6IHtcbiAgICAgICAgIE15T3V0cHV0OiB7IERlc2NyaXB0aW9uOiAnT3V0IScgfSB9IH0pO1xuXG4gICAgdGVzdC5kb25lKCk7XG4gIH0sXG5cbiAgJ2V4Y2VwdGlvbiBpcyB0aHJvd24gaW4gY29uc3RydWN0aW9uIGlmIGFuIGVudGl0eSBmcm9tIGFuIGluY2x1ZGVkIHRlbXBsYXRlIGhhcyB0aGUgc2FtZSBpZCBhcyBhIHByb2dyYW1tYXRpYyBlbnRpdHknKHRlc3Q6IFRlc3QpIHtcbiAgICBjb25zdCBzdGFjayA9IG5ldyBTdGFjaygpO1xuXG4gICAgbmV3IEluY2x1ZGUoc3RhY2ssICdUMScsIHsgdGVtcGxhdGUgfSk7XG4gICAgbmV3IFJlc291cmNlKHN0YWNrLCAnTXlSZXNvdXJjZTMnLCB7IHR5cGU6ICdSZXNvdXJjZVR5cGUzJywgcHJvcGVydGllczogeyBQMzogJ0hlbGxvJyB9IH0pO1xuICAgIG5ldyBPdXRwdXQoc3RhY2ssICdNeU91dHB1dCcsIHsgZGVzY3JpcHRpb246ICdPdXQhJyB9KTtcbiAgICBuZXcgUGFyYW1ldGVyKHN0YWNrLCAnTXlQYXJhbScsIHsgdHlwZTogJ0ludGVnZXInIH0pOyAvLyBkdXBsaWNhdGUhXG5cbiAgICB0ZXN0LnRocm93cygoKSA9PiBzdGFjay50b0Nsb3VkRm9ybWF0aW9uKCkpO1xuICAgIHRlc3QuZG9uZSgpO1xuICB9LFxufTtcblxuY29uc3QgdGVtcGxhdGUgPSB7XG4gIFBhcmFtZXRlcnM6IHtcbiAgICBNeVBhcmFtOiB7XG4gICAgICBUeXBlOiAnU3RyaW5nJyxcbiAgICAgIERlZmF1bHQ6ICdIZWxsbydcbiAgICB9XG4gIH0sXG4gIFJlc291cmNlczoge1xuICAgIE15UmVzb3VyY2UxOiB7XG4gICAgICBUeXBlOiAnUmVzb3VyY2VUeXBlMScsXG4gICAgICBQcm9wZXJ0aWVzOiB7XG4gICAgICAgIFAxOiAxLFxuICAgICAgICBQMjogMixcbiAgICAgIH1cbiAgICB9LFxuICAgIE15UmVzb3VyY2UyOiB7XG4gICAgICBUeXBlOiAnUmVzb3VyY2VUeXBlMidcbiAgICB9XG4gIH1cbn07XG5cbi8qKlxuICogQHBhcmFtIG9iaiBhbiBvYmplY3QgdG8gY2xvbmVcbiAqIEByZXR1cm5zIGEgZGVlcCBjbG9uZSBvZiBgYG9iamAuXG4gKi9cbmZ1bmN0aW9uIGNsb25lKG9iajogYW55KTogYW55IHtcbiAgc3dpdGNoICh0eXBlb2Ygb2JqKSB7XG4gIGNhc2UgJ29iamVjdCc6XG4gICAgaWYgKEFycmF5LmlzQXJyYXkob2JqKSkge1xuICAgICAgcmV0dXJuIG9iai5tYXAoZWx0ID0+IGNsb25lKGVsdCkpO1xuICAgIH0gZWxzZSB7XG4gICAgICBjb25zdCBjbG9uZWQ6IGFueSA9IHt9O1xuICAgICAgZm9yIChjb25zdCBrZXkgb2YgT2JqZWN0LmtleXMob2JqKSkge1xuICAgICAgICBjbG9uZWRba2V5XSA9IGNsb25lKG9ialtrZXldKTtcbiAgICAgIH1cbiAgICAgIHJldHVybiBjbG9uZWQ7XG4gICAgfVxuICBkZWZhdWx0OlxuICAgIHJldHVybiBvYmo7XG4gIH1cbn1cbiJdfQ==

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

module.exports = exp;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.logical-id.js","sourceRoot":"","sources":["test.logical-id.ts"],"names":[],"mappings":";AACA,mCAAuG;AAEvG;;GAEG;AACH,MAAM,WAAW,GAAG;IAChB,0FAA0F,CAAC,IAAU;QACjG,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,WAAK,CAAC,SAAS,EAAE,WAAW,EAAE,EAAE,YAAY,EAAE,IAAI,4BAAsB,EAAE,EAAE,CAAC,CAAC;QAEhG,MAAM,CAAC,GAAG,IAAI,eAAS,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;QACpC,IAAI,cAAQ,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC;QAE5C,OAAO;QACP,MAAM,EAAE,GAAG,IAAI,eAAS,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QACtC,IAAI,cAAQ,CAAC,EAAE,EAAE,GAAG,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC;QAE5C,qBAAqB;QAErB,IAAI,CAAC,IAAI,EAAE,CAAC;IAChB,CAAC;IAED,iEAAiE,CAAC,IAAU;QACxE,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,WAAK,CAAC,SAAS,EAAE,WAAW,EAAE,EAAE,YAAY,EAAE,IAAI,4BAAsB,EAAE,EAAE,CAAC,CAAC;QAEhG,OAAO;QACP,MAAM,CAAC,GAAG,IAAI,cAAQ,CAAC,KAAK,EAAE,eAAe,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC;QAErE,OAAO;QACP,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,EAAE,eAAe,CAAC,CAAC;QAEzC,IAAI,CAAC,IAAI,EAAE,CAAC;IAChB,CAAC;IAED,+CAA+C,CAAC,IAAU;QACtD,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,WAAK,EAAE,CAAC;QAC1B,KAAK,CAAC,aAAa,CAAC,6BAA6B,EAAE,SAAS,CAAC,CAAC;QAE9D,OAAO;QACP,MAAM,MAAM,GAAG,IAAI,eAAS,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;QAC9C,IAAI,cAAQ,CAAC,MAAM,EAAE,eAAe,EAAE,EAAE,IAAI,EAAE,kBAAkB,EAAE,CAAC,CAAC;QAEpE,OAAO;QACP,MAAM,QAAQ,GAAG,KAAK,CAAC,gBAAgB,EAAE,CAAC;QAC1C,IAAI,CAAC,EAAE,CAAC,SAAS,IAAI,QAAQ,CAAC,SAAS,CAAC,CAAC;QAEzC,IAAI,CAAC,IAAI,EAAE,CAAC;IAChB,CAAC;IAED,4CAA4C,CAAC,IAAU;QACnD,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,WAAK,EAAE,CAAC;QAC1B,KAAK,CAAC,aAAa,CAAC,cAAc,EAAE,SAAS,CAAC,CAAC;QAE/C,OAAO;QACP,IAAI,eAAS,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;QAE/B,OAAO;QACP,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE;YACb,KAAK,CAAC,gBAAgB,EAAE,CAAC;QAC7B,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,IAAI,EAAE,CAAC;IAChB,CAAC;IAED,uDAAuD,CAAC,IAAU;QAC9D,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,WAAK,EAAE,CAAC;QAC1B,KAAK,CAAC,aAAa,CAAC,8BAA8B,EAAE,8BAA8B,CAAC,CAAC;QAEpF,OAAO;QACP,MAAM,MAAM,GAAG,IAAI,eAAS,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;QAC9C,IAAI,cAAQ,CAAC,MAAM,EAAE,gBAAgB,EAAE,EAAE,IAAI,EAAE,kBAAkB,EAAE,CAAC,CAAC;QAErE,OAAO;QACP,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE;YACb,IAAI,cAAQ,CAAC,MAAM,EAAE,gBAAgB,EAAE,EAAE,IAAI,EAAE,kBAAkB,EAAE,CAAC,CAAC;QACzE,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,IAAI,EAAE,CAAC;IAChB,CAAC;IAED,iFAAiF,CAAC,IAAU;QACxF,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,WAAK,EAAE,CAAC;QAE1B,OAAO;QACP,MAAM,MAAM,GAAG,IAAI,eAAS,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;QAC9C,MAAM,MAAM,GAAG,IAAI,eAAS,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QAC9C,MAAM,MAAM,GAAG,IAAI,eAAS,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;QAEjD,IAAI,cAAQ,CAAC,MAAM,EAAE,UAAU,EAAE,EAAE,IAAI,EAAE,kBAAkB,EAAE,CAAC,CAAC;QAE/D,OAAO;QACP,MAAM,QAAQ,GAAG,KAAK,CAAC,gBAAgB,EAAE,CAAC;QAC1C,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE;YACrB,SAAS,EAAE;gBACP,2BAA2B,EAAE;oBACzB,IAAI,EAAE,kBAAkB;iBAC3B;aACJ;SACJ,CAAC,CAAC;QAEH,IAAI,CAAC,IAAI,EAAE,CAAC;IAChB,CAAC;IAED,sDAAsD,CAAC,IAAU;QAC7D,QAAQ;QACR,MAAM,MAAM,GAAG,IAAI,WAAK,EAAE,CAAC;QAC3B,MAAM,OAAO,GAAG,IAAI,eAAS,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;QAChD,IAAI,cAAQ,CAAC,OAAO,EAAE,UAAU,EAAE,EAAE,IAAI,EAAE,kBAAkB,EAAE,CAAC,CAAC;QAChE,MAAM,SAAS,GAAG,MAAM,CAAC,gBAAgB,EAAE,CAAC;QAE5C,MAAM;QACN,MAAM,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;QACnD,IAAI,CAAC,KAAK,CAAC,kBAAkB,EAAE,SAAS,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC;QAEjE,OAAO;QACP,MAAM,MAAM,GAAG,IAAI,WAAK,EAAE,CAAC;QAC3B,MAAM,OAAO,GAAG,IAAI,eAAS,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;QAChD,MAAM,gBAAgB,GAAG,IAAI,eAAS,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;QAC3D,IAAI,cAAQ,CAAC,gBAAgB,EAAE,UAAU,EAAE,EAAE,IAAI,EAAE,kBAAkB,EAAE,CAAC,CAAC;QACzE,MAAM,SAAS,GAAG,MAAM,CAAC,gBAAgB,EAAE,CAAC;QAE5C,MAAM,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;QACnD,IAAI,CAAC,KAAK,CAAC,kBAAkB,EAAE,SAAS,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC;QAEjE,6BAA6B;QAC7B,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;QAE3B,IAAI,CAAC,IAAI,EAAE,CAAC;IAChB,CAAC;IAED,+EAA+E,CAAC,IAAU;QACtF,MAAM,MAAM,GAAG,IAAI,4BAAsB,EAAE,CAAC;QAC5C,MAAM,IAAI,GAAG,MAAM,CAAC,eAAe,CAAC,CAAE,SAAS,EAAE,MAAM,EAAE,aAAa,EAAE,kBAAkB,CAAE,CAAC,CAAC;QAC9F,MAAM,IAAI,GAAG,MAAM,CAAC,eAAe,CAAC,CAAE,QAAQ,EAAE,MAAM,EAAE,YAAY,EAAE,cAAc,CAAE,CAAC,CAAC;QAExF,kCAAkC;QAClC,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,0CAA0C,CAAC,CAAC;QACjE,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,0CAA0C,CAAC,CAAC;QACjE,IAAI,CAAC,IAAI,EAAE,CAAC;IAChB,CAAC;CACJ,CAAC;AAEF,MAAM,OAAO,GAAwC;IACjD,gBAAgB,EAAE,IAAI,4BAAsB,EAAE;CACjD,CAAC;AAEF;;GAEG;AACH,MAAM,eAAe,GAAuE;IACxF,mCAAmC,CAAC,MAAyB,EAAE,IAAU;QACrE,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,WAAK,CAAC,SAAS,EAAE,WAAW,EAAE,EAAE,YAAY,EAAE,MAAM,EAAE,CAAC,CAAC;QAE1E,OAAO;QACP,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE;YACZ,IAAI,cAAQ,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC;QAC7C,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,IAAI,EAAE,CAAC;IAChB,CAAC;IAED,6DAA6D,CAAC,MAAyB,EAAE,IAAU;QAC/F,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,WAAK,CAAC,SAAS,EAAE,WAAW,EAAE,EAAE,YAAY,EAAE,MAAM,EAAE,CAAC,CAAC;QAE1E,MAAM,CAAC,GAAG,IAAI,eAAS,CAAC,KAAK,EAAE,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC;QACpD,MAAM,CAAC,GAAG,IAAI,eAAS,CAAC,CAAC,EAAE,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC;QAEhD,OAAO;QACP,MAAM,SAAS,GAAG,cAAc,CAAC,EAAE,CAAC,CAAC;QACrC,oFAAoF;QACpF,yDAAyD;QAEzD,MAAM,EAAE,GAAG,IAAI,cAAQ,CAAC,CAAC,EAAE,SAAS,GAAG,cAAc,CAAC,EAAE,CAAC,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC;QACjF,MAAM,EAAE,GAAG,IAAI,cAAQ,CAAC,CAAC,EAAE,SAAS,GAAG,cAAc,CAAC,EAAE,CAAC,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC;QAEjF,OAAO;QACP,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,SAAS,CAAC,MAAM,IAAI,GAAG,CAAC,CAAC;QACpC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,SAAS,CAAC,MAAM,IAAI,GAAG,CAAC,CAAC;QACpC,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;QAEtB,IAAI,CAAC,IAAI,EAAE,CAAC;IAChB,CAAC;IAED,8EAA8E,CAAC,MAAyB,EAAE,IAAU;QAChH,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,WAAK,CAAC,SAAS,EAAE,WAAW,EAAE,EAAE,YAAY,EAAE,MAAM,EAAE,CAAC,CAAC;QAC1E,KAAK,CAAC,aAAa,CAAC,cAAc,EAAE,SAAS,CAAC,CAAC;QAE/C,OAAO;QACP,MAAM,EAAE,GAAG,IAAI,cAAQ,CAAC,KAAK,EAAE,cAAc,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;QAC/D,MAAM,GAAG,GAAG,IAAI,SAAG,CAAC,EAAE,CAAC,CAAC;QAExB,MAAM,EAAE,GAAG,IAAI,cAAQ,CAAC,KAAK,EAAE,YAAY,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,UAAU,EAAE,EAAE,aAAa,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC;QACjG,EAAE,CAAC,aAAa,CAAC,EAAE,CAAC,CAAC;QAErB,OAAO;QACP,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,gBAAgB,EAAE,EAAE;YACrC,SAAS,EAAE;gBACP,CAAC,EAAE,CAAC,SAAS,CAAC,EAAE;oBACZ,IAAI,EAAE,IAAI;iBAAE;gBAChB,CAAC,EAAE,CAAC,SAAS,CAAC,EAAE;oBACZ,IAAI,EAAE,IAAI;oBACV,UAAU,EAAE;wBACR,aAAa,EAAE,EAAE,GAAG,EAAE,EAAE,CAAC,SAAS,EAAE;qBAAE;oBAC1C,SAAS,EAAE,CAAE,EAAE,CAAC,SAAS,CAAE;iBAAE;aAAE;SAAE,CAAC,CAAC;QAE/C,IAAI,CAAC,IAAI,EAAE,CAAC;IAChB,CAAC;CACJ,CAAC;AAEF,+DAA+D;AAC/D,MAAM,GAAG,GAAQ,WAAW,CAAC;AAC7B,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE;IACtC,MAAM,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC;IACnC,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE;QAC5C,MAAM,YAAY,GAAG,eAAe,CAAC,QAAQ,CAAC,CAAC;QAC/C,GAAG,CAAC,GAAG,UAAU,KAAK,QAAQ,EAAE,CAAC,GAAG,CAAC,IAAU,EAAE,EAAE;YAC/C,YAAY,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QAC/B,CAAC,CAAC;IACN,CAAC,CAAC,CAAC;AACP,CAAC,CAAC,CAAC;AAIH,SAAS,cAAc,CAAC,KAAa;IACjC,IAAI,CAAC,GAAG,EAAE,CAAC;IACX,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,EAAE,EAAE,CAAC,EAAE;QAC5B,CAAC,IAAI,WAAW,EAAE,CAAC;KACtB;IACD,OAAO,CAAC,CAAC;IAET,SAAS,WAAW;QAChB,OAAO,MAAM,CAAC,YAAY,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC;IACnF,CAAC;AACL,CAAC;AAZD,iBAAS,GAAG,CAAC","sourcesContent":["import { Test } from 'nodeunit';\nimport { Construct, HashedAddressingScheme, IAddressingScheme, Ref, Resource, Stack } from '../../lib';\n\n/**\n * These tests are executed once (for specific ID schemes)\n */\nconst uniqueTests = {\n    'if the naming scheme uniquifies with a hash we can have the same concatenated identifier'(test: Test) {\n        // GIVEN\n        const stack = new Stack(undefined, 'TestStack', { namingScheme: new HashedAddressingScheme() });\n\n        const A = new Construct(stack, 'A');\n        new Resource(A, 'BC', { type: 'Resource' });\n\n        // WHEN\n        const AB = new Construct(stack, 'AB');\n        new Resource(AB, 'C', { type: 'Resource' });\n\n        // THEN: no exception\n\n        test.done();\n    },\n\n    'special case: if the resource is top-level, a hash is not added'(test: Test) {\n        // GIVEN\n        const stack = new Stack(undefined, 'TestStack', { namingScheme: new HashedAddressingScheme() });\n\n        // WHEN\n        const r = new Resource(stack, 'MyAwesomeness', { type: 'Resource' });\n\n        // THEN\n        test.equal(r.logicalId, 'MyAwesomeness');\n\n        test.done();\n    },\n\n    'Logical IDs can be renamed at the stack level'(test: Test) {\n        // GIVEN\n        const stack = new Stack();\n        stack.renameLogical('ParentThingResource75D1D9CB', 'Renamed');\n\n        // WHEN\n        const parent = new Construct(stack, 'Parent');\n        new Resource(parent, 'ThingResource', { type: 'AWS::TAAS::Thing' });\n\n        // THEN\n        const template = stack.toCloudFormation();\n        test.ok('Renamed' in template.Resources);\n\n        test.done();\n    },\n\n    'Renames for objects that don\\'t exist fail'(test: Test) {\n        // GIVEN\n        const stack = new Stack();\n        stack.renameLogical('DOESNOTEXIST', 'Renamed');\n\n        // WHEN\n        new Construct(stack, 'Parent');\n\n        // THEN\n        test.throws(() => {\n            stack.toCloudFormation();\n        });\n\n        test.done();\n    },\n\n    'ID Renames that collide with existing IDs should fail'(test: Test) {\n        // GIVEN\n        const stack = new Stack();\n        stack.renameLogical('ParentThingResource1916E7808', 'ParentThingResource2F19948CB');\n\n        // WHEN\n        const parent = new Construct(stack, 'Parent');\n        new Resource(parent, 'ThingResource1', { type: 'AWS::TAAS::Thing' });\n\n        // THEN\n        test.throws(() => {\n            new Resource(parent, 'ThingResource2', { type: 'AWS::TAAS::Thing' });\n        });\n\n        test.done();\n    },\n\n    'hashed naming scheme filters constructs named \"Resource\" from the human portion'(test: Test) {\n        // GIVEN\n        const stack = new Stack();\n\n        // WHEN\n        const parent = new Construct(stack, 'Parent');\n        const child1 = new Construct(parent, 'Child');\n        const child2 = new Construct(child1, 'Resource');\n\n        new Resource(child2, 'HeyThere', { type: 'AWS::TAAS::Thing' });\n\n        // THEN\n        const template = stack.toCloudFormation();\n        test.deepEqual(template, {\n            Resources: {\n                ParentChildHeyThere35220347: {\n                    Type: 'AWS::TAAS::Thing'\n                }\n            }\n        });\n\n        test.done();\n    },\n\n    'can transparently wrap constructs using \"Default\" id'(test: Test) {\n        // GIVEN\n        const stack1 = new Stack();\n        const parent1 = new Construct(stack1, 'Parent');\n        new Resource(parent1, 'HeyThere', { type: 'AWS::TAAS::Thing' });\n        const template1 = stack1.toCloudFormation();\n\n        // AND\n        const theId1 = Object.keys(template1.Resources)[0];\n        test.equal('AWS::TAAS::Thing', template1.Resources[theId1].Type);\n\n        // WHEN\n        const stack2 = new Stack();\n        const parent2 = new Construct(stack2, 'Parent');\n        const invisibleWrapper = new Construct(parent2, 'Default');\n        new Resource(invisibleWrapper, 'HeyThere', { type: 'AWS::TAAS::Thing' });\n        const template2 = stack1.toCloudFormation();\n\n        const theId2 = Object.keys(template2.Resources)[0];\n        test.equal('AWS::TAAS::Thing', template2.Resources[theId2].Type);\n\n        // THEN: same ID, same object\n        test.equal(theId1, theId2);\n\n        test.done();\n    },\n\n    'non-alphanumeric characters are removed from the human part of the logical ID'(test: Test) {\n        const scheme = new HashedAddressingScheme();\n        const val1 = scheme.allocateAddress([ 'Foo-bar', 'B00m', 'Hello_World', '&&Horray Horray.' ]);\n        const val2 = scheme.allocateAddress([ 'Foobar', 'B00m', 'HelloWorld', 'HorrayHorray' ]);\n\n        // same human part, different hash\n        test.deepEqual(val1, 'FoobarB00mHelloWorldHorrayHorray640E99FB');\n        test.deepEqual(val2, 'FoobarB00mHelloWorldHorrayHorray744334FD');\n        test.done();\n    }\n};\n\nconst schemes: {[name: string]: IAddressingScheme} = {\n    \"hashing scheme\": new HashedAddressingScheme(),\n};\n\n/**\n * These tests are executed for all generators\n */\nconst allSchemesTests: {[name: string]: (scheme: IAddressingScheme, test: Test) => void } = {\n    'empty identifiers are not allowed'(scheme: IAddressingScheme, test: Test) {\n        // GIVEN\n        const stack = new Stack(undefined, 'TestStack', { namingScheme: scheme });\n\n        // WHEN\n        test.throws(() => {\n             new Resource(stack, '.', { type: 'R' });\n        });\n        test.done();\n    },\n\n    'too large identifiers are truncated yet still remain unique'(scheme: IAddressingScheme, test: Test) {\n        // GIVEN\n        const stack = new Stack(undefined, 'TestStack', { namingScheme: scheme });\n\n        const A = new Construct(stack, generateString(100));\n        const B = new Construct(A, generateString(100));\n\n        // WHEN\n        const firstPart = generateString(60);\n        // The shared part has now exceeded the maximum length of CloudFormation identifiers\n        // so the identity generator will have to something smart\n\n        const C1 = new Resource(B, firstPart + generateString(40), { type: 'Resource' });\n        const C2 = new Resource(B, firstPart + generateString(40), { type: 'Resource' });\n\n        // THEN\n        test.ok(C1.logicalId.length <= 255);\n        test.ok(C2.logicalId.length <= 255);\n        test.notEqual(C1, C2);\n\n        test.done();\n    },\n\n    'Refs and dependencies will correctly reflect renames done at the stack level'(scheme: IAddressingScheme, test: Test) {\n        // GIVEN\n        const stack = new Stack(undefined, 'TestStack', { namingScheme: scheme });\n        stack.renameLogical('OriginalName', 'NewName');\n\n        // WHEN\n        const c1 = new Resource(stack, 'OriginalName', { type: 'R1' });\n        const ref = new Ref(c1);\n\n        const c2 = new Resource(stack, 'Construct2', { type: 'R2', properties: { ReferenceToR1: ref } });\n        c2.addDependency(c1);\n\n        // THEN\n        test.deepEqual(stack.toCloudFormation(), {\n            Resources: {\n                [c1.logicalId]: {\n                    Type: 'R1' },\n                [c2.logicalId]: {\n                    Type: 'R2',\n                    Properties: {\n                        ReferenceToR1: { Ref: c1.logicalId } },\n                    DependsOn: [ c1.logicalId ] } } });\n\n        test.done();\n    },\n};\n\n// Combine the one-off tests and generate tests for each scheme\nconst exp: any = uniqueTests;\nObject.keys(schemes).forEach(schemeName => {\n    const scheme = schemes[schemeName];\n    Object.keys(allSchemesTests).forEach(testName => {\n        const testFunction = allSchemesTests[testName];\n        exp[`${schemeName}: ${testName}`] = (test: Test) => {\n            testFunction(scheme, test);\n        };\n    });\n});\n\nexport = exp;\n\nfunction generateString(chars: number) {\n    let s = '';\n    for (let i = 0; i < chars; ++i) {\n        s += randomAlpha();\n    }\n    return s;\n\n    function randomAlpha() {\n        return String.fromCharCode('a'.charCodeAt(0) + Math.floor(Math.random() * 26));\n    }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.logical-id.js","sourceRoot":"","sources":["test.logical-id.ts"],"names":[],"mappings":"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","sourcesContent":["import { Test } from 'nodeunit';\nimport { Construct, HashedAddressingScheme, IAddressingScheme, Ref, Resource, Stack } from '../../lib';\n\n/**\n * These tests are executed once (for specific ID schemes)\n */\nconst uniqueTests = {\n  'if the naming scheme uniquifies with a hash we can have the same concatenated identifier'(test: Test) {\n    // GIVEN\n    const stack = new Stack(undefined, 'TestStack', { namingScheme: new HashedAddressingScheme() });\n\n    const A = new Construct(stack, 'A');\n    new Resource(A, 'BC', { type: 'Resource' });\n\n    // WHEN\n    const AB = new Construct(stack, 'AB');\n    new Resource(AB, 'C', { type: 'Resource' });\n\n    // THEN: no exception\n\n    test.done();\n  },\n\n  'special case: if the resource is top-level, a hash is not added'(test: Test) {\n    // GIVEN\n    const stack = new Stack(undefined, 'TestStack', { namingScheme: new HashedAddressingScheme() });\n\n    // WHEN\n    const r = new Resource(stack, 'MyAwesomeness', { type: 'Resource' });\n\n    // THEN\n    test.equal(r.logicalId, 'MyAwesomeness');\n\n    test.done();\n  },\n\n  'Logical IDs can be renamed at the stack level'(test: Test) {\n    // GIVEN\n    const stack = new Stack();\n    stack.renameLogical('ParentThingResource75D1D9CB', 'Renamed');\n\n    // WHEN\n    const parent = new Construct(stack, 'Parent');\n    new Resource(parent, 'ThingResource', { type: 'AWS::TAAS::Thing' });\n\n    // THEN\n    const template = stack.toCloudFormation();\n    test.ok('Renamed' in template.Resources);\n\n    test.done();\n  },\n\n  'Renames for objects that don\\'t exist fail'(test: Test) {\n    // GIVEN\n    const stack = new Stack();\n    stack.renameLogical('DOESNOTEXIST', 'Renamed');\n\n    // WHEN\n    new Construct(stack, 'Parent');\n\n    // THEN\n    test.throws(() => {\n      stack.toCloudFormation();\n    });\n\n    test.done();\n  },\n\n  'ID Renames that collide with existing IDs should fail'(test: Test) {\n    // GIVEN\n    const stack = new Stack();\n    stack.renameLogical('ParentThingResource1916E7808', 'ParentThingResource2F19948CB');\n\n    // WHEN\n    const parent = new Construct(stack, 'Parent');\n    new Resource(parent, 'ThingResource1', { type: 'AWS::TAAS::Thing' });\n\n    // THEN\n    test.throws(() => {\n      new Resource(parent, 'ThingResource2', { type: 'AWS::TAAS::Thing' });\n    });\n\n    test.done();\n  },\n\n  'hashed naming scheme filters constructs named \"Resource\" from the human portion'(test: Test) {\n    // GIVEN\n    const stack = new Stack();\n\n    // WHEN\n    const parent = new Construct(stack, 'Parent');\n    const child1 = new Construct(parent, 'Child');\n    const child2 = new Construct(child1, 'Resource');\n\n    new Resource(child2, 'HeyThere', { type: 'AWS::TAAS::Thing' });\n\n    // THEN\n    const template = stack.toCloudFormation();\n    test.deepEqual(template, {\n      Resources: {\n        ParentChildHeyThere35220347: {\n          Type: 'AWS::TAAS::Thing'\n        }\n      }\n    });\n\n    test.done();\n  },\n\n  'can transparently wrap constructs using \"Default\" id'(test: Test) {\n    // GIVEN\n    const stack1 = new Stack();\n    const parent1 = new Construct(stack1, 'Parent');\n    new Resource(parent1, 'HeyThere', { type: 'AWS::TAAS::Thing' });\n    const template1 = stack1.toCloudFormation();\n\n    // AND\n    const theId1 = Object.keys(template1.Resources)[0];\n    test.equal('AWS::TAAS::Thing', template1.Resources[theId1].Type);\n\n    // WHEN\n    const stack2 = new Stack();\n    const parent2 = new Construct(stack2, 'Parent');\n    const invisibleWrapper = new Construct(parent2, 'Default');\n    new Resource(invisibleWrapper, 'HeyThere', { type: 'AWS::TAAS::Thing' });\n    const template2 = stack1.toCloudFormation();\n\n    const theId2 = Object.keys(template2.Resources)[0];\n    test.equal('AWS::TAAS::Thing', template2.Resources[theId2].Type);\n\n    // THEN: same ID, same object\n    test.equal(theId1, theId2);\n\n    test.done();\n  },\n\n  'non-alphanumeric characters are removed from the human part of the logical ID'(test: Test) {\n    const scheme = new HashedAddressingScheme();\n    const val1 = scheme.allocateAddress([ 'Foo-bar', 'B00m', 'Hello_World', '&&Horray Horray.' ]);\n    const val2 = scheme.allocateAddress([ 'Foobar', 'B00m', 'HelloWorld', 'HorrayHorray' ]);\n\n    // same human part, different hash\n    test.deepEqual(val1, 'FoobarB00mHelloWorldHorrayHorray640E99FB');\n    test.deepEqual(val2, 'FoobarB00mHelloWorldHorrayHorray744334FD');\n    test.done();\n  }\n};\n\nconst schemes: {[name: string]: IAddressingScheme} = {\n  \"hashing scheme\": new HashedAddressingScheme(),\n};\n\n/**\n * These tests are executed for all generators\n */\nconst allSchemesTests: {[name: string]: (scheme: IAddressingScheme, test: Test) => void } = {\n  'empty identifiers are not allowed'(scheme: IAddressingScheme, test: Test) {\n    // GIVEN\n    const stack = new Stack(undefined, 'TestStack', { namingScheme: scheme });\n\n    // WHEN\n    test.throws(() => {\n       new Resource(stack, '.', { type: 'R' });\n    });\n    test.done();\n  },\n\n  'too large identifiers are truncated yet still remain unique'(scheme: IAddressingScheme, test: Test) {\n    // GIVEN\n    const stack = new Stack(undefined, 'TestStack', { namingScheme: scheme });\n\n    const A = new Construct(stack, generateString(100));\n    const B = new Construct(A, generateString(100));\n\n    // WHEN\n    const firstPart = generateString(60);\n    // The shared part has now exceeded the maximum length of CloudFormation identifiers\n    // so the identity generator will have to something smart\n\n    const C1 = new Resource(B, firstPart + generateString(40), { type: 'Resource' });\n    const C2 = new Resource(B, firstPart + generateString(40), { type: 'Resource' });\n\n    // THEN\n    test.ok(C1.logicalId.length <= 255);\n    test.ok(C2.logicalId.length <= 255);\n    test.notEqual(C1, C2);\n\n    test.done();\n  },\n\n  'Refs and dependencies will correctly reflect renames done at the stack level'(scheme: IAddressingScheme, test: Test) {\n    // GIVEN\n    const stack = new Stack(undefined, 'TestStack', { namingScheme: scheme });\n    stack.renameLogical('OriginalName', 'NewName');\n\n    // WHEN\n    const c1 = new Resource(stack, 'OriginalName', { type: 'R1' });\n    const ref = new Ref(c1);\n\n    const c2 = new Resource(stack, 'Construct2', { type: 'R2', properties: { ReferenceToR1: ref } });\n    c2.addDependency(c1);\n\n    // THEN\n    test.deepEqual(stack.toCloudFormation(), {\n      Resources: {\n        [c1.logicalId]: {\n          Type: 'R1' },\n        [c2.logicalId]: {\n          Type: 'R2',\n          Properties: {\n            ReferenceToR1: { Ref: c1.logicalId } },\n          DependsOn: [ c1.logicalId ] } } });\n\n    test.done();\n  },\n};\n\n// Combine the one-off tests and generate tests for each scheme\nconst exp: any = uniqueTests;\nObject.keys(schemes).forEach(schemeName => {\n  const scheme = schemes[schemeName];\n  Object.keys(allSchemesTests).forEach(testName => {\n    const testFunction = allSchemesTests[testName];\n    exp[`${schemeName}: ${testName}`] = (test: Test) => {\n      testFunction(scheme, test);\n    };\n  });\n});\n\nexport = exp;\n\nfunction generateString(chars: number) {\n  let s = '';\n  for (let i = 0; i < chars; ++i) {\n    s += randomAlpha();\n  }\n  return s;\n\n  function randomAlpha() {\n    return String.fromCharCode('a'.charCodeAt(0) + Math.floor(Math.random() * 26));\n  }\n}\n"]}

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

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5tYXBwaW5ncy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInRlc3QubWFwcGluZ3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUNBLG1DQUFxRDtBQUVyRCxpQkFBUztJQUNMLG1HQUFtRyxDQUFDLElBQVU7UUFDMUcsTUFBTSxLQUFLLEdBQUcsSUFBSSxXQUFLLEVBQUUsQ0FBQztRQUMxQixNQUFNLE9BQU8sR0FBRyxJQUFJLGFBQU8sQ0FBQyxLQUFLLEVBQUUsV0FBVyxFQUFFLEVBQUUsT0FBTyxFQUFFO2dCQUN2RCxZQUFZLEVBQUU7b0JBQ1YsZUFBZSxFQUFFLENBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUU7b0JBQzVCLGVBQWUsRUFBRSxFQUFFLEtBQUssRUFBRSxPQUFPLEVBQUU7aUJBQ3RDO2dCQUNELFlBQVksRUFBRTtvQkFDVixlQUFlLEVBQUUsQ0FBRSxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsQ0FBRTtpQkFDbEM7YUFDSixFQUFFLENBQUMsQ0FBQztRQUVMLDRDQUE0QztRQUM1QyxJQUFJLGNBQVEsQ0FBQyxLQUFLLEVBQUUsWUFBWSxFQUFFO1lBQzlCLElBQUksRUFBRSxHQUFHO1lBQ1QsVUFBVSxFQUFFO2dCQUNSLGVBQWUsRUFBRSxPQUFPLENBQUMsU0FBUyxDQUFDLGNBQWMsRUFBRSxpQkFBaUIsQ0FBQzthQUN4RTtTQUNKLENBQUMsQ0FBQztRQUNILElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxFQUFFLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxrQkFBa0IsRUFBRSxVQUFVLENBQUMsRUFBRSw2Q0FBNkMsQ0FBQyxDQUFDO1FBQ3BILElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxFQUFFLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxjQUFjLEVBQUUsVUFBVSxDQUFDLEVBQUUsNkNBQTZDLENBQUMsQ0FBQztRQUVoSCx1REFBdUQ7UUFDdkQsT0FBTyxDQUFDLFFBQVEsQ0FBQyxjQUFjLEVBQUUsaUJBQWlCLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFDMUQsT0FBTyxDQUFDLFFBQVEsQ0FBQyxjQUFjLEVBQUUsaUJBQWlCLEVBQUUsQ0FBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUUsQ0FBQyxDQUFDO1FBRXBFLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLGdCQUFnQixFQUFFLEVBQUUsRUFBRSxRQUFRLEVBQy9DLEVBQUUsU0FBUyxFQUNSLEVBQUUsWUFBWSxFQUNYLEVBQUUsZUFBZSxFQUFFLENBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFFO3dCQUMvQixlQUFlLEVBQUUsRUFBRSxLQUFLLEVBQUUsT0FBTyxFQUFFLEVBQUU7b0JBQ3hDLFlBQVksRUFBRSxFQUFFLGVBQWUsRUFBRSxDQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxDQUFFLEVBQUUsZUFBZSxFQUFFLElBQUksRUFBRSxFQUFFLEVBQUU7WUFDbEYsU0FBUyxFQUNSLEVBQUUsVUFBVSxFQUNULEVBQUUsSUFBSSxFQUFFLEdBQUc7b0JBQ1QsVUFBVSxFQUNULEVBQUUsZUFBZSxFQUNkLEVBQUUsZUFBZSxFQUFFLENBQUUsV0FBVyxFQUFFLGNBQWMsRUFBRSxpQkFBaUIsQ0FBRSxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRTlGLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNoQixDQUFDO0NBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRlc3QgfSBmcm9tICdub2RldW5pdCc7XG5pbXBvcnQgeyBNYXBwaW5nLCBSZXNvdXJjZSwgU3RhY2sgfSBmcm9tICcuLi8uLi9saWInO1xuXG5leHBvcnQgPSB7XG4gICAgJ21hcHBpbmdzIGNhbiBiZSBhZGRlZCBhcyBhbm90aGVyIHR5cGUgb2YgZW50aXR5LCBhbmQgbWFwcGluZy5maW5kSW5NYXAgY2FuIGJlIHVzZWQgdG8gZ2V0IGEgdG9rZW4nKHRlc3Q6IFRlc3QpIHtcbiAgICAgICAgY29uc3Qgc3RhY2sgPSBuZXcgU3RhY2soKTtcbiAgICAgICAgY29uc3QgbWFwcGluZyA9IG5ldyBNYXBwaW5nKHN0YWNrLCAnTXlNYXBwaW5nJywgeyBtYXBwaW5nOiB7XG4gICAgICAgICAgICBUb3BMZXZlbEtleTE6IHtcbiAgICAgICAgICAgICAgICBTZWNvbmRMZXZlbEtleTE6IFsgMSwgMiwgMyBdLFxuICAgICAgICAgICAgICAgIFNlY29uZExldmVsS2V5MjogeyBIZWxsbzogJ1dvcmxkJyB9XG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgVG9wTGV2ZWxLZXkyOiB7XG4gICAgICAgICAgICAgICAgU2Vjb25kTGV2ZWxLZXkxOiBbIDk5LCA5OSwgOTkgXVxuICAgICAgICAgICAgfVxuICAgICAgICB9IH0pO1xuXG4gICAgICAgIC8vIGZpbmRJbk1hcCBjYW4gYmUgdXNlZCB0byB0YWtlIGEgcmVmZXJlbmNlXG4gICAgICAgIG5ldyBSZXNvdXJjZShzdGFjaywgJ015UmVzb3VyY2UnLCB7XG4gICAgICAgICAgICB0eXBlOiAnUicsXG4gICAgICAgICAgICBwcm9wZXJ0aWVzOiB7XG4gICAgICAgICAgICAgICAgUmVmVG9WYWx1ZUluTWFwOiBtYXBwaW5nLmZpbmRJbk1hcCgnVG9wTGV2ZWxLZXkxJywgJ1NlY29uZExldmVsS2V5MScpXG4gICAgICAgICAgICB9XG4gICAgICAgIH0pO1xuICAgICAgICB0ZXN0LnRocm93cygoKSA9PiBtYXBwaW5nLmZpbmRJbk1hcCgnTm90Rm91bmRUb3BMZXZlbCcsICdOb3RGb3VuZCcpLCAnY2FudCB0YWtlIGEgcmVmZXJlbmNlIG9uIGEgbm9uIGV4aXN0aW5nIGtleScpO1xuICAgICAgICB0ZXN0LnRocm93cygoKSA9PiBtYXBwaW5nLmZpbmRJbk1hcCgnVG9wTGV2ZWxLZXkxJywgJ05vdEZvdW5kJyksICdjYW50IHRha2UgYSByZWZlcmVuY2Ugb24gYSBub24gZXhpc3Rpbmcga2V5Jyk7XG5cbiAgICAgICAgLy8gc2V0IHZhbHVlIGNhbiBiZSB1c2VkIHRvIHNldC9tb2RpZnkgYSBzcGVjaWZpYyB2YWx1ZVxuICAgICAgICBtYXBwaW5nLnNldFZhbHVlKCdUb3BMZXZlbEtleTInLCAnU2Vjb25kTGV2ZWxLZXkyJywgJ0hpJyk7XG4gICAgICAgIG1hcHBpbmcuc2V0VmFsdWUoJ1RvcExldmVsS2V5MScsICdTZWNvbmRMZXZlbEtleTEnLCBbIDEsIDIsIDMsIDQgXSk7XG5cbiAgICAgICAgdGVzdC5kZWVwRXF1YWwoc3RhY2sudG9DbG91ZEZvcm1hdGlvbigpLCB7IE1hcHBpbmdzOlxuICAgICAgICAgICAgeyBNeU1hcHBpbmc6XG4gICAgICAgICAgICAgICB7IFRvcExldmVsS2V5MTpcbiAgICAgICAgICAgICAgICAgIHsgU2Vjb25kTGV2ZWxLZXkxOiBbIDEsIDIsIDMsIDQgXSxcbiAgICAgICAgICAgICAgICAgICAgU2Vjb25kTGV2ZWxLZXkyOiB7IEhlbGxvOiAnV29ybGQnIH0gfSxcbiAgICAgICAgICAgICAgICAgVG9wTGV2ZWxLZXkyOiB7IFNlY29uZExldmVsS2V5MTogWyA5OSwgOTksIDk5IF0sIFNlY29uZExldmVsS2V5MjogJ0hpJyB9IH0gfSxcbiAgICAgICAgICAgUmVzb3VyY2VzOlxuICAgICAgICAgICAgeyBNeVJlc291cmNlOlxuICAgICAgICAgICAgICAgeyBUeXBlOiAnUicsXG4gICAgICAgICAgICAgICAgIFByb3BlcnRpZXM6XG4gICAgICAgICAgICAgICAgICB7IFJlZlRvVmFsdWVJbk1hcDpcbiAgICAgICAgICAgICAgICAgICAgIHsgJ0ZuOjpGaW5kSW5NYXAnOiBbICdNeU1hcHBpbmcnLCAnVG9wTGV2ZWxLZXkxJywgJ1NlY29uZExldmVsS2V5MScgXSB9IH0gfSB9IH0pO1xuXG4gICAgICAgIHRlc3QuZG9uZSgpO1xuICAgIH0sXG59O1xuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5tYXBwaW5ncy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInRlc3QubWFwcGluZ3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUNBLG1DQUFxRDtBQUVyRCxpQkFBUztJQUNQLG1HQUFtRyxDQUFDLElBQVU7UUFDNUcsTUFBTSxLQUFLLEdBQUcsSUFBSSxXQUFLLEVBQUUsQ0FBQztRQUMxQixNQUFNLE9BQU8sR0FBRyxJQUFJLGFBQU8sQ0FBQyxLQUFLLEVBQUUsV0FBVyxFQUFFLEVBQUUsT0FBTyxFQUFFO2dCQUN6RCxZQUFZLEVBQUU7b0JBQ1osZUFBZSxFQUFFLENBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUU7b0JBQzVCLGVBQWUsRUFBRSxFQUFFLEtBQUssRUFBRSxPQUFPLEVBQUU7aUJBQ3BDO2dCQUNELFlBQVksRUFBRTtvQkFDWixlQUFlLEVBQUUsQ0FBRSxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsQ0FBRTtpQkFDaEM7YUFDRixFQUFFLENBQUMsQ0FBQztRQUVMLDRDQUE0QztRQUM1QyxJQUFJLGNBQVEsQ0FBQyxLQUFLLEVBQUUsWUFBWSxFQUFFO1lBQ2hDLElBQUksRUFBRSxHQUFHO1lBQ1QsVUFBVSxFQUFFO2dCQUNWLGVBQWUsRUFBRSxPQUFPLENBQUMsU0FBUyxDQUFDLGNBQWMsRUFBRSxpQkFBaUIsQ0FBQzthQUN0RTtTQUNGLENBQUMsQ0FBQztRQUNILElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxFQUFFLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxrQkFBa0IsRUFBRSxVQUFVLENBQUMsRUFBRSw2Q0FBNkMsQ0FBQyxDQUFDO1FBQ3BILElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxFQUFFLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxjQUFjLEVBQUUsVUFBVSxDQUFDLEVBQUUsNkNBQTZDLENBQUMsQ0FBQztRQUVoSCx1REFBdUQ7UUFDdkQsT0FBTyxDQUFDLFFBQVEsQ0FBQyxjQUFjLEVBQUUsaUJBQWlCLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFDMUQsT0FBTyxDQUFDLFFBQVEsQ0FBQyxjQUFjLEVBQUUsaUJBQWlCLEVBQUUsQ0FBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUUsQ0FBQyxDQUFDO1FBRXBFLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLGdCQUFnQixFQUFFLEVBQUUsRUFBRSxRQUFRLEVBQ2pELEVBQUUsU0FBUyxFQUNSLEVBQUUsWUFBWSxFQUNiLEVBQUUsZUFBZSxFQUFFLENBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFFO3dCQUNqQyxlQUFlLEVBQUUsRUFBRSxLQUFLLEVBQUUsT0FBTyxFQUFFLEVBQUU7b0JBQ3RDLFlBQVksRUFBRSxFQUFFLGVBQWUsRUFBRSxDQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxDQUFFLEVBQUUsZUFBZSxFQUFFLElBQUksRUFBRSxFQUFFLEVBQUU7WUFDOUUsU0FBUyxFQUNWLEVBQUUsVUFBVSxFQUNULEVBQUUsSUFBSSxFQUFFLEdBQUc7b0JBQ1gsVUFBVSxFQUNULEVBQUUsZUFBZSxFQUNoQixFQUFFLGVBQWUsRUFBRSxDQUFFLFdBQVcsRUFBRSxjQUFjLEVBQUUsaUJBQWlCLENBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUV4RixJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDZCxDQUFDO0NBQ0YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRlc3QgfSBmcm9tICdub2RldW5pdCc7XG5pbXBvcnQgeyBNYXBwaW5nLCBSZXNvdXJjZSwgU3RhY2sgfSBmcm9tICcuLi8uLi9saWInO1xuXG5leHBvcnQgPSB7XG4gICdtYXBwaW5ncyBjYW4gYmUgYWRkZWQgYXMgYW5vdGhlciB0eXBlIG9mIGVudGl0eSwgYW5kIG1hcHBpbmcuZmluZEluTWFwIGNhbiBiZSB1c2VkIHRvIGdldCBhIHRva2VuJyh0ZXN0OiBUZXN0KSB7XG4gICAgY29uc3Qgc3RhY2sgPSBuZXcgU3RhY2soKTtcbiAgICBjb25zdCBtYXBwaW5nID0gbmV3IE1hcHBpbmcoc3RhY2ssICdNeU1hcHBpbmcnLCB7IG1hcHBpbmc6IHtcbiAgICAgIFRvcExldmVsS2V5MToge1xuICAgICAgICBTZWNvbmRMZXZlbEtleTE6IFsgMSwgMiwgMyBdLFxuICAgICAgICBTZWNvbmRMZXZlbEtleTI6IHsgSGVsbG86ICdXb3JsZCcgfVxuICAgICAgfSxcbiAgICAgIFRvcExldmVsS2V5Mjoge1xuICAgICAgICBTZWNvbmRMZXZlbEtleTE6IFsgOTksIDk5LCA5OSBdXG4gICAgICB9XG4gICAgfSB9KTtcblxuICAgIC8vIGZpbmRJbk1hcCBjYW4gYmUgdXNlZCB0byB0YWtlIGEgcmVmZXJlbmNlXG4gICAgbmV3IFJlc291cmNlKHN0YWNrLCAnTXlSZXNvdXJjZScsIHtcbiAgICAgIHR5cGU6ICdSJyxcbiAgICAgIHByb3BlcnRpZXM6IHtcbiAgICAgICAgUmVmVG9WYWx1ZUluTWFwOiBtYXBwaW5nLmZpbmRJbk1hcCgnVG9wTGV2ZWxLZXkxJywgJ1NlY29uZExldmVsS2V5MScpXG4gICAgICB9XG4gICAgfSk7XG4gICAgdGVzdC50aHJvd3MoKCkgPT4gbWFwcGluZy5maW5kSW5NYXAoJ05vdEZvdW5kVG9wTGV2ZWwnLCAnTm90Rm91bmQnKSwgJ2NhbnQgdGFrZSBhIHJlZmVyZW5jZSBvbiBhIG5vbiBleGlzdGluZyBrZXknKTtcbiAgICB0ZXN0LnRocm93cygoKSA9PiBtYXBwaW5nLmZpbmRJbk1hcCgnVG9wTGV2ZWxLZXkxJywgJ05vdEZvdW5kJyksICdjYW50IHRha2UgYSByZWZlcmVuY2Ugb24gYSBub24gZXhpc3Rpbmcga2V5Jyk7XG5cbiAgICAvLyBzZXQgdmFsdWUgY2FuIGJlIHVzZWQgdG8gc2V0L21vZGlmeSBhIHNwZWNpZmljIHZhbHVlXG4gICAgbWFwcGluZy5zZXRWYWx1ZSgnVG9wTGV2ZWxLZXkyJywgJ1NlY29uZExldmVsS2V5MicsICdIaScpO1xuICAgIG1hcHBpbmcuc2V0VmFsdWUoJ1RvcExldmVsS2V5MScsICdTZWNvbmRMZXZlbEtleTEnLCBbIDEsIDIsIDMsIDQgXSk7XG5cbiAgICB0ZXN0LmRlZXBFcXVhbChzdGFjay50b0Nsb3VkRm9ybWF0aW9uKCksIHsgTWFwcGluZ3M6XG4gICAgICB7IE15TWFwcGluZzpcbiAgICAgICAgIHsgVG9wTGV2ZWxLZXkxOlxuICAgICAgICAgIHsgU2Vjb25kTGV2ZWxLZXkxOiBbIDEsIDIsIDMsIDQgXSxcbiAgICAgICAgICBTZWNvbmRMZXZlbEtleTI6IHsgSGVsbG86ICdXb3JsZCcgfSB9LFxuICAgICAgICAgVG9wTGV2ZWxLZXkyOiB7IFNlY29uZExldmVsS2V5MTogWyA5OSwgOTksIDk5IF0sIFNlY29uZExldmVsS2V5MjogJ0hpJyB9IH0gfSxcbiAgICAgICBSZXNvdXJjZXM6XG4gICAgICB7IE15UmVzb3VyY2U6XG4gICAgICAgICB7IFR5cGU6ICdSJyxcbiAgICAgICAgIFByb3BlcnRpZXM6XG4gICAgICAgICAgeyBSZWZUb1ZhbHVlSW5NYXA6XG4gICAgICAgICAgIHsgJ0ZuOjpGaW5kSW5NYXAnOiBbICdNeU1hcHBpbmcnLCAnVG9wTGV2ZWxLZXkxJywgJ1NlY29uZExldmVsS2V5MScgXSB9IH0gfSB9IH0pO1xuXG4gICAgdGVzdC5kb25lKCk7XG4gIH0sXG59O1xuIl19

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

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5vdXRwdXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJ0ZXN0Lm91dHB1dC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQ0EsbUNBQTZFO0FBRTdFLGlCQUFTO0lBQ0wsbUNBQW1DLENBQUMsSUFBVTtRQUMxQyxNQUFNLEtBQUssR0FBRyxJQUFJLFdBQUssRUFBRSxDQUFDO1FBQzFCLE1BQU0sR0FBRyxHQUFHLElBQUksY0FBUSxDQUFDLEtBQUssRUFBRSxZQUFZLEVBQUUsRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQztRQUM3RCxNQUFNLEdBQUcsR0FBRyxJQUFJLFNBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUV6QixJQUFJLFlBQU0sQ0FBQyxLQUFLLEVBQUUsVUFBVSxFQUFFO1lBQzFCLE1BQU0sRUFBRSxZQUFZO1lBQ3BCLEtBQUssRUFBRSxHQUFHO1lBQ1YsV0FBVyxFQUFFLG1CQUFtQjtTQUNuQyxDQUFDLENBQUM7UUFDSCxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxnQkFBZ0IsRUFBRSxFQUFFLEVBQUUsU0FBUyxFQUFFLEVBQUUsVUFBVSxFQUFFLEVBQUUsSUFBSSxFQUFFLEdBQUcsRUFBRSxFQUFFO1lBQ25GLE9BQU8sRUFDTixFQUFFLFFBQVEsRUFDUCxFQUFFLFdBQVcsRUFBRSxtQkFBbUI7b0JBQ2hDLE1BQU0sRUFBRSxFQUFFLElBQUksRUFBRSxZQUFZLEVBQUU7b0JBQzlCLEtBQUssRUFBRSxFQUFFLEdBQUcsRUFBRSxZQUFZLEVBQUUsRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQzFDLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNoQixDQUFDO0lBRUQsOEJBQThCLENBQUMsSUFBVTtRQUNyQyxNQUFNLEtBQUssR0FBRyxJQUFJLFdBQUssRUFBRSxDQUFDO1FBQzFCLE1BQU0sTUFBTSxHQUFHLElBQUksWUFBTSxDQUFDLEtBQUssRUFBRSxVQUFVLEVBQUUsRUFBRSxXQUFXLEVBQUUsV0FBVyxFQUFFLENBQUMsQ0FBQztRQUMzRSxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsRUFBRSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUM5QixJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDaEIsQ0FBQztJQUVELDJDQUEyQyxDQUFDLElBQVU7UUFDbEQsTUFBTSxLQUFLLEdBQUcsSUFBSSxXQUFLLENBQUMsU0FBUyxFQUFFLFNBQVMsQ0FBQyxDQUFDO1FBQzlDLE1BQU0sTUFBTSxHQUFHLElBQUksWUFBTSxDQUFDLEtBQUssRUFBRSxVQUFVLENBQUMsQ0FBQztRQUM3QyxNQUFNLEtBQUssR0FBRyxJQUFJLGVBQVMsQ0FBQyxLQUFLLEVBQUUsYUFBYSxDQUFDLENBQUM7UUFDbEQsTUFBTSxPQUFPLEdBQUcsSUFBSSxZQUFNLENBQUMsS0FBSyxFQUFFLFdBQVcsQ0FBQyxDQUFDO1FBQy9DLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLE1BQU0sRUFBRSxrQkFBa0IsQ0FBQyxDQUFDO1FBQzlDLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRSxzQ0FBc0MsQ0FBQyxDQUFDO1FBQ25FLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNoQixDQUFDO0lBRUQsK0RBQStELENBQUMsSUFBVTtRQUN0RSxNQUFNLEtBQUssR0FBRyxJQUFJLFdBQUssRUFBRSxDQUFDO1FBQzFCLE1BQU0sTUFBTSxHQUFHLElBQUksWUFBTSxDQUFDLEtBQUssRUFBRSxVQUFVLEVBQUUsRUFBRSxhQUFhLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztRQUV0RSxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFFaEMsZ0VBQWdFO1FBQ2hFLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxZQUFNLENBQUMsS0FBSyxFQUFFLFlBQVksRUFBRTtZQUM5QyxhQUFhLEVBQUUsSUFBSTtZQUNuQixNQUFNLEVBQUUsS0FBSztTQUNoQixDQUFDLEVBQUUsdURBQXVELENBQUMsQ0FBQztRQUU3RCxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDaEIsQ0FBQztJQUVELGlGQUFpRixDQUFDLElBQVU7UUFDeEYsTUFBTSxLQUFLLEdBQUcsSUFBSSxXQUFLLEVBQUUsQ0FBQztRQUMxQixNQUFNLE1BQU0sR0FBRyxJQUFJLFlBQU0sQ0FBQyxLQUFLLEVBQUUsVUFBVSxDQUFDLENBQUM7UUFDN0MsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsTUFBTSxFQUFFLFVBQVUsQ0FBQyxDQUFDO1FBQ3RDLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNoQixDQUFDO0lBRUQseUVBQXlFLENBQUMsSUFBVTtRQUNoRixNQUFNLEtBQUssR0FBRyxJQUFJLFdBQUssQ0FBQyxTQUFTLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDOUMsTUFBTSxNQUFNLEdBQUcsSUFBSSxZQUFNLENBQUMsS0FBSyxFQUFFLFVBQVUsQ0FBQyxDQUFDO1FBQzdDLElBQUksQ0FBQyxTQUFTLENBQUMsYUFBTyxDQUFDLE1BQU0sQ0FBQyxlQUFlLEVBQUUsQ0FBQyxFQUFFLEVBQUUsaUJBQWlCLEVBQUUsa0JBQWtCLEVBQUUsQ0FBQyxDQUFDO1FBQzdGLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNoQixDQUFDO0NBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRlc3QgfSBmcm9tICdub2RldW5pdCc7XG5pbXBvcnQgeyBDb25zdHJ1Y3QsIE91dHB1dCwgUmVmLCByZXNvbHZlLCBSZXNvdXJjZSwgU3RhY2sgfSBmcm9tICcuLi8uLi9saWInO1xuXG5leHBvcnQgPSB7XG4gICAgJ291dHB1dHMgY2FuIGJlIGFkZGVkIHRvIHRoZSBzdGFjaycodGVzdDogVGVzdCkge1xuICAgICAgICBjb25zdCBzdGFjayA9IG5ldyBTdGFjaygpO1xuICAgICAgICBjb25zdCByZXMgPSBuZXcgUmVzb3VyY2Uoc3RhY2ssICdNeVJlc291cmNlJywgeyB0eXBlOiAnUicgfSk7XG4gICAgICAgIGNvbnN0IHJlZiA9IG5ldyBSZWYocmVzKTtcblxuICAgICAgICBuZXcgT3V0cHV0KHN0YWNrLCAnTXlPdXRwdXQnLCB7XG4gICAgICAgICAgICBleHBvcnQ6ICdFeHBvcnROYW1lJyxcbiAgICAgICAgICAgIHZhbHVlOiByZWYsXG4gICAgICAgICAgICBkZXNjcmlwdGlvbjogJ091dHB1dCBwcm9wZXJ0aWVzJ1xuICAgICAgICB9KTtcbiAgICAgICAgdGVzdC5kZWVwRXF1YWwoc3RhY2sudG9DbG91ZEZvcm1hdGlvbigpLCB7IFJlc291cmNlczogeyBNeVJlc291cmNlOiB7IFR5cGU6ICdSJyB9IH0sXG4gICAgICAgIE91dHB1dHM6XG4gICAgICAgICB7IE15T3V0cHV0OlxuICAgICAgICAgICAgeyBEZXNjcmlwdGlvbjogJ091dHB1dCBwcm9wZXJ0aWVzJyxcbiAgICAgICAgICAgICAgRXhwb3J0OiB7IE5hbWU6ICdFeHBvcnROYW1lJyB9LFxuICAgICAgICAgICAgICBWYWx1ZTogeyBSZWY6ICdNeVJlc291cmNlJyB9IH0gfSB9KTtcbiAgICAgICAgdGVzdC5kb25lKCk7XG4gICAgfSxcblxuICAgICdvdXRwdXRzIGNhbm5vdCBiZSByZWZlcmVuY2VkJyh0ZXN0OiBUZXN0KSB7XG4gICAgICAgIGNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKCk7XG4gICAgICAgIGNvbnN0IG91dHB1dCA9IG5ldyBPdXRwdXQoc3RhY2ssICdNeU91dHB1dCcsIHsgZGVzY3JpcHRpb246ICdNeSBPdXRwdXQnIH0pO1xuICAgICAgICB0ZXN0LnRocm93cygoKSA9PiBvdXRwdXQucmVmKTtcbiAgICAgICAgdGVzdC5kb25lKCk7XG4gICAgfSxcblxuICAgICdvdXRwdXRzIGhhdmUgYSBkZWZhdWx0IHVuaXF1ZSBleHBvcnQgbmFtZScodGVzdDogVGVzdCkge1xuICAgICAgICBjb25zdCBzdGFjayA9IG5ldyBTdGFjayh1bmRlZmluZWQsICdNeVN0YWNrJyk7XG4gICAgICAgIGNvbnN0IG91dHB1dCA9IG5ldyBPdXRwdXQoc3RhY2ssICdNeU91dHB1dCcpO1xuICAgICAgICBjb25zdCBjaGlsZCA9IG5ldyBDb25zdHJ1Y3Qoc3RhY2ssICdNeUNvbnN0cnVjdCcpO1xuICAgICAgICBjb25zdCBvdXRwdXQyID0gbmV3IE91dHB1dChjaGlsZCwgJ015T3V0cHV0MicpO1xuICAgICAgICB0ZXN0LmVxdWFsKG91dHB1dC5leHBvcnQsICdNeVN0YWNrOk15T3V0cHV0Jyk7XG4gICAgICAgIHRlc3QuZXF1YWwob3V0cHV0Mi5leHBvcnQsICdNeVN0YWNrOk15Q29uc3RydWN0TXlPdXRwdXQyNTUzMjJEMTUnKTtcbiAgICAgICAgdGVzdC5kb25lKCk7XG4gICAgfSxcblxuICAgICdkaXNhYmxlRXhwb3J0IGNhbiBiZSB1c2VkIHRvIGRpc2FibGUgdGhlIGF1dG8tZXhwb3J0IGJlaGF2aW9yJyh0ZXN0OiBUZXN0KSB7XG4gICAgICAgIGNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKCk7XG4gICAgICAgIGNvbnN0IG91dHB1dCA9IG5ldyBPdXRwdXQoc3RhY2ssICdNeU91dHB1dCcsIHsgZGlzYWJsZUV4cG9ydDogdHJ1ZSB9KTtcblxuICAgICAgICB0ZXN0LmVxdWFsKG91dHB1dC5leHBvcnQsIG51bGwpO1xuXG4gICAgICAgIC8vIGNhbm5vdCBzcGVjaWZ5IGBleHBvcnRgIGFuZCBgZGlzYWJsZUV4cG9ydGAgYXQgdGhlIHNhbWUgdGltZS5cbiAgICAgICAgdGVzdC50aHJvd3MoKCkgPT4gbmV3IE91dHB1dChzdGFjaywgJ1lvdXJPdXRwdXQnLCB7XG4gICAgICAgICAgICBkaXNhYmxlRXhwb3J0OiB0cnVlLFxuICAgICAgICAgICAgZXhwb3J0OiAnYmxhJ1xuICAgICAgICB9KSwgL0Nhbm5vdCBzZXQgYGRpc2FibGVFeHBvcnRgIGFuZCBzcGVjaWZ5IGFuIGV4cG9ydCBuYW1lLyk7XG5cbiAgICAgICAgdGVzdC5kb25lKCk7XG4gICAgfSxcblxuICAgICdpcyBzdGFjayBuYW1lIGlzIHVuZGVmaW5lZCwgd2Ugd2lsbCBvbmx5IHVzZSB0aGUgbG9naWNhbCBJRCBmb3IgdGhlIGV4cG9ydCBuYW1lJyh0ZXN0OiBUZXN0KSB7XG4gICAgICAgIGNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKCk7XG4gICAgICAgIGNvbnN0IG91dHB1dCA9IG5ldyBPdXRwdXQoc3RhY2ssICdNeU91dHB1dCcpO1xuICAgICAgICB0ZXN0LmVxdWFsKG91dHB1dC5leHBvcnQsICdNeU91dHB1dCcpO1xuICAgICAgICB0ZXN0LmRvbmUoKTtcbiAgICB9LFxuXG4gICAgJ21ha2VJbXBvcnRWYWx1ZSBjYW4gYmUgdXNlZCB0byBjcmVhdGUgYW4gRm46OkltcG9ydFZhbHVlIGZyb20gYW4gb3V0cHV0Jyh0ZXN0OiBUZXN0KSB7XG4gICAgICAgIGNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKHVuZGVmaW5lZCwgJ015U3RhY2snKTtcbiAgICAgICAgY29uc3Qgb3V0cHV0ID0gbmV3IE91dHB1dChzdGFjaywgJ015T3V0cHV0Jyk7XG4gICAgICAgIHRlc3QuZGVlcEVxdWFsKHJlc29sdmUob3V0cHV0Lm1ha2VJbXBvcnRWYWx1ZSgpKSwgeyAnRm46OkltcG9ydFZhbHVlJzogJ015U3RhY2s6TXlPdXRwdXQnIH0pO1xuICAgICAgICB0ZXN0LmRvbmUoKTtcbiAgICB9XG59O1xuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5vdXRwdXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJ0ZXN0Lm91dHB1dC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQ0EsbUNBQTZFO0FBRTdFLGlCQUFTO0lBQ1AsbUNBQW1DLENBQUMsSUFBVTtRQUM1QyxNQUFNLEtBQUssR0FBRyxJQUFJLFdBQUssRUFBRSxDQUFDO1FBQzFCLE1BQU0sR0FBRyxHQUFHLElBQUksY0FBUSxDQUFDLEtBQUssRUFBRSxZQUFZLEVBQUUsRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQztRQUM3RCxNQUFNLEdBQUcsR0FBRyxJQUFJLFNBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUV6QixJQUFJLFlBQU0sQ0FBQyxLQUFLLEVBQUUsVUFBVSxFQUFFO1lBQzVCLE1BQU0sRUFBRSxZQUFZO1lBQ3BCLEtBQUssRUFBRSxHQUFHO1lBQ1YsV0FBVyxFQUFFLG1CQUFtQjtTQUNqQyxDQUFDLENBQUM7UUFDSCxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxnQkFBZ0IsRUFBRSxFQUFFLEVBQUUsU0FBUyxFQUFFLEVBQUUsVUFBVSxFQUFFLEVBQUUsSUFBSSxFQUFFLEdBQUcsRUFBRSxFQUFFO1lBQ25GLE9BQU8sRUFDTixFQUFFLFFBQVEsRUFDVCxFQUFFLFdBQVcsRUFBRSxtQkFBbUI7b0JBQ2hDLE1BQU0sRUFBRSxFQUFFLElBQUksRUFBRSxZQUFZLEVBQUU7b0JBQzlCLEtBQUssRUFBRSxFQUFFLEdBQUcsRUFBRSxZQUFZLEVBQUUsRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQ3hDLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNkLENBQUM7SUFFRCw4QkFBOEIsQ0FBQyxJQUFVO1FBQ3ZDLE1BQU0sS0FBSyxHQUFHLElBQUksV0FBSyxFQUFFLENBQUM7UUFDMUIsTUFBTSxNQUFNLEdBQUcsSUFBSSxZQUFNLENBQUMsS0FBSyxFQUFFLFVBQVUsRUFBRSxFQUFFLFdBQVcsRUFBRSxXQUFXLEVBQUUsQ0FBQyxDQUFDO1FBQzNFLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxFQUFFLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQzlCLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNkLENBQUM7SUFFRCwyQ0FBMkMsQ0FBQyxJQUFVO1FBQ3BELE1BQU0sS0FBSyxHQUFHLElBQUksV0FBSyxDQUFDLFNBQVMsRUFBRSxTQUFTLENBQUMsQ0FBQztRQUM5QyxNQUFNLE1BQU0sR0FBRyxJQUFJLFlBQU0sQ0FBQyxLQUFLLEVBQUUsVUFBVSxDQUFDLENBQUM7UUFDN0MsTUFBTSxLQUFLLEdBQUcsSUFBSSxlQUFTLENBQUMsS0FBSyxFQUFFLGFBQWEsQ0FBQyxDQUFDO1FBQ2xELE1BQU0sT0FBTyxHQUFHLElBQUksWUFBTSxDQUFDLEtBQUssRUFBRSxXQUFXLENBQUMsQ0FBQztRQUMvQyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsa0JBQWtCLENBQUMsQ0FBQztRQUM5QyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxNQUFNLEVBQUUsc0NBQXNDLENBQUMsQ0FBQztRQUNuRSxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDZCxDQUFDO0lBRUQsK0RBQStELENBQUMsSUFBVTtRQUN4RSxNQUFNLEtBQUssR0FBRyxJQUFJLFdBQUssRUFBRSxDQUFDO1FBQzFCLE1BQU0sTUFBTSxHQUFHLElBQUksWUFBTSxDQUFDLEtBQUssRUFBRSxVQUFVLEVBQUUsRUFBRSxhQUFhLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztRQUV0RSxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFFaEMsZ0VBQWdFO1FBQ2hFLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxZQUFNLENBQUMsS0FBSyxFQUFFLFlBQVksRUFBRTtZQUNoRCxhQUFhLEVBQUUsSUFBSTtZQUNuQixNQUFNLEVBQUUsS0FBSztTQUNkLENBQUMsRUFBRSx1REFBdUQsQ0FBQyxDQUFDO1FBRTdELElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNkLENBQUM7SUFFRCxpRkFBaUYsQ0FBQyxJQUFVO1FBQzFGLE1BQU0sS0FBSyxHQUFHLElBQUksV0FBSyxFQUFFLENBQUM7UUFDMUIsTUFBTSxNQUFNLEdBQUcsSUFBSSxZQUFNLENBQUMsS0FBSyxFQUFFLFVBQVUsQ0FBQyxDQUFDO1FBQzdDLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLE1BQU0sRUFBRSxVQUFVLENBQUMsQ0FBQztRQUN0QyxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDZCxDQUFDO0lBRUQseUVBQXlFLENBQUMsSUFBVTtRQUNsRixNQUFNLEtBQUssR0FBRyxJQUFJLFdBQUssQ0FBQyxTQUFTLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDOUMsTUFBTSxNQUFNLEdBQUcsSUFBSSxZQUFNLENBQUMsS0FBSyxFQUFFLFVBQVUsQ0FBQyxDQUFDO1FBQzdDLElBQUksQ0FBQyxTQUFTLENBQUMsYUFBTyxDQUFDLE1BQU0sQ0FBQyxlQUFlLEVBQUUsQ0FBQyxFQUFFLEVBQUUsaUJBQWlCLEVBQUUsa0JBQWtCLEVBQUUsQ0FBQyxDQUFDO1FBQzdGLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNkLENBQUM7Q0FDRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGVzdCB9IGZyb20gJ25vZGV1bml0JztcbmltcG9ydCB7IENvbnN0cnVjdCwgT3V0cHV0LCBSZWYsIHJlc29sdmUsIFJlc291cmNlLCBTdGFjayB9IGZyb20gJy4uLy4uL2xpYic7XG5cbmV4cG9ydCA9IHtcbiAgJ291dHB1dHMgY2FuIGJlIGFkZGVkIHRvIHRoZSBzdGFjaycodGVzdDogVGVzdCkge1xuICAgIGNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKCk7XG4gICAgY29uc3QgcmVzID0gbmV3IFJlc291cmNlKHN0YWNrLCAnTXlSZXNvdXJjZScsIHsgdHlwZTogJ1InIH0pO1xuICAgIGNvbnN0IHJlZiA9IG5ldyBSZWYocmVzKTtcblxuICAgIG5ldyBPdXRwdXQoc3RhY2ssICdNeU91dHB1dCcsIHtcbiAgICAgIGV4cG9ydDogJ0V4cG9ydE5hbWUnLFxuICAgICAgdmFsdWU6IHJlZixcbiAgICAgIGRlc2NyaXB0aW9uOiAnT3V0cHV0IHByb3BlcnRpZXMnXG4gICAgfSk7XG4gICAgdGVzdC5kZWVwRXF1YWwoc3RhY2sudG9DbG91ZEZvcm1hdGlvbigpLCB7IFJlc291cmNlczogeyBNeVJlc291cmNlOiB7IFR5cGU6ICdSJyB9IH0sXG4gICAgT3V0cHV0czpcbiAgICAgeyBNeU91dHB1dDpcbiAgICAgIHsgRGVzY3JpcHRpb246ICdPdXRwdXQgcHJvcGVydGllcycsXG4gICAgICAgIEV4cG9ydDogeyBOYW1lOiAnRXhwb3J0TmFtZScgfSxcbiAgICAgICAgVmFsdWU6IHsgUmVmOiAnTXlSZXNvdXJjZScgfSB9IH0gfSk7XG4gICAgdGVzdC5kb25lKCk7XG4gIH0sXG5cbiAgJ291dHB1dHMgY2Fubm90IGJlIHJlZmVyZW5jZWQnKHRlc3Q6IFRlc3QpIHtcbiAgICBjb25zdCBzdGFjayA9IG5ldyBTdGFjaygpO1xuICAgIGNvbnN0IG91dHB1dCA9IG5ldyBPdXRwdXQoc3RhY2ssICdNeU91dHB1dCcsIHsgZGVzY3JpcHRpb246ICdNeSBPdXRwdXQnIH0pO1xuICAgIHRlc3QudGhyb3dzKCgpID0+IG91dHB1dC5yZWYpO1xuICAgIHRlc3QuZG9uZSgpO1xuICB9LFxuXG4gICdvdXRwdXRzIGhhdmUgYSBkZWZhdWx0IHVuaXF1ZSBleHBvcnQgbmFtZScodGVzdDogVGVzdCkge1xuICAgIGNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKHVuZGVmaW5lZCwgJ015U3RhY2snKTtcbiAgICBjb25zdCBvdXRwdXQgPSBuZXcgT3V0cHV0KHN0YWNrLCAnTXlPdXRwdXQnKTtcbiAgICBjb25zdCBjaGlsZCA9IG5ldyBDb25zdHJ1Y3Qoc3RhY2ssICdNeUNvbnN0cnVjdCcpO1xuICAgIGNvbnN0IG91dHB1dDIgPSBuZXcgT3V0cHV0KGNoaWxkLCAnTXlPdXRwdXQyJyk7XG4gICAgdGVzdC5lcXVhbChvdXRwdXQuZXhwb3J0LCAnTXlTdGFjazpNeU91dHB1dCcpO1xuICAgIHRlc3QuZXF1YWwob3V0cHV0Mi5leHBvcnQsICdNeVN0YWNrOk15Q29uc3RydWN0TXlPdXRwdXQyNTUzMjJEMTUnKTtcbiAgICB0ZXN0LmRvbmUoKTtcbiAgfSxcblxuICAnZGlzYWJsZUV4cG9ydCBjYW4gYmUgdXNlZCB0byBkaXNhYmxlIHRoZSBhdXRvLWV4cG9ydCBiZWhhdmlvcicodGVzdDogVGVzdCkge1xuICAgIGNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKCk7XG4gICAgY29uc3Qgb3V0cHV0ID0gbmV3IE91dHB1dChzdGFjaywgJ015T3V0cHV0JywgeyBkaXNhYmxlRXhwb3J0OiB0cnVlIH0pO1xuXG4gICAgdGVzdC5lcXVhbChvdXRwdXQuZXhwb3J0LCBudWxsKTtcblxuICAgIC8vIGNhbm5vdCBzcGVjaWZ5IGBleHBvcnRgIGFuZCBgZGlzYWJsZUV4cG9ydGAgYXQgdGhlIHNhbWUgdGltZS5cbiAgICB0ZXN0LnRocm93cygoKSA9PiBuZXcgT3V0cHV0KHN0YWNrLCAnWW91ck91dHB1dCcsIHtcbiAgICAgIGRpc2FibGVFeHBvcnQ6IHRydWUsXG4gICAgICBleHBvcnQ6ICdibGEnXG4gICAgfSksIC9DYW5ub3Qgc2V0IGBkaXNhYmxlRXhwb3J0YCBhbmQgc3BlY2lmeSBhbiBleHBvcnQgbmFtZS8pO1xuXG4gICAgdGVzdC5kb25lKCk7XG4gIH0sXG5cbiAgJ2lzIHN0YWNrIG5hbWUgaXMgdW5kZWZpbmVkLCB3ZSB3aWxsIG9ubHkgdXNlIHRoZSBsb2dpY2FsIElEIGZvciB0aGUgZXhwb3J0IG5hbWUnKHRlc3Q6IFRlc3QpIHtcbiAgICBjb25zdCBzdGFjayA9IG5ldyBTdGFjaygpO1xuICAgIGNvbnN0IG91dHB1dCA9IG5ldyBPdXRwdXQoc3RhY2ssICdNeU91dHB1dCcpO1xuICAgIHRlc3QuZXF1YWwob3V0cHV0LmV4cG9ydCwgJ015T3V0cHV0Jyk7XG4gICAgdGVzdC5kb25lKCk7XG4gIH0sXG5cbiAgJ21ha2VJbXBvcnRWYWx1ZSBjYW4gYmUgdXNlZCB0byBjcmVhdGUgYW4gRm46OkltcG9ydFZhbHVlIGZyb20gYW4gb3V0cHV0Jyh0ZXN0OiBUZXN0KSB7XG4gICAgY29uc3Qgc3RhY2sgPSBuZXcgU3RhY2sodW5kZWZpbmVkLCAnTXlTdGFjaycpO1xuICAgIGNvbnN0IG91dHB1dCA9IG5ldyBPdXRwdXQoc3RhY2ssICdNeU91dHB1dCcpO1xuICAgIHRlc3QuZGVlcEVxdWFsKHJlc29sdmUob3V0cHV0Lm1ha2VJbXBvcnRWYWx1ZSgpKSwgeyAnRm46OkltcG9ydFZhbHVlJzogJ015U3RhY2s6TXlPdXRwdXQnIH0pO1xuICAgIHRlc3QuZG9uZSgpO1xuICB9XG59O1xuIl19

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

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5wYXJhbWV0ZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJ0ZXN0LnBhcmFtZXRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQ0EsbUNBQTJFO0FBRTNFLGlCQUFTO0lBQ0wsdURBQXVELENBQUMsSUFBVTtRQUM5RCxNQUFNLEtBQUssR0FBRyxJQUFJLFdBQUssRUFBRSxDQUFDO1FBRTFCLE1BQU0sS0FBSyxHQUFHLElBQUksZUFBUyxDQUFDLEtBQUssRUFBRSxPQUFPLENBQUMsQ0FBQztRQUM1QyxNQUFNLEtBQUssR0FBRyxJQUFJLGVBQVMsQ0FBQyxLQUFLLEVBQUUsU0FBUyxFQUFFO1lBQzFDLE9BQU8sRUFBRSxFQUFFO1lBQ1gsSUFBSSxFQUFFLFNBQVM7WUFDZixXQUFXLEVBQUUsb0JBQW9CO1NBQ3BDLENBQUMsQ0FBQztRQUVILElBQUksY0FBUSxDQUFDLEtBQUssRUFBRSxVQUFVLEVBQUUsRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxFQUFFLGdCQUFnQixFQUFFLEtBQUssQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFL0YsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsZ0JBQWdCLEVBQUUsRUFBRTtZQUNyQyxVQUFVLEVBQUU7Z0JBQ1IsQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLEVBQUU7b0JBQ2YsT0FBTyxFQUFFLEVBQUU7b0JBQ1gsSUFBSSxFQUFFLFNBQVM7b0JBQ2YsV0FBVyxFQUFFLG9CQUFvQjtpQkFBRTthQUFFO1lBQzdDLFNBQVMsRUFBRTtnQkFDUCxRQUFRLEVBQUU7b0JBQ04sSUFBSSxFQUFFLE1BQU07b0JBQ1osVUFBVSxFQUFFLEVBQUUsZ0JBQWdCLEVBQUUsRUFBRSxHQUFHLEVBQUUsS0FBSyxDQUFDLFNBQVMsRUFBRSxFQUFFO2lCQUFFO2FBQUU7U0FBRSxDQUFDLENBQUM7UUFFOUUsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ2hCLENBQUM7SUFFRCx5RkFBeUYsQ0FBQyxJQUFVO1FBQ2hHLE1BQU0sS0FBSyxHQUFHLElBQUksV0FBSyxFQUFFLENBQUM7UUFDMUIsTUFBTSxLQUFLLEdBQUcsSUFBSSxlQUFTLENBQUMsS0FBSyxFQUFFLFNBQVMsRUFBRSxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsQ0FBQyxDQUFDO1FBRWxFLElBQUksQ0FBQyxTQUFTLENBQUMsYUFBTyxDQUFDLEtBQUssQ0FBQyxFQUFFLEVBQUUsR0FBRyxFQUFFLFNBQVMsRUFBRSxDQUFDLENBQUM7UUFDbkQsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ2hCLENBQUM7Q0FDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGVzdCB9IGZyb20gJ25vZGV1bml0JztcbmltcG9ydCB7IENvbnN0cnVjdCwgUGFyYW1ldGVyLCByZXNvbHZlLCBSZXNvdXJjZSwgU3RhY2sgfSBmcm9tICcuLi8uLi9saWInO1xuXG5leHBvcnQgPSB7XG4gICAgJ3BhcmFtZXRlcnMgY2FuIGJlIHVzZWQgYW5kIHJlZmVyZW5jZWQgdXNpbmcgcGFyYW0ucmVmJyh0ZXN0OiBUZXN0KSB7XG4gICAgICAgIGNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKCk7XG5cbiAgICAgICAgY29uc3QgY2hpbGQgPSBuZXcgQ29uc3RydWN0KHN0YWNrLCAnQ2hpbGQnKTtcbiAgICAgICAgY29uc3QgcGFyYW0gPSBuZXcgUGFyYW1ldGVyKGNoaWxkLCAnTXlQYXJhbScsIHtcbiAgICAgICAgICAgIGRlZmF1bHQ6IDEwLFxuICAgICAgICAgICAgdHlwZTogJ0ludGVnZXInLFxuICAgICAgICAgICAgZGVzY3JpcHRpb246ICdNeSBmaXJzdCBwYXJhbWV0ZXInXG4gICAgICAgIH0pO1xuXG4gICAgICAgIG5ldyBSZXNvdXJjZShzdGFjaywgJ1Jlc291cmNlJywgeyB0eXBlOiAnVHlwZScsIHByb3BlcnRpZXM6IHsgUmVmZXJlbmNlVG9QYXJhbTogcGFyYW0ucmVmIH0gfSk7XG5cbiAgICAgICAgdGVzdC5kZWVwRXF1YWwoc3RhY2sudG9DbG91ZEZvcm1hdGlvbigpLCB7XG4gICAgICAgICAgICBQYXJhbWV0ZXJzOiB7XG4gICAgICAgICAgICAgICAgW3BhcmFtLmxvZ2ljYWxJZF06IHtcbiAgICAgICAgICAgICAgICAgICAgRGVmYXVsdDogMTAsXG4gICAgICAgICAgICAgICAgICAgIFR5cGU6ICdJbnRlZ2VyJyxcbiAgICAgICAgICAgICAgICAgICAgRGVzY3JpcHRpb246ICdNeSBmaXJzdCBwYXJhbWV0ZXInIH0gfSxcbiAgICAgICAgICAgIFJlc291cmNlczoge1xuICAgICAgICAgICAgICAgIFJlc291cmNlOiB7XG4gICAgICAgICAgICAgICAgICAgIFR5cGU6ICdUeXBlJyxcbiAgICAgICAgICAgICAgICAgICAgUHJvcGVydGllczogeyBSZWZlcmVuY2VUb1BhcmFtOiB7IFJlZjogcGFyYW0ubG9naWNhbElkIH0gfSB9IH0gfSk7XG5cbiAgICAgICAgdGVzdC5kb25lKCk7XG4gICAgfSxcblxuICAgICdwYXJhbWV0ZXJzIGFyZSB0b2tlbnMsIHNvIHRoZXkgY2FuIGJlIGFzc2lnbmVkIHdpdGhvdXQgLnJlZiBhbmQgdGhlaXIgUmVmIHdpbGwgYmUgdGFrZW4nKHRlc3Q6IFRlc3QpIHtcbiAgICAgICAgY29uc3Qgc3RhY2sgPSBuZXcgU3RhY2soKTtcbiAgICAgICAgY29uc3QgcGFyYW0gPSBuZXcgUGFyYW1ldGVyKHN0YWNrLCAnTXlQYXJhbScsIHsgdHlwZTogJ1N0cmluZycgfSk7XG5cbiAgICAgICAgdGVzdC5kZWVwRXF1YWwocmVzb2x2ZShwYXJhbSksIHsgUmVmOiAnTXlQYXJhbScgfSk7XG4gICAgICAgIHRlc3QuZG9uZSgpO1xuICAgIH1cbn07XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5wYXJhbWV0ZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJ0ZXN0LnBhcmFtZXRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQ0EsbUNBQTJFO0FBRTNFLGlCQUFTO0lBQ1AsdURBQXVELENBQUMsSUFBVTtRQUNoRSxNQUFNLEtBQUssR0FBRyxJQUFJLFdBQUssRUFBRSxDQUFDO1FBRTFCLE1BQU0sS0FBSyxHQUFHLElBQUksZUFBUyxDQUFDLEtBQUssRUFBRSxPQUFPLENBQUMsQ0FBQztRQUM1QyxNQUFNLEtBQUssR0FBRyxJQUFJLGVBQVMsQ0FBQyxLQUFLLEVBQUUsU0FBUyxFQUFFO1lBQzVDLE9BQU8sRUFBRSxFQUFFO1lBQ1gsSUFBSSxFQUFFLFNBQVM7WUFDZixXQUFXLEVBQUUsb0JBQW9CO1NBQ2xDLENBQUMsQ0FBQztRQUVILElBQUksY0FBUSxDQUFDLEtBQUssRUFBRSxVQUFVLEVBQUUsRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxFQUFFLGdCQUFnQixFQUFFLEtBQUssQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFL0YsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsZ0JBQWdCLEVBQUUsRUFBRTtZQUN2QyxVQUFVLEVBQUU7Z0JBQ1YsQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLEVBQUU7b0JBQ2pCLE9BQU8sRUFBRSxFQUFFO29CQUNYLElBQUksRUFBRSxTQUFTO29CQUNmLFdBQVcsRUFBRSxvQkFBb0I7aUJBQUU7YUFBRTtZQUN6QyxTQUFTLEVBQUU7Z0JBQ1QsUUFBUSxFQUFFO29CQUNSLElBQUksRUFBRSxNQUFNO29CQUNaLFVBQVUsRUFBRSxFQUFFLGdCQUFnQixFQUFFLEVBQUUsR0FBRyxFQUFFLEtBQUssQ0FBQyxTQUFTLEVBQUUsRUFBRTtpQkFBRTthQUFFO1NBQUUsQ0FBQyxDQUFDO1FBRXhFLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNkLENBQUM7SUFFRCx5RkFBeUYsQ0FBQyxJQUFVO1FBQ2xHLE1BQU0sS0FBSyxHQUFHLElBQUksV0FBSyxFQUFFLENBQUM7UUFDMUIsTUFBTSxLQUFLLEdBQUcsSUFBSSxlQUFTLENBQUMsS0FBSyxFQUFFLFNBQVMsRUFBRSxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsQ0FBQyxDQUFDO1FBRWxFLElBQUksQ0FBQyxTQUFTLENBQUMsYUFBTyxDQUFDLEtBQUssQ0FBQyxFQUFFLEVBQUUsR0FBRyxFQUFFLFNBQVMsRUFBRSxDQUFDLENBQUM7UUFDbkQsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ2QsQ0FBQztDQUNGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUZXN0IH0gZnJvbSAnbm9kZXVuaXQnO1xuaW1wb3J0IHsgQ29uc3RydWN0LCBQYXJhbWV0ZXIsIHJlc29sdmUsIFJlc291cmNlLCBTdGFjayB9IGZyb20gJy4uLy4uL2xpYic7XG5cbmV4cG9ydCA9IHtcbiAgJ3BhcmFtZXRlcnMgY2FuIGJlIHVzZWQgYW5kIHJlZmVyZW5jZWQgdXNpbmcgcGFyYW0ucmVmJyh0ZXN0OiBUZXN0KSB7XG4gICAgY29uc3Qgc3RhY2sgPSBuZXcgU3RhY2soKTtcblxuICAgIGNvbnN0IGNoaWxkID0gbmV3IENvbnN0cnVjdChzdGFjaywgJ0NoaWxkJyk7XG4gICAgY29uc3QgcGFyYW0gPSBuZXcgUGFyYW1ldGVyKGNoaWxkLCAnTXlQYXJhbScsIHtcbiAgICAgIGRlZmF1bHQ6IDEwLFxuICAgICAgdHlwZTogJ0ludGVnZXInLFxuICAgICAgZGVzY3JpcHRpb246ICdNeSBmaXJzdCBwYXJhbWV0ZXInXG4gICAgfSk7XG5cbiAgICBuZXcgUmVzb3VyY2Uoc3RhY2ssICdSZXNvdXJjZScsIHsgdHlwZTogJ1R5cGUnLCBwcm9wZXJ0aWVzOiB7IFJlZmVyZW5jZVRvUGFyYW06IHBhcmFtLnJlZiB9IH0pO1xuXG4gICAgdGVzdC5kZWVwRXF1YWwoc3RhY2sudG9DbG91ZEZvcm1hdGlvbigpLCB7XG4gICAgICBQYXJhbWV0ZXJzOiB7XG4gICAgICAgIFtwYXJhbS5sb2dpY2FsSWRdOiB7XG4gICAgICAgICAgRGVmYXVsdDogMTAsXG4gICAgICAgICAgVHlwZTogJ0ludGVnZXInLFxuICAgICAgICAgIERlc2NyaXB0aW9uOiAnTXkgZmlyc3QgcGFyYW1ldGVyJyB9IH0sXG4gICAgICBSZXNvdXJjZXM6IHtcbiAgICAgICAgUmVzb3VyY2U6IHtcbiAgICAgICAgICBUeXBlOiAnVHlwZScsXG4gICAgICAgICAgUHJvcGVydGllczogeyBSZWZlcmVuY2VUb1BhcmFtOiB7IFJlZjogcGFyYW0ubG9naWNhbElkIH0gfSB9IH0gfSk7XG5cbiAgICB0ZXN0LmRvbmUoKTtcbiAgfSxcblxuICAncGFyYW1ldGVycyBhcmUgdG9rZW5zLCBzbyB0aGV5IGNhbiBiZSBhc3NpZ25lZCB3aXRob3V0IC5yZWYgYW5kIHRoZWlyIFJlZiB3aWxsIGJlIHRha2VuJyh0ZXN0OiBUZXN0KSB7XG4gICAgY29uc3Qgc3RhY2sgPSBuZXcgU3RhY2soKTtcbiAgICBjb25zdCBwYXJhbSA9IG5ldyBQYXJhbWV0ZXIoc3RhY2ssICdNeVBhcmFtJywgeyB0eXBlOiAnU3RyaW5nJyB9KTtcblxuICAgIHRlc3QuZGVlcEVxdWFsKHJlc29sdmUocGFyYW0pLCB7IFJlZjogJ015UGFyYW0nIH0pO1xuICAgIHRlc3QuZG9uZSgpO1xuICB9XG59O1xuIl19

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

};
//# 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"]}
//# 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"]}

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

'resource.ref returns the {Ref} token'(test: Test): void;
'overrides': {
'addOverride(p, v) allows assigning arbitrary values to synthesized resource definitions'(test: Test): void;
'addOverride(p, null) will assign an "null" value'(test: Test): void;
'addOverride(p, undefined) can be used to delete a value'(test: Test): void;
'addOverride(p, undefined) will not create empty trees'(test: Test): void;
'addDeletionOverride(p) and addPropertyDeletionOverride(pp) are sugar `undefined`'(test: Test): void;
'addOverride(p, v) will overwrite any non-objects along the path'(test: Test): void;
'addPropertyOverride(pp, v) is a sugar for overriding properties'(test: Test): void;
'untypedPropertyOverrides': {
'can be used by derived classes to specify overrides before render()'(test: Test): void;
'"properties" is undefined'(test: Test): void;
'"properties" is empty'(test: Test): void;
};
};
};
export = _default;

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

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5ydWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsidGVzdC5ydWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFDQSxtQ0FBNEU7QUFFNUUsaUJBQVM7SUFDTCxrQ0FBa0MsQ0FBQyxJQUFVO1FBQ3pDLE1BQU0sS0FBSyxHQUFHLElBQUksV0FBSyxFQUFFLENBQUM7UUFFMUIsTUFBTSxJQUFJLEdBQUcsSUFBSSxVQUFJLENBQUMsS0FBSyxFQUFFLFFBQVEsQ0FBQyxDQUFDO1FBQ3ZDLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxjQUFRLENBQUMsS0FBSyxFQUFFLEtBQUssQ0FBQyxFQUFFLGdCQUFnQixDQUFDLENBQUM7UUFDaEUsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLFdBQUssQ0FBQyxJQUFJLFdBQUssQ0FBQyxJQUFJLGdCQUFVLENBQUMsQ0FBRSxPQUFPLEVBQUUsT0FBTyxDQUFFLEVBQUUsT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFLGdCQUFnQixDQUFDLENBQUM7UUFFekcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsZ0JBQWdCLEVBQUUsRUFBRTtZQUNyQyxLQUFLLEVBQUU7Z0JBQ0gsTUFBTSxFQUFFO29CQUNKLFVBQVUsRUFBRTt3QkFDUjs0QkFDSSxNQUFNLEVBQUUsRUFBRSxZQUFZLEVBQUUsQ0FBRSxLQUFLLEVBQUUsS0FBSyxDQUFFLEVBQUU7NEJBQzFDLGlCQUFpQixFQUFFLGdCQUFnQjt5QkFDdEM7d0JBQ0Q7NEJBQ0ksTUFBTSxFQUFFLEVBQUUsU0FBUyxFQUFFLENBQUUsRUFBRSxTQUFTLEVBQUUsQ0FBRSxFQUFFLGNBQWMsRUFBRSxDQUFFLENBQUUsT0FBTyxFQUFFLE9BQU8sQ0FBRSxFQUFFLE9BQU8sQ0FBRSxFQUFFLENBQUUsRUFBRSxDQUFFLEVBQUU7NEJBQ25HLGlCQUFpQixFQUFFLGdCQUFnQjt5QkFDdEM7cUJBQ0o7aUJBQ0o7YUFDSjtTQUNKLENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNoQixDQUFDO0NBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRlc3QgfSBmcm9tICdub2RldW5pdCc7XG5pbXBvcnQgeyBGbkFuZCwgRm5Db250YWlucywgRm5FcXVhbHMsIEZuTm90LCBSdWxlLCBTdGFjayB9IGZyb20gJy4uLy4uL2xpYic7XG5cbmV4cG9ydCA9IHtcbiAgICAnUnVsZSBjYW4gYmUgdXNlZCB0byBjcmVhdGUgcnVsZXMnKHRlc3Q6IFRlc3QpIHtcbiAgICAgICAgY29uc3Qgc3RhY2sgPSBuZXcgU3RhY2soKTtcblxuICAgICAgICBjb25zdCBydWxlID0gbmV3IFJ1bGUoc3RhY2ssICdNeVJ1bGUnKTtcbiAgICAgICAgcnVsZS5hZGRBc3NlcnRpb24obmV3IEZuRXF1YWxzKCdsaHMnLCAncmhzJyksICdsaHMgZXF1YWxzIHJocycpO1xuICAgICAgICBydWxlLmFkZEFzc2VydGlvbihuZXcgRm5Ob3QobmV3IEZuQW5kKG5ldyBGbkNvbnRhaW5zKFsgJ2hlbGxvJywgJ3dvcmxkJyBdLCBcIndvcmxkXCIpKSksICdzb21lIGFzc2VydGlvbicpO1xuXG4gICAgICAgIHRlc3QuZGVlcEVxdWFsKHN0YWNrLnRvQ2xvdWRGb3JtYXRpb24oKSwge1xuICAgICAgICAgICAgUnVsZXM6IHtcbiAgICAgICAgICAgICAgICBNeVJ1bGU6IHtcbiAgICAgICAgICAgICAgICAgICAgQXNzZXJ0aW9uczogW1xuICAgICAgICAgICAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIEFzc2VydDogeyAnRm46OkVxdWFscyc6IFsgJ2xocycsICdyaHMnIF0gfSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBBc3NlcnREZXNjcmlwdGlvbjogJ2xocyBlcXVhbHMgcmhzJ1xuICAgICAgICAgICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBBc3NlcnQ6IHsgJ0ZuOjpOb3QnOiBbIHsgJ0ZuOjpBbmQnOiBbIHsgJ0ZuOjpDb250YWlucyc6IFsgWyAnaGVsbG8nLCAnd29ybGQnIF0sICd3b3JsZCcgXSB9IF0gfSBdIH0sXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgQXNzZXJ0RGVzY3JpcHRpb246ICdzb21lIGFzc2VydGlvbidcbiAgICAgICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgXVxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgfSk7XG5cbiAgICAgICAgdGVzdC5kb25lKCk7XG4gICAgfVxufTtcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5ydWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsidGVzdC5ydWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFDQSxtQ0FBNEU7QUFFNUUsaUJBQVM7SUFDUCxrQ0FBa0MsQ0FBQyxJQUFVO1FBQzNDLE1BQU0sS0FBSyxHQUFHLElBQUksV0FBSyxFQUFFLENBQUM7UUFFMUIsTUFBTSxJQUFJLEdBQUcsSUFBSSxVQUFJLENBQUMsS0FBSyxFQUFFLFFBQVEsQ0FBQyxDQUFDO1FBQ3ZDLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxjQUFRLENBQUMsS0FBSyxFQUFFLEtBQUssQ0FBQyxFQUFFLGdCQUFnQixDQUFDLENBQUM7UUFDaEUsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLFdBQUssQ0FBQyxJQUFJLFdBQUssQ0FBQyxJQUFJLGdCQUFVLENBQUMsQ0FBRSxPQUFPLEVBQUUsT0FBTyxDQUFFLEVBQUUsT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFLGdCQUFnQixDQUFDLENBQUM7UUFFekcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsZ0JBQWdCLEVBQUUsRUFBRTtZQUN2QyxLQUFLLEVBQUU7Z0JBQ0wsTUFBTSxFQUFFO29CQUNOLFVBQVUsRUFBRTt3QkFDVjs0QkFDRSxNQUFNLEVBQUUsRUFBRSxZQUFZLEVBQUUsQ0FBRSxLQUFLLEVBQUUsS0FBSyxDQUFFLEVBQUU7NEJBQzFDLGlCQUFpQixFQUFFLGdCQUFnQjt5QkFDcEM7d0JBQ0Q7NEJBQ0UsTUFBTSxFQUFFLEVBQUUsU0FBUyxFQUFFLENBQUUsRUFBRSxTQUFTLEVBQUUsQ0FBRSxFQUFFLGNBQWMsRUFBRSxDQUFFLENBQUUsT0FBTyxFQUFFLE9BQU8sQ0FBRSxFQUFFLE9BQU8sQ0FBRSxFQUFFLENBQUUsRUFBRSxDQUFFLEVBQUU7NEJBQ25HLGlCQUFpQixFQUFFLGdCQUFnQjt5QkFDcEM7cUJBQ0Y7aUJBQ0Y7YUFDRjtTQUNGLENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNkLENBQUM7Q0FDRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGVzdCB9IGZyb20gJ25vZGV1bml0JztcbmltcG9ydCB7IEZuQW5kLCBGbkNvbnRhaW5zLCBGbkVxdWFscywgRm5Ob3QsIFJ1bGUsIFN0YWNrIH0gZnJvbSAnLi4vLi4vbGliJztcblxuZXhwb3J0ID0ge1xuICAnUnVsZSBjYW4gYmUgdXNlZCB0byBjcmVhdGUgcnVsZXMnKHRlc3Q6IFRlc3QpIHtcbiAgICBjb25zdCBzdGFjayA9IG5ldyBTdGFjaygpO1xuXG4gICAgY29uc3QgcnVsZSA9IG5ldyBSdWxlKHN0YWNrLCAnTXlSdWxlJyk7XG4gICAgcnVsZS5hZGRBc3NlcnRpb24obmV3IEZuRXF1YWxzKCdsaHMnLCAncmhzJyksICdsaHMgZXF1YWxzIHJocycpO1xuICAgIHJ1bGUuYWRkQXNzZXJ0aW9uKG5ldyBGbk5vdChuZXcgRm5BbmQobmV3IEZuQ29udGFpbnMoWyAnaGVsbG8nLCAnd29ybGQnIF0sIFwid29ybGRcIikpKSwgJ3NvbWUgYXNzZXJ0aW9uJyk7XG5cbiAgICB0ZXN0LmRlZXBFcXVhbChzdGFjay50b0Nsb3VkRm9ybWF0aW9uKCksIHtcbiAgICAgIFJ1bGVzOiB7XG4gICAgICAgIE15UnVsZToge1xuICAgICAgICAgIEFzc2VydGlvbnM6IFtcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgQXNzZXJ0OiB7ICdGbjo6RXF1YWxzJzogWyAnbGhzJywgJ3JocycgXSB9LFxuICAgICAgICAgICAgICBBc3NlcnREZXNjcmlwdGlvbjogJ2xocyBlcXVhbHMgcmhzJ1xuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgQXNzZXJ0OiB7ICdGbjo6Tm90JzogWyB7ICdGbjo6QW5kJzogWyB7ICdGbjo6Q29udGFpbnMnOiBbIFsgJ2hlbGxvJywgJ3dvcmxkJyBdLCAnd29ybGQnIF0gfSBdIH0gXSB9LFxuICAgICAgICAgICAgICBBc3NlcnREZXNjcmlwdGlvbjogJ3NvbWUgYXNzZXJ0aW9uJ1xuICAgICAgICAgICAgfVxuICAgICAgICAgIF1cbiAgICAgICAgfVxuICAgICAgfVxuICAgIH0pO1xuXG4gICAgdGVzdC5kb25lKCk7XG4gIH1cbn07XG4iXX0=

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

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5zZWNyZXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJ0ZXN0LnNlY3JldC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQ0EsbUNBQW9FO0FBRXBFLGlCQUFTO0lBQ0wsMEJBQTBCLENBQUMsSUFBVTtRQUNqQyxNQUFNLEdBQUcsR0FBRyxJQUFJLFlBQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUM5QixNQUFNLEdBQUcsR0FBRyxJQUFJLFlBQU0sQ0FBQyxHQUFHLEVBQUUsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUVwQyxJQUFJLENBQUMsU0FBUyxDQUFDLGFBQU8sQ0FBQyxHQUFHLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQztRQUNwQyxJQUFJLENBQUMsU0FBUyxDQUFDLGFBQU8sQ0FBQyxHQUFHLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQztRQUNwQyxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDaEIsQ0FBQztJQUVELGtHQUFrRyxDQUFDLElBQVU7UUFDekcsTUFBTSxLQUFLLEdBQUcsSUFBSSxXQUFLLEVBQUUsQ0FBQztRQUUxQixNQUFNLFFBQVEsR0FBRyxJQUFJLHFCQUFlLENBQUMsS0FBSyxFQUFFLFVBQVUsRUFBRSxFQUFFLFlBQVksRUFBRSxrQkFBa0IsRUFBRSxDQUFDLENBQUM7UUFFOUYsSUFBSSxxQkFBZSxDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUU7WUFDL0IsWUFBWSxFQUFFLE1BQU07WUFDcEIsV0FBVyxFQUFFLGFBQWE7WUFDMUIscUJBQXFCLEVBQUUsdUJBQXVCO1lBQzlDLFNBQVMsRUFBRSxDQUFDLEdBQUc7WUFDZixTQUFTLEVBQUUsSUFBSTtZQUNmLGNBQWMsRUFBRSxpQkFBaUI7WUFDakMsYUFBYSxFQUFFLENBQUUsU0FBUyxFQUFFLFFBQVEsQ0FBRTtTQUN6QyxDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxnQkFBZ0IsRUFBRSxFQUFFLEVBQUUsVUFBVSxFQUNqRCxFQUFFLHlCQUF5QixFQUN4QixFQUFFLElBQUksRUFBRSxvQ0FBb0M7b0JBQzFDLE9BQU8sRUFBRSxrQkFBa0I7b0JBQzNCLE1BQU0sRUFBRSxJQUFJLEVBQUU7Z0JBQ2pCLHFCQUFxQixFQUNwQixFQUFFLElBQUksRUFBRSxvQ0FBb0M7b0JBQzFDLE9BQU8sRUFBRSxNQUFNO29CQUNmLGNBQWMsRUFBRSxpQkFBaUI7b0JBQ2pDLGFBQWEsRUFBRSxDQUFFLFNBQVMsRUFBRSxRQUFRLENBQUU7b0JBQ3RDLHFCQUFxQixFQUFFLHVCQUF1QjtvQkFDOUMsV0FBVyxFQUFFLGFBQWE7b0JBQzFCLFNBQVMsRUFBRSxJQUFJO29CQUNmLFNBQVMsRUFBRSxDQUFDLEdBQUc7b0JBQ2YsTUFBTSxFQUFFLElBQUksRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRTdCLDRCQUE0QjtRQUM1QixJQUFJLENBQUMsU0FBUyxDQUFDLGFBQU8sQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLEVBQUUsRUFBRSxHQUFHLEVBQUUsMkJBQTJCLEVBQUUsQ0FBQyxDQUFDO1FBRTlFLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNoQixDQUFDO0NBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRlc3QgfSBmcm9tICdub2RldW5pdCc7XG5pbXBvcnQgeyByZXNvbHZlLCBTZWNyZXQsIFNlY3JldFBhcmFtZXRlciwgU3RhY2sgfSBmcm9tICcuLi8uLi9saWInO1xuXG5leHBvcnQgPSB7XG4gICAgJ1NlY3JldCBpcyBtZXJlbHkgYSB0b2tlbicodGVzdDogVGVzdCkge1xuICAgICAgICBjb25zdCBmb28gPSBuZXcgU2VjcmV0KCdGb28nKTtcbiAgICAgICAgY29uc3QgYmFyID0gbmV3IFNlY3JldCgoKSA9PiAnQmFyJyk7XG5cbiAgICAgICAgdGVzdC5kZWVwRXF1YWwocmVzb2x2ZShmb28pLCAnRm9vJyk7XG4gICAgICAgIHRlc3QuZGVlcEVxdWFsKHJlc29sdmUoYmFyKSwgJ0JhcicpO1xuICAgICAgICB0ZXN0LmRvbmUoKTtcbiAgICB9LFxuXG4gICAgJ1NlY3JldFBhcmFtZXRlciBjYW4gYmUgdXNlZCB0byBkZWZpbmUgdmFsdWVzIHJlc29sdmVkIGZyb20gU1NNIHBhcmFtZXRlciBzdG9yZSBkdXJpbmcgZGVwbG95bWVudCcodGVzdDogVGVzdCkge1xuICAgICAgICBjb25zdCBzdGFjayA9IG5ldyBTdGFjaygpO1xuXG4gICAgICAgIGNvbnN0IG15U2VjcmV0ID0gbmV3IFNlY3JldFBhcmFtZXRlcihzdGFjaywgJ015U2VjcmV0JywgeyBzc21QYXJhbWV0ZXI6ICcvbXkvc2VjcmV0L3BhcmFtJyB9KTtcblxuICAgICAgICBuZXcgU2VjcmV0UGFyYW1ldGVyKHN0YWNrLCAnQm9vbScsIHtcbiAgICAgICAgICAgIHNzbVBhcmFtZXRlcjogJ0Jvb20nLFxuICAgICAgICAgICAgZGVzY3JpcHRpb246ICdkZXNjcmlwdGlvbicsXG4gICAgICAgICAgICBjb25zdHJhaW50RGVzY3JpcHRpb246ICdjb25zdHJhaW50RGVzY3JpcHRpb24nLFxuICAgICAgICAgICAgbWluTGVuZ3RoOiAtMTAwLFxuICAgICAgICAgICAgbWF4TGVuZ3RoOiAyMDAwLFxuICAgICAgICAgICAgYWxsb3dlZFBhdHRlcm46ICdhbGxvd2VkLXBhdHRlcm4nLFxuICAgICAgICAgICAgYWxsb3dlZFZhbHVlczogWyAnYWxsb3dlZCcsICd2YWx1ZXMnIF0sXG4gICAgICAgIH0pO1xuXG4gICAgICAgIHRlc3QuZGVlcEVxdWFsKHN0YWNrLnRvQ2xvdWRGb3JtYXRpb24oKSwgeyBQYXJhbWV0ZXJzOlxuICAgICAgICAgICAgeyBNeVNlY3JldFBhcmFtZXRlckJCODFERTU4OlxuICAgICAgICAgICAgICAgeyBUeXBlOiAnQVdTOjpTU006OlBhcmFtZXRlcjo6VmFsdWU8U3RyaW5nPicsXG4gICAgICAgICAgICAgICAgIERlZmF1bHQ6ICcvbXkvc2VjcmV0L3BhcmFtJyxcbiAgICAgICAgICAgICAgICAgTm9FY2hvOiB0cnVlIH0sXG4gICAgICAgICAgICAgIEJvb21QYXJhbWV0ZXJCM0VCMzk0MjpcbiAgICAgICAgICAgICAgIHsgVHlwZTogJ0FXUzo6U1NNOjpQYXJhbWV0ZXI6OlZhbHVlPFN0cmluZz4nLFxuICAgICAgICAgICAgICAgICBEZWZhdWx0OiAnQm9vbScsXG4gICAgICAgICAgICAgICAgIEFsbG93ZWRQYXR0ZXJuOiAnYWxsb3dlZC1wYXR0ZXJuJyxcbiAgICAgICAgICAgICAgICAgQWxsb3dlZFZhbHVlczogWyAnYWxsb3dlZCcsICd2YWx1ZXMnIF0sXG4gICAgICAgICAgICAgICAgIENvbnN0cmFpbnREZXNjcmlwdGlvbjogJ2NvbnN0cmFpbnREZXNjcmlwdGlvbicsXG4gICAgICAgICAgICAgICAgIERlc2NyaXB0aW9uOiAnZGVzY3JpcHRpb24nLFxuICAgICAgICAgICAgICAgICBNYXhMZW5ndGg6IDIwMDAsXG4gICAgICAgICAgICAgICAgIE1pbkxlbmd0aDogLTEwMCxcbiAgICAgICAgICAgICAgICAgTm9FY2hvOiB0cnVlIH0gfSB9KTtcblxuICAgICAgICAvLyB2YWx1ZSByZXNvbHZlcyB0byBhIFwiUmVmXCJcbiAgICAgICAgdGVzdC5kZWVwRXF1YWwocmVzb2x2ZShteVNlY3JldC52YWx1ZSksIHsgUmVmOiAnTXlTZWNyZXRQYXJhbWV0ZXJCQjgxREU1OCcgfSk7XG5cbiAgICAgICAgdGVzdC5kb25lKCk7XG4gICAgfVxufTtcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5zZWNyZXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJ0ZXN0LnNlY3JldC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQ0EsbUNBQW9FO0FBRXBFLGlCQUFTO0lBQ1AsMEJBQTBCLENBQUMsSUFBVTtRQUNuQyxNQUFNLEdBQUcsR0FBRyxJQUFJLFlBQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUM5QixNQUFNLEdBQUcsR0FBRyxJQUFJLFlBQU0sQ0FBQyxHQUFHLEVBQUUsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUVwQyxJQUFJLENBQUMsU0FBUyxDQUFDLGFBQU8sQ0FBQyxHQUFHLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQztRQUNwQyxJQUFJLENBQUMsU0FBUyxDQUFDLGFBQU8sQ0FBQyxHQUFHLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQztRQUNwQyxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDZCxDQUFDO0lBRUQsa0dBQWtHLENBQUMsSUFBVTtRQUMzRyxNQUFNLEtBQUssR0FBRyxJQUFJLFdBQUssRUFBRSxDQUFDO1FBRTFCLE1BQU0sUUFBUSxHQUFHLElBQUkscUJBQWUsQ0FBQyxLQUFLLEVBQUUsVUFBVSxFQUFFLEVBQUUsWUFBWSxFQUFFLGtCQUFrQixFQUFFLENBQUMsQ0FBQztRQUU5RixJQUFJLHFCQUFlLENBQUMsS0FBSyxFQUFFLE1BQU0sRUFBRTtZQUNqQyxZQUFZLEVBQUUsTUFBTTtZQUNwQixXQUFXLEVBQUUsYUFBYTtZQUMxQixxQkFBcUIsRUFBRSx1QkFBdUI7WUFDOUMsU0FBUyxFQUFFLENBQUMsR0FBRztZQUNmLFNBQVMsRUFBRSxJQUFJO1lBQ2YsY0FBYyxFQUFFLGlCQUFpQjtZQUNqQyxhQUFhLEVBQUUsQ0FBRSxTQUFTLEVBQUUsUUFBUSxDQUFFO1NBQ3ZDLENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLGdCQUFnQixFQUFFLEVBQUUsRUFBRSxVQUFVLEVBQ25ELEVBQUUseUJBQXlCLEVBQ3hCLEVBQUUsSUFBSSxFQUFFLG9DQUFvQztvQkFDNUMsT0FBTyxFQUFFLGtCQUFrQjtvQkFDM0IsTUFBTSxFQUFFLElBQUksRUFBRTtnQkFDZixxQkFBcUIsRUFDcEIsRUFBRSxJQUFJLEVBQUUsb0NBQW9DO29CQUM1QyxPQUFPLEVBQUUsTUFBTTtvQkFDZixjQUFjLEVBQUUsaUJBQWlCO29CQUNqQyxhQUFhLEVBQUUsQ0FBRSxTQUFTLEVBQUUsUUFBUSxDQUFFO29CQUN0QyxxQkFBcUIsRUFBRSx1QkFBdUI7b0JBQzlDLFdBQVcsRUFBRSxhQUFhO29CQUMxQixTQUFTLEVBQUUsSUFBSTtvQkFDZixTQUFTLEVBQUUsQ0FBQyxHQUFHO29CQUNmLE1BQU0sRUFBRSxJQUFJLEVBQUUsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUV6Qiw0QkFBNEI7UUFDNUIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxhQUFPLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxFQUFFLEVBQUUsR0FBRyxFQUFFLDJCQUEyQixFQUFFLENBQUMsQ0FBQztRQUU5RSxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDZCxDQUFDO0NBQ0YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRlc3QgfSBmcm9tICdub2RldW5pdCc7XG5pbXBvcnQgeyByZXNvbHZlLCBTZWNyZXQsIFNlY3JldFBhcmFtZXRlciwgU3RhY2sgfSBmcm9tICcuLi8uLi9saWInO1xuXG5leHBvcnQgPSB7XG4gICdTZWNyZXQgaXMgbWVyZWx5IGEgdG9rZW4nKHRlc3Q6IFRlc3QpIHtcbiAgICBjb25zdCBmb28gPSBuZXcgU2VjcmV0KCdGb28nKTtcbiAgICBjb25zdCBiYXIgPSBuZXcgU2VjcmV0KCgpID0+ICdCYXInKTtcblxuICAgIHRlc3QuZGVlcEVxdWFsKHJlc29sdmUoZm9vKSwgJ0ZvbycpO1xuICAgIHRlc3QuZGVlcEVxdWFsKHJlc29sdmUoYmFyKSwgJ0JhcicpO1xuICAgIHRlc3QuZG9uZSgpO1xuICB9LFxuXG4gICdTZWNyZXRQYXJhbWV0ZXIgY2FuIGJlIHVzZWQgdG8gZGVmaW5lIHZhbHVlcyByZXNvbHZlZCBmcm9tIFNTTSBwYXJhbWV0ZXIgc3RvcmUgZHVyaW5nIGRlcGxveW1lbnQnKHRlc3Q6IFRlc3QpIHtcbiAgICBjb25zdCBzdGFjayA9IG5ldyBTdGFjaygpO1xuXG4gICAgY29uc3QgbXlTZWNyZXQgPSBuZXcgU2VjcmV0UGFyYW1ldGVyKHN0YWNrLCAnTXlTZWNyZXQnLCB7IHNzbVBhcmFtZXRlcjogJy9teS9zZWNyZXQvcGFyYW0nIH0pO1xuXG4gICAgbmV3IFNlY3JldFBhcmFtZXRlcihzdGFjaywgJ0Jvb20nLCB7XG4gICAgICBzc21QYXJhbWV0ZXI6ICdCb29tJyxcbiAgICAgIGRlc2NyaXB0aW9uOiAnZGVzY3JpcHRpb24nLFxuICAgICAgY29uc3RyYWludERlc2NyaXB0aW9uOiAnY29uc3RyYWludERlc2NyaXB0aW9uJyxcbiAgICAgIG1pbkxlbmd0aDogLTEwMCxcbiAgICAgIG1heExlbmd0aDogMjAwMCxcbiAgICAgIGFsbG93ZWRQYXR0ZXJuOiAnYWxsb3dlZC1wYXR0ZXJuJyxcbiAgICAgIGFsbG93ZWRWYWx1ZXM6IFsgJ2FsbG93ZWQnLCAndmFsdWVzJyBdLFxuICAgIH0pO1xuXG4gICAgdGVzdC5kZWVwRXF1YWwoc3RhY2sudG9DbG91ZEZvcm1hdGlvbigpLCB7IFBhcmFtZXRlcnM6XG4gICAgICB7IE15U2VjcmV0UGFyYW1ldGVyQkI4MURFNTg6XG4gICAgICAgICB7IFR5cGU6ICdBV1M6OlNTTTo6UGFyYW1ldGVyOjpWYWx1ZTxTdHJpbmc+JyxcbiAgICAgICAgIERlZmF1bHQ6ICcvbXkvc2VjcmV0L3BhcmFtJyxcbiAgICAgICAgIE5vRWNobzogdHJ1ZSB9LFxuICAgICAgICBCb29tUGFyYW1ldGVyQjNFQjM5NDI6XG4gICAgICAgICB7IFR5cGU6ICdBV1M6OlNTTTo6UGFyYW1ldGVyOjpWYWx1ZTxTdHJpbmc+JyxcbiAgICAgICAgIERlZmF1bHQ6ICdCb29tJyxcbiAgICAgICAgIEFsbG93ZWRQYXR0ZXJuOiAnYWxsb3dlZC1wYXR0ZXJuJyxcbiAgICAgICAgIEFsbG93ZWRWYWx1ZXM6IFsgJ2FsbG93ZWQnLCAndmFsdWVzJyBdLFxuICAgICAgICAgQ29uc3RyYWludERlc2NyaXB0aW9uOiAnY29uc3RyYWludERlc2NyaXB0aW9uJyxcbiAgICAgICAgIERlc2NyaXB0aW9uOiAnZGVzY3JpcHRpb24nLFxuICAgICAgICAgTWF4TGVuZ3RoOiAyMDAwLFxuICAgICAgICAgTWluTGVuZ3RoOiAtMTAwLFxuICAgICAgICAgTm9FY2hvOiB0cnVlIH0gfSB9KTtcblxuICAgIC8vIHZhbHVlIHJlc29sdmVzIHRvIGEgXCJSZWZcIlxuICAgIHRlc3QuZGVlcEVxdWFsKHJlc29sdmUobXlTZWNyZXQudmFsdWUpLCB7IFJlZjogJ015U2VjcmV0UGFyYW1ldGVyQkI4MURFNTgnIH0pO1xuXG4gICAgdGVzdC5kb25lKCk7XG4gIH1cbn07XG4iXX0=

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

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.stack.js","sourceRoot":"","sources":["test.stack.ts"],"names":[],"mappings":"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","sourcesContent":["import { Test } from 'nodeunit';\nimport { App, Condition, Construct, Include, Output, Parameter, Resource, Root, Stack, Token } from '../../lib';\n\nexport = {\n    'a stack can be serialized into a CloudFormation template, initially it\\'s empty'(test: Test) {\n        const stack = new Stack();\n        test.deepEqual(stack.toCloudFormation(), { });\n        test.done();\n    },\n\n    'stack objects have some template-level propeties, such as Description, Version, Transform'(test: Test) {\n        const stack = new Stack();\n        stack.templateOptions.templateFormatVersion = 'MyTemplateVersion';\n        stack.templateOptions.description = 'This is my description';\n        stack.templateOptions.transform = 'SAMy';\n        test.deepEqual(stack.toCloudFormation(), {\n            Description: 'This is my description',\n            AWSTemplateFormatVersion: 'MyTemplateVersion',\n            Transform: 'SAMy'\n        });\n        test.done();\n    },\n\n    'Stack.find(c) can be used to find the stack from any point in the tree'(test: Test) {\n        const stack = new Stack();\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(Stack.find(res1), stack);\n        test.equal(Stack.find(res2), stack);\n        test.equal(Stack.find(level2), stack);\n\n        const root = new Root();\n        const child = new Construct(root, 'child');\n\n        test.throws(() => Stack.find(child));\n        test.throws(() => Stack.find(root));\n\n        test.done();\n    },\n\n    'Stack.isStack indicates that a construct is a stack'(test: Test) {\n        const stack = new Stack();\n        const c = new Construct(stack, 'Construct');\n        test.ok(stack.isStack);\n        test.ok(!(c as any).isStack);\n        test.done();\n    },\n\n    'stack.id is not included in the logical identities of resources within it'(test: Test) {\n        const stack = new Stack(undefined, 'MyStack');\n        new Resource(stack, 'MyResource', { type: 'MyResourceType' });\n\n        test.deepEqual(stack.toCloudFormation(), { Resources: { MyResource: { Type: 'MyResourceType' } } });\n        test.done();\n    },\n\n    'stack.templateOptions can be used to set template-level options'(test: Test) {\n        const stack = new Stack();\n\n        stack.templateOptions.description = 'StackDescription';\n        stack.templateOptions.templateFormatVersion = 'TemplateVersion';\n        stack.templateOptions.transform = 'Transform';\n        stack.templateOptions.metadata = {\n            MetadataKey: 'MetadataValue'\n        };\n\n        test.deepEqual(stack.toCloudFormation(), {\n            Description: 'StackDescription',\n            Transform: 'Transform',\n            AWSTemplateFormatVersion: 'TemplateVersion',\n            Metadata: { MetadataKey: 'MetadataValue' }\n        });\n\n        test.done();\n    },\n\n    // This approach will only apply to TypeScript code, but at least it's a temporary\n    // workaround for people running into issues caused by SDK-3003.\n    // We should come up with a proper solution that involved jsii callbacks (when they exist)\n    // so this can be implemented by jsii languages as well.\n    'Overriding `Stack.toCloudFormation` allows arbitrary post-processing of the generated template during synthesis'(test: Test) {\n\n        const stack = new StackWithPostProcessor();\n\n        new Resource(stack, 'myResource', {\n            type: 'AWS::MyResource',\n            properties: {\n                MyProp1: 'hello',\n                MyProp2: 'howdy',\n                Environment: {\n                    Key: 'value'\n                }\n            }\n        });\n\n        test.deepEqual(stack.toCloudFormation(), { Resources:\n            { myResource:\n               { Type: 'AWS::MyResource',\n                 Properties:\n                  { MyProp1: 'hello',\n                    MyProp2: 'howdy',\n                    Environment: { key: 'value' } } } } });\n\n        test.done();\n    },\n\n    'Construct.findResource(logicalId) can be used to retrieve a resource by its path'(test: Test) {\n        const stack = new Stack();\n\n        test.ok(!stack.tryFindChild('foo'), 'empty stack');\n\n        const r1 = new Resource(stack, 'Hello', { type: 'MyResource' });\n        test.equal(stack.findResource(r1.stackPath), r1, 'look up top-level');\n\n        const child = new Construct(stack, 'Child');\n        const r2 = new Resource(child, 'Hello', { type: 'MyResource' });\n\n        test.equal(stack.findResource(r2.stackPath), r2, 'look up child');\n\n        test.done();\n    },\n\n    'Stack.findResource will fail if the element is not a resource'(test: Test) {\n        const stack = new Stack();\n\n        const p = new Parameter(stack, 'MyParam', { type: 'String' });\n\n        test.throws(() => stack.findResource(p.path));\n        test.done();\n    },\n\n    'Stack.getByPath can be used to find any CloudFormation element (Parameter, Output, etc)'(test: Test) {\n\n        const stack = new Stack();\n\n        const p = new Parameter(stack, 'MyParam', { type: 'String' });\n        const o = new Output(stack, 'MyOutput');\n        const c = new Condition(stack, 'MyCondition');\n\n        test.equal(stack.findChild(p.path), p);\n        test.equal(stack.findChild(o.path), o);\n        test.equal(stack.findChild(c.path), c);\n\n        test.done();\n    },\n\n    'Stack names can have hyphens in them'(test: Test) {\n        const root = new App();\n\n        new Stack(root, 'Hello-World');\n        // Did not throw\n\n        test.done();\n    },\n\n    'Include should support non-hash top-level template elements like \"Description\"'(test: Test) {\n        const stack = new Stack();\n\n        const template = {\n            Description: 'hello, world'\n        };\n\n        new Include(stack, 'Include', { template });\n\n        const output = stack.toCloudFormation();\n\n        test.equal(typeof output.Description, 'string');\n        test.done();\n    },\n\n    'Can\\'t add children during synthesis'(test: Test) {\n        const stack = new Stack();\n\n        // add a construct with a token that when resolved adds a child. this\n        // means that this child is going to be added during synthesis and this\n        // is a no-no.\n        new Resource(stack, 'Resource', { type: 'T', properties: {\n            foo: new Token(() => new Construct(stack, 'Foo'))\n        }});\n\n        test.throws(() => stack.toCloudFormation(), /Cannot add children during synthesis/);\n\n        // okay to add after synthesis\n        new Construct(stack, 'C1');\n\n        test.done();\n    },\n};\n\nclass StackWithPostProcessor extends Stack {\n\n    // ...\n\n    public toCloudFormation() {\n        const template = super.toCloudFormation();\n\n        // manipulate template (e.g. rename \"Key\" to \"key\")\n        template.Resources.myResource.Properties.Environment.key =\n            template.Resources.myResource.Properties.Environment.Key;\n        delete template.Resources.myResource.Properties.Environment.Key;\n\n        return template;\n    }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.stack.js","sourceRoot":"","sources":["test.stack.ts"],"names":[],"mappings":"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","sourcesContent":["import { Test } from 'nodeunit';\nimport { App, Condition, Construct, Include, Output, Parameter, Resource, Root, Stack, Token } from '../../lib';\n\nexport = {\n  'a stack can be serialized into a CloudFormation template, initially it\\'s empty'(test: Test) {\n    const stack = new Stack();\n    test.deepEqual(stack.toCloudFormation(), { });\n    test.done();\n  },\n\n  'stack objects have some template-level propeties, such as Description, Version, Transform'(test: Test) {\n    const stack = new Stack();\n    stack.templateOptions.templateFormatVersion = 'MyTemplateVersion';\n    stack.templateOptions.description = 'This is my description';\n    stack.templateOptions.transform = 'SAMy';\n    test.deepEqual(stack.toCloudFormation(), {\n      Description: 'This is my description',\n      AWSTemplateFormatVersion: 'MyTemplateVersion',\n      Transform: 'SAMy'\n    });\n    test.done();\n  },\n\n  'Stack.find(c) can be used to find the stack from any point in the tree'(test: Test) {\n    const stack = new Stack();\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(Stack.find(res1), stack);\n    test.equal(Stack.find(res2), stack);\n    test.equal(Stack.find(level2), stack);\n\n    const root = new Root();\n    const child = new Construct(root, 'child');\n\n    test.throws(() => Stack.find(child));\n    test.throws(() => Stack.find(root));\n\n    test.done();\n  },\n\n  'Stack.isStack indicates that a construct is a stack'(test: Test) {\n    const stack = new Stack();\n    const c = new Construct(stack, 'Construct');\n    test.ok(stack.isStack);\n    test.ok(!(c as any).isStack);\n    test.done();\n  },\n\n  'stack.id is not included in the logical identities of resources within it'(test: Test) {\n    const stack = new Stack(undefined, 'MyStack');\n    new Resource(stack, 'MyResource', { type: 'MyResourceType' });\n\n    test.deepEqual(stack.toCloudFormation(), { Resources: { MyResource: { Type: 'MyResourceType' } } });\n    test.done();\n  },\n\n  'stack.templateOptions can be used to set template-level options'(test: Test) {\n    const stack = new Stack();\n\n    stack.templateOptions.description = 'StackDescription';\n    stack.templateOptions.templateFormatVersion = 'TemplateVersion';\n    stack.templateOptions.transform = 'Transform';\n    stack.templateOptions.metadata = {\n      MetadataKey: 'MetadataValue'\n    };\n\n    test.deepEqual(stack.toCloudFormation(), {\n      Description: 'StackDescription',\n      Transform: 'Transform',\n      AWSTemplateFormatVersion: 'TemplateVersion',\n      Metadata: { MetadataKey: 'MetadataValue' }\n    });\n\n    test.done();\n  },\n\n  // This approach will only apply to TypeScript code, but at least it's a temporary\n  // workaround for people running into issues caused by SDK-3003.\n  // We should come up with a proper solution that involved jsii callbacks (when they exist)\n  // so this can be implemented by jsii languages as well.\n  'Overriding `Stack.toCloudFormation` allows arbitrary post-processing of the generated template during synthesis'(test: Test) {\n\n    const stack = new StackWithPostProcessor();\n\n    new Resource(stack, 'myResource', {\n      type: 'AWS::MyResource',\n      properties: {\n        MyProp1: 'hello',\n        MyProp2: 'howdy',\n        Environment: {\n          Key: 'value'\n        }\n      }\n    });\n\n    test.deepEqual(stack.toCloudFormation(), { Resources:\n      { myResource:\n         { Type: 'AWS::MyResource',\n         Properties:\n          { MyProp1: 'hello',\n          MyProp2: 'howdy',\n          Environment: { key: 'value' } } } } });\n\n    test.done();\n  },\n\n  'Construct.findResource(logicalId) can be used to retrieve a resource by its path'(test: Test) {\n    const stack = new Stack();\n\n    test.ok(!stack.tryFindChild('foo'), 'empty stack');\n\n    const r1 = new Resource(stack, 'Hello', { type: 'MyResource' });\n    test.equal(stack.findResource(r1.stackPath), r1, 'look up top-level');\n\n    const child = new Construct(stack, 'Child');\n    const r2 = new Resource(child, 'Hello', { type: 'MyResource' });\n\n    test.equal(stack.findResource(r2.stackPath), r2, 'look up child');\n\n    test.done();\n  },\n\n  'Stack.findResource will fail if the element is not a resource'(test: Test) {\n    const stack = new Stack();\n\n    const p = new Parameter(stack, 'MyParam', { type: 'String' });\n\n    test.throws(() => stack.findResource(p.path));\n    test.done();\n  },\n\n  'Stack.getByPath can be used to find any CloudFormation element (Parameter, Output, etc)'(test: Test) {\n\n    const stack = new Stack();\n\n    const p = new Parameter(stack, 'MyParam', { type: 'String' });\n    const o = new Output(stack, 'MyOutput');\n    const c = new Condition(stack, 'MyCondition');\n\n    test.equal(stack.findChild(p.path), p);\n    test.equal(stack.findChild(o.path), o);\n    test.equal(stack.findChild(c.path), c);\n\n    test.done();\n  },\n\n  'Stack names can have hyphens in them'(test: Test) {\n    const root = new App();\n\n    new Stack(root, 'Hello-World');\n    // Did not throw\n\n    test.done();\n  },\n\n  'Include should support non-hash top-level template elements like \"Description\"'(test: Test) {\n    const stack = new Stack();\n\n    const template = {\n      Description: 'hello, world'\n    };\n\n    new Include(stack, 'Include', { template });\n\n    const output = stack.toCloudFormation();\n\n    test.equal(typeof output.Description, 'string');\n    test.done();\n  },\n\n  'Can\\'t add children during synthesis'(test: Test) {\n    const stack = new Stack();\n\n    // add a construct with a token that when resolved adds a child. this\n    // means that this child is going to be added during synthesis and this\n    // is a no-no.\n    new Resource(stack, 'Resource', { type: 'T', properties: {\n      foo: new Token(() => new Construct(stack, 'Foo'))\n    }});\n\n    test.throws(() => stack.toCloudFormation(), /Cannot add children during synthesis/);\n\n    // okay to add after synthesis\n    new Construct(stack, 'C1');\n\n    test.done();\n  },\n};\n\nclass StackWithPostProcessor extends Stack {\n\n  // ...\n\n  public toCloudFormation() {\n    const template = super.toCloudFormation();\n\n    // manipulate template (e.g. rename \"Key\" to \"key\")\n    template.Resources.myResource.Properties.Environment.key =\n      template.Resources.myResource.Properties.Environment.Key;\n    delete template.Resources.myResource.Properties.Environment.Key;\n\n    return template;\n  }\n}\n"]}

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

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.construct.js","sourceRoot":"","sources":["test.construct.ts"],"names":[],"mappings":"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","sourcesContent":["import cxapi = require('@aws-cdk/cx-api');\nimport { Test } from 'nodeunit';\nimport { Construct, Root } from '../../lib';\n\n// tslint:disable:variable-name\n// tslint:disable:max-line-length\n\nexport = {\n    'the \"Root\" construct is a special construct which can be used as the root of the tree'(test: Test) {\n        const root = new Root();\n        test.equal(root.id, '', 'if not specified, name of a root construct is an empty string');\n        test.ok(!root.parent, 'no parent');\n        test.equal(root.children.length, 0, 'a construct is created without children'); // no children\n        test.done();\n    },\n\n    'constructs cannot be created with an empty name unless they are root'(test: Test) {\n        const root = new Root();\n        test.throws(() => new Construct(root, ''));\n        test.done();\n    },\n\n    'construct.name returns the name of the construct'(test: Test) {\n        const t = createTree();\n\n        test.equal(t.child1.id, 'Child1');\n        test.equal(t.child2.id, 'Child2');\n        test.equal(t.child1_1.id, 'Child11');\n        test.equal(t.child1_2.id, 'Child12');\n        test.equal(t.child1_1_1.id, 'Child111');\n        test.equal(t.child2_1.id, 'Child21');\n\n        test.done();\n    },\n\n    'construct id can use any character except the path separator'(test: Test) {\n        const root = new Root();\n        new Construct(root, 'valid');\n        new Construct(root, 'ValiD');\n        new Construct(root, 'Va123lid');\n        new Construct(root, 'v');\n        new Construct(root, '  invalid' );\n        new Construct(root, 'invalid   ' );\n        new Construct(root, '123invalid' );\n        new Construct(root, 'in valid' );\n        new Construct(root, 'in_Valid' );\n        new Construct(root, 'in-Valid' );\n        new Construct(root, 'in\\\\Valid' );\n        new Construct(root, 'in.Valid' );\n\n        test.throws(() => new Construct(root, 'in/Valid' ), Error, 'backslashes are not allowed');\n        test.done();\n    },\n\n    'construct.uniqueId returns a tree-unique alphanumeric id of this construct'(test: Test) {\n        const root = new Root();\n\n        const child1 = new Construct(root, 'This is the first child');\n        const child2 = new Construct(child1, 'Second level');\n        const c1 = new Construct(child2, 'My construct');\n        const c2 = new Construct(child1, 'My construct');\n\n        test.deepEqual(c1.path, 'This is the first child/Second level/My construct');\n        test.deepEqual(c2.path, 'This is the first child/My construct');\n        test.deepEqual(c1.uniqueId, 'ThisisthefirstchildSecondlevelMyconstruct202131E0');\n        test.deepEqual(c2.uniqueId, 'ThisisthefirstchildMyconstruct8C288DF9');\n        test.done();\n    },\n\n    'cannot calculate uniqueId if the construct path is [\"Default\"]'(test: Test) {\n        const root = new Root();\n        test.throws(() => new Construct(root, 'Default'), /Unable to calculate a unique id for an empty set of components/);\n        test.done();\n    },\n\n    'construct.getChildren() returns an array of all children'(test: Test) {\n        const root = new Root();\n        const child = new Construct(root, 'Child1');\n        new Construct(root, 'Child2');\n        test.equal(child.children.length, 0, 'no children');\n        test.equal(root.children.length, 2, 'two children are expected');\n        test.done();\n    },\n\n    'construct.findChild(name) can be used to retrieve a child from a parent'(test: Test) {\n        const root = new Root();\n        const child = new Construct(root, 'Contruct');\n        test.strictEqual(root.tryFindChild(child.id), child, 'findChild(name) can be used to retrieve the child from a parent');\n        test.ok(!root.tryFindChild('NotFound'), 'findChild(name) returns undefined if the child is not found');\n        test.done();\n    },\n\n    'construct.getChild(name) can be used to retrieve a child from a parent'(test: Test) {\n        const root = new Root();\n        const child = new Construct(root, 'Contruct');\n        test.strictEqual(root.findChild(child.id), child, 'getChild(name) can be used to retrieve the child from a parent');\n        test.throws(() => {\n            root.findChild('NotFound');\n        }, '', 'getChild(name) returns undefined if the child is not found');\n        test.done();\n    },\n\n    'construct.toString() and construct.toTreeString() can be used for diagnostics'(test: Test) {\n        const t = createTree();\n\n        test.equal(t.root.toString(), 'Root');\n        test.equal(t.child1_1_1.toString(), 'Construct [Child1/Child11/Child111]');\n        test.equal(t.child2.toString(), 'Construct [Child2]');\n        test.equal(t.root.toTreeString(), 'Root\\n  Construct [Child1]\\n    Construct [Child11]\\n      Construct [Child111]\\n    Construct [Child12]\\n  Construct [Child2]\\n    Construct [Child21]\\n');\n        test.done();\n    },\n\n    'construct.getContext(key) can be used to read a value from context defined at the root level'(test: Test) {\n        const context = {\n            ctx1: 12,\n            ctx2: 'hello'\n        };\n\n        const t = createTree(context);\n        test.equal(t.root.getContext('ctx1'), 12);\n        test.equal(t.child1_1_1.getContext('ctx2'), 'hello');\n        test.done();\n    },\n\n    'construct.setContext(k,v) sets context at some level and construct.getContext(key) will return the lowermost value defined in the stack'(test: Test) {\n        const root = new Root();\n        root.setContext('c1', 'root');\n        root.setContext('c2', 'root');\n\n        const child1 = new Construct(root, 'child1');\n        child1.setContext('c2', 'child1');\n        child1.setContext('c3', 'child1');\n\n        const child2 = new Construct(root, 'child2');\n        const child3 = new Construct(child1, 'child1child1');\n        child3.setContext('c1', 'child3');\n        child3.setContext('c4', 'child3');\n\n        test.equal(root.getContext('c1'), 'root');\n        test.equal(root.getContext('c2'), 'root');\n        test.equal(root.getContext('c3'), undefined);\n\n        test.equal(child1.getContext('c1'), 'root');\n        test.equal(child1.getContext('c2'), 'child1');\n        test.equal(child1.getContext('c3'), 'child1');\n\n        test.equal(child2.getContext('c1'), 'root');\n        test.equal(child2.getContext('c2'), 'root');\n        test.equal(child2.getContext('c3'), undefined);\n\n        test.equal(child3.getContext('c1'), 'child3');\n        test.equal(child3.getContext('c2'), 'child1');\n        test.equal(child3.getContext('c3'), 'child1');\n        test.equal(child3.getContext('c4'), 'child3');\n\n        test.done();\n    },\n\n    'construct.setContext(key, value) can only be called before adding any children'(test: Test) {\n        const root = new Root();\n        new Construct(root, 'child1');\n        test.throws(() => root.setContext('k', 'v'));\n        test.done();\n    },\n\n    'construct.pathParts returns an array of strings of all names from root to node'(test: Test) {\n        const tree = createTree();\n        test.deepEqual(tree.root.path, '');\n        test.deepEqual(tree.child1_1_1.path, 'Child1/Child11/Child111');\n        test.deepEqual(tree.child2.path, 'Child2');\n        test.done();\n    },\n\n    'if a root construct has a name, it should be included in the path'(test: Test) {\n        const tree = createTree({});\n        test.deepEqual(tree.root.path, '');\n        test.deepEqual(tree.child1_1_1.path, 'Child1/Child11/Child111');\n        test.done();\n    },\n\n    'construct can not be created with the name of a sibling'(test: Test) {\n        const root = new Root();\n\n        // WHEN\n        new Construct(root, 'SameName');\n\n        // THEN: They have different paths\n        test.throws(() => {\n            new Construct(root, 'SameName');\n        });\n\n        test.done();\n    },\n\n    'addMetadata(type, data) can be used to attach metadata to constructs FIND_ME'(test: Test) {\n        const root = new Root();\n        const con = new Construct(root, 'MyConstruct');\n        test.deepEqual(con.metadata, [], 'starts empty');\n\n        con.addMetadata('key', 'value');\n        con.addMetadata('number', 103);\n        con.addMetadata('array', [ 123, 456 ]);\n\n        test.deepEqual(con.metadata[0].type, 'key');\n        test.deepEqual(con.metadata[0].data, 'value');\n        test.deepEqual(con.metadata[1].data, 103);\n        test.deepEqual(con.metadata[2].data, [ 123, 456 ]);\n        test.ok(con.metadata[0].trace[0].indexOf('FIND_ME') !== -1, 'First stack line should include this function\\s name');\n        test.done();\n    },\n\n    'addMetadata(type, undefined/null) is ignored'(test: Test) {\n        const root = new Root();\n        const con = new Construct(root, 'Foo');\n        con.addMetadata('Null', null);\n        con.addMetadata('Undefined', undefined);\n        con.addMetadata('True', true);\n        con.addMetadata('False', false);\n        con.addMetadata('Empty', '');\n\n        const exists = (key: string) => con.metadata.find(x => x.type === key);\n\n        test.ok(!exists('Null'));\n        test.ok(!exists('Undefined'));\n        test.ok(exists('True'));\n        test.ok(exists('False'));\n        test.ok(exists('Empty'));\n        test.done();\n    },\n\n    'addWarning(message) can be used to add a \"WARNING\" message entry to the construct'(test: Test) {\n        const root = new Root();\n        const con = new Construct(root, 'MyConstruct');\n        con.addWarning('This construct is deprecated, use the other one instead');\n        test.deepEqual(con.metadata[0].type, cxapi.WARNING_METADATA_KEY);\n        test.deepEqual(con.metadata[0].data, 'This construct is deprecated, use the other one instead');\n        test.ok(con.metadata[0].trace.length > 0);\n        test.done();\n    },\n\n    'addError(message) can be used to add a \"ERROR\" message entry to the construct'(test: Test) {\n        const root = new Root();\n        const con = new Construct(root, 'MyConstruct');\n        con.addError('Stop!');\n        test.deepEqual(con.metadata[0].type, cxapi.ERROR_METADATA_KEY);\n        test.deepEqual(con.metadata[0].data, 'Stop!');\n        test.ok(con.metadata[0].trace.length > 0);\n        test.done();\n    },\n\n    'addInfo(message) can be used to add an \"INFO\" message entry to the construct'(test: Test) {\n        const root = new Root();\n        const con = new Construct(root, 'MyConstruct');\n        con.addInfo('Hey there, how do you do?');\n        test.deepEqual(con.metadata[0].type, cxapi.INFO_METADATA_KEY);\n        test.deepEqual(con.metadata[0].data, 'Hey there, how do you do?');\n        test.ok(con.metadata[0].trace.length > 0);\n        test.done();\n    },\n\n    'multiple children of the same type, with explicit names are welcome'(test: Test) {\n        const root = new Root();\n        new MyBeautifulConstruct(root, 'mbc1');\n        new MyBeautifulConstruct(root, 'mbc2');\n        new MyBeautifulConstruct(root, 'mbc3');\n        new MyBeautifulConstruct(root, 'mbc4');\n        test.equal(root.children.length, 4);\n        test.done();\n    },\n\n    'construct.required(props, name) can be used to validate that required properties are defined'(test: Test) {\n        const root = new Root();\n\n        // should be ok\n        const c = new ConstructWithRequired(root, 'Construct', { requiredProp: 123, anotherRequiredProp: true });\n        test.equal(c.requiredProp, 123);\n        test.equal(c.anotherRequiredProp, true);\n\n        // should throw\n        test.throws(() => new ConstructWithRequired(root, 'C', { optionalProp: 'hello' } as any));\n        test.done();\n    },\n\n    'Construct name validation can be overridden'(test: Test) {\n        const root = new Root();\n\n        test.throws(() => new IAmSpartacusConstruct(root, \"Caesar\"));\n        new IAmSpartacusConstruct(root, \"Spartacus\");\n\n        test.done();\n    },\n\n    // tslint:disable-next-line:max-line-length\n    'construct.validate() can be implemented to perform validation, construct.validateTree() will return all errors from the subtree (DFS)'(test: Test) {\n\n        class MyConstruct extends Construct {\n            public validate() {\n                return [ 'my-error1', 'my-error2' ];\n            }\n        }\n\n        class YourConstruct extends Construct {\n            public validate() {\n                return [ 'your-error1' ];\n            }\n        }\n\n        class TheirConstruct extends Construct {\n            constructor(parent: Construct, name: string) {\n                super(parent, name);\n\n                new YourConstruct(this, 'YourConstruct');\n            }\n\n            public validate() {\n                return [ 'their-error' ];\n            }\n        }\n\n        class Stack extends Root {\n            constructor() {\n                super();\n\n                new MyConstruct(this, 'MyConstruct');\n                new TheirConstruct(this, 'TheirConstruct');\n            }\n\n            public validate() {\n                return  [ 'stack-error' ];\n            }\n        }\n\n        const stack = new Stack();\n\n        const errors = (stack.validateTree()).map(v => ({ path: v.source.path, message: v.message }));\n\n        // validate DFS\n        test.deepEqual(errors, [\n            { path: 'MyConstruct', message: 'my-error1' },\n            { path: 'MyConstruct', message: 'my-error2' },\n            { path: 'TheirConstruct/YourConstruct', message: 'your-error1' },\n            { path: 'TheirConstruct', message: 'their-error' },\n            { path: '', message: 'stack-error' }\n        ]);\n\n        test.done();\n    },\n\n    'construct.lock() protects against adding children anywhere under this construct (direct or indirect)'(test: Test) {\n\n        class LockableConstruct extends Construct {\n            public lockMe() {\n                this.lock();\n            }\n\n            public unlockMe() {\n                this.unlock();\n            }\n        }\n\n        const stack = new Root();\n\n        const c0a = new LockableConstruct(stack, 'c0a');\n        const c0b = new Construct(stack, 'c0b');\n\n        const c1a = new Construct(c0a, 'c1a');\n        const c1b = new Construct(c0a, 'c1b');\n\n        c0a.lockMe();\n\n        // now we should still be able to add children to c0b, but not to c0a or any its children\n        new Construct(c0b, 'c1a');\n        test.throws(() => new Construct(c0a, 'fail1'), /Cannot add children to \"c0a\" during synthesis/);\n        test.throws(() => new Construct(c1a, 'fail2'), /Cannot add children to \"c0a\\/c1a\" during synthesis/);\n        test.throws(() => new Construct(c1b, 'fail3'), /Cannot add children to \"c0a\\/c1b\" during synthesis/);\n\n        c0a.unlockMe();\n\n        new Construct(c0a, 'c0aZ');\n        new Construct(c1a, 'c1aZ');\n        new Construct(c1b, 'c1bZ');\n\n        test.done();\n    }\n};\n\nfunction createTree(context?: any) {\n    const root = new Root();\n    if (context) {\n        Object.keys(context).forEach(key => root.setContext(key, context[key]));\n    }\n\n    const child1 = new Construct(root, 'Child1');\n    const child2 = new Construct(root, 'Child2');\n    const child1_1 = new Construct(child1, 'Child11');\n    const child1_2 = new Construct(child1, 'Child12');\n    const child1_1_1 = new Construct(child1_1, 'Child111');\n    const child2_1 = new Construct(child2, 'Child21');\n\n    return {\n        root, child1, child2, child1_1, child1_2, child1_1_1, child2_1\n    };\n}\n\nclass MyBeautifulConstruct extends Construct {\n    constructor(parent: Construct, name: string) {\n        super(parent, name);\n    }\n}\n\ninterface ConstructWithRequiredProps {\n    optionalProp?: string;\n    requiredProp: number;\n    anotherRequiredProp: boolean;\n}\n\nclass ConstructWithRequired extends Construct {\n    public readonly requiredProp: string;\n    public readonly anotherRequiredProp: boolean;\n\n    constructor(parent: Construct, name: string, props: ConstructWithRequiredProps) {\n        super(parent, name);\n\n        this.requiredProp = this.required(props, 'requiredProp');\n        this.anotherRequiredProp = this.required(props, 'anotherRequiredProp');\n    }\n}\n\n/**\n * Construct that *must* be named \"Spartacus\"\n */\nclass IAmSpartacusConstruct extends Construct {\n    protected _validateId(name: string) {\n        if (name !== \"Spartacus\") {\n            throw new Error(\"Construct name must be 'Spartacus'\");\n        }\n    }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.construct.js","sourceRoot":"","sources":["test.construct.ts"],"names":[],"mappings":"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","sourcesContent":["import cxapi = require('@aws-cdk/cx-api');\nimport { Test } from 'nodeunit';\nimport { Construct, Root } from '../../lib';\n\n// tslint:disable:variable-name\n// tslint:disable:max-line-length\n\nexport = {\n  'the \"Root\" construct is a special construct which can be used as the root of the tree'(test: Test) {\n    const root = new Root();\n    test.equal(root.id, '', 'if not specified, name of a root construct is an empty string');\n    test.ok(!root.parent, 'no parent');\n    test.equal(root.children.length, 0, 'a construct is created without children'); // no children\n    test.done();\n  },\n\n  'constructs cannot be created with an empty name unless they are root'(test: Test) {\n    const root = new Root();\n    test.throws(() => new Construct(root, ''));\n    test.done();\n  },\n\n  'construct.name returns the name of the construct'(test: Test) {\n    const t = createTree();\n\n    test.equal(t.child1.id, 'Child1');\n    test.equal(t.child2.id, 'Child2');\n    test.equal(t.child1_1.id, 'Child11');\n    test.equal(t.child1_2.id, 'Child12');\n    test.equal(t.child1_1_1.id, 'Child111');\n    test.equal(t.child2_1.id, 'Child21');\n\n    test.done();\n  },\n\n  'construct id can use any character except the path separator'(test: Test) {\n    const root = new Root();\n    new Construct(root, 'valid');\n    new Construct(root, 'ValiD');\n    new Construct(root, 'Va123lid');\n    new Construct(root, 'v');\n    new Construct(root, '  invalid' );\n    new Construct(root, 'invalid   ' );\n    new Construct(root, '123invalid' );\n    new Construct(root, 'in valid' );\n    new Construct(root, 'in_Valid' );\n    new Construct(root, 'in-Valid' );\n    new Construct(root, 'in\\\\Valid' );\n    new Construct(root, 'in.Valid' );\n\n    test.throws(() => new Construct(root, 'in/Valid' ), Error, 'backslashes are not allowed');\n    test.done();\n  },\n\n  'construct.uniqueId returns a tree-unique alphanumeric id of this construct'(test: Test) {\n    const root = new Root();\n\n    const child1 = new Construct(root, 'This is the first child');\n    const child2 = new Construct(child1, 'Second level');\n    const c1 = new Construct(child2, 'My construct');\n    const c2 = new Construct(child1, 'My construct');\n\n    test.deepEqual(c1.path, 'This is the first child/Second level/My construct');\n    test.deepEqual(c2.path, 'This is the first child/My construct');\n    test.deepEqual(c1.uniqueId, 'ThisisthefirstchildSecondlevelMyconstruct202131E0');\n    test.deepEqual(c2.uniqueId, 'ThisisthefirstchildMyconstruct8C288DF9');\n    test.done();\n  },\n\n  'cannot calculate uniqueId if the construct path is [\"Default\"]'(test: Test) {\n    const root = new Root();\n    test.throws(() => new Construct(root, 'Default'), /Unable to calculate a unique id for an empty set of components/);\n    test.done();\n  },\n\n  'construct.getChildren() returns an array of all children'(test: Test) {\n    const root = new Root();\n    const child = new Construct(root, 'Child1');\n    new Construct(root, 'Child2');\n    test.equal(child.children.length, 0, 'no children');\n    test.equal(root.children.length, 2, 'two children are expected');\n    test.done();\n  },\n\n  'construct.findChild(name) can be used to retrieve a child from a parent'(test: Test) {\n    const root = new Root();\n    const child = new Construct(root, 'Contruct');\n    test.strictEqual(root.tryFindChild(child.id), child, 'findChild(name) can be used to retrieve the child from a parent');\n    test.ok(!root.tryFindChild('NotFound'), 'findChild(name) returns undefined if the child is not found');\n    test.done();\n  },\n\n  'construct.getChild(name) can be used to retrieve a child from a parent'(test: Test) {\n    const root = new Root();\n    const child = new Construct(root, 'Contruct');\n    test.strictEqual(root.findChild(child.id), child, 'getChild(name) can be used to retrieve the child from a parent');\n    test.throws(() => {\n      root.findChild('NotFound');\n    }, '', 'getChild(name) returns undefined if the child is not found');\n    test.done();\n  },\n\n  'construct.toString() and construct.toTreeString() can be used for diagnostics'(test: Test) {\n    const t = createTree();\n\n    test.equal(t.root.toString(), 'Root');\n    test.equal(t.child1_1_1.toString(), 'Construct [Child1/Child11/Child111]');\n    test.equal(t.child2.toString(), 'Construct [Child2]');\n    test.equal(t.root.toTreeString(), 'Root\\n  Construct [Child1]\\n    Construct [Child11]\\n      Construct [Child111]\\n    Construct [Child12]\\n  Construct [Child2]\\n    Construct [Child21]\\n');\n    test.done();\n  },\n\n  'construct.getContext(key) can be used to read a value from context defined at the root level'(test: Test) {\n    const context = {\n      ctx1: 12,\n      ctx2: 'hello'\n    };\n\n    const t = createTree(context);\n    test.equal(t.root.getContext('ctx1'), 12);\n    test.equal(t.child1_1_1.getContext('ctx2'), 'hello');\n    test.done();\n  },\n\n  'construct.setContext(k,v) sets context at some level and construct.getContext(key) will return the lowermost value defined in the stack'(test: Test) {\n    const root = new Root();\n    root.setContext('c1', 'root');\n    root.setContext('c2', 'root');\n\n    const child1 = new Construct(root, 'child1');\n    child1.setContext('c2', 'child1');\n    child1.setContext('c3', 'child1');\n\n    const child2 = new Construct(root, 'child2');\n    const child3 = new Construct(child1, 'child1child1');\n    child3.setContext('c1', 'child3');\n    child3.setContext('c4', 'child3');\n\n    test.equal(root.getContext('c1'), 'root');\n    test.equal(root.getContext('c2'), 'root');\n    test.equal(root.getContext('c3'), undefined);\n\n    test.equal(child1.getContext('c1'), 'root');\n    test.equal(child1.getContext('c2'), 'child1');\n    test.equal(child1.getContext('c3'), 'child1');\n\n    test.equal(child2.getContext('c1'), 'root');\n    test.equal(child2.getContext('c2'), 'root');\n    test.equal(child2.getContext('c3'), undefined);\n\n    test.equal(child3.getContext('c1'), 'child3');\n    test.equal(child3.getContext('c2'), 'child1');\n    test.equal(child3.getContext('c3'), 'child1');\n    test.equal(child3.getContext('c4'), 'child3');\n\n    test.done();\n  },\n\n  'construct.setContext(key, value) can only be called before adding any children'(test: Test) {\n    const root = new Root();\n    new Construct(root, 'child1');\n    test.throws(() => root.setContext('k', 'v'));\n    test.done();\n  },\n\n  'construct.pathParts returns an array of strings of all names from root to node'(test: Test) {\n    const tree = createTree();\n    test.deepEqual(tree.root.path, '');\n    test.deepEqual(tree.child1_1_1.path, 'Child1/Child11/Child111');\n    test.deepEqual(tree.child2.path, 'Child2');\n    test.done();\n  },\n\n  'if a root construct has a name, it should be included in the path'(test: Test) {\n    const tree = createTree({});\n    test.deepEqual(tree.root.path, '');\n    test.deepEqual(tree.child1_1_1.path, 'Child1/Child11/Child111');\n    test.done();\n  },\n\n  'construct can not be created with the name of a sibling'(test: Test) {\n    const root = new Root();\n\n    // WHEN\n    new Construct(root, 'SameName');\n\n    // THEN: They have different paths\n    test.throws(() => {\n      new Construct(root, 'SameName');\n    });\n\n    test.done();\n  },\n\n  'addMetadata(type, data) can be used to attach metadata to constructs FIND_ME'(test: Test) {\n    const root = new Root();\n    const con = new Construct(root, 'MyConstruct');\n    test.deepEqual(con.metadata, [], 'starts empty');\n\n    con.addMetadata('key', 'value');\n    con.addMetadata('number', 103);\n    con.addMetadata('array', [ 123, 456 ]);\n\n    test.deepEqual(con.metadata[0].type, 'key');\n    test.deepEqual(con.metadata[0].data, 'value');\n    test.deepEqual(con.metadata[1].data, 103);\n    test.deepEqual(con.metadata[2].data, [ 123, 456 ]);\n    test.ok(con.metadata[0].trace[0].indexOf('FIND_ME') !== -1, 'First stack line should include this function\\s name');\n    test.done();\n  },\n\n  'addMetadata(type, undefined/null) is ignored'(test: Test) {\n    const root = new Root();\n    const con = new Construct(root, 'Foo');\n    con.addMetadata('Null', null);\n    con.addMetadata('Undefined', undefined);\n    con.addMetadata('True', true);\n    con.addMetadata('False', false);\n    con.addMetadata('Empty', '');\n\n    const exists = (key: string) => con.metadata.find(x => x.type === key);\n\n    test.ok(!exists('Null'));\n    test.ok(!exists('Undefined'));\n    test.ok(exists('True'));\n    test.ok(exists('False'));\n    test.ok(exists('Empty'));\n    test.done();\n  },\n\n  'addWarning(message) can be used to add a \"WARNING\" message entry to the construct'(test: Test) {\n    const root = new Root();\n    const con = new Construct(root, 'MyConstruct');\n    con.addWarning('This construct is deprecated, use the other one instead');\n    test.deepEqual(con.metadata[0].type, cxapi.WARNING_METADATA_KEY);\n    test.deepEqual(con.metadata[0].data, 'This construct is deprecated, use the other one instead');\n    test.ok(con.metadata[0].trace.length > 0);\n    test.done();\n  },\n\n  'addError(message) can be used to add a \"ERROR\" message entry to the construct'(test: Test) {\n    const root = new Root();\n    const con = new Construct(root, 'MyConstruct');\n    con.addError('Stop!');\n    test.deepEqual(con.metadata[0].type, cxapi.ERROR_METADATA_KEY);\n    test.deepEqual(con.metadata[0].data, 'Stop!');\n    test.ok(con.metadata[0].trace.length > 0);\n    test.done();\n  },\n\n  'addInfo(message) can be used to add an \"INFO\" message entry to the construct'(test: Test) {\n    const root = new Root();\n    const con = new Construct(root, 'MyConstruct');\n    con.addInfo('Hey there, how do you do?');\n    test.deepEqual(con.metadata[0].type, cxapi.INFO_METADATA_KEY);\n    test.deepEqual(con.metadata[0].data, 'Hey there, how do you do?');\n    test.ok(con.metadata[0].trace.length > 0);\n    test.done();\n  },\n\n  'multiple children of the same type, with explicit names are welcome'(test: Test) {\n    const root = new Root();\n    new MyBeautifulConstruct(root, 'mbc1');\n    new MyBeautifulConstruct(root, 'mbc2');\n    new MyBeautifulConstruct(root, 'mbc3');\n    new MyBeautifulConstruct(root, 'mbc4');\n    test.equal(root.children.length, 4);\n    test.done();\n  },\n\n  'construct.required(props, name) can be used to validate that required properties are defined'(test: Test) {\n    const root = new Root();\n\n    // should be ok\n    const c = new ConstructWithRequired(root, 'Construct', { requiredProp: 123, anotherRequiredProp: true });\n    test.equal(c.requiredProp, 123);\n    test.equal(c.anotherRequiredProp, true);\n\n    // should throw\n    test.throws(() => new ConstructWithRequired(root, 'C', { optionalProp: 'hello' } as any));\n    test.done();\n  },\n\n  'Construct name validation can be overridden'(test: Test) {\n    const root = new Root();\n\n    test.throws(() => new IAmSpartacusConstruct(root, \"Caesar\"));\n    new IAmSpartacusConstruct(root, \"Spartacus\");\n\n    test.done();\n  },\n\n  // tslint:disable-next-line:max-line-length\n  'construct.validate() can be implemented to perform validation, construct.validateTree() will return all errors from the subtree (DFS)'(test: Test) {\n\n    class MyConstruct extends Construct {\n      public validate() {\n        return [ 'my-error1', 'my-error2' ];\n      }\n    }\n\n    class YourConstruct extends Construct {\n      public validate() {\n        return [ 'your-error1' ];\n      }\n    }\n\n    class TheirConstruct extends Construct {\n      constructor(parent: Construct, name: string) {\n        super(parent, name);\n\n        new YourConstruct(this, 'YourConstruct');\n      }\n\n      public validate() {\n        return [ 'their-error' ];\n      }\n    }\n\n    class Stack extends Root {\n      constructor() {\n        super();\n\n        new MyConstruct(this, 'MyConstruct');\n        new TheirConstruct(this, 'TheirConstruct');\n      }\n\n      public validate() {\n        return  [ 'stack-error' ];\n      }\n    }\n\n    const stack = new Stack();\n\n    const errors = (stack.validateTree()).map(v => ({ path: v.source.path, message: v.message }));\n\n    // validate DFS\n    test.deepEqual(errors, [\n      { path: 'MyConstruct', message: 'my-error1' },\n      { path: 'MyConstruct', message: 'my-error2' },\n      { path: 'TheirConstruct/YourConstruct', message: 'your-error1' },\n      { path: 'TheirConstruct', message: 'their-error' },\n      { path: '', message: 'stack-error' }\n    ]);\n\n    test.done();\n  },\n\n  'construct.lock() protects against adding children anywhere under this construct (direct or indirect)'(test: Test) {\n\n    class LockableConstruct extends Construct {\n      public lockMe() {\n        this.lock();\n      }\n\n      public unlockMe() {\n        this.unlock();\n      }\n    }\n\n    const stack = new Root();\n\n    const c0a = new LockableConstruct(stack, 'c0a');\n    const c0b = new Construct(stack, 'c0b');\n\n    const c1a = new Construct(c0a, 'c1a');\n    const c1b = new Construct(c0a, 'c1b');\n\n    c0a.lockMe();\n\n    // now we should still be able to add children to c0b, but not to c0a or any its children\n    new Construct(c0b, 'c1a');\n    test.throws(() => new Construct(c0a, 'fail1'), /Cannot add children to \"c0a\" during synthesis/);\n    test.throws(() => new Construct(c1a, 'fail2'), /Cannot add children to \"c0a\\/c1a\" during synthesis/);\n    test.throws(() => new Construct(c1b, 'fail3'), /Cannot add children to \"c0a\\/c1b\" during synthesis/);\n\n    c0a.unlockMe();\n\n    new Construct(c0a, 'c0aZ');\n    new Construct(c1a, 'c1aZ');\n    new Construct(c1b, 'c1bZ');\n\n    test.done();\n  }\n};\n\nfunction createTree(context?: any) {\n  const root = new Root();\n  if (context) {\n    Object.keys(context).forEach(key => root.setContext(key, context[key]));\n  }\n\n  const child1 = new Construct(root, 'Child1');\n  const child2 = new Construct(root, 'Child2');\n  const child1_1 = new Construct(child1, 'Child11');\n  const child1_2 = new Construct(child1, 'Child12');\n  const child1_1_1 = new Construct(child1_1, 'Child111');\n  const child2_1 = new Construct(child2, 'Child21');\n\n  return {\n    root, child1, child2, child1_1, child1_2, child1_1_1, child2_1\n  };\n}\n\nclass MyBeautifulConstruct extends Construct {\n  constructor(parent: Construct, name: string) {\n    super(parent, name);\n  }\n}\n\ninterface ConstructWithRequiredProps {\n  optionalProp?: string;\n  requiredProp: number;\n  anotherRequiredProp: boolean;\n}\n\nclass ConstructWithRequired extends Construct {\n  public readonly requiredProp: string;\n  public readonly anotherRequiredProp: boolean;\n\n  constructor(parent: Construct, name: string, props: ConstructWithRequiredProps) {\n    super(parent, name);\n\n    this.requiredProp = this.required(props, 'requiredProp');\n    this.anotherRequiredProp = this.required(props, 'anotherRequiredProp');\n  }\n}\n\n/**\n * Construct that *must* be named \"Spartacus\"\n */\nclass IAmSpartacusConstruct extends Construct {\n  protected _validateId(name: string) {\n    if (name !== \"Spartacus\") {\n      throw new Error(\"Construct name must be 'Spartacus'\");\n    }\n  }\n}\n"]}

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

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.tag-manager.js","sourceRoot":"","sources":["test.tag-manager.ts"],"names":[],"mappings":"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","sourcesContent":["import { Test } from 'nodeunit';\nimport { Construct, Root } from '../../lib/core/construct';\nimport { ITaggable, TagManager } from '../../lib/core/tag-manager';\n\nclass ChildTagger extends Construct implements ITaggable {\n    public readonly tags: TagManager;\n    constructor(parent: Construct, name: string) {\n        super(parent, name);\n        this.tags = new TagManager(parent);\n    }\n}\nclass Child extends Construct {\n    constructor(parent: Construct, name: string) {\n        super(parent, name);\n    }\n}\n\nexport = {\n\n    'TagManger handles tags for a Contruct Tree': {\n        'setTag by default propagates to children'(test: Test) {\n            const root = new Root();\n            const ctagger = new ChildTagger(root, 'one');\n            const ctagger1 = new ChildTagger(ctagger, 'two');\n            const ctagger2 = new ChildTagger(root, 'three');\n\n            // not taggable at all\n            new Child(ctagger, 'notag');\n\n            const tag = {key: 'Name', value: 'TheCakeIsALie'};\n            ctagger.tags.setTag(tag.key, tag.value);\n\n            const tagArray = [tag];\n            for (const construct of [ctagger, ctagger1]) {\n                test.deepEqual(construct.tags.resolve(), tagArray);\n            }\n\n            test.deepEqual(ctagger2.tags.resolve().length, 0);\n            test.done();\n        },\n        'setTag with propagate false tags do not propagate'(test: Test) {\n            const root = new Root();\n            const ctagger = new ChildTagger(root, 'one');\n            const ctagger1 = new ChildTagger(ctagger, 'two');\n            const ctagger2 = new ChildTagger(root, 'three');\n\n            // not taggable at all\n            new Child(ctagger, 'notag');\n\n            const tag = {key: 'Name', value: 'TheCakeIsALie'};\n            ctagger.tags.setTag(tag.key, tag.value, {propagate: false});\n\n            for (const construct of [ctagger1, ctagger2]) {\n                test.deepEqual(construct.tags.resolve().length, 0);\n            }\n            test.deepEqual(ctagger.tags.resolve()[0].key, 'Name');\n            test.deepEqual(ctagger.tags.resolve()[0].value, 'TheCakeIsALie');\n            test.done();\n        },\n        'setTag with overwrite false does not overwrite a tag'(test: Test) {\n            const root = new Root();\n            const ctagger = new ChildTagger(root, 'one');\n            ctagger.tags.setTag('Env', 'Dev');\n            ctagger.tags.setTag('Env', 'Prod', {overwrite: false});\n            const result = ctagger.tags.resolve();\n            test.deepEqual(result, [{key: 'Env', value: 'Dev'}]);\n            test.done();\n        },\n        'setTag with sticky false enables propagations to overwrite child tags'(test: Test) {\n            const root = new Root();\n            const ctagger = new ChildTagger(root, 'one');\n            const ctagger1 = new ChildTagger(ctagger, 'two');\n            ctagger.tags.setTag('Parent', 'Is always right');\n            ctagger1.tags.setTag('Parent', 'Is wrong', {sticky: false});\n            const parent = ctagger.tags.resolve();\n            const child = ctagger1.tags.resolve();\n            test.deepEqual(parent, child);\n            test.done();\n\n        },\n        'tags propagate from all parents'(test: Test) {\n            const root = new Root();\n            const ctagger = new ChildTagger(root, 'one');\n            new ChildTagger(ctagger, 'two');\n            const cNoTag = new Child(ctagger, 'three');\n            const ctagger2 = new ChildTagger(cNoTag, 'four');\n            const tag = {key: 'Name', value: 'TheCakeIsALie'};\n            ctagger.tags.setTag(tag.key, tag.value, {propagate: true});\n            test.deepEqual(ctagger2.tags.resolve(), [tag]);\n            test.done();\n        },\n        'a tag can be removed and added back'(test: Test) {\n            const root = new Root();\n            const ctagger = new ChildTagger(root, 'one');\n            const tag = {key: 'Name', value: 'TheCakeIsALie'};\n            ctagger.tags.setTag(tag.key, tag.value, {propagate: true});\n            test.deepEqual(ctagger.tags.resolve(), [tag]);\n            ctagger.tags.removeTag(tag.key);\n            test.deepEqual(ctagger.tags.resolve(), []);\n            ctagger.tags.setTag(tag.key, tag.value, {propagate: true});\n            test.deepEqual(ctagger.tags.resolve(), [tag]);\n            test.done();\n        },\n        'removeTag removes a tag by key'(test: Test) {\n            const root = new Root();\n            const ctagger = new ChildTagger(root, 'one');\n            const ctagger1 = new ChildTagger(ctagger, 'two');\n            const ctagger2 = new ChildTagger(root, 'three');\n\n            // not taggable at all\n            new Child(ctagger, 'notag');\n\n            const tag = {key: 'Name', value: 'TheCakeIsALie'};\n            ctagger.tags.setTag(tag.key, tag.value);\n            ctagger.tags.removeTag('Name');\n\n            for (const construct of [ctagger, ctagger1, ctagger2]) {\n                test.deepEqual(construct.tags.resolve().length, 0);\n            }\n            test.done();\n        },\n        'removeTag with blockPropagate removes any propagated tags'(test: Test) {\n            const root = new Root();\n            const ctagger = new ChildTagger(root, 'one');\n            const ctagger1 = new ChildTagger(ctagger, 'two');\n            ctagger.tags.setTag('Env', 'Dev');\n            ctagger1.tags.removeTag('Env', {blockPropagate: true});\n            const result = ctagger.tags.resolve();\n            test.deepEqual(result, [{key: 'Env', value: 'Dev'}]);\n            test.deepEqual(ctagger1.tags.resolve(), []);\n            test.done();\n        },\n        'children can override parent propagated tags'(test: Test) {\n            const root = new Root();\n            const ctagger = new ChildTagger(root, 'one');\n            const ctagChild = new ChildTagger(ctagger, 'one');\n            const tag = {key: 'BestBeach', value: 'StoneSteps'};\n            const tag2 = {key: 'BestBeach', value: 'k-38'};\n            ctagger.tags.setTag(tag2.key, tag2.value);\n            ctagger.tags.setTag(tag.key, tag.value);\n            ctagChild.tags.setTag(tag2.key, tag2.value);\n            const parentTags = ctagger.tags.resolve();\n            const childTags = ctagChild.tags.resolve();\n            test.deepEqual(parentTags, [tag]);\n            test.deepEqual(childTags, [tag2]);\n            test.done();\n        },\n        'resolve() returns all tags'(test: Test) {\n            const root = new Root();\n            const ctagger = new ChildTagger(root, 'one');\n            const ctagChild = new ChildTagger(ctagger, 'one');\n            const tagsNoProp = [\n                {key: 'NorthCountySpot', value: 'Tabletops'},\n                {key: 'Crowded', value: 'Trestles'},\n            ];\n            const tagsProp = [\n                {key: 'BestBeach', value: 'StoneSteps'},\n                {key: 'BestWaves', value: 'Blacks'},\n            ];\n            for (const tag of tagsNoProp) {\n                ctagger.tags.setTag(tag.key, tag.value, {propagate: false});\n            }\n            for (const tag of tagsProp) {\n                ctagger.tags.setTag(tag.key, tag.value);\n            }\n            const allTags = tagsNoProp.concat(tagsProp);\n            const cAll = ctagger.tags;\n            const cProp = ctagChild.tags;\n\n            for (const tag of cAll.resolve()) {\n                const expectedTag = allTags.filter( (t) => (t.key === tag.key));\n                test.deepEqual(expectedTag[0].value, tag.value);\n            }\n            for (const tag of cProp.resolve()) {\n                const expectedTag = tagsProp.filter( (t) => (t.key === tag.key));\n                test.deepEqual(expectedTag[0].value, tag.value);\n            }\n            test.done();\n        },\n    },\n};\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.tag-manager.js","sourceRoot":"","sources":["test.tag-manager.ts"],"names":[],"mappings":"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","sourcesContent":["import { Test } from 'nodeunit';\nimport { Construct, Root } from '../../lib/core/construct';\nimport { ITaggable, TagManager } from '../../lib/core/tag-manager';\n\nclass ChildTagger extends Construct implements ITaggable {\n  public readonly tags: TagManager;\n  constructor(parent: Construct, name: string) {\n    super(parent, name);\n    this.tags = new TagManager(parent);\n  }\n}\n\nclass Child extends Construct {\n  constructor(parent: Construct, name: string) {\n    super(parent, name);\n  }\n}\n\nexport = {\n  'TagManger handles tags for a Contruct Tree': {\n    'setTag by default propagates to children'(test: Test) {\n      const root = new Root();\n      const ctagger = new ChildTagger(root, 'one');\n      const ctagger1 = new ChildTagger(ctagger, 'two');\n      const ctagger2 = new ChildTagger(root, 'three');\n\n      // not taggable at all\n      new Child(ctagger, 'notag');\n\n      const tag = {key: 'Name', value: 'TheCakeIsALie'};\n      ctagger.tags.setTag(tag.key, tag.value);\n\n      const tagArray = [tag];\n      for (const construct of [ctagger, ctagger1]) {\n        test.deepEqual(construct.tags.resolve(), tagArray);\n      }\n\n      test.deepEqual(ctagger2.tags.resolve().length, 0);\n      test.done();\n    },\n    'setTag with propagate false tags do not propagate'(test: Test) {\n      const root = new Root();\n      const ctagger = new ChildTagger(root, 'one');\n      const ctagger1 = new ChildTagger(ctagger, 'two');\n      const ctagger2 = new ChildTagger(root, 'three');\n\n      // not taggable at all\n      new Child(ctagger, 'notag');\n\n      const tag = {key: 'Name', value: 'TheCakeIsALie'};\n      ctagger.tags.setTag(tag.key, tag.value, {propagate: false});\n\n      for (const construct of [ctagger1, ctagger2]) {\n        test.deepEqual(construct.tags.resolve().length, 0);\n      }\n      test.deepEqual(ctagger.tags.resolve()[0].key, 'Name');\n      test.deepEqual(ctagger.tags.resolve()[0].value, 'TheCakeIsALie');\n      test.done();\n    },\n    'setTag with overwrite false does not overwrite a tag'(test: Test) {\n      const root = new Root();\n      const ctagger = new ChildTagger(root, 'one');\n      ctagger.tags.setTag('Env', 'Dev');\n      ctagger.tags.setTag('Env', 'Prod', {overwrite: false});\n      const result = ctagger.tags.resolve();\n      test.deepEqual(result, [{key: 'Env', value: 'Dev'}]);\n      test.done();\n    },\n    'setTag with sticky false enables propagations to overwrite child tags'(test: Test) {\n      const root = new Root();\n      const ctagger = new ChildTagger(root, 'one');\n      const ctagger1 = new ChildTagger(ctagger, 'two');\n      ctagger.tags.setTag('Parent', 'Is always right');\n      ctagger1.tags.setTag('Parent', 'Is wrong', {sticky: false});\n      const parent = ctagger.tags.resolve();\n      const child = ctagger1.tags.resolve();\n      test.deepEqual(parent, child);\n      test.done();\n\n    },\n    'tags propagate from all parents'(test: Test) {\n      const root = new Root();\n      const ctagger = new ChildTagger(root, 'one');\n      new ChildTagger(ctagger, 'two');\n      const cNoTag = new Child(ctagger, 'three');\n      const ctagger2 = new ChildTagger(cNoTag, 'four');\n      const tag = {key: 'Name', value: 'TheCakeIsALie'};\n      ctagger.tags.setTag(tag.key, tag.value, {propagate: true});\n      test.deepEqual(ctagger2.tags.resolve(), [tag]);\n      test.done();\n    },\n    'a tag can be removed and added back'(test: Test) {\n      const root = new Root();\n      const ctagger = new ChildTagger(root, 'one');\n      const tag = {key: 'Name', value: 'TheCakeIsALie'};\n      ctagger.tags.setTag(tag.key, tag.value, {propagate: true});\n      test.deepEqual(ctagger.tags.resolve(), [tag]);\n      ctagger.tags.removeTag(tag.key);\n      test.deepEqual(ctagger.tags.resolve(), []);\n      ctagger.tags.setTag(tag.key, tag.value, {propagate: true});\n      test.deepEqual(ctagger.tags.resolve(), [tag]);\n      test.done();\n    },\n    'removeTag removes a tag by key'(test: Test) {\n      const root = new Root();\n      const ctagger = new ChildTagger(root, 'one');\n      const ctagger1 = new ChildTagger(ctagger, 'two');\n      const ctagger2 = new ChildTagger(root, 'three');\n\n      // not taggable at all\n      new Child(ctagger, 'notag');\n\n      const tag = {key: 'Name', value: 'TheCakeIsALie'};\n      ctagger.tags.setTag(tag.key, tag.value);\n      ctagger.tags.removeTag('Name');\n\n      for (const construct of [ctagger, ctagger1, ctagger2]) {\n        test.deepEqual(construct.tags.resolve().length, 0);\n      }\n      test.done();\n    },\n    'removeTag with blockPropagate removes any propagated tags'(test: Test) {\n      const root = new Root();\n      const ctagger = new ChildTagger(root, 'one');\n      const ctagger1 = new ChildTagger(ctagger, 'two');\n      ctagger.tags.setTag('Env', 'Dev');\n      ctagger1.tags.removeTag('Env', {blockPropagate: true});\n      const result = ctagger.tags.resolve();\n      test.deepEqual(result, [{key: 'Env', value: 'Dev'}]);\n      test.deepEqual(ctagger1.tags.resolve(), []);\n      test.done();\n    },\n    'children can override parent propagated tags'(test: Test) {\n      const root = new Root();\n      const ctagger = new ChildTagger(root, 'one');\n      const ctagChild = new ChildTagger(ctagger, 'one');\n      const tag = {key: 'BestBeach', value: 'StoneSteps'};\n      const tag2 = {key: 'BestBeach', value: 'k-38'};\n      ctagger.tags.setTag(tag2.key, tag2.value);\n      ctagger.tags.setTag(tag.key, tag.value);\n      ctagChild.tags.setTag(tag2.key, tag2.value);\n      const parentTags = ctagger.tags.resolve();\n      const childTags = ctagChild.tags.resolve();\n      test.deepEqual(parentTags, [tag]);\n      test.deepEqual(childTags, [tag2]);\n      test.done();\n    },\n    'resolve() returns all tags'(test: Test) {\n      const root = new Root();\n      const ctagger = new ChildTagger(root, 'one');\n      const ctagChild = new ChildTagger(ctagger, 'one');\n      const tagsNoProp = [\n        {key: 'NorthCountySpot', value: 'Tabletops'},\n        {key: 'Crowded', value: 'Trestles'},\n      ];\n      const tagsProp = [\n        {key: 'BestBeach', value: 'StoneSteps'},\n        {key: 'BestWaves', value: 'Blacks'},\n      ];\n      for (const tag of tagsNoProp) {\n        ctagger.tags.setTag(tag.key, tag.value, {propagate: false});\n      }\n      for (const tag of tagsProp) {\n        ctagger.tags.setTag(tag.key, tag.value);\n      }\n      const allTags = tagsNoProp.concat(tagsProp);\n      const cAll = ctagger.tags;\n      const cProp = ctagChild.tags;\n\n      for (const tag of cAll.resolve()) {\n        const expectedTag = allTags.filter( (t) => (t.key === tag.key));\n        test.deepEqual(expectedTag[0].value, tag.value);\n      }\n      for (const tag of cProp.resolve()) {\n        const expectedTag = tagsProp.filter( (t) => (t.key === tag.key));\n        test.deepEqual(expectedTag[0].value, tag.value);\n      }\n      test.done();\n    },\n  },\n};\n"]}

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

};
//# 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}"]}
//# 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}\n"]}

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

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.util.js","sourceRoot":"","sources":["test.util.ts"],"names":[],"mappings":"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","sourcesContent":["import { Test } from 'nodeunit';\nimport { capitalizePropertyNames, ignoreEmpty } from '../../lib/core/util';\n\nexport = {\n    'capitalizeResourceProperties capitalizes all keys of an object (recursively) from camelCase to PascalCase'(test: Test) {\n\n        test.equal(capitalizePropertyNames(undefined), undefined);\n        test.equal(capitalizePropertyNames(12), 12);\n        test.equal(capitalizePropertyNames('hello'), 'hello');\n        test.deepEqual(capitalizePropertyNames([ 'hello', 88 ]), [ 'hello', 88 ]);\n        test.deepEqual(capitalizePropertyNames(\n            { Hello: 'world', hey: 'dude' }),\n            { Hello: 'world', Hey: 'dude' });\n        test.deepEqual(capitalizePropertyNames(\n            [ 1, 2, { three: 3 }]),\n            [ 1, 2, { Three: 3 }]);\n        test.deepEqual(capitalizePropertyNames(\n            { Hello: 'world', recursive: { foo: 123, there: { another: [ 'hello', { world: 123 } ]} } }),\n            { Hello: 'world', Recursive: { Foo: 123, There: { Another: [ 'hello', { World: 123 } ]} } });\n\n        // make sure tokens are resolved and result is also capitalized\n        test.deepEqual(capitalizePropertyNames(\n            { hello: { resolve: () => ({ foo: 'bar' }) }, world: new SomeToken() }),\n            { Hello: { Foo: 'bar' }, World: 100 });\n\n        test.done();\n    },\n\n    'ignoreEmpty': {\n\n        '[]'(test: Test) {\n            test.strictEqual(ignoreEmpty([]), undefined);\n            test.done();\n        },\n\n        '{}'(test: Test) {\n            test.strictEqual(ignoreEmpty({}), undefined);\n            test.done();\n        },\n\n        'undefined/null'(test: Test) {\n            test.strictEqual(ignoreEmpty(undefined), undefined);\n            test.strictEqual(ignoreEmpty(null), null);\n            test.done();\n        },\n\n        'primitives'(test: Test) {\n            test.strictEqual(ignoreEmpty(12), 12);\n            test.strictEqual(ignoreEmpty(\"12\"), \"12\");\n            test.done();\n        },\n\n        'non-empty arrays/objects'(test: Test) {\n            test.deepEqual(ignoreEmpty([ 1, 2, 3, undefined ]), [ 1, 2, 3 ]); // undefined array values is cleaned up by \"resolve\"\n            test.deepEqual(ignoreEmpty({ o: 1, b: 2, j: 3 }), { o: 1, b: 2, j: 3 });\n            test.done();\n        },\n\n        'resolve first'(test: Test) {\n            test.deepEqual(ignoreEmpty({ xoo: { resolve: () => 123 }}), { xoo: 123 });\n            test.strictEqual(ignoreEmpty({ xoo: { resolve: () => undefined }}), undefined);\n            test.deepEqual(ignoreEmpty({ xoo: { resolve: () => [ ] }}), { xoo: [] });\n            test.deepEqual(ignoreEmpty({ xoo: { resolve: () => [ undefined, undefined ] }}), { xoo: [] });\n            test.done();\n        }\n    }\n};\n\nclass SomeToken {\n    public foo = 60;\n    public goo = 40;\n    public resolve() {\n        return this.foo + this.goo;\n    }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC51dGlsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsidGVzdC51dGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFDQSw4Q0FBMkU7QUFtRTNFLE1BQU0sU0FBUztJQUFmO1FBQ1MsUUFBRyxHQUFHLEVBQUUsQ0FBQztRQUNULFFBQUcsR0FBRyxFQUFFLENBQUM7SUFJbEIsQ0FBQztJQUhRLE9BQU87UUFDWixPQUFPLElBQUksQ0FBQyxHQUFHLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQztJQUM3QixDQUFDO0NBQ0Y7QUF2RUQsaUJBQVM7SUFDUCwyR0FBMkcsQ0FBQyxJQUFVO1FBRXBILElBQUksQ0FBQyxLQUFLLENBQUMsOEJBQXVCLENBQUMsU0FBUyxDQUFDLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDMUQsSUFBSSxDQUFDLEtBQUssQ0FBQyw4QkFBdUIsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUM1QyxJQUFJLENBQUMsS0FBSyxDQUFDLDhCQUF1QixDQUFDLE9BQU8sQ0FBQyxFQUFFLE9BQU8sQ0FBQyxDQUFDO1FBQ3RELElBQUksQ0FBQyxTQUFTLENBQUMsOEJBQXVCLENBQUMsQ0FBRSxPQUFPLEVBQUUsRUFBRSxDQUFFLENBQUMsRUFBRSxDQUFFLE9BQU8sRUFBRSxFQUFFLENBQUUsQ0FBQyxDQUFDO1FBQzFFLElBQUksQ0FBQyxTQUFTLENBQUMsOEJBQXVCLENBQ3BDLEVBQUUsS0FBSyxFQUFFLE9BQU8sRUFBRSxHQUFHLEVBQUUsTUFBTSxFQUFFLENBQUMsRUFDaEMsRUFBRSxLQUFLLEVBQUUsT0FBTyxFQUFFLEdBQUcsRUFBRSxNQUFNLEVBQUUsQ0FBQyxDQUFDO1FBQ25DLElBQUksQ0FBQyxTQUFTLENBQUMsOEJBQXVCLENBQ3BDLENBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLEtBQUssRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLEVBQ3RCLENBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxF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Q0FBQyxFQUFFLEdBQUcsRUFBRSxFQUFFLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyxHQUFHLEVBQUUsRUFBQyxDQUFDLEVBQUUsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQztZQUMxRSxJQUFJLENBQUMsV0FBVyxDQUFDLGtCQUFXLENBQUMsRUFBRSxHQUFHLEVBQUUsRUFBRSxPQUFPLEVBQUUsR0FBRyxFQUFFLENBQUMsU0FBUyxFQUFFLEVBQUMsQ0FBQyxFQUFFLFNBQVMsQ0FBQyxDQUFDO1lBQy9FLElBQUksQ0FBQyxTQUFTLENBQUMsa0JBQVcsQ0FBQyxFQUFFLEdBQUcsRUFBRSxFQUFFLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyxFQUFHLEVBQUUsRUFBQyxDQUFDLEVBQUUsRUFBRSxHQUFHLEVBQUUsRUFBRSxFQUFFLENBQUMsQ0FBQztZQUN6RSxJQUFJLENBQUMsU0FBUyxDQUFDLGtCQUFXLENBQUMsRUFBRSxHQUFHLEVBQUUsRUFBRSxPQUFPLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBRSxTQUFTLEVBQUUsU0FBUyxDQUFFLEVBQUUsRUFBQyxDQUFDLEVBQUUsRUFBRSxHQUFHLEVBQUUsRUFBRSxFQUFFLENBQUMsQ0FBQztZQUM5RixJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDZCxDQUFDO0tBQ0Y7Q0FDRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGVzdCB9IGZyb20gJ25vZGV1bml0JztcbmltcG9ydCB7IGNhcGl0YWxpemVQcm9wZXJ0eU5hbWVzLCBpZ25vcmVFbXB0eSB9IGZyb20gJy4uLy4uL2xpYi9jb3JlL3V0aWwnO1xuXG5leHBvcnQgPSB7XG4gICdjYXBpdGFsaXplUmVzb3VyY2VQcm9wZXJ0aWVzIGNhcGl0YWxpemVzIGFsbCBrZXlzIG9mIGFuIG9iamVjdCAocmVjdXJzaXZlbHkpIGZyb20gY2FtZWxDYXNlIHRvIFBhc2NhbENhc2UnKHRlc3Q6IFRlc3QpIHtcblxuICAgIHRlc3QuZXF1YWwoY2FwaXRhbGl6ZVByb3BlcnR5TmFtZXModW5kZWZpbmVkKSwgdW5kZWZpbmVkKTtcbiAgICB0ZXN0LmVxdWFsKGNhcGl0YWxpemVQcm9wZXJ0eU5hbWVzKDEyKSwgMTIpO1xuICAgIHRlc3QuZXF1YWwoY2FwaXRhbGl6ZVByb3BlcnR5TmFtZXMoJ2hlbGxvJyksICdoZWxsbycpO1xuICAgIHRlc3QuZGVlcEVxdWFsKGNhcGl0YWxpemVQcm9wZXJ0eU5hbWVzKFsgJ2hlbGxvJywgODggXSksIFsgJ2hlbGxvJywgODggXSk7XG4gICAgdGVzdC5kZWVwRXF1YWwoY2FwaXRhbGl6ZVByb3BlcnR5TmFtZXMoXG4gICAgICB7IEhlbGxvOiAnd29ybGQnLCBoZXk6ICdkdWRlJyB9KSxcbiAgICAgIHsgSGVsbG86ICd3b3JsZCcsIEhleTogJ2R1ZGUnIH0pO1xuICAgIHRlc3QuZGVlcEVxdWFsKGNhcGl0YWxpemVQcm9wZXJ0eU5hbWVzKFxuICAgICAgWyAxLCAyLCB7IHRocmVlOiAzIH1dKSxcbiAgICAgIFsgMSwgMiwgeyBUaHJlZTogMyB9XSk7XG4gICAgdGVzdC5kZWVwRXF1YWwoY2FwaXRhbGl6ZVByb3BlcnR5TmFtZXMoXG4gICAgICB7IEhlbGxvOiAnd29ybGQnLCByZWN1cnNpdmU6IHsgZm9vOiAxMjMsIHRoZXJlOiB7IGFub3RoZXI6IFsgJ2hlbGxvJywgeyB3b3JsZDogMTIzIH0gXX0gfSB9KSxcbiAgICAgIHsgSGVsbG86ICd3b3JsZCcsIFJlY3Vyc2l2ZTogeyBGb286IDEyMywgVGhlcmU6IHsgQW5vdGhlcjogWyAnaGVsbG8nLCB7IFdvcmxkOiAxMjMgfSBdfSB9IH0pO1xuXG4gICAgLy8gbWFrZSBzdXJlIHRva2VucyBhcmUgcmVzb2x2ZWQgYW5kIHJlc3VsdCBpcyBhbHNvIGNhcGl0YWxpemVkXG4gICAgdGVzdC5kZWVwRXF1YWwoY2FwaXRhbGl6ZVByb3BlcnR5TmFtZXMoXG4gICAgICB7IGhlbGxvOiB7IHJlc29sdmU6ICgpID0+ICh7IGZvbzogJ2JhcicgfSkgfSwgd29ybGQ6IG5ldyBTb21lVG9rZW4oKSB9KSxcbiAgICAgIHsgSGVsbG86IHsgRm9vOiAnYmFyJyB9LCBXb3JsZDogMTAwIH0pO1xuXG4gICAgdGVzdC5kb25lKCk7XG4gIH0sXG5cbiAgJ2lnbm9yZUVtcHR5Jzoge1xuXG4gICAgJ1tdJyh0ZXN0OiBUZXN0KSB7XG4gICAgICB0ZXN0LnN0cmljdEVxdWFsKGlnbm9yZUVtcHR5KFtdKSwgdW5kZWZpbmVkKTtcbiAgICAgIHRlc3QuZG9uZSgpO1xuICAgIH0sXG5cbiAgICAne30nKHRlc3Q6IFRlc3QpIHtcbiAgICAgIHRlc3Quc3RyaWN0RXF1YWwoaWdub3JlRW1wdHkoe30pLCB1bmRlZmluZWQpO1xuICAgICAgdGVzdC5kb25lKCk7XG4gICAgfSxcblxuICAgICd1bmRlZmluZWQvbnVsbCcodGVzdDogVGVzdCkge1xuICAgICAgdGVzdC5zdHJpY3RFcXVhbChpZ25vcmVFbXB0eSh1bmRlZmluZWQpLCB1bmRlZmluZWQpO1xuICAgICAgdGVzdC5zdHJpY3RFcXVhbChpZ25vcmVFbXB0eShudWxsKSwgbnVsbCk7XG4gICAgICB0ZXN0LmRvbmUoKTtcbiAgICB9LFxuXG4gICAgJ3ByaW1pdGl2ZXMnKHRlc3Q6IFRlc3QpIHtcbiAgICAgIHRlc3Quc3RyaWN0RXF1YWwoaWdub3JlRW1wdHkoMTIpLCAxMik7XG4gICAgICB0ZXN0LnN0cmljdEVxdWFsKGlnbm9yZUVtcHR5KFwiMTJcIiksIFwiMTJcIik7XG4gICAgICB0ZXN0LmRvbmUoKTtcbiAgICB9LFxuXG4gICAgJ25vbi1lbXB0eSBhcnJheXMvb2JqZWN0cycodGVzdDogVGVzdCkge1xuICAgICAgdGVzdC5kZWVwRXF1YWwoaWdub3JlRW1wdHkoWyAxLCAyLCAzLCB1bmRlZmluZWQgXSksIFsgMSwgMiwgMyBdKTsgLy8gdW5kZWZpbmVkIGFycmF5IHZhbHVlcyBpcyBjbGVhbmVkIHVwIGJ5IFwicmVzb2x2ZVwiXG4gICAgICB0ZXN0LmRlZXBFcXVhbChpZ25vcmVFbXB0eSh7IG86IDEsIGI6IDIsIGo6IDMgfSksIHsgbzogMSwgYjogMiwgajogMyB9KTtcbiAgICAgIHRlc3QuZG9uZSgpO1xuICAgIH0sXG5cbiAgICAncmVzb2x2ZSBmaXJzdCcodGVzdDogVGVzdCkge1xuICAgICAgdGVzdC5kZWVwRXF1YWwoaWdub3JlRW1wdHkoeyB4b286IHsgcmVzb2x2ZTogKCkgPT4gMTIzIH19KSwgeyB4b286IDEyMyB9KTtcbiAgICAgIHRlc3Quc3RyaWN0RXF1YWwoaWdub3JlRW1wdHkoeyB4b286IHsgcmVzb2x2ZTogKCkgPT4gdW5kZWZpbmVkIH19KSwgdW5kZWZpbmVkKTtcbiAgICAgIHRlc3QuZGVlcEVxdWFsKGlnbm9yZUVtcHR5KHsgeG9vOiB7IHJlc29sdmU6ICgpID0+IFsgXSB9fSksIHsgeG9vOiBbXSB9KTtcbiAgICAgIHRlc3QuZGVlcEVxdWFsKGlnbm9yZUVtcHR5KHsgeG9vOiB7IHJlc29sdmU6ICgpID0+IFsgdW5kZWZpbmVkLCB1bmRlZmluZWQgXSB9fSksIHsgeG9vOiBbXSB9KTtcbiAgICAgIHRlc3QuZG9uZSgpO1xuICAgIH1cbiAgfVxufTtcblxuY2xhc3MgU29tZVRva2VuIHtcbiAgcHVibGljIGZvbyA9IDYwO1xuICBwdWJsaWMgZ29vID0gNDA7XG4gIHB1YmxpYyByZXNvbHZlKCkge1xuICAgIHJldHVybiB0aGlzLmZvbyArIHRoaXMuZ29vO1xuICB9XG59XG4iXX0=

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

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.app.js","sourceRoot":"","sources":["test.app.ts"],"names":[],"mappings":"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","sourcesContent":["import cxapi = require('@aws-cdk/cx-api');\nimport { Test } from 'nodeunit';\nimport { Construct, Resource, Stack, StackProps } from '../lib';\nimport { App } from '../lib/app';\n\n//\n// this is the idiomatic way we want our apps to look like:\n\nfunction main(...argv: string[]): any {\n    const app = new App([ 'myprog', ...argv ]);\n\n    // stacks are children of the program\n\n    const stack1 = new Stack(app, 'stack1', { env: { account: '12345', region: 'us-east-1' } });\n    new Resource(stack1, 's1c1', { type: 'DummyResource', properties: { Prop1: 'Prop1' } });\n    const r2 = new Resource(stack1, 's1c2', { type: 'DummyResource', properties: { Foo: 123 } });\n\n    const stack2 = new Stack(app, 'stack2');\n    new Resource(stack2, 's2c1', { type: 'DummyResource', properties: { Prog2: 'Prog2' } });\n    const c1 = new MyConstruct(stack2, 's1c2');\n\n    // add some metadata\n    stack1.addMetadata('meta', 111);\n    r2.addWarning('warning1');\n    r2.addWarning('warning2');\n    c1.addMetadata('meta', { key: 'value' });\n    app.addMetadata('applevel', 123); // apps can also have metadata\n\n    return JSON.parse(app.run());\n}\n\nfunction runMain(object: cxapi.CXRequest) {\n    return main(JSON.stringify(object));\n}\n\nfunction runList() {\n    return (main(JSON.stringify({type: 'list'})) as cxapi.ListStacksResponse).stacks;\n}\n\nfunction runConsNoMeta1(stack: string, context?: any): cxapi.SynthesizedStack {\n    const response = main(JSON.stringify({\n        type: 'synth',\n        stacks: [stack],\n        context\n    }));\n    delete response.stacks[0].metadata;\n    return response.stacks[0];\n}\n\nexport = {\n    'first line is the version of the cx interface'(test: Test) {\n        const prog = new App();\n        test.ok((prog.run()).indexOf('CloudExecutable/1.0') === 0);\n        test.done();\n    },\n\n    'when executed without arguments, shows interface version and usage usage'(test: Test) {\n        const output = new App([ 'myprog' ]).run();\n\n        test.notEqual(output.indexOf('myprog'), -1, 'Output should contain program name');\n        test.notEqual(output.indexOf('Usage'), -1, 'Output should contain usage');\n        test.done();\n    },\n\n    async 'unknown command will throw an error'(test: Test) {\n        test.throws(\n            () => { main('foo'); }\n        );\n        test.done();\n    },\n\n    '\"list\" with no stacks returns with an empty array'(test: Test) {\n        const output = new App([ 'myprog', JSON.stringify({type: 'list'}) ]).run();\n        test.deepEqual(JSON.parse(output).stacks, []);\n        test.done();\n    },\n\n    '\"list\" returns a list of all stacks, with region information if exists'(test: Test) {\n        // tslint:disable-next-line:max-line-length\n        test.deepEqual(runList(), [ { name: 'stack1', environment: { name: '12345/us-east-1', region: 'us-east-1', account: '12345' } }, { name: 'stack2' } ]);\n        test.done();\n    },\n\n    'list() can be used programmatically'(test: Test) {\n        const prog = new App();\n        test.deepEqual(prog.listStacks(), []);\n        test.done();\n    },\n\n    '\"cons\" throws if the stack do not exist'(test: Test) {\n        test.throws(\n            () => { runMain({type: 'synth', stacks: ['stack99'] }); }\n        );\n        test.done();\n    },\n\n    '\"cons\" will return region info for the required stack'(test: Test) {\n        const out = (runConsNoMeta1('stack1'));\n        test.equal('stack1', out.name);\n        test.equal('12345', out.environment!.account);\n        test.equal('us-east-1', out.environment!.region);\n        test.done();\n    },\n\n    '\"cons\" will return the cloudformation template for the required stack'(test: Test) {\n        const out1 = (runConsNoMeta1('stack1')).template;\n        test.deepEqual(out1, { Resources:\n            { s1c1: { Type: 'DummyResource', Properties: { Prop1: 'Prop1' } },\n              s1c2: { Type: 'DummyResource', Properties: { Foo: 123 } } } });\n\n        const out2 = (runConsNoMeta1('stack2')).template;\n        test.deepEqual(out2,\n            { Resources:\n            { s2c1: { Type: 'DummyResource', Properties: { Prog2: 'Prog2' } },\n                s1c2r1D1791C01: { Type: 'ResourceType1' },\n                s1c2r25F685FFF: { Type: 'ResourceType2' } } });\n\n        test.done();\n    },\n\n    'synth(name) can be used programmatically'(test: Test) {\n        const prog = new App();\n        const stack = new Stack(prog, 'MyStack');\n        new Resource(stack, 'MyResource', { type: 'MyResourceType' });\n\n        let throws;\n        try {\n            prog.synthesizeStacks(['foo']);\n        } catch (e) {\n            throws = e.message;\n        }\n        test.ok(throws.indexOf('Cannot find stack foo') !== -1);\n\n        test.deepEqual(prog.synthesizeStack('MyStack').template,\n            { Resources: { MyResource: { Type: 'MyResourceType' } } });\n        test.done();\n    },\n\n    'synth(name) also collects metadata from all constructs in the stack'(test: Test) {\n        const response = runMain({type: 'synth', stacks: ['stack1']}) as cxapi.SynthesizeResponse;\n\n        const output = response.stacks[0].metadata;\n        stripStackTraces(output);\n\n        test.ok(output['/'], 'app-level metadata is included under \".\"');\n        test.equal(output['/'][0].type, 'applevel');\n        test.equal(output['/'][0].data, 123);\n\n        test.ok(output['/stack1'], 'the construct \"stack1\" has metadata');\n        test.equal(output['/stack1'][0].type, 'meta');\n        test.equal(output['/stack1'][0].data, 111);\n        test.ok(output['/stack1'][0].trace.length > 0, 'trace contains multiple entries');\n\n        test.ok(output['/stack1/s1c2']);\n        test.equal(output['/stack1/s1c2'].length, 2, 'two entries');\n        test.equal(output['/stack1/s1c2'][0].data, 'warning1');\n\n        const response2 = runMain({type: 'synth', stacks: ['stack2']}) as cxapi.SynthesizeResponse;\n        const output2 = response2.stacks[0].metadata;\n\n        test.ok(output2['/stack2/s1c2']);\n        test.equal(output2['/stack2/s1c2'][0].type, 'meta');\n        test.deepEqual(output2['/stack2/s1c2'][0].data, { key: 'value' });\n\n        test.done();\n    },\n\n    'context can be passed using the -c option'(test: Test) {\n        const prog = new App([ 'myprog', JSON.stringify({\n            type: 'synth',\n            stackName: 'stack',\n            context: {\n                key1: 'val1',\n                key2: 'val2'\n            }\n        })]);\n        test.deepEqual(prog.getContext('key1'), 'val1');\n        test.deepEqual(prog.getContext('key2'), 'val2');\n        test.done();\n    },\n\n    'context from the command line can be used when creating the stack'(test: Test) {\n        const output = runConsNoMeta1('stack2', { ctx1: 'HELLO' });\n\n        test.deepEqual(output.template, {\n            Resources: {\n              s2c1: {\n                Type: \"DummyResource\",\n                Properties: {\n                  Prog2: \"Prog2\"\n                }\n              },\n              s1c2r1D1791C01: {\n                Type: \"ResourceType1\"\n              },\n              s1c2r25F685FFF: {\n                Type: \"ResourceType2\",\n                Properties: {\n                  FromContext: \"HELLO\"\n                }\n              }\n            }\n        });\n        test.done();\n    },\n\n    'setContext(k,v) can be used to set context programmatically'(test: Test) {\n        const prog = new App();\n        prog.setContext('foo', 'bar');\n        test.deepEqual(prog.getContext('foo'), 'bar');\n        test.done();\n    },\n\n    'setContext(k,v) cannot be called after stacks have been added because stacks may use the context'(test: Test) {\n        const prog = new App();\n        new Stack(prog, 's1');\n        test.throws(() => prog.setContext('foo', 'bar'));\n        test.done();\n    },\n\n    'app.synthesizeStack(stack) performs validation first (app.validateAll()) and if there are errors, it returns the errors'(test: Test) {\n\n        class Child extends Construct {\n            public validate() {\n                return [ `Error from ${this.id}` ];\n            }\n        }\n\n        class Parent extends Stack {\n\n        }\n\n        const app = new App();\n\n        const parent = new Parent(app, 'Parent');\n        new Child(parent, 'C1');\n        new Child(parent, 'C2');\n\n        test.throws(() => {\n            app.synthesizeStacks(['Parent']);\n        }, /Stack validation failed with the following errors/);\n\n        test.done();\n    },\n\n    'app.synthesizeStack(stack) will return a list of missing contextual information'(test: Test) {\n        const command: cxapi.CXRequest = {\n            type: 'synth',\n            stacks: ['MyStack']\n        };\n\n        class MyStack extends Stack {\n            constructor(parent: App, name: string, props?: StackProps) {\n                super(parent, name, props);\n\n                this.reportMissingContext('missing-context-key', {\n                    provider: 'ctx-provider',\n                    args: [ 'arg1', 'arg2' ],\n                    scope: [ 'scope1', 'scope2' ]\n                });\n\n                this.reportMissingContext('missing-context-key-2', {\n                    provider: 'ctx-provider',\n                    args: [ 'arg1', 'arg2' ],\n                    scope: [ 'scope1', 'scope2' ]\n                });\n            }\n        }\n\n        const app = new App([ 'prog', JSON.stringify(command) ]);\n\n        new MyStack(app, 'MyStack');\n\n        const response = JSON.parse(app.run()) as cxapi.SynthesizeResponse;\n\n        test.deepEqual(response.stacks[0].missing, {\n            \"missing-context-key\": {\n            provider: \"ctx-provider\",\n            args: [\n                \"arg1\",\n                \"arg2\"\n            ],\n            scope: [\n                \"scope1\",\n                \"scope2\"\n            ]\n            },\n            \"missing-context-key-2\": {\n            provider: \"ctx-provider\",\n            args: [\n                \"arg1\",\n                \"arg2\"\n            ],\n            scope: [\n                \"scope1\",\n                \"scope2\"\n            ]\n            }\n        });\n\n        test.done();\n    },\n\n    'requests can also be base64 encoded'(test: Test) {\n        const req = {\n            type: 'list'\n        };\n        const resp = main('base64:' + new Buffer(JSON.stringify(req)).toString('base64'));\n        test.deepEqual(resp, {\n            stacks: [\n              {\n                name: \"stack1\",\n                environment: {\n                  name: \"12345/us-east-1\",\n                  account: \"12345\",\n                  region: \"us-east-1\"\n                }\n              },\n              {\n                name: \"stack2\"\n              }\n            ]\n        });\n\n        test.done();\n    },\n\n    'fails when base64 cannot be encoded'(test: Test) {\n        test.throws(() => main('base64:'), /Unexpected end of JSON input/);\n        test.done();\n    }\n};\n\nclass MyConstruct extends Construct {\n    constructor(parent: Construct, name: string) {\n        super(parent, name);\n\n        new Resource(this, 'r1', { type: 'ResourceType1' });\n        new Resource(this, 'r2', { type: 'ResourceType2', properties: { FromContext: this.getContext('ctx1') } });\n    }\n}\n\n/**\n * Strip stack traces from metadata\n */\nfunction stripStackTraces(meta: cxapi.StackMetadata) {\n    for (const key of Object.keys(meta)) {\n        meta[key] = meta[key].filter(entry => entry.type !== 'aws:cdk:logicalId');\n    }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.app.js","sourceRoot":"","sources":["test.app.ts"],"names":[],"mappings":"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","sourcesContent":["import cxapi = require('@aws-cdk/cx-api');\nimport { Test } from 'nodeunit';\nimport { Construct, Resource, Stack, StackProps } from '../lib';\nimport { App } from '../lib/app';\n\n//\n// this is the idiomatic way we want our apps to look like:\n\nfunction main(...argv: string[]): any {\n  const app = new App([ 'myprog', ...argv ]);\n\n  // stacks are children of the program\n\n  const stack1 = new Stack(app, 'stack1', { env: { account: '12345', region: 'us-east-1' } });\n  new Resource(stack1, 's1c1', { type: 'DummyResource', properties: { Prop1: 'Prop1' } });\n  const r2 = new Resource(stack1, 's1c2', { type: 'DummyResource', properties: { Foo: 123 } });\n\n  const stack2 = new Stack(app, 'stack2');\n  new Resource(stack2, 's2c1', { type: 'DummyResource', properties: { Prog2: 'Prog2' } });\n  const c1 = new MyConstruct(stack2, 's1c2');\n\n  // add some metadata\n  stack1.addMetadata('meta', 111);\n  r2.addWarning('warning1');\n  r2.addWarning('warning2');\n  c1.addMetadata('meta', { key: 'value' });\n  app.addMetadata('applevel', 123); // apps can also have metadata\n\n  return JSON.parse(app.run());\n}\n\nfunction runMain(object: cxapi.CXRequest) {\n  return main(JSON.stringify(object));\n}\n\nfunction runList() {\n  return (main(JSON.stringify({type: 'list'})) as cxapi.ListStacksResponse).stacks;\n}\n\nfunction runConsNoMeta1(stack: string, context?: any): cxapi.SynthesizedStack {\n  const response = main(JSON.stringify({\n    type: 'synth',\n    stacks: [stack],\n    context\n  }));\n  delete response.stacks[0].metadata;\n  return response.stacks[0];\n}\n\nexport = {\n  'first line is the version of the cx interface'(test: Test) {\n    const prog = new App();\n    test.ok((prog.run()).indexOf('CloudExecutable/1.0') === 0);\n    test.done();\n  },\n\n  'when executed without arguments, shows interface version and usage usage'(test: Test) {\n    const output = new App([ 'myprog' ]).run();\n\n    test.notEqual(output.indexOf('myprog'), -1, 'Output should contain program name');\n    test.notEqual(output.indexOf('Usage'), -1, 'Output should contain usage');\n    test.done();\n  },\n\n  async 'unknown command will throw an error'(test: Test) {\n    test.throws(\n      () => { main('foo'); }\n    );\n    test.done();\n  },\n\n  '\"list\" with no stacks returns with an empty array'(test: Test) {\n    const output = new App([ 'myprog', JSON.stringify({type: 'list'}) ]).run();\n    test.deepEqual(JSON.parse(output).stacks, []);\n    test.done();\n  },\n\n  '\"list\" returns a list of all stacks, with region information if exists'(test: Test) {\n    // tslint:disable-next-line:max-line-length\n    test.deepEqual(runList(), [ { name: 'stack1', environment: { name: '12345/us-east-1', region: 'us-east-1', account: '12345' } }, { name: 'stack2' } ]);\n    test.done();\n  },\n\n  'list() can be used programmatically'(test: Test) {\n    const prog = new App();\n    test.deepEqual(prog.listStacks(), []);\n    test.done();\n  },\n\n  '\"cons\" throws if the stack do not exist'(test: Test) {\n    test.throws(\n      () => { runMain({type: 'synth', stacks: ['stack99'] }); }\n    );\n    test.done();\n  },\n\n  '\"cons\" will return region info for the required stack'(test: Test) {\n    const out = (runConsNoMeta1('stack1'));\n    test.equal('stack1', out.name);\n    test.equal('12345', out.environment!.account);\n    test.equal('us-east-1', out.environment!.region);\n    test.done();\n  },\n\n  '\"cons\" will return the cloudformation template for the required stack'(test: Test) {\n    const out1 = (runConsNoMeta1('stack1')).template;\n    test.deepEqual(out1, { Resources:\n      { s1c1: { Type: 'DummyResource', Properties: { Prop1: 'Prop1' } },\n        s1c2: { Type: 'DummyResource', Properties: { Foo: 123 } } } });\n\n    const out2 = (runConsNoMeta1('stack2')).template;\n    test.deepEqual(out2,\n      { Resources:\n      { s2c1: { Type: 'DummyResource', Properties: { Prog2: 'Prog2' } },\n        s1c2r1D1791C01: { Type: 'ResourceType1' },\n        s1c2r25F685FFF: { Type: 'ResourceType2' } } });\n\n    test.done();\n  },\n\n  'synth(name) can be used programmatically'(test: Test) {\n    const prog = new App();\n    const stack = new Stack(prog, 'MyStack');\n    new Resource(stack, 'MyResource', { type: 'MyResourceType' });\n\n    let throws;\n    try {\n      prog.synthesizeStacks(['foo']);\n    } catch (e) {\n      throws = e.message;\n    }\n    test.ok(throws.indexOf('Cannot find stack foo') !== -1);\n\n    test.deepEqual(prog.synthesizeStack('MyStack').template,\n      { Resources: { MyResource: { Type: 'MyResourceType' } } });\n    test.done();\n  },\n\n  'synth(name) also collects metadata from all constructs in the stack'(test: Test) {\n    const response = runMain({type: 'synth', stacks: ['stack1']}) as cxapi.SynthesizeResponse;\n\n    const output = response.stacks[0].metadata;\n    stripStackTraces(output);\n\n    test.ok(output['/'], 'app-level metadata is included under \".\"');\n    test.equal(output['/'][0].type, 'applevel');\n    test.equal(output['/'][0].data, 123);\n\n    test.ok(output['/stack1'], 'the construct \"stack1\" has metadata');\n    test.equal(output['/stack1'][0].type, 'meta');\n    test.equal(output['/stack1'][0].data, 111);\n    test.ok(output['/stack1'][0].trace.length > 0, 'trace contains multiple entries');\n\n    test.ok(output['/stack1/s1c2']);\n    test.equal(output['/stack1/s1c2'].length, 2, 'two entries');\n    test.equal(output['/stack1/s1c2'][0].data, 'warning1');\n\n    const response2 = runMain({type: 'synth', stacks: ['stack2']}) as cxapi.SynthesizeResponse;\n    const output2 = response2.stacks[0].metadata;\n\n    test.ok(output2['/stack2/s1c2']);\n    test.equal(output2['/stack2/s1c2'][0].type, 'meta');\n    test.deepEqual(output2['/stack2/s1c2'][0].data, { key: 'value' });\n\n    test.done();\n  },\n\n  'context can be passed using the -c option'(test: Test) {\n    const prog = new App([ 'myprog', JSON.stringify({\n      type: 'synth',\n      stackName: 'stack',\n      context: {\n        key1: 'val1',\n        key2: 'val2'\n      }\n    })]);\n    test.deepEqual(prog.getContext('key1'), 'val1');\n    test.deepEqual(prog.getContext('key2'), 'val2');\n    test.done();\n  },\n\n  'context from the command line can be used when creating the stack'(test: Test) {\n    const output = runConsNoMeta1('stack2', { ctx1: 'HELLO' });\n\n    test.deepEqual(output.template, {\n      Resources: {\n        s2c1: {\n        Type: \"DummyResource\",\n        Properties: {\n          Prog2: \"Prog2\"\n        }\n        },\n        s1c2r1D1791C01: {\n        Type: \"ResourceType1\"\n        },\n        s1c2r25F685FFF: {\n        Type: \"ResourceType2\",\n        Properties: {\n          FromContext: \"HELLO\"\n        }\n        }\n      }\n    });\n    test.done();\n  },\n\n  'setContext(k,v) can be used to set context programmatically'(test: Test) {\n    const prog = new App();\n    prog.setContext('foo', 'bar');\n    test.deepEqual(prog.getContext('foo'), 'bar');\n    test.done();\n  },\n\n  'setContext(k,v) cannot be called after stacks have been added because stacks may use the context'(test: Test) {\n    const prog = new App();\n    new Stack(prog, 's1');\n    test.throws(() => prog.setContext('foo', 'bar'));\n    test.done();\n  },\n\n  'app.synthesizeStack(stack) performs validation first (app.validateAll()) and if there are errors, it returns the errors'(test: Test) {\n\n    class Child extends Construct {\n      public validate() {\n        return [ `Error from ${this.id}` ];\n      }\n    }\n\n    class Parent extends Stack {\n\n    }\n\n    const app = new App();\n\n    const parent = new Parent(app, 'Parent');\n    new Child(parent, 'C1');\n    new Child(parent, 'C2');\n\n    test.throws(() => {\n      app.synthesizeStacks(['Parent']);\n    }, /Stack validation failed with the following errors/);\n\n    test.done();\n  },\n\n  'app.synthesizeStack(stack) will return a list of missing contextual information'(test: Test) {\n    const command: cxapi.CXRequest = {\n      type: 'synth',\n      stacks: ['MyStack']\n    };\n\n    class MyStack extends Stack {\n      constructor(parent: App, name: string, props?: StackProps) {\n        super(parent, name, props);\n\n        this.reportMissingContext('missing-context-key', {\n          provider: 'ctx-provider',\n          args: [ 'arg1', 'arg2' ],\n          scope: [ 'scope1', 'scope2' ]\n        });\n\n        this.reportMissingContext('missing-context-key-2', {\n          provider: 'ctx-provider',\n          args: [ 'arg1', 'arg2' ],\n          scope: [ 'scope1', 'scope2' ]\n        });\n      }\n    }\n\n    const app = new App([ 'prog', JSON.stringify(command) ]);\n\n    new MyStack(app, 'MyStack');\n\n    const response = JSON.parse(app.run()) as cxapi.SynthesizeResponse;\n\n    test.deepEqual(response.stacks[0].missing, {\n      \"missing-context-key\": {\n      provider: \"ctx-provider\",\n      args: [\n        \"arg1\",\n        \"arg2\"\n      ],\n      scope: [\n        \"scope1\",\n        \"scope2\"\n      ]\n      },\n      \"missing-context-key-2\": {\n      provider: \"ctx-provider\",\n      args: [\n        \"arg1\",\n        \"arg2\"\n      ],\n      scope: [\n        \"scope1\",\n        \"scope2\"\n      ]\n      }\n    });\n\n    test.done();\n  },\n\n  'requests can also be base64 encoded'(test: Test) {\n    const req = {\n      type: 'list'\n    };\n    const resp = main('base64:' + new Buffer(JSON.stringify(req)).toString('base64'));\n    test.deepEqual(resp, {\n      stacks: [\n        {\n        name: \"stack1\",\n        environment: {\n          name: \"12345/us-east-1\",\n          account: \"12345\",\n          region: \"us-east-1\"\n        }\n        },\n        {\n        name: \"stack2\"\n        }\n      ]\n    });\n\n    test.done();\n  },\n\n  'fails when base64 cannot be encoded'(test: Test) {\n    test.throws(() => main('base64:'), /Unexpected end of JSON input/);\n    test.done();\n  }\n};\n\nclass MyConstruct extends Construct {\n  constructor(parent: Construct, name: string) {\n    super(parent, name);\n\n    new Resource(this, 'r1', { type: 'ResourceType1' });\n    new Resource(this, 'r2', { type: 'ResourceType2', properties: { FromContext: this.getContext('ctx1') } });\n  }\n}\n\n/**\n * Strip stack traces from metadata\n */\nfunction stripStackTraces(meta: cxapi.StackMetadata) {\n  for (const key of Object.keys(meta)) {\n    meta[key] = meta[key].filter(entry => entry.type !== 'aws:cdk:logicalId');\n  }\n}\n"]}

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

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.context.js","sourceRoot":"","sources":["test.context.ts"],"names":[],"mappings":"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","sourcesContent":["import cxapi = require('@aws-cdk/cx-api');\nimport { Test } from 'nodeunit';\nimport { App, AvailabilityZoneProvider, Construct, MetadataEntry, resolve, SSMParameterProvider, Stack } from '../lib';\n\nexport = {\n    'AvailabilityZoneProvider returns a list with dummy values if the context is not available'(test: Test) {\n        const stack = new Stack(undefined, 'TestStack', { env: { account: '12345', region: 'us-east-1' } });\n        const azs = new AvailabilityZoneProvider(stack).availabilityZones;\n\n        test.deepEqual(azs, ['dummy1a', 'dummy1b', 'dummy1c']);\n        test.done();\n    },\n\n    'AvailabilityZoneProvider will return context list if available'(test: Test) {\n        const stack = new Stack(undefined, 'TestStack', { env: { account: '12345', region: 'us-east-1' } });\n        const before = new AvailabilityZoneProvider(stack).availabilityZones;\n        test.deepEqual(before, [ 'dummy1a', 'dummy1b', 'dummy1c' ]);\n        const key = expectedContextKey(stack);\n\n        stack.setContext(key, ['us-east-1a', 'us-east-1b']);\n\n        const azs = new AvailabilityZoneProvider(stack).availabilityZones;\n        test.deepEqual(azs, ['us-east-1a', 'us-east-1b']);\n\n        test.done();\n    },\n\n    'AvailabilityZoneProvider will complain if not given a list'(test: Test) {\n        const stack = new Stack(undefined, 'TestStack', { env: { account: '12345', region: 'us-east-1' } });\n        const before = new AvailabilityZoneProvider(stack).availabilityZones;\n        test.deepEqual(before, [ 'dummy1a', 'dummy1b', 'dummy1c' ]);\n        const key = expectedContextKey(stack);\n\n        stack.setContext(key, 'not-a-list');\n\n        test.throws(\n            () => new AvailabilityZoneProvider(stack).availabilityZones\n        );\n\n        test.done();\n    },\n\n    'SSM parameter provider will return context values if available'(test: Test) {\n        const stack = new Stack(undefined, 'TestStack', { env: { account: '12345', region: 'us-east-1' } });\n        new SSMParameterProvider(stack).getString('test');\n        const key = expectedContextKey(stack);\n\n        stack.setContext(key, 'abc');\n\n        const azs = resolve(new SSMParameterProvider(stack).getString('test'));\n        test.deepEqual(azs, 'abc');\n\n        test.done();\n    },\n\n    'Return default values if \"env\" is undefined to facilitate unit tests, but also expect metadata to include \"error\" messages'(test: Test) {\n        const app = new App();\n        const stack = new Stack(app, 'test-stack');\n\n        const child = new Construct(stack, 'ChildConstruct');\n\n        test.deepEqual(new AvailabilityZoneProvider(stack).availabilityZones, [ 'dummy1a', 'dummy1b', 'dummy1c' ]);\n        test.deepEqual(new SSMParameterProvider(child).getString('foo'), 'dummy');\n\n        const output = app.synthesizeStack(stack.id);\n\n        const azError: MetadataEntry | undefined = output.metadata['/test-stack'].find(x => x.type === cxapi.ERROR_METADATA_KEY);\n        const ssmError: MetadataEntry | undefined = output.metadata['/test-stack/ChildConstruct'].find(x => x.type === cxapi.ERROR_METADATA_KEY);\n\n        test.ok(azError && (azError.data as string).includes('Cannot determine scope for context provider availability-zones.'));\n        test.ok(ssmError && (ssmError.data as string).includes('Cannot determine scope for context provider ssm[\"foo\"].'));\n\n        test.done();\n    },\n};\n\nfunction firstKey(obj: any): string {\n    return Object.keys(obj)[0];\n}\n\n/**\n * Get the expected context key from a stack with missing parameters\n */\nfunction expectedContextKey(stack: Stack): string {\n    return firstKey(stack.missingContext);\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.context.js","sourceRoot":"","sources":["test.context.ts"],"names":[],"mappings":"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","sourcesContent":["import cxapi = require('@aws-cdk/cx-api');\nimport { Test } from 'nodeunit';\nimport { App, AvailabilityZoneProvider, Construct, MetadataEntry, resolve, SSMParameterProvider, Stack } from '../lib';\n\nexport = {\n  'AvailabilityZoneProvider returns a list with dummy values if the context is not available'(test: Test) {\n    const stack = new Stack(undefined, 'TestStack', { env: { account: '12345', region: 'us-east-1' } });\n    const azs = new AvailabilityZoneProvider(stack).availabilityZones;\n\n    test.deepEqual(azs, ['dummy1a', 'dummy1b', 'dummy1c']);\n    test.done();\n  },\n\n  'AvailabilityZoneProvider will return context list if available'(test: Test) {\n    const stack = new Stack(undefined, 'TestStack', { env: { account: '12345', region: 'us-east-1' } });\n    const before = new AvailabilityZoneProvider(stack).availabilityZones;\n    test.deepEqual(before, [ 'dummy1a', 'dummy1b', 'dummy1c' ]);\n    const key = expectedContextKey(stack);\n\n    stack.setContext(key, ['us-east-1a', 'us-east-1b']);\n\n    const azs = new AvailabilityZoneProvider(stack).availabilityZones;\n    test.deepEqual(azs, ['us-east-1a', 'us-east-1b']);\n\n    test.done();\n  },\n\n  'AvailabilityZoneProvider will complain if not given a list'(test: Test) {\n    const stack = new Stack(undefined, 'TestStack', { env: { account: '12345', region: 'us-east-1' } });\n    const before = new AvailabilityZoneProvider(stack).availabilityZones;\n    test.deepEqual(before, [ 'dummy1a', 'dummy1b', 'dummy1c' ]);\n    const key = expectedContextKey(stack);\n\n    stack.setContext(key, 'not-a-list');\n\n    test.throws(\n      () => new AvailabilityZoneProvider(stack).availabilityZones\n    );\n\n    test.done();\n  },\n\n  'SSM parameter provider will return context values if available'(test: Test) {\n    const stack = new Stack(undefined, 'TestStack', { env: { account: '12345', region: 'us-east-1' } });\n    new SSMParameterProvider(stack).getString('test');\n    const key = expectedContextKey(stack);\n\n    stack.setContext(key, 'abc');\n\n    const azs = resolve(new SSMParameterProvider(stack).getString('test'));\n    test.deepEqual(azs, 'abc');\n\n    test.done();\n  },\n\n  'Return default values if \"env\" is undefined to facilitate unit tests, but also expect metadata to include \"error\" messages'(test: Test) {\n    const app = new App();\n    const stack = new Stack(app, 'test-stack');\n\n    const child = new Construct(stack, 'ChildConstruct');\n\n    test.deepEqual(new AvailabilityZoneProvider(stack).availabilityZones, [ 'dummy1a', 'dummy1b', 'dummy1c' ]);\n    test.deepEqual(new SSMParameterProvider(child).getString('foo'), 'dummy');\n\n    const output = app.synthesizeStack(stack.id);\n\n    const azError: MetadataEntry | undefined = output.metadata['/test-stack'].find(x => x.type === cxapi.ERROR_METADATA_KEY);\n    const ssmError: MetadataEntry | undefined = output.metadata['/test-stack/ChildConstruct'].find(x => x.type === cxapi.ERROR_METADATA_KEY);\n\n    test.ok(azError && (azError.data as string).includes('Cannot determine scope for context provider availability-zones.'));\n    test.ok(ssmError && (ssmError.data as string).includes('Cannot determine scope for context provider ssm[\"foo\"].'));\n\n    test.done();\n  },\n};\n\nfunction firstKey(obj: any): string {\n  return Object.keys(obj)[0];\n}\n\n/**\n * Get the expected context key from a stack with missing parameters\n */\nfunction expectedContextKey(stack: Stack): string {\n  return firstKey(stack.missingContext);\n}\n"]}

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

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5lbnZpcm9ubWVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInRlc3QuZW52aXJvbm1lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLDRDQUEwRjtBQUUxRixnQ0FBb0M7QUFFcEMsaUJBQVM7SUFDTCw0REFBNEQsQ0FBQyxJQUFVO1FBQ25FLE1BQU0sS0FBSyxHQUFHLElBQUksV0FBSyxFQUFFLENBQUM7UUFDMUIsSUFBSSxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDbkIsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUNwQyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxDQUFDO1FBQ25DLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNoQixDQUFDO0lBRUQsMkhBQTJILENBQUMsSUFBVTtRQUNsSSxNQUFNLEdBQUcsR0FBRyxJQUFJLFNBQUcsRUFBRSxDQUFDO1FBRXRCLEdBQUcsQ0FBQyxVQUFVLENBQUMsb0NBQTJCLEVBQUUsb0JBQW9CLENBQUMsQ0FBQztRQUNsRSxHQUFHLENBQUMsVUFBVSxDQUFDLG1DQUEwQixFQUFFLG1CQUFtQixDQUFDLENBQUM7UUFFaEUsTUFBTSxLQUFLLEdBQUcsSUFBSSxXQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFFN0IsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLE9BQU8sRUFBRSxvQkFBb0IsQ0FBQyxDQUFDO1FBQ3BELElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxNQUFNLEVBQUUsbUJBQW1CLENBQUMsQ0FBQztRQUVsRCxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDaEIsQ0FBQztJQUVELDBGQUEwRixDQUFDLElBQVU7UUFDakcsTUFBTSxHQUFHLEdBQUcsSUFBSSxTQUFHLEVBQUUsQ0FBQztRQUV0QixHQUFHLENBQUMsVUFBVSxDQUFDLG9DQUEyQixFQUFFLG9CQUFvQixDQUFDLENBQUM7UUFDbEUsR0FBRyxDQUFDLFVBQVUsQ0FBQyxtQ0FBMEIsRUFBRSxtQkFBbUIsQ0FBQyxDQUFDO1FBRWhFLE1BQU0sTUFBTSxHQUFHLElBQUksV0FBSyxDQUFDLEdBQUcsRUFBRSxJQUFJLEVBQUUsRUFBRSxHQUFHLEVBQUUsRUFBRSxNQUFNLEVBQUUsYUFBYSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQ3hFLE1BQU0sTUFBTSxHQUFHLElBQUksV0FBSyxDQUFDLEdBQUcsRUFBRSxJQUFJLEVBQUUsRUFBRSxHQUFHLEVBQUUsRUFBRSxPQUFPLEVBQUUsY0FBYyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRTFFLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxPQUFPLEVBQUUsb0JBQW9CLENBQUMsQ0FBQztRQUNyRCxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsTUFBTSxFQUFFLGFBQWEsQ0FBQyxDQUFDO1FBRTdDLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxPQUFPLEVBQUUsY0FBYyxDQUFDLENBQUM7UUFDL0MsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLE1BQU0sRUFBRSxtQkFBbUIsQ0FBQyxDQUFDO1FBRW5ELElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNoQixDQUFDO0NBQ0csQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERFRkFVTFRfQUNDT1VOVF9DT05URVhUX0tFWSwgREVGQVVMVF9SRUdJT05fQ09OVEVYVF9LRVkgfSBmcm9tICdAYXdzLWNkay9jeC1hcGknO1xuaW1wb3J0IHsgVGVzdCB9IGZyb20gJ25vZGV1bml0JztcbmltcG9ydCB7IEFwcCwgU3RhY2sgfSBmcm9tICcuLi9saWInO1xuXG5leHBvcnQgPSB7XG4gICAgJ0J5IGRlZmF1bHQsIGVudmlyb25tZW50IHJlZ2lvbiBhbmQgYWNjb3VudCBhcmUgbm90IGRlZmluZWQnKHRlc3Q6IFRlc3QpIHtcbiAgICAgICAgY29uc3Qgc3RhY2sgPSBuZXcgU3RhY2soKTtcbiAgICAgICAgdGVzdC5vayhzdGFjay5lbnYpO1xuICAgICAgICB0ZXN0LmVxdWFsKHN0YWNrLmVudi5hY2NvdW50LCBudWxsKTtcbiAgICAgICAgdGVzdC5lcXVhbChzdGFjay5lbnYucmVnaW9uLCBudWxsKTtcbiAgICAgICAgdGVzdC5kb25lKCk7XG4gICAgfSxcblxuICAgICdEZWZhdWx0IGFjY291bnQgYW5kIHJlZ2lvbiBjYW4gYmUgc2V0IGluIGNvbnRleHQgKGBhd3M6Y2RrOnRvb2xraXQ6ZGVmYXVsdC1hY2NvdW50YCBhbmQgYGF3czpjZGs6dG9vbGtpdDpkZWZhdWx0LXJlZ2lvbmApJyh0ZXN0OiBUZXN0KSB7XG4gICAgICAgIGNvbnN0IGFwcCA9IG5ldyBBcHAoKTtcblxuICAgICAgICBhcHAuc2V0Q29udGV4dChERUZBVUxUX0FDQ09VTlRfQ09OVEVYVF9LRVksICdteS1kZWZhdWx0LWFjY291bnQnKTtcbiAgICAgICAgYXBwLnNldENvbnRleHQoREVGQVVMVF9SRUdJT05fQ09OVEVYVF9LRVksICdteS1kZWZhdWx0LXJlZ2lvbicpO1xuXG4gICAgICAgIGNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKGFwcCk7XG5cbiAgICAgICAgdGVzdC5lcXVhbChzdGFjay5lbnYuYWNjb3VudCwgJ215LWRlZmF1bHQtYWNjb3VudCcpO1xuICAgICAgICB0ZXN0LmVxdWFsKHN0YWNrLmVudi5yZWdpb24sICdteS1kZWZhdWx0LXJlZ2lvbicpO1xuXG4gICAgICAgIHRlc3QuZG9uZSgpO1xuICAgIH0sXG5cbiAgICAnSWYgb25seSBgZW52LnJlZ2lvbmAgb3IgYGVudi5hY2NvdW50YCBhcmUgc3BlY2lmaWVkLCBkZWZhdWx0cyB3aWxsIGJlIHVzZWQgZm9yIHRoZSBvdGhlcicodGVzdDogVGVzdCkge1xuICAgICAgICBjb25zdCBhcHAgPSBuZXcgQXBwKCk7XG5cbiAgICAgICAgYXBwLnNldENvbnRleHQoREVGQVVMVF9BQ0NPVU5UX0NPTlRFWFRfS0VZLCAnbXktZGVmYXVsdC1hY2NvdW50Jyk7XG4gICAgICAgIGFwcC5zZXRDb250ZXh0KERFRkFVTFRfUkVHSU9OX0NPTlRFWFRfS0VZLCAnbXktZGVmYXVsdC1yZWdpb24nKTtcblxuICAgICAgICBjb25zdCBzdGFjazEgPSBuZXcgU3RhY2soYXBwLCAnUzEnLCB7IGVudjogeyByZWdpb246ICdvbmx5LXJlZ2lvbicgfSB9KTtcbiAgICAgICAgY29uc3Qgc3RhY2syID0gbmV3IFN0YWNrKGFwcCwgJ1MyJywgeyBlbnY6IHsgYWNjb3VudDogJ29ubHktYWNjb3VudCcgfSB9KTtcblxuICAgICAgICB0ZXN0LmVxdWFsKHN0YWNrMS5lbnYuYWNjb3VudCwgJ215LWRlZmF1bHQtYWNjb3VudCcpO1xuICAgICAgICB0ZXN0LmVxdWFsKHN0YWNrMS5lbnYucmVnaW9uLCAnb25seS1yZWdpb24nKTtcblxuICAgICAgICB0ZXN0LmVxdWFsKHN0YWNrMi5lbnYuYWNjb3VudCwgJ29ubHktYWNjb3VudCcpO1xuICAgICAgICB0ZXN0LmVxdWFsKHN0YWNrMi5lbnYucmVnaW9uLCAnbXktZGVmYXVsdC1yZWdpb24nKTtcblxuICAgICAgICB0ZXN0LmRvbmUoKTtcbiAgICB9LFxufSBhcyBhbnk7XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5lbnZpcm9ubWVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInRlc3QuZW52aXJvbm1lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLDRDQUEwRjtBQUUxRixnQ0FBb0M7QUFFcEMsaUJBQVM7SUFDUCw0REFBNEQsQ0FBQyxJQUFVO1FBQ3JFLE1BQU0sS0FBSyxHQUFHLElBQUksV0FBSyxFQUFFLENBQUM7UUFDMUIsSUFBSSxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDbkIsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUNwQyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxDQUFDO1FBQ25DLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNkLENBQUM7SUFFRCwySEFBMkgsQ0FBQyxJQUFVO1FBQ3BJLE1BQU0sR0FBRyxHQUFHLElBQUksU0FBRyxFQUFFLENBQUM7UUFFdEIsR0FBRyxDQUFDLFVBQVUsQ0FBQyxvQ0FBMkIsRUFBRSxvQkFBb0IsQ0FBQyxDQUFDO1FBQ2xFLEdBQUcsQ0FBQyxVQUFVLENBQUMsbUNBQTBCLEVBQUUsbUJBQW1CLENBQUMsQ0FBQztRQUVoRSxNQUFNLEtBQUssR0FBRyxJQUFJLFdBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUU3QixJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsT0FBTyxFQUFFLG9CQUFvQixDQUFDLENBQUM7UUFDcEQsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLE1BQU0sRUFBRSxtQkFBbUIsQ0FBQyxDQUFDO1FBRWxELElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNkLENBQUM7SUFFRCwwRkFBMEYsQ0FBQyxJQUFVO1FBQ25HLE1BQU0sR0FBRyxHQUFHLElBQUksU0FBRyxFQUFFLENBQUM7UUFFdEIsR0FBRyxDQUFDLFVBQVUsQ0FBQyxvQ0FBMkIsRUFBRSxvQkFBb0IsQ0FBQyxDQUFDO1FBQ2xFLEdBQUcsQ0FBQyxVQUFVLENBQUMsbUNBQTBCLEVBQUUsbUJBQW1CLENBQUMsQ0FBQztRQUVoRSxNQUFNLE1BQU0sR0FBRyxJQUFJLFdBQUssQ0FBQyxHQUFHLEVBQUUsSUFBSSxFQUFFLEVBQUUsR0FBRyxFQUFFLEVBQUUsTUFBTSxFQUFFLGFBQWEsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUN4RSxNQUFNLE1BQU0sR0FBRyxJQUFJLFdBQUssQ0FBQyxHQUFHLEVBQUUsSUFBSSxFQUFFLEVBQUUsR0FBRyxFQUFFLEVBQUUsT0FBTyxFQUFFLGNBQWMsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUUxRSxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsT0FBTyxFQUFFLG9CQUFvQixDQUFDLENBQUM7UUFDckQsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLE1BQU0sRUFBRSxhQUFhLENBQUMsQ0FBQztRQUU3QyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsT0FBTyxFQUFFLGNBQWMsQ0FBQyxDQUFDO1FBQy9DLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxNQUFNLEVBQUUsbUJBQW1CLENBQUMsQ0FBQztRQUVuRCxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDZCxDQUFDO0NBQ0ssQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERFRkFVTFRfQUNDT1VOVF9DT05URVhUX0tFWSwgREVGQVVMVF9SRUdJT05fQ09OVEVYVF9LRVkgfSBmcm9tICdAYXdzLWNkay9jeC1hcGknO1xuaW1wb3J0IHsgVGVzdCB9IGZyb20gJ25vZGV1bml0JztcbmltcG9ydCB7IEFwcCwgU3RhY2sgfSBmcm9tICcuLi9saWInO1xuXG5leHBvcnQgPSB7XG4gICdCeSBkZWZhdWx0LCBlbnZpcm9ubWVudCByZWdpb24gYW5kIGFjY291bnQgYXJlIG5vdCBkZWZpbmVkJyh0ZXN0OiBUZXN0KSB7XG4gICAgY29uc3Qgc3RhY2sgPSBuZXcgU3RhY2soKTtcbiAgICB0ZXN0Lm9rKHN0YWNrLmVudik7XG4gICAgdGVzdC5lcXVhbChzdGFjay5lbnYuYWNjb3VudCwgbnVsbCk7XG4gICAgdGVzdC5lcXVhbChzdGFjay5lbnYucmVnaW9uLCBudWxsKTtcbiAgICB0ZXN0LmRvbmUoKTtcbiAgfSxcblxuICAnRGVmYXVsdCBhY2NvdW50IGFuZCByZWdpb24gY2FuIGJlIHNldCBpbiBjb250ZXh0IChgYXdzOmNkazp0b29sa2l0OmRlZmF1bHQtYWNjb3VudGAgYW5kIGBhd3M6Y2RrOnRvb2xraXQ6ZGVmYXVsdC1yZWdpb25gKScodGVzdDogVGVzdCkge1xuICAgIGNvbnN0IGFwcCA9IG5ldyBBcHAoKTtcblxuICAgIGFwcC5zZXRDb250ZXh0KERFRkFVTFRfQUNDT1VOVF9DT05URVhUX0tFWSwgJ215LWRlZmF1bHQtYWNjb3VudCcpO1xuICAgIGFwcC5zZXRDb250ZXh0KERFRkFVTFRfUkVHSU9OX0NPTlRFWFRfS0VZLCAnbXktZGVmYXVsdC1yZWdpb24nKTtcblxuICAgIGNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKGFwcCk7XG5cbiAgICB0ZXN0LmVxdWFsKHN0YWNrLmVudi5hY2NvdW50LCAnbXktZGVmYXVsdC1hY2NvdW50Jyk7XG4gICAgdGVzdC5lcXVhbChzdGFjay5lbnYucmVnaW9uLCAnbXktZGVmYXVsdC1yZWdpb24nKTtcblxuICAgIHRlc3QuZG9uZSgpO1xuICB9LFxuXG4gICdJZiBvbmx5IGBlbnYucmVnaW9uYCBvciBgZW52LmFjY291bnRgIGFyZSBzcGVjaWZpZWQsIGRlZmF1bHRzIHdpbGwgYmUgdXNlZCBmb3IgdGhlIG90aGVyJyh0ZXN0OiBUZXN0KSB7XG4gICAgY29uc3QgYXBwID0gbmV3IEFwcCgpO1xuXG4gICAgYXBwLnNldENvbnRleHQoREVGQVVMVF9BQ0NPVU5UX0NPTlRFWFRfS0VZLCAnbXktZGVmYXVsdC1hY2NvdW50Jyk7XG4gICAgYXBwLnNldENvbnRleHQoREVGQVVMVF9SRUdJT05fQ09OVEVYVF9LRVksICdteS1kZWZhdWx0LXJlZ2lvbicpO1xuXG4gICAgY29uc3Qgc3RhY2sxID0gbmV3IFN0YWNrKGFwcCwgJ1MxJywgeyBlbnY6IHsgcmVnaW9uOiAnb25seS1yZWdpb24nIH0gfSk7XG4gICAgY29uc3Qgc3RhY2syID0gbmV3IFN0YWNrKGFwcCwgJ1MyJywgeyBlbnY6IHsgYWNjb3VudDogJ29ubHktYWNjb3VudCcgfSB9KTtcblxuICAgIHRlc3QuZXF1YWwoc3RhY2sxLmVudi5hY2NvdW50LCAnbXktZGVmYXVsdC1hY2NvdW50Jyk7XG4gICAgdGVzdC5lcXVhbChzdGFjazEuZW52LnJlZ2lvbiwgJ29ubHktcmVnaW9uJyk7XG5cbiAgICB0ZXN0LmVxdWFsKHN0YWNrMi5lbnYuYWNjb3VudCwgJ29ubHktYWNjb3VudCcpO1xuICAgIHRlc3QuZXF1YWwoc3RhY2syLmVudi5yZWdpb24sICdteS1kZWZhdWx0LXJlZ2lvbicpO1xuXG4gICAgdGVzdC5kb25lKCk7XG4gIH0sXG59IGFzIGFueTtcbiJdfQ==

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is too big to display

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