UNPKG

@aws-cdk/core

Version:

AWS Cloud Development Kit Core Library

809 lines 96 kB
"use strict"; var _a; Object.defineProperty(exports, "__esModule", { value: true }); exports.Fn = void 0; const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const cloudformation_lang_1 = require("./private/cloudformation-lang"); const intrinsic_1 = require("./private/intrinsic"); const reference_1 = require("./reference"); const stack_trace_1 = require("./stack-trace"); const token_1 = require("./token"); /* eslint-disable max-len */ /** * CloudFormation intrinsic functions. * http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/intrinsic-function-reference.html */ class Fn { constructor() { } /** * The ``Ref`` intrinsic function returns the value of the specified parameter or resource. * Note that it doesn't validate the logicalName, it mainly serves paremeter/resource reference defined in a ``CfnInclude`` template. * @param logicalName The logical name of a parameter/resource for which you want to retrieve its value. */ static ref(logicalName) { return new FnRef(logicalName).toString(); } /** * The ``Fn::GetAtt`` intrinsic function returns the value of an attribute * from a resource in the template. * @param logicalNameOfResource The logical name (also called logical ID) of * the resource that contains the attribute that you want. * @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. * @returns an IResolvable object */ static getAtt(logicalNameOfResource, attributeName) { return new FnGetAtt(logicalNameOfResource, attributeName); } /** * The intrinsic function ``Fn::Join`` appends a set of values into a single * value, separated by the specified delimiter. If a delimiter is the empty * string, the set of values are concatenated with no delimiter. * @param delimiter The value you want to occur between fragments. The * delimiter will occur between fragments only. It will not terminate the * final value. * @param listOfValues The list of values you want combined. * @returns a token represented as a string */ static join(delimiter, listOfValues) { if (listOfValues.length === 0) { throw new Error('FnJoin requires at least one value to be provided'); } return new FnJoin(delimiter, listOfValues).toString(); } /** * Split a string token into a token list of string values. * * Specify the location of splits with a delimiter such as ',' (a comma). * Renders to the `Fn::Split` intrinsic function. * * Lists with unknown lengths (default) * ------------------------------------- * * Since this function is used to work with deploy-time values, if `assumedLength` * is not given the CDK cannot know the length of the resulting list at synthesis time. * This brings the following restrictions: * * - You must use `Fn.select(i, list)` to pick elements out of the list (you must not use * `list[i]`). * - You cannot add elements to the list, remove elements from the list, * combine two such lists together, or take a slice of the list. * - You cannot pass the list to constructs that do any of the above. * * The only valid operation with such a tokenized list is to pass it unmodified to a * CloudFormation Resource construct. * * Lists with assumed lengths * -------------------------- * * Pass `assumedLength` if you know the length of the list that will be * produced by splitting. The actual list length at deploy time may be * *longer* than the number you pass, but not *shorter*. * * The returned list will look like: * * ``` * [Fn.select(0, split), Fn.select(1, split), Fn.select(2, split), ...] * ``` * * The restrictions from the section "Lists with unknown lengths" will now be lifted, * at the expense of having to know and fix the length of the list. * * @param delimiter A string value that determines where the source string is divided. * @param source The string value that you want to split. * @param assumedLength The length of the list that will be produced by splitting * @returns a token represented as a string array */ static split(delimiter, source, assumedLength) { // short-circut if source is not a token if (!token_1.Token.isUnresolved(source)) { return source.split(delimiter); } if (token_1.Token.isUnresolved(delimiter)) { // Limitation of CloudFormation throw new Error('Fn.split: \'delimiter\' may not be a token value'); } const split = token_1.Token.asList(new FnSplit(delimiter, source)); if (assumedLength === undefined) { return split; } if (token_1.Token.isUnresolved(assumedLength)) { throw new Error('Fn.split: \'assumedLength\' may not be a token value'); } return range(assumedLength).map(i => Fn.select(i, split)); } /** * The intrinsic function ``Fn::Select`` returns a single object from a list of objects by index. * @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. * @param array The list of objects to select from. This list must not be null, nor can it have null entries. * @returns a token represented as a string */ static select(index, array) { if (!token_1.Token.isUnresolved(index) && !token_1.Token.isUnresolved(array) && !array.some(token_1.Token.isUnresolved)) { return array[index]; } return new FnSelect(index, array).toString(); } /** * The intrinsic function ``Fn::Sub`` substitutes variables in an input string * with values that you specify. In your templates, you can use this function * to construct commands or outputs that include values that aren't available * until you create or update a stack. * @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. * @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. * @returns a token represented as a string */ static sub(body, variables) { return new FnSub(body, variables).toString(); } /** * The intrinsic function ``Fn::Base64`` returns the Base64 representation of * the input string. This function is typically used to pass encoded data to * Amazon EC2 instances by way of the UserData property. * @param data The string value you want to convert to Base64. * @returns a token represented as a string */ static base64(data) { return new FnBase64(data).toString(); } /** * The intrinsic function ``Fn::Cidr`` returns the specified Cidr address block. * @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 sizeMask The digit covered in the subnet. * @returns a token represented as a string */ static cidr(ipBlock, count, sizeMask) { return token_1.Token.asList(new FnCidr(ipBlock, count, sizeMask)); } /** * Given an url, parse the domain name * @param url the url to parse */ static parseDomainName(url) { const noHttps = Fn.select(1, Fn.split('//', url)); return Fn.select(0, Fn.split('/', noHttps)); } /** * The intrinsic function ``Fn::GetAZs`` returns an array that lists * Availability Zones for a specified region. Because customers have access to * different Availability Zones, the intrinsic function ``Fn::GetAZs`` enables * template authors to write templates that adapt to the calling user's * access. That way you don't have to hard-code a full list of Availability * Zones for a specified region. * @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. * @returns a token represented as a string array */ static getAzs(region) { return token_1.Token.asList(new FnGetAZs(region)); } /** * The intrinsic function ``Fn::ImportValue`` returns the value of an output * exported by another stack. You typically use this function to create * cross-stack references. In the following example template snippets, Stack A * exports VPC security group values and Stack B imports them. * @param sharedValueToImport The stack output value that you want to import. * @returns a token represented as a string */ static importValue(sharedValueToImport) { return new FnImportValue(sharedValueToImport).toString(); } /** * Like `Fn.importValue`, but import a list with a known length * * If you explicitly want a list with an unknown length, call `Fn.split(',', * Fn.importValue(exportName))`. See the documentation of `Fn.split` to read * more about the limitations of using lists of unknown length. * * `Fn.importListValue(exportName, assumedLength)` is the same as * `Fn.split(',', Fn.importValue(exportName), assumedLength)`, * but easier to read and impossible to forget to pass `assumedLength`. */ static importListValue(sharedValueToImport, assumedLength, delimiter = ',') { return Fn.split(delimiter, Fn.importValue(sharedValueToImport), assumedLength); } /** * The intrinsic function ``Fn::FindInMap`` returns the value corresponding to * keys in a two-level map that is declared in the Mappings section. * @returns a token represented as a string */ static findInMap(mapName, topLevelKey, secondLevelKey) { return Fn._findInMap(mapName, topLevelKey, secondLevelKey).toString(); } /** * An additional function used in CfnParser, * as Fn::FindInMap does not always return a string. * * @internal */ static _findInMap(mapName, topLevelKey, secondLevelKey) { return new FnFindInMap(mapName, topLevelKey, secondLevelKey); } /** * Creates a token representing the ``Fn::Transform`` expression * @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/intrinsic-function-reference-transform.html * @param macroName The name of the macro to perform the processing * @param parameters The parameters to be passed to the macro * @returns a token representing the transform expression */ static transform(macroName, parameters) { return new FnTransform(macroName, parameters); } /** * Returns true if all the specified conditions evaluate to true, or returns * false if any one of the conditions evaluates to false. ``Fn::And`` acts as * an AND operator. The minimum number of conditions that you can include is * 1. * @param conditions conditions to AND * @returns an FnCondition token */ static conditionAnd(...conditions) { try { jsiiDeprecationWarnings._aws_cdk_core_ICfnConditionExpression(conditions); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.conditionAnd); } throw error; } if (conditions.length === 0) { throw new Error('Fn.conditionAnd() needs at least one argument'); } if (conditions.length === 1) { return conditions[0]; } return Fn.conditionAnd(..._inGroupsOf(conditions, 10).map(group => new FnAnd(...group))); } /** * Compares if two values are equal. Returns true if the two values are equal * or false if they aren't. * @param lhs A value of any type that you want to compare. * @param rhs A value of any type that you want to compare. * @returns an FnCondition token */ static conditionEquals(lhs, rhs) { return new FnEquals(lhs, rhs); } /** * Returns one value if the specified condition evaluates to true and another * value if the specified condition evaluates to false. Currently, AWS * CloudFormation supports the ``Fn::If`` intrinsic function in the metadata * attribute, update policy attribute, and property values in the Resources * section and Outputs sections of a template. You can use the AWS::NoValue * pseudo parameter as a return value to remove the corresponding property. * @param conditionId A reference to a condition in the Conditions section. Use * the condition's name to reference it. * @param valueIfTrue A value to be returned if the specified condition * evaluates to true. * @param valueIfFalse A value to be returned if the specified condition * evaluates to false. * @returns an FnCondition token */ static conditionIf(conditionId, valueIfTrue, valueIfFalse) { return new FnIf(conditionId, valueIfTrue, valueIfFalse); } /** * Returns true for a condition that evaluates to false or returns false for a * condition that evaluates to true. ``Fn::Not`` acts as a NOT operator. * @param condition A condition such as ``Fn::Equals`` that evaluates to true * or false. * @returns an FnCondition token */ static conditionNot(condition) { try { jsiiDeprecationWarnings._aws_cdk_core_ICfnConditionExpression(condition); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.conditionNot); } throw error; } return new FnNot(condition); } /** * Returns true if any one of the specified conditions evaluate to true, or * returns false if all of the conditions evaluates to false. ``Fn::Or`` acts * as an OR operator. The minimum number of conditions that you can include is * 1. * @param conditions conditions that evaluates to true or false. * @returns an FnCondition token */ static conditionOr(...conditions) { try { jsiiDeprecationWarnings._aws_cdk_core_ICfnConditionExpression(conditions); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.conditionOr); } throw error; } if (conditions.length === 0) { throw new Error('Fn.conditionOr() needs at least one argument'); } if (conditions.length === 1) { return conditions[0]; } return Fn.conditionOr(..._inGroupsOf(conditions, 10).map(group => new FnOr(...group))); } /** * Returns true if a specified string matches at least one value in a list of * strings. * @param listOfStrings A list of strings, such as "A", "B", "C". * @param value A string, such as "A", that you want to compare against a list of strings. * @returns an FnCondition token */ static conditionContains(listOfStrings, value) { return new FnContains(listOfStrings, value); } /** * Returns true if a specified string matches all values in a list. * @param listOfStrings A list of strings, such as "A", "B", "C". * @param value A string, such as "A", that you want to compare against a list * of strings. * @returns an FnCondition token */ static conditionEachMemberEquals(listOfStrings, value) { return new FnEachMemberEquals(listOfStrings, value); } /** * Returns true if each member in a list of strings matches at least one value * in a second list of strings. * @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. * @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. * @returns an FnCondition token */ static conditionEachMemberIn(stringsToCheck, stringsToMatch) { return new FnEachMemberIn(stringsToCheck, stringsToMatch); } /** * Returns all values for a specified parameter type. * @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. * @returns a token represented as a string array */ static refAll(parameterType) { return token_1.Token.asList(new FnRefAll(parameterType)); } /** * Returns an attribute value or list of values for a specific parameter and * attribute. * @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. * @param attribute The name of an attribute from which you want to retrieve a * value. * @returns a token represented as a string */ static valueOf(parameterOrLogicalId, attribute) { return new FnValueOf(parameterOrLogicalId, attribute).toString(); } /** * Returns a list of all attribute values for a given parameter type and * attribute. * @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. * @param attribute The name of an attribute from which you want to retrieve a * value. For more information about attributes, see Supported Attributes. * @returns a token represented as a string array */ static valueOfAll(parameterType, attribute) { return token_1.Token.asList(new FnValueOfAll(parameterType, attribute)); } } exports.Fn = Fn; _a = JSII_RTTI_SYMBOL_1; Fn[_a] = { fqn: "@aws-cdk/core.Fn", version: "1.204.0" }; /** * Base class for tokens that represent CloudFormation intrinsic functions. */ class FnBase extends intrinsic_1.Intrinsic { constructor(name, value) { super({ [name]: value }); } } /** * The intrinsic function ``Ref`` returns the value of the specified parameter or resource. * When you specify a parameter's logical name, it returns the value of the parameter. * When you specify a resource's logical name, it returns a value that you can typically use to refer to that resource, such as a physical ID. */ class FnRef extends FnBase { /** * Creates an ``Ref`` function. * @param logicalName The logical name of a parameter/resource for which you want to retrieve its value. */ constructor(logicalName) { super('Ref', logicalName); } } /** * The intrinsic function ``Fn::FindInMap`` returns the value corresponding to keys in a two-level * map that is declared in the Mappings section. */ class FnFindInMap extends FnBase { /** * Creates an ``Fn::FindInMap`` function. * @param mapName The logical name of a mapping declared in the Mappings section that contains the keys and values. * @param topLevelKey The top-level key name. Its value is a list of key-value pairs. * @param secondLevelKey The second-level key name, which is set to one of the keys from the list assigned to TopLevelKey. */ constructor(mapName, topLevelKey, secondLevelKey) { super('Fn::FindInMap', [mapName, topLevelKey, secondLevelKey]); } } /** * The intrinsic function ``Fn::Transform`` specifies a macro to perform custom processing on part of a stack template. */ class FnTransform extends FnBase { /** * creates an ``Fn::Transform`` function. * @param macroName The name of the macro to be invoked * @param parameters the parameters to pass to it */ constructor(macroName, parameters) { super('Fn::Transform', { Name: macroName, Parameters: parameters }); } } /** * The ``Fn::GetAtt`` intrinsic function returns the value of an attribute from a resource in the template. */ class FnGetAtt extends FnBase { /** * Creates a ``Fn::GetAtt`` function. * @param logicalNameOfResource The logical name (also called logical ID) of the resource that contains the attribute that you want. * @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. */ constructor(logicalNameOfResource, attributeName) { super('Fn::GetAtt', [logicalNameOfResource, attributeName]); } } /** * The intrinsic function ``Fn::GetAZs`` returns an array that lists Availability Zones for a * specified region. Because customers have access to different Availability Zones, the intrinsic * function ``Fn::GetAZs`` enables template authors to write templates that adapt to the calling * user's access. That way you don't have to hard-code a full list of Availability Zones for a * specified region. */ class FnGetAZs extends FnBase { /** * Creates an ``Fn::GetAZs`` function. * @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. */ constructor(region) { super('Fn::GetAZs', region || ''); } } /** * The intrinsic function ``Fn::ImportValue`` returns the value of an output exported by another stack. * You typically use this function to create cross-stack references. In the following example * template snippets, Stack A exports VPC security group values and Stack B imports them. */ class FnImportValue extends FnBase { /** * Creates an ``Fn::ImportValue`` function. * @param sharedValueToImport The stack output value that you want to import. */ constructor(sharedValueToImport) { super('Fn::ImportValue', sharedValueToImport); } } /** * The intrinsic function ``Fn::Select`` returns a single object from a list of objects by index. */ class FnSelect extends FnBase { /** * Creates an ``Fn::Select`` function. * @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. * @param array The list of objects to select from. This list must not be null, nor can it have null entries. */ constructor(index, array) { super('Fn::Select', [index, array]); } } /** * To split a string into a list of string values so that you can select an element from the * resulting string list, use the ``Fn::Split`` intrinsic function. Specify the location of splits * with a delimiter, such as , (a comma). After you split a string, use the ``Fn::Select`` function * to pick a specific element. */ class FnSplit extends FnBase { /** * Create an ``Fn::Split`` function. * @param delimiter A string value that determines where the source string is divided. * @param source The string value that you want to split. */ constructor(delimiter, source) { super('Fn::Split', [delimiter, source]); } } /** * The intrinsic function ``Fn::Sub`` substitutes variables in an input string with values that * you specify. In your templates, you can use this function to construct commands or outputs * that include values that aren't available until you create or update a stack. */ class FnSub extends FnBase { /** * Creates an ``Fn::Sub`` function. * @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. * @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. */ constructor(body, variables) { super('Fn::Sub', variables ? [body, variables] : body); } } /** * The intrinsic function ``Fn::Base64`` returns the Base64 representation of the input string. * This function is typically used to pass encoded data to Amazon EC2 instances by way of * the UserData property. */ class FnBase64 extends FnBase { /** * Creates an ``Fn::Base64`` function. * @param data The string value you want to convert to Base64. */ constructor(data) { super('Fn::Base64', data); } } /** * The intrinsic function ``Fn::Cidr`` returns the specified Cidr address block. */ class FnCidr extends FnBase { /** * Creates an ``Fn::Cidr`` function. * @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 sizeMask The digit covered in the subnet. */ constructor(ipBlock, count, sizeMask) { if (count < 1 || count > 256) { throw new Error(`Fn::Cidr's count attribute must be betwen 1 and 256, ${count} was provided.`); } super('Fn::Cidr', [ipBlock, count, sizeMask]); } } class FnConditionBase extends intrinsic_1.Intrinsic { constructor(type, value) { super({ [type]: value }); this.disambiguator = true; } } /** * Returns true if all the specified conditions evaluate to true, or returns false if any one * of the conditions evaluates to false. ``Fn::And`` acts as an AND operator. The minimum number of * conditions that you can include is 2, and the maximum is 10. */ class FnAnd extends FnConditionBase { constructor(...condition) { super('Fn::And', condition); } } /** * Compares if two values are equal. Returns true if the two values are equal or false * if they aren't. */ class FnEquals extends FnConditionBase { /** * Creates an ``Fn::Equals`` condition function. * @param lhs A value of any type that you want to compare. * @param rhs A value of any type that you want to compare. */ constructor(lhs, rhs) { super('Fn::Equals', [lhs, rhs]); } } /** * Returns one value if the specified condition evaluates to true and another value if the * specified condition evaluates to false. Currently, AWS CloudFormation supports the ``Fn::If`` * intrinsic function in the metadata attribute, update policy attribute, and property values * in the Resources section and Outputs sections of a template. You can use the AWS::NoValue * pseudo parameter as a return value to remove the corresponding property. */ class FnIf extends FnConditionBase { /** * Creates an ``Fn::If`` condition function. * @param condition A reference to a condition in the Conditions section. Use the condition's name to reference it. * @param valueIfTrue A value to be returned if the specified condition evaluates to true. * @param valueIfFalse A value to be returned if the specified condition evaluates to false. */ constructor(condition, valueIfTrue, valueIfFalse) { super('Fn::If', [condition, valueIfTrue, valueIfFalse]); } } /** * Returns true for a condition that evaluates to false or returns false for a condition that evaluates to true. * ``Fn::Not`` acts as a NOT operator. */ class FnNot extends FnConditionBase { /** * Creates an ``Fn::Not`` condition function. * @param condition A condition such as ``Fn::Equals`` that evaluates to true or false. */ constructor(condition) { super('Fn::Not', [condition]); } } /** * Returns true if any one of the specified conditions evaluate to true, or returns false if * all of the conditions evaluates to false. ``Fn::Or`` acts as an OR operator. The minimum number * of conditions that you can include is 2, and the maximum is 10. */ class FnOr extends FnConditionBase { /** * Creates an ``Fn::Or`` condition function. * @param condition A condition that evaluates to true or false. */ constructor(...condition) { super('Fn::Or', condition); } } /** * Returns true if a specified string matches at least one value in a list of strings. */ class FnContains extends FnConditionBase { /** * Creates an ``Fn::Contains`` function. * @param listOfStrings A list of strings, such as "A", "B", "C". * @param value A string, such as "A", that you want to compare against a list of strings. */ constructor(listOfStrings, value) { super('Fn::Contains', [listOfStrings, value]); } } /** * Returns true if a specified string matches all values in a list. */ class FnEachMemberEquals extends FnConditionBase { /** * Creates an ``Fn::EachMemberEquals`` function. * @param listOfStrings A list of strings, such as "A", "B", "C". * @param value A string, such as "A", that you want to compare against a list of strings. */ constructor(listOfStrings, value) { super('Fn::EachMemberEquals', [listOfStrings, value]); } } /** * Returns true if each member in a list of strings matches at least one value in a second * list of strings. */ class FnEachMemberIn extends FnConditionBase { /** * Creates an ``Fn::EachMemberIn`` function. * @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. * @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. */ constructor(stringsToCheck, stringsToMatch) { super('Fn::EachMemberIn', [stringsToCheck, stringsToMatch]); } } /** * Returns all values for a specified parameter type. */ class FnRefAll extends FnBase { /** * Creates an ``Fn::RefAll`` function. * @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. */ constructor(parameterType) { super('Fn::RefAll', parameterType); } } /** * Returns an attribute value or list of values for a specific parameter and attribute. */ class FnValueOf extends FnBase { /** * Creates an ``Fn::ValueOf`` function. * @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. * @param attribute The name of an attribute from which you want to retrieve a value. */ constructor(parameterOrLogicalId, attribute) { super('Fn::ValueOf', [parameterOrLogicalId, attribute]); } } /** * Returns a list of all attribute values for a given parameter type and attribute. */ class FnValueOfAll extends FnBase { /** * Creates an ``Fn::ValueOfAll`` function. * @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. * @param attribute The name of an attribute from which you want to retrieve a value. For more information about attributes, see Supported Attributes. */ constructor(parameterType, attribute) { super('Fn::ValueOfAll', [parameterType, attribute]); } } /** * The intrinsic function ``Fn::Join`` appends a set of values into a single value, separated by * the specified delimiter. If a delimiter is the empty string, the set of values are concatenated * with no delimiter. */ class FnJoin { /** * Creates an ``Fn::Join`` function. * @param delimiter The value you want to occur between fragments. The delimiter will occur between fragments only. * It will not terminate the final value. * @param listOfValues The list of values you want combined. */ constructor(delimiter, listOfValues) { if (listOfValues.length === 0) { throw new Error('FnJoin requires at least one value to be provided'); } this.delimiter = delimiter; this.listOfValues = listOfValues; this.creationStack = stack_trace_1.captureStackTrace(); } resolve(context) { if (token_1.Token.isUnresolved(this.listOfValues)) { // This is a list token, don't try to do smart things with it. return { 'Fn::Join': [this.delimiter, this.listOfValues] }; } const resolved = this.resolveValues(context); if (resolved.length === 1) { return resolved[0]; } return { 'Fn::Join': [this.delimiter, resolved] }; } toString() { return token_1.Token.asString(this, { displayHint: 'Fn::Join' }); } toJSON() { return '<Fn::Join>'; } /** * Optimization: if an Fn::Join is nested in another one and they share the same delimiter, then flatten it up. Also, * if two concatenated elements are literal strings (not tokens), then pre-concatenate them with the delimiter, to * generate shorter output. */ resolveValues(context) { const resolvedValues = this.listOfValues.map(x => reference_1.Reference.isReference(x) ? x : context.resolve(x)); return cloudformation_lang_1.minimalCloudFormationJoin(this.delimiter, resolvedValues); } } function _inGroupsOf(array, maxGroup) { const result = new Array(); for (let i = 0; i < array.length; i += maxGroup) { result.push(array.slice(i, i + maxGroup)); } return result; } function range(n) { const ret = []; for (let i = 0; i < n; i++) { ret.push(i); } return ret; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cfn-fn.js","sourceRoot":"","sources":["cfn-fn.ts"],"names":[],"mappings":";;;;;;AACA,uEAA0E;AAC1E,mDAAgD;AAChD,2CAAwC;AAExC,+CAAkD;AAClD,mCAAgC;AAEhC,4BAA4B;AAE5B;;;GAGG;AACH,MAAa,EAAE;IAgZb,iBAAyB;IA/YzB;;;;OAIG;IACI,MAAM,CAAC,GAAG,CAAC,WAAmB;QACnC,OAAO,IAAI,KAAK,CAAC,WAAW,CAAC,CAAC,QAAQ,EAAE,CAAC;KAC1C;IAED;;;;;;;;;OASG;IACI,MAAM,CAAC,MAAM,CAAC,qBAA6B,EAAE,aAAqB;QACvE,OAAO,IAAI,QAAQ,CAAC,qBAAqB,EAAE,aAAa,CAAC,CAAC;KAC3D;IAED;;;;;;;;;OASG;IACI,MAAM,CAAC,IAAI,CAAC,SAAiB,EAAE,YAAsB;QAC1D,IAAI,YAAY,CAAC,MAAM,KAAK,CAAC,EAAE;YAC7B,MAAM,IAAI,KAAK,CAAC,mDAAmD,CAAC,CAAC;SACtE;QAED,OAAO,IAAI,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,CAAC,QAAQ,EAAE,CAAC;KACvD;IAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA0CG;IACI,MAAM,CAAC,KAAK,CAAC,SAAiB,EAAE,MAAc,EAAE,aAAsB;QAC3E,wCAAwC;QACxC,IAAI,CAAC,aAAK,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE;YAC/B,OAAO,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;SAChC;QAED,IAAI,aAAK,CAAC,YAAY,CAAC,SAAS,CAAC,EAAE;YACjC,+BAA+B;YAC/B,MAAM,IAAI,KAAK,CAAC,kDAAkD,CAAC,CAAC;SACrE;QAED,MAAM,KAAK,GAAG,aAAK,CAAC,MAAM,CAAC,IAAI,OAAO,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC,CAAC;QAC3D,IAAI,aAAa,KAAK,SAAS,EAAE;YAC/B,OAAO,KAAK,CAAC;SACd;QAED,IAAI,aAAK,CAAC,YAAY,CAAC,aAAa,CAAC,EAAE;YACrC,MAAM,IAAI,KAAK,CAAC,sDAAsD,CAAC,CAAC;SACzE;QAED,OAAO,KAAK,CAAC,aAAa,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC;KAC3D;IAED;;;;;OAKG;IACI,MAAM,CAAC,MAAM,CAAC,KAAa,EAAE,KAAe;QACjD,IAAI,CAAC,aAAK,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,CAAC,aAAK,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,aAAK,CAAC,YAAY,CAAC,EAAE;YAC/F,OAAO,KAAK,CAAC,KAAK,CAAC,CAAC;SACrB;QAED,OAAO,IAAI,QAAQ,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,QAAQ,EAAE,CAAC;KAC9C;IAED;;;;;;;;;;;;;;;OAeG;IACI,MAAM,CAAC,GAAG,CAAC,IAAY,EAAE,SAAqC;QACnE,OAAO,IAAI,KAAK,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC,QAAQ,EAAE,CAAC;KAC9C;IAED;;;;;;OAMG;IACI,MAAM,CAAC,MAAM,CAAC,IAAY;QAC/B,OAAO,IAAI,QAAQ,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,CAAC;KACtC;IAED;;;;;;OAMG;IACI,MAAM,CAAC,IAAI,CAAC,OAAe,EAAE,KAAa,EAAE,QAAiB;QAClE,OAAO,aAAK,CAAC,MAAM,CAAC,IAAI,MAAM,CAAC,OAAO,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC;KAC3D;IAED;;;OAGG;IACI,MAAM,CAAC,eAAe,CAAC,GAAW;QACvC,MAAM,OAAO,GAAG,EAAE,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC,CAAC;QAClD,OAAO,EAAE,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC,CAAC;KAC7C;IAED;;;;;;;;;;;;OAYG;IACI,MAAM,CAAC,MAAM,CAAC,MAAe;QAClC,OAAO,aAAK,CAAC,MAAM,CAAC,IAAI,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC;KAC3C;IAED;;;;;;;OAOG;IACI,MAAM,CAAC,WAAW,CAAC,mBAA2B;QACnD,OAAO,IAAI,aAAa,CAAC,mBAAmB,CAAC,CAAC,QAAQ,EAAE,CAAC;KAC1D;IAED;;;;;;;;;;OAUG;IACI,MAAM,CAAC,eAAe,CAAC,mBAA2B,EAAE,aAAqB,EAAE,SAAS,GAAG,GAAG;QAC/F,OAAO,EAAE,CAAC,KAAK,CAAC,SAAS,EAAE,EAAE,CAAC,WAAW,CAAC,mBAAmB,CAAC,EAAE,aAAa,CAAC,CAAC;KAChF;IAED;;;;OAIG;IACI,MAAM,CAAC,SAAS,CAAC,OAAe,EAAE,WAAmB,EAAE,cAAsB;QAClF,OAAO,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,WAAW,EAAE,cAAc,CAAC,CAAC,QAAQ,EAAE,CAAC;KACvE;IAED;;;;;OAKG;IACI,MAAM,CAAC,UAAU,CAAC,OAAe,EAAE,WAAmB,EAAE,cAAsB;QACnF,OAAO,IAAI,WAAW,CAAC,OAAO,EAAE,WAAW,EAAE,cAAc,CAAC,CAAC;KAC9D;IAED;;;;;;OAMG;IACI,MAAM,CAAC,SAAS,CAAC,SAAiB,EAAE,UAAmC;QAC5E,OAAO,IAAI,WAAW,CAAC,SAAS,EAAE,UAAU,CAAC,CAAC;KAC/C;IAED;;;;;;;OAOG;IACI,MAAM,CAAC,YAAY,CAAC,GAAG,UAAqC;;;;;;;;;;QACjE,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE;YAC3B,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC,CAAC;SAClE;QACD,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE;YAC3B,OAAO,UAAU,CAAC,CAAC,CAAgC,CAAC;SACrD;QACD,OAAO,EAAE,CAAC,YAAY,CAAC,GAAG,WAAW,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,KAAK,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;KAC1F;IAED;;;;;;OAMG;IACI,MAAM,CAAC,eAAe,CAAC,GAAQ,EAAE,GAAQ;QAC9C,OAAO,IAAI,QAAQ,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;KAC/B;IAED;;;;;;;;;;;;;;OAcG;IACI,MAAM,CAAC,WAAW,CAAC,WAAmB,EAAE,WAAgB,EAAE,YAAiB;QAChF,OAAO,IAAI,IAAI,CAAC,WAAW,EAAE,WAAW,EAAE,YAAY,CAAC,CAAC;KACzD;IAED;;;;;;OAMG;IACI,MAAM,CAAC,YAAY,CAAC,SAAkC;;;;;;;;;;QAC3D,OAAO,IAAI,KAAK,CAAC,SAAS,CAAC,CAAC;KAC7B;IAED;;;;;;;OAOG;IACI,MAAM,CAAC,WAAW,CAAC,GAAG,UAAqC;;;;;;;;;;QAChE,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE;YAC3B,MAAM,IAAI,KAAK,CAAC,8CAA8C,CAAC,CAAC;SACjE;QACD,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE;YAC3B,OAAO,UAAU,CAAC,CAAC,CAAgC,CAAC;SACrD;QACD,OAAO,EAAE,CAAC,WAAW,CAAC,GAAG,WAAW,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,IAAI,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;KACxF;IAED;;;;;;OAMG;IACI,MAAM,CAAC,iBAAiB,CAAC,aAAuB,EAAE,KAAa;QACpE,OAAO,IAAI,UAAU,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;KAC7C;IAED;;;;;;OAMG;IACI,MAAM,CAAC,yBAAyB,CAAC,aAAuB,EAAE,KAAa;QAC5E,OAAO,IAAI,kBAAkB,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;KACrD;IAED;;;;;;;;;;OAUG;IACI,MAAM,CAAC,qBAAqB,CAAC,cAAwB,EAAE,cAAwB;QACpF,OAAO,IAAI,cAAc,CAAC,cAAc,EAAE,cAAc,CAAC,CAAC;KAC3D;IAED;;;;;;OAMG;IACI,MAAM,CAAC,MAAM,CAAC,aAAqB;QACxC,OAAO,aAAK,CAAC,MAAM,CAAC,IAAI,QAAQ,CAAC,aAAa,CAAC,CAAC,CAAC;KAClD;IAED;;;;;;;;;OASG;IACI,MAAM,CAAC,OAAO,CAAC,oBAA4B,EAAE,SAAiB;QACnE,OAAO,IAAI,SAAS,CAAC,oBAAoB,EAAE,SAAS,CAAC,CAAC,QAAQ,EAAE,CAAC;KAClE;IAED;;;;;;;;;OASG;IACI,MAAM,CAAC,UAAU,CAAC,aAAqB,EAAE,SAAiB;QAC/D,OAAO,aAAK,CAAC,MAAM,CAAC,IAAI,YAAY,CAAC,aAAa,EAAE,SAAS,CAAC,CAAC,CAAC;KACjE;;AA9YH,gBAiZC;;;AAED;;GAEG;AACH,MAAM,MAAO,SAAQ,qBAAS;IAC5B,YAAY,IAAY,EAAE,KAAU;QAClC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;KAC1B;CACF;AAED;;;;GAIG;AACH,MAAM,KAAM,SAAQ,MAAM;IACxB;;;OAGG;IACH,YAAY,WAAmB;QAC7B,KAAK,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;KAC3B;CACF;AAED;;;GAGG;AACH,MAAM,WAAY,SAAQ,MAAM;IAC9B;;;;;OAKG;IACH,YAAY,OAAe,EAAE,WAAgB,EAAE,cAAmB;QAChE,KAAK,CAAC,eAAe,EAAE,CAAC,OAAO,EAAE,WAAW,EAAE,cAAc,CAAC,CAAC,CAAC;KAChE;CACF;AAED;;GAEG;AACH,MAAM,WAAY,SAAQ,MAAM;IAC9B;;;;OAIG;IACH,YAAY,SAAiB,EAAE,UAAmC;QAChE,KAAK,CAAC,eAAe,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,UAAU,EAAE,UAAU,EAAE,CAAC,CAAC;KACrE;CACF;AAED;;GAEG;AACH,MAAM,QAAS,SAAQ,MAAM;IAC3B;;;;OAIG;IACH,YAAY,qBAA6B,EAAE,aAAqB;QAC9D,KAAK,CAAC,YAAY,EAAE,CAAC,qBAAqB,EAAE,aAAa,CAAC,CAAC,CAAC;KAC7D;CACF;AAED;;;;;;GAMG;AACH,MAAM,QAAS,SAAQ,MAAM;IAC3B;;;;;;OAMG;IACH,YAAY,MAAe;QACzB,KAAK,CAAC,YAAY,EAAE,MAAM,IAAI,EAAE,CAAC,CAAC;KACnC;CACF;AAED;;;;GAIG;AACH,MAAM,aAAc,SAAQ,MAAM;IAChC;;;OAGG;IACH,YAAY,mBAA2B;QACrC,KAAK,CAAC,iBAAiB,EAAE,mBAAmB,CAAC,CAAC;KAC/C;CACF;AAED;;GAEG;AACH,MAAM,QAAS,SAAQ,MAAM;IAC3B;;;;OAIG;IACH,YAAY,KAAa,EAAE,KAAU;QACnC,KAAK,CAAC,YAAY,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC;KACrC;CACF;AAED;;;;;GAKG;AACH,MAAM,OAAQ,SAAQ,MAAM;IAC1B;;;;OAIG;IACH,YAAY,SAAiB,EAAE,MAAW;QACxC,KAAK,CAAC,WAAW,EAAE,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC,CAAC;KACzC;CACF;AAED;;;;GAIG;AACH,MAAM,KAAM,SAAQ,MAAM;IACxB;;;;;;;;;OASG;IACH,YAAY,IAAY,EAAE,SAAkC;QAC1D,KAAK,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;KACxD;CACF;AAED;;;;GAIG;AACH,MAAM,QAAS,SAAQ,MAAM;IAE3B;;;OAGG;IACH,YAAY,IAAS;QACnB,KAAK,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;KAC3B;CACF;AAED;;GAEG;AACH,MAAM,MAAO,SAAQ,MAAM;IACzB;;;;;OAKG;IACH,YAAY,OAAY,EAAE,KAAU,EAAE,QAAc;QAClD,IAAI,KAAK,GAAG,CAAC,IAAI,KAAK,GAAG,GAAG,EAAE;YAC5B,MAAM,IAAI,KAAK,CAAC,wDAAwD,KAAK,gBAAgB,CAAC,CAAC;SAChG;QACD,KAAK,CAAC,UAAU,EAAE,CAAC,OAAO,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC;KAC/C;CACF;AAED,MAAM,eAAgB,SAAQ,qBAAS;IAErC,YAAY,IAAY,EAAE,KAAU;QAClC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;QAFlB,kBAAa,GAAG,IAAI,CAAC;KAG7B;CACF;AAED;;;;GAIG;AACH,MAAM,KAAM,SAAQ,eAAe;IACjC,YAAY,GAAG,SAAoC;QACjD,KAAK,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;KAC7B;CACF;AAED;;;GAGG;AACH,MAAM,QAAS,SAAQ,eAAe;IACpC;;;;OAIG;IACH,YAAY,GAAQ,EAAE,GAAQ;QAC5B,KAAK,CAAC,YAAY,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;KACjC;CACF;AAED;;;;;;GAMG;AACH,MAAM,IAAK,SAAQ,eAAe;IAChC;;;;;OAKG;IACH,YAAY,SAAiB,EAAE,WAAgB,EAAE,YAAiB;QAChE,KAAK,CAAC,QAAQ,EAAE,CAAC,SAAS,EAAE,WAAW,EAAE,YAAY,CAAC,CAAC,CAAC;KACzD;CACF;AAED;;;GAGG;AACH,MAAM,KAAM,SAAQ,eAAe;IACjC;;;OAGG;IACH,YAAY,SAAkC;QAC5C,KAAK,CAAC,SAAS,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC;KAC/B;CACF;AAED;;;;GAIG;AACH,MAAM,IAAK,SAAQ,eAAe;IAChC;;;OAGG;IACH,YAAY,GAAG,SAAoC;QACjD,KAAK,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;KAC5B;CACF;AAED;;GAEG;AACH,MAAM,UAAW,SAAQ,eAAe;IACtC;;;;OAIG;IACH,YAAY,aAAkB,EAAE,KAAa;QAC3C,KAAK,CAAC,cAAc,EAAE,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC,CAAC;KAC/C;CACF;AAED;;GAEG;AACH,MAAM,kBAAmB,SAAQ,eAAe;IAC9C;;;;OAIG;IACH,YAAY,aAAkB,EAAE,KAAa;QAC3C,KAAK,CAAC,sBAAsB,EAAE,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC,CAAC;KACvD;CACF;AAED;;;GAGG;AACH,MAAM,cAAe,SAAQ,eAAe;IAC1C;;;;OAIG;IACH,YAAY,cAAwB,EAAE,cAAwB;QAC5D,KAAK,CAAC,kBAAkB,EAAE,CAAC,cAAc,EAAE,cAAc,CAAC,CAAC,CAAC;KAC7D;CACF;AAED;;GAEG;AACH,MAAM,QAAS,SAAQ,MAAM;IAC3B;;;;;OAKG;IACH,YAAY,aAAqB;QAC/B,KAAK,CAAC,YAAY,EAAE,aAAa,CAAC,CAAC;KACpC;CACF;AAED;;GAEG;AACH,MAAM,SAAU,SAAQ,MAAM;IAC5B;;;;OAIG;IACH,YAAY,oBAA4B,EAAE,SAAiB;QACzD,KAAK,CAAC,aAAa,EAAE,CAAC,oBAAoB,EAAE,SAAS,CAAC,CAAC,CAAC;KACzD;CACF;AAED;;GAEG;AACH,MAAM,YAAa,SAAQ,MAAM;IAC/B;;;;OAIG;IACH,YAAY,aAAqB,EAAE,SAAiB;QAClD,KAAK,CAAC,gBAAgB,EAAE,CAAC,aAAa,EAAE,SAAS,CAAC,CAAC,CAAC;KACrD;CACF;AAED;;;;GAIG;AACH,MAAM,MAAM;IAMV;;;;;OAKG;IACH,YAAY,SAAiB,EAAE,YAAmB;QAChD,IAAI,YAAY,CAAC,MAAM,KAAK,CAAC,EAAE;YAC7B,MAAM,IAAI,KAAK,CAAC,mDAAmD,CAAC,CAAC;SACtE;QAED,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;QACjC,IAAI,CAAC,aAAa,GAAG,+BAAiB,EAAE,CAAC;KAC1C;IAEM,OAAO,CAAC,OAAwB;QACrC,IAAI,aAAK,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE;YACzC,8DAA8D;YAC9D,OAAO,EAAE,UAAU,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC;SAC5D;QACD,MAAM,QAAQ,GAAG,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;QAC7C,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE;YACzB,OAAO,QAAQ,CAAC,CAAC,CAAC,CAAC;SACpB;QACD,OAAO,EAAE,UAAU,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,QAAQ,CAAC,EAAE,CAAC;KACnD;IAEM,QAAQ;QACb,OAAO,aAAK,CAAC,QAAQ,CAAC,IAAI,EAAE,EAAE,WAAW,EAAE,UAAU,EAAE,CAAC,CAAC;KAC1D;IAEM,MAAM;QACX,OAAO,YAAY,CAAC;KACrB;IAED;;;;OAIG;IACK,aAAa,CAAC,OAAwB;QAC5C,MAAM,cAAc,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,qBAAS,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;QACrG,OAAO,+CAAyB,CAAC,IAAI,CAAC,SAAS,EAAE,cAAc,CAAC,CAAC;KAClE;CACF;AAED,SAAS,WAAW,CAAI,KAAU,EAAE,QAAgB;IAClD,MAAM,MAAM,GAAG,IAAI,KAAK,EAAO,CAAC;IAChC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,IAAI,QAAQ,EAAE;QAC/C,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC;KAC3C;IACD,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,SAAS,KAAK,CAAC,CAAS;IACtB,MAAM,GAAG,GAAG,EAAE,CAAC;IACf,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;QAC1B,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;KACb;IACD,OAAO,GAAG,CAAC;AACb,CAAC","sourcesContent":["import { ICfnConditionExpression, ICfnRuleConditionExpression } from './cfn-condition';\nimport { minimalCloudFormationJoin } from './private/cloudformation-lang';\nimport { Intrinsic } from './private/intrinsic';\nimport { Reference } from './reference';\nimport { IResolvable, IResolveContext } from './resolvable';\nimport { captureStackTrace } from './stack-trace';\nimport { Token } from './token';\n\n/* eslint-disable max-len */\n\n/**\n * CloudFormation intrinsic functions.\n * http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/intrinsic-function-reference.html\n */\nexport class Fn {\n  /**\n   * The ``Ref`` intrinsic function returns the value of the specified parameter or resource.\n   * Note that it doesn't validate the logicalName, it mainly serves paremeter