1 | ;
|
2 | var _a;
|
3 | Object.defineProperty(exports, "__esModule", { value: true });
|
4 | exports.Fn = void 0;
|
5 | const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
|
6 | const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
7 | const cloudformation_lang_1 = require("./private/cloudformation-lang");
|
8 | const intrinsic_1 = require("./private/intrinsic");
|
9 | const reference_1 = require("./reference");
|
10 | const stack_trace_1 = require("./stack-trace");
|
11 | const token_1 = require("./token");
|
12 | /* eslint-disable max-len */
|
13 | /**
|
14 | * CloudFormation intrinsic functions.
|
15 | * http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/intrinsic-function-reference.html
|
16 | */
|
17 | class Fn {
|
18 | constructor() { }
|
19 | /**
|
20 | * The ``Ref`` intrinsic function returns the value of the specified parameter or resource.
|
21 | * Note that it doesn't validate the logicalName, it mainly serves paremeter/resource reference defined in a ``CfnInclude`` template.
|
22 | * @param logicalName The logical name of a parameter/resource for which you want to retrieve its value.
|
23 | */
|
24 | static ref(logicalName) {
|
25 | return new FnRef(logicalName).toString();
|
26 | }
|
27 | /**
|
28 | * The ``Fn::GetAtt`` intrinsic function returns the value of an attribute
|
29 | * from a resource in the template.
|
30 | * @param logicalNameOfResource The logical name (also called logical ID) of
|
31 | * the resource that contains the attribute that you want.
|
32 | * @param attributeName The name of the resource-specific attribute whose
|
33 | * value you want. See the resource's reference page for details about the
|
34 | * attributes available for that resource type.
|
35 | * @returns an IResolvable object
|
36 | */
|
37 | static getAtt(logicalNameOfResource, attributeName) {
|
38 | return new FnGetAtt(logicalNameOfResource, attributeName);
|
39 | }
|
40 | /**
|
41 | * The intrinsic function ``Fn::Join`` appends a set of values into a single
|
42 | * value, separated by the specified delimiter. If a delimiter is the empty
|
43 | * string, the set of values are concatenated with no delimiter.
|
44 | * @param delimiter The value you want to occur between fragments. The
|
45 | * delimiter will occur between fragments only. It will not terminate the
|
46 | * final value.
|
47 | * @param listOfValues The list of values you want combined.
|
48 | * @returns a token represented as a string
|
49 | */
|
50 | static join(delimiter, listOfValues) {
|
51 | if (listOfValues.length === 0) {
|
52 | throw new Error('FnJoin requires at least one value to be provided');
|
53 | }
|
54 | return new FnJoin(delimiter, listOfValues).toString();
|
55 | }
|
56 | /**
|
57 | * Split a string token into a token list of string values.
|
58 | *
|
59 | * Specify the location of splits with a delimiter such as ',' (a comma).
|
60 | * Renders to the `Fn::Split` intrinsic function.
|
61 | *
|
62 | * Lists with unknown lengths (default)
|
63 | * -------------------------------------
|
64 | *
|
65 | * Since this function is used to work with deploy-time values, if `assumedLength`
|
66 | * is not given the CDK cannot know the length of the resulting list at synthesis time.
|
67 | * This brings the following restrictions:
|
68 | *
|
69 | * - You must use `Fn.select(i, list)` to pick elements out of the list (you must not use
|
70 | * `list[i]`).
|
71 | * - You cannot add elements to the list, remove elements from the list,
|
72 | * combine two such lists together, or take a slice of the list.
|
73 | * - You cannot pass the list to constructs that do any of the above.
|
74 | *
|
75 | * The only valid operation with such a tokenized list is to pass it unmodified to a
|
76 | * CloudFormation Resource construct.
|
77 | *
|
78 | * Lists with assumed lengths
|
79 | * --------------------------
|
80 | *
|
81 | * Pass `assumedLength` if you know the length of the list that will be
|
82 | * produced by splitting. The actual list length at deploy time may be
|
83 | * *longer* than the number you pass, but not *shorter*.
|
84 | *
|
85 | * The returned list will look like:
|
86 | *
|
87 | * ```
|
88 | * [Fn.select(0, split), Fn.select(1, split), Fn.select(2, split), ...]
|
89 | * ```
|
90 | *
|
91 | * The restrictions from the section "Lists with unknown lengths" will now be lifted,
|
92 | * at the expense of having to know and fix the length of the list.
|
93 | *
|
94 | * @param delimiter A string value that determines where the source string is divided.
|
95 | * @param source The string value that you want to split.
|
96 | * @param assumedLength The length of the list that will be produced by splitting
|
97 | * @returns a token represented as a string array
|
98 | */
|
99 | static split(delimiter, source, assumedLength) {
|
100 | // short-circut if source is not a token
|
101 | if (!token_1.Token.isUnresolved(source)) {
|
102 | return source.split(delimiter);
|
103 | }
|
104 | if (token_1.Token.isUnresolved(delimiter)) {
|
105 | // Limitation of CloudFormation
|
106 | throw new Error('Fn.split: \'delimiter\' may not be a token value');
|
107 | }
|
108 | const split = token_1.Token.asList(new FnSplit(delimiter, source));
|
109 | if (assumedLength === undefined) {
|
110 | return split;
|
111 | }
|
112 | if (token_1.Token.isUnresolved(assumedLength)) {
|
113 | throw new Error('Fn.split: \'assumedLength\' may not be a token value');
|
114 | }
|
115 | return range(assumedLength).map(i => Fn.select(i, split));
|
116 | }
|
117 | /**
|
118 | * The intrinsic function ``Fn::Select`` returns a single object from a list of objects by index.
|
119 | * @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.
|
120 | * @param array The list of objects to select from. This list must not be null, nor can it have null entries.
|
121 | * @returns a token represented as a string
|
122 | */
|
123 | static select(index, array) {
|
124 | if (!token_1.Token.isUnresolved(index) && !token_1.Token.isUnresolved(array) && !array.some(token_1.Token.isUnresolved)) {
|
125 | return array[index];
|
126 | }
|
127 | return new FnSelect(index, array).toString();
|
128 | }
|
129 | /**
|
130 | * The intrinsic function ``Fn::Sub`` substitutes variables in an input string
|
131 | * with values that you specify. In your templates, you can use this function
|
132 | * to construct commands or outputs that include values that aren't available
|
133 | * until you create or update a stack.
|
134 | * @param body A string with variables that AWS CloudFormation substitutes
|
135 | * with their associated values at runtime. Write variables as ${MyVarName}.
|
136 | * Variables can be template parameter names, resource logical IDs, resource
|
137 | * attributes, or a variable in a key-value map. If you specify only template
|
138 | * parameter names, resource logical IDs, and resource attributes, don't
|
139 | * specify a key-value map.
|
140 | * @param variables The name of a variable that you included in the String
|
141 | * parameter. The value that AWS CloudFormation substitutes for the associated
|
142 | * variable name at runtime.
|
143 | * @returns a token represented as a string
|
144 | */
|
145 | static sub(body, variables) {
|
146 | return new FnSub(body, variables).toString();
|
147 | }
|
148 | /**
|
149 | * The intrinsic function ``Fn::Base64`` returns the Base64 representation of
|
150 | * the input string. This function is typically used to pass encoded data to
|
151 | * Amazon EC2 instances by way of the UserData property.
|
152 | * @param data The string value you want to convert to Base64.
|
153 | * @returns a token represented as a string
|
154 | */
|
155 | static base64(data) {
|
156 | return new FnBase64(data).toString();
|
157 | }
|
158 | /**
|
159 | * The intrinsic function ``Fn::Cidr`` returns the specified Cidr address block.
|
160 | * @param ipBlock The user-specified default Cidr address block.
|
161 | * @param count The number of subnets' Cidr block wanted. Count can be 1 to 256.
|
162 | * @param sizeMask The digit covered in the subnet.
|
163 | * @returns a token represented as a string
|
164 | */
|
165 | static cidr(ipBlock, count, sizeMask) {
|
166 | return token_1.Token.asList(new FnCidr(ipBlock, count, sizeMask));
|
167 | }
|
168 | /**
|
169 | * Given an url, parse the domain name
|
170 | * @param url the url to parse
|
171 | */
|
172 | static parseDomainName(url) {
|
173 | const noHttps = Fn.select(1, Fn.split('//', url));
|
174 | return Fn.select(0, Fn.split('/', noHttps));
|
175 | }
|
176 | /**
|
177 | * The intrinsic function ``Fn::GetAZs`` returns an array that lists
|
178 | * Availability Zones for a specified region. Because customers have access to
|
179 | * different Availability Zones, the intrinsic function ``Fn::GetAZs`` enables
|
180 | * template authors to write templates that adapt to the calling user's
|
181 | * access. That way you don't have to hard-code a full list of Availability
|
182 | * Zones for a specified region.
|
183 | * @param region The name of the region for which you want to get the
|
184 | * Availability Zones. You can use the AWS::Region pseudo parameter to specify
|
185 | * the region in which the stack is created. Specifying an empty string is
|
186 | * equivalent to specifying AWS::Region.
|
187 | * @returns a token represented as a string array
|
188 | */
|
189 | static getAzs(region) {
|
190 | return token_1.Token.asList(new FnGetAZs(region));
|
191 | }
|
192 | /**
|
193 | * The intrinsic function ``Fn::ImportValue`` returns the value of an output
|
194 | * exported by another stack. You typically use this function to create
|
195 | * cross-stack references. In the following example template snippets, Stack A
|
196 | * exports VPC security group values and Stack B imports them.
|
197 | * @param sharedValueToImport The stack output value that you want to import.
|
198 | * @returns a token represented as a string
|
199 | */
|
200 | static importValue(sharedValueToImport) {
|
201 | return new FnImportValue(sharedValueToImport).toString();
|
202 | }
|
203 | /**
|
204 | * Like `Fn.importValue`, but import a list with a known length
|
205 | *
|
206 | * If you explicitly want a list with an unknown length, call `Fn.split(',',
|
207 | * Fn.importValue(exportName))`. See the documentation of `Fn.split` to read
|
208 | * more about the limitations of using lists of unknown length.
|
209 | *
|
210 | * `Fn.importListValue(exportName, assumedLength)` is the same as
|
211 | * `Fn.split(',', Fn.importValue(exportName), assumedLength)`,
|
212 | * but easier to read and impossible to forget to pass `assumedLength`.
|
213 | */
|
214 | static importListValue(sharedValueToImport, assumedLength, delimiter = ',') {
|
215 | return Fn.split(delimiter, Fn.importValue(sharedValueToImport), assumedLength);
|
216 | }
|
217 | /**
|
218 | * The intrinsic function ``Fn::FindInMap`` returns the value corresponding to
|
219 | * keys in a two-level map that is declared in the Mappings section.
|
220 | * @returns a token represented as a string
|
221 | */
|
222 | static findInMap(mapName, topLevelKey, secondLevelKey) {
|
223 | return Fn._findInMap(mapName, topLevelKey, secondLevelKey).toString();
|
224 | }
|
225 | /**
|
226 | * An additional function used in CfnParser,
|
227 | * as Fn::FindInMap does not always return a string.
|
228 | *
|
229 | * @internal
|
230 | */
|
231 | static _findInMap(mapName, topLevelKey, secondLevelKey) {
|
232 | return new FnFindInMap(mapName, topLevelKey, secondLevelKey);
|
233 | }
|
234 | /**
|
235 | * Creates a token representing the ``Fn::Transform`` expression
|
236 | * @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/intrinsic-function-reference-transform.html
|
237 | * @param macroName The name of the macro to perform the processing
|
238 | * @param parameters The parameters to be passed to the macro
|
239 | * @returns a token representing the transform expression
|
240 | */
|
241 | static transform(macroName, parameters) {
|
242 | return new FnTransform(macroName, parameters);
|
243 | }
|
244 | /**
|
245 | * Returns true if all the specified conditions evaluate to true, or returns
|
246 | * false if any one of the conditions evaluates to false. ``Fn::And`` acts as
|
247 | * an AND operator. The minimum number of conditions that you can include is
|
248 | * 1.
|
249 | * @param conditions conditions to AND
|
250 | * @returns an FnCondition token
|
251 | */
|
252 | static conditionAnd(...conditions) {
|
253 | try {
|
254 | jsiiDeprecationWarnings._aws_cdk_core_ICfnConditionExpression(conditions);
|
255 | }
|
256 | catch (error) {
|
257 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
258 | Error.captureStackTrace(error, this.conditionAnd);
|
259 | }
|
260 | throw error;
|
261 | }
|
262 | if (conditions.length === 0) {
|
263 | throw new Error('Fn.conditionAnd() needs at least one argument');
|
264 | }
|
265 | if (conditions.length === 1) {
|
266 | return conditions[0];
|
267 | }
|
268 | return Fn.conditionAnd(..._inGroupsOf(conditions, 10).map(group => new FnAnd(...group)));
|
269 | }
|
270 | /**
|
271 | * Compares if two values are equal. Returns true if the two values are equal
|
272 | * or false if they aren't.
|
273 | * @param lhs A value of any type that you want to compare.
|
274 | * @param rhs A value of any type that you want to compare.
|
275 | * @returns an FnCondition token
|
276 | */
|
277 | static conditionEquals(lhs, rhs) {
|
278 | return new FnEquals(lhs, rhs);
|
279 | }
|
280 | /**
|
281 | * Returns one value if the specified condition evaluates to true and another
|
282 | * value if the specified condition evaluates to false. Currently, AWS
|
283 | * CloudFormation supports the ``Fn::If`` intrinsic function in the metadata
|
284 | * attribute, update policy attribute, and property values in the Resources
|
285 | * section and Outputs sections of a template. You can use the AWS::NoValue
|
286 | * pseudo parameter as a return value to remove the corresponding property.
|
287 | * @param conditionId A reference to a condition in the Conditions section. Use
|
288 | * the condition's name to reference it.
|
289 | * @param valueIfTrue A value to be returned if the specified condition
|
290 | * evaluates to true.
|
291 | * @param valueIfFalse A value to be returned if the specified condition
|
292 | * evaluates to false.
|
293 | * @returns an FnCondition token
|
294 | */
|
295 | static conditionIf(conditionId, valueIfTrue, valueIfFalse) {
|
296 | return new FnIf(conditionId, valueIfTrue, valueIfFalse);
|
297 | }
|
298 | /**
|
299 | * Returns true for a condition that evaluates to false or returns false for a
|
300 | * condition that evaluates to true. ``Fn::Not`` acts as a NOT operator.
|
301 | * @param condition A condition such as ``Fn::Equals`` that evaluates to true
|
302 | * or false.
|
303 | * @returns an FnCondition token
|
304 | */
|
305 | static conditionNot(condition) {
|
306 | try {
|
307 | jsiiDeprecationWarnings._aws_cdk_core_ICfnConditionExpression(condition);
|
308 | }
|
309 | catch (error) {
|
310 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
311 | Error.captureStackTrace(error, this.conditionNot);
|
312 | }
|
313 | throw error;
|
314 | }
|
315 | return new FnNot(condition);
|
316 | }
|
317 | /**
|
318 | * Returns true if any one of the specified conditions evaluate to true, or
|
319 | * returns false if all of the conditions evaluates to false. ``Fn::Or`` acts
|
320 | * as an OR operator. The minimum number of conditions that you can include is
|
321 | * 1.
|
322 | * @param conditions conditions that evaluates to true or false.
|
323 | * @returns an FnCondition token
|
324 | */
|
325 | static conditionOr(...conditions) {
|
326 | try {
|
327 | jsiiDeprecationWarnings._aws_cdk_core_ICfnConditionExpression(conditions);
|
328 | }
|
329 | catch (error) {
|
330 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
331 | Error.captureStackTrace(error, this.conditionOr);
|
332 | }
|
333 | throw error;
|
334 | }
|
335 | if (conditions.length === 0) {
|
336 | throw new Error('Fn.conditionOr() needs at least one argument');
|
337 | }
|
338 | if (conditions.length === 1) {
|
339 | return conditions[0];
|
340 | }
|
341 | return Fn.conditionOr(..._inGroupsOf(conditions, 10).map(group => new FnOr(...group)));
|
342 | }
|
343 | /**
|
344 | * Returns true if a specified string matches at least one value in a list of
|
345 | * strings.
|
346 | * @param listOfStrings A list of strings, such as "A", "B", "C".
|
347 | * @param value A string, such as "A", that you want to compare against a list of strings.
|
348 | * @returns an FnCondition token
|
349 | */
|
350 | static conditionContains(listOfStrings, value) {
|
351 | return new FnContains(listOfStrings, value);
|
352 | }
|
353 | /**
|
354 | * Returns true if a specified string matches all values in a list.
|
355 | * @param listOfStrings A list of strings, such as "A", "B", "C".
|
356 | * @param value A string, such as "A", that you want to compare against a list
|
357 | * of strings.
|
358 | * @returns an FnCondition token
|
359 | */
|
360 | static conditionEachMemberEquals(listOfStrings, value) {
|
361 | return new FnEachMemberEquals(listOfStrings, value);
|
362 | }
|
363 | /**
|
364 | * Returns true if each member in a list of strings matches at least one value
|
365 | * in a second list of strings.
|
366 | * @param stringsToCheck A list of strings, such as "A", "B", "C". AWS
|
367 | * CloudFormation checks whether each member in the strings_to_check parameter
|
368 | * is in the strings_to_match parameter.
|
369 | * @param stringsToMatch A list of strings, such as "A", "B", "C". Each member
|
370 | * in the strings_to_match parameter is compared against the members of the
|
371 | * strings_to_check parameter.
|
372 | * @returns an FnCondition token
|
373 | */
|
374 | static conditionEachMemberIn(stringsToCheck, stringsToMatch) {
|
375 | return new FnEachMemberIn(stringsToCheck, stringsToMatch);
|
376 | }
|
377 | /**
|
378 | * Returns all values for a specified parameter type.
|
379 | * @param parameterType An AWS-specific parameter type, such as
|
380 | * AWS::EC2::SecurityGroup::Id or AWS::EC2::VPC::Id. For more information, see
|
381 | * Parameters in the AWS CloudFormation User Guide.
|
382 | * @returns a token represented as a string array
|
383 | */
|
384 | static refAll(parameterType) {
|
385 | return token_1.Token.asList(new FnRefAll(parameterType));
|
386 | }
|
387 | /**
|
388 | * Returns an attribute value or list of values for a specific parameter and
|
389 | * attribute.
|
390 | * @param parameterOrLogicalId The name of a parameter for which you want to
|
391 | * retrieve attribute values. The parameter must be declared in the Parameters
|
392 | * section of the template.
|
393 | * @param attribute The name of an attribute from which you want to retrieve a
|
394 | * value.
|
395 | * @returns a token represented as a string
|
396 | */
|
397 | static valueOf(parameterOrLogicalId, attribute) {
|
398 | return new FnValueOf(parameterOrLogicalId, attribute).toString();
|
399 | }
|
400 | /**
|
401 | * Returns a list of all attribute values for a given parameter type and
|
402 | * attribute.
|
403 | * @param parameterType An AWS-specific parameter type, such as
|
404 | * AWS::EC2::SecurityGroup::Id or AWS::EC2::VPC::Id. For more information, see
|
405 | * Parameters in the AWS CloudFormation User Guide.
|
406 | * @param attribute The name of an attribute from which you want to retrieve a
|
407 | * value. For more information about attributes, see Supported Attributes.
|
408 | * @returns a token represented as a string array
|
409 | */
|
410 | static valueOfAll(parameterType, attribute) {
|
411 | return token_1.Token.asList(new FnValueOfAll(parameterType, attribute));
|
412 | }
|
413 | }
|
414 | exports.Fn = Fn;
|
415 | _a = JSII_RTTI_SYMBOL_1;
|
416 | Fn[_a] = { fqn: "@aws-cdk/core.Fn", version: "1.204.0" };
|
417 | /**
|
418 | * Base class for tokens that represent CloudFormation intrinsic functions.
|
419 | */
|
420 | class FnBase extends intrinsic_1.Intrinsic {
|
421 | constructor(name, value) {
|
422 | super({ [name]: value });
|
423 | }
|
424 | }
|
425 | /**
|
426 | * The intrinsic function ``Ref`` returns the value of the specified parameter or resource.
|
427 | * When you specify a parameter's logical name, it returns the value of the parameter.
|
428 | * 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.
|
429 | */
|
430 | class FnRef extends FnBase {
|
431 | /**
|
432 | * Creates an ``Ref`` function.
|
433 | * @param logicalName The logical name of a parameter/resource for which you want to retrieve its value.
|
434 | */
|
435 | constructor(logicalName) {
|
436 | super('Ref', logicalName);
|
437 | }
|
438 | }
|
439 | /**
|
440 | * The intrinsic function ``Fn::FindInMap`` returns the value corresponding to keys in a two-level
|
441 | * map that is declared in the Mappings section.
|
442 | */
|
443 | class FnFindInMap extends FnBase {
|
444 | /**
|
445 | * Creates an ``Fn::FindInMap`` function.
|
446 | * @param mapName The logical name of a mapping declared in the Mappings section that contains the keys and values.
|
447 | * @param topLevelKey The top-level key name. Its value is a list of key-value pairs.
|
448 | * @param secondLevelKey The second-level key name, which is set to one of the keys from the list assigned to TopLevelKey.
|
449 | */
|
450 | constructor(mapName, topLevelKey, secondLevelKey) {
|
451 | super('Fn::FindInMap', [mapName, topLevelKey, secondLevelKey]);
|
452 | }
|
453 | }
|
454 | /**
|
455 | * The intrinsic function ``Fn::Transform`` specifies a macro to perform custom processing on part of a stack template.
|
456 | */
|
457 | class FnTransform extends FnBase {
|
458 | /**
|
459 | * creates an ``Fn::Transform`` function.
|
460 | * @param macroName The name of the macro to be invoked
|
461 | * @param parameters the parameters to pass to it
|
462 | */
|
463 | constructor(macroName, parameters) {
|
464 | super('Fn::Transform', { Name: macroName, Parameters: parameters });
|
465 | }
|
466 | }
|
467 | /**
|
468 | * The ``Fn::GetAtt`` intrinsic function returns the value of an attribute from a resource in the template.
|
469 | */
|
470 | class FnGetAtt extends FnBase {
|
471 | /**
|
472 | * Creates a ``Fn::GetAtt`` function.
|
473 | * @param logicalNameOfResource The logical name (also called logical ID) of the resource that contains the attribute that you want.
|
474 | * @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.
|
475 | */
|
476 | constructor(logicalNameOfResource, attributeName) {
|
477 | super('Fn::GetAtt', [logicalNameOfResource, attributeName]);
|
478 | }
|
479 | }
|
480 | /**
|
481 | * The intrinsic function ``Fn::GetAZs`` returns an array that lists Availability Zones for a
|
482 | * specified region. Because customers have access to different Availability Zones, the intrinsic
|
483 | * function ``Fn::GetAZs`` enables template authors to write templates that adapt to the calling
|
484 | * user's access. That way you don't have to hard-code a full list of Availability Zones for a
|
485 | * specified region.
|
486 | */
|
487 | class FnGetAZs extends FnBase {
|
488 | /**
|
489 | * Creates an ``Fn::GetAZs`` function.
|
490 | * @param region The name of the region for which you want to get the Availability Zones.
|
491 | * You can use the AWS::Region pseudo parameter to specify the region in
|
492 | * which the stack is created. Specifying an empty string is equivalent to
|
493 | * specifying AWS::Region.
|
494 | */
|
495 | constructor(region) {
|
496 | super('Fn::GetAZs', region || '');
|
497 | }
|
498 | }
|
499 | /**
|
500 | * The intrinsic function ``Fn::ImportValue`` returns the value of an output exported by another stack.
|
501 | * You typically use this function to create cross-stack references. In the following example
|
502 | * template snippets, Stack A exports VPC security group values and Stack B imports them.
|
503 | */
|
504 | class FnImportValue extends FnBase {
|
505 | /**
|
506 | * Creates an ``Fn::ImportValue`` function.
|
507 | * @param sharedValueToImport The stack output value that you want to import.
|
508 | */
|
509 | constructor(sharedValueToImport) {
|
510 | super('Fn::ImportValue', sharedValueToImport);
|
511 | }
|
512 | }
|
513 | /**
|
514 | * The intrinsic function ``Fn::Select`` returns a single object from a list of objects by index.
|
515 | */
|
516 | class FnSelect extends FnBase {
|
517 | /**
|
518 | * Creates an ``Fn::Select`` function.
|
519 | * @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.
|
520 | * @param array The list of objects to select from. This list must not be null, nor can it have null entries.
|
521 | */
|
522 | constructor(index, array) {
|
523 | super('Fn::Select', [index, array]);
|
524 | }
|
525 | }
|
526 | /**
|
527 | * To split a string into a list of string values so that you can select an element from the
|
528 | * resulting string list, use the ``Fn::Split`` intrinsic function. Specify the location of splits
|
529 | * with a delimiter, such as , (a comma). After you split a string, use the ``Fn::Select`` function
|
530 | * to pick a specific element.
|
531 | */
|
532 | class FnSplit extends FnBase {
|
533 | /**
|
534 | * Create an ``Fn::Split`` function.
|
535 | * @param delimiter A string value that determines where the source string is divided.
|
536 | * @param source The string value that you want to split.
|
537 | */
|
538 | constructor(delimiter, source) {
|
539 | super('Fn::Split', [delimiter, source]);
|
540 | }
|
541 | }
|
542 | /**
|
543 | * The intrinsic function ``Fn::Sub`` substitutes variables in an input string with values that
|
544 | * you specify. In your templates, you can use this function to construct commands or outputs
|
545 | * that include values that aren't available until you create or update a stack.
|
546 | */
|
547 | class FnSub extends FnBase {
|
548 | /**
|
549 | * Creates an ``Fn::Sub`` function.
|
550 | * @param body A string with variables that AWS CloudFormation substitutes with their
|
551 | * associated values at runtime. Write variables as ${MyVarName}. Variables
|
552 | * can be template parameter names, resource logical IDs, resource attributes,
|
553 | * or a variable in a key-value map. If you specify only template parameter names,
|
554 | * resource logical IDs, and resource attributes, don't specify a key-value map.
|
555 | * @param variables The name of a variable that you included in the String parameter.
|
556 | * The value that AWS CloudFormation substitutes for the associated variable name at runtime.
|
557 | */
|
558 | constructor(body, variables) {
|
559 | super('Fn::Sub', variables ? [body, variables] : body);
|
560 | }
|
561 | }
|
562 | /**
|
563 | * The intrinsic function ``Fn::Base64`` returns the Base64 representation of the input string.
|
564 | * This function is typically used to pass encoded data to Amazon EC2 instances by way of
|
565 | * the UserData property.
|
566 | */
|
567 | class FnBase64 extends FnBase {
|
568 | /**
|
569 | * Creates an ``Fn::Base64`` function.
|
570 | * @param data The string value you want to convert to Base64.
|
571 | */
|
572 | constructor(data) {
|
573 | super('Fn::Base64', data);
|
574 | }
|
575 | }
|
576 | /**
|
577 | * The intrinsic function ``Fn::Cidr`` returns the specified Cidr address block.
|
578 | */
|
579 | class FnCidr extends FnBase {
|
580 | /**
|
581 | * Creates an ``Fn::Cidr`` function.
|
582 | * @param ipBlock The user-specified default Cidr address block.
|
583 | * @param count The number of subnets' Cidr block wanted. Count can be 1 to 256.
|
584 | * @param sizeMask The digit covered in the subnet.
|
585 | */
|
586 | constructor(ipBlock, count, sizeMask) {
|
587 | if (count < 1 || count > 256) {
|
588 | throw new Error(`Fn::Cidr's count attribute must be betwen 1 and 256, ${count} was provided.`);
|
589 | }
|
590 | super('Fn::Cidr', [ipBlock, count, sizeMask]);
|
591 | }
|
592 | }
|
593 | class FnConditionBase extends intrinsic_1.Intrinsic {
|
594 | constructor(type, value) {
|
595 | super({ [type]: value });
|
596 | this.disambiguator = true;
|
597 | }
|
598 | }
|
599 | /**
|
600 | * Returns true if all the specified conditions evaluate to true, or returns false if any one
|
601 | * of the conditions evaluates to false. ``Fn::And`` acts as an AND operator. The minimum number of
|
602 | * conditions that you can include is 2, and the maximum is 10.
|
603 | */
|
604 | class FnAnd extends FnConditionBase {
|
605 | constructor(...condition) {
|
606 | super('Fn::And', condition);
|
607 | }
|
608 | }
|
609 | /**
|
610 | * Compares if two values are equal. Returns true if the two values are equal or false
|
611 | * if they aren't.
|
612 | */
|
613 | class FnEquals extends FnConditionBase {
|
614 | /**
|
615 | * Creates an ``Fn::Equals`` condition function.
|
616 | * @param lhs A value of any type that you want to compare.
|
617 | * @param rhs A value of any type that you want to compare.
|
618 | */
|
619 | constructor(lhs, rhs) {
|
620 | super('Fn::Equals', [lhs, rhs]);
|
621 | }
|
622 | }
|
623 | /**
|
624 | * Returns one value if the specified condition evaluates to true and another value if the
|
625 | * specified condition evaluates to false. Currently, AWS CloudFormation supports the ``Fn::If``
|
626 | * intrinsic function in the metadata attribute, update policy attribute, and property values
|
627 | * in the Resources section and Outputs sections of a template. You can use the AWS::NoValue
|
628 | * pseudo parameter as a return value to remove the corresponding property.
|
629 | */
|
630 | class FnIf extends FnConditionBase {
|
631 | /**
|
632 | * Creates an ``Fn::If`` condition function.
|
633 | * @param condition A reference to a condition in the Conditions section. Use the condition's name to reference it.
|
634 | * @param valueIfTrue A value to be returned if the specified condition evaluates to true.
|
635 | * @param valueIfFalse A value to be returned if the specified condition evaluates to false.
|
636 | */
|
637 | constructor(condition, valueIfTrue, valueIfFalse) {
|
638 | super('Fn::If', [condition, valueIfTrue, valueIfFalse]);
|
639 | }
|
640 | }
|
641 | /**
|
642 | * Returns true for a condition that evaluates to false or returns false for a condition that evaluates to true.
|
643 | * ``Fn::Not`` acts as a NOT operator.
|
644 | */
|
645 | class FnNot extends FnConditionBase {
|
646 | /**
|
647 | * Creates an ``Fn::Not`` condition function.
|
648 | * @param condition A condition such as ``Fn::Equals`` that evaluates to true or false.
|
649 | */
|
650 | constructor(condition) {
|
651 | super('Fn::Not', [condition]);
|
652 | }
|
653 | }
|
654 | /**
|
655 | * Returns true if any one of the specified conditions evaluate to true, or returns false if
|
656 | * all of the conditions evaluates to false. ``Fn::Or`` acts as an OR operator. The minimum number
|
657 | * of conditions that you can include is 2, and the maximum is 10.
|
658 | */
|
659 | class FnOr extends FnConditionBase {
|
660 | /**
|
661 | * Creates an ``Fn::Or`` condition function.
|
662 | * @param condition A condition that evaluates to true or false.
|
663 | */
|
664 | constructor(...condition) {
|
665 | super('Fn::Or', condition);
|
666 | }
|
667 | }
|
668 | /**
|
669 | * Returns true if a specified string matches at least one value in a list of strings.
|
670 | */
|
671 | class FnContains extends FnConditionBase {
|
672 | /**
|
673 | * Creates an ``Fn::Contains`` function.
|
674 | * @param listOfStrings A list of strings, such as "A", "B", "C".
|
675 | * @param value A string, such as "A", that you want to compare against a list of strings.
|
676 | */
|
677 | constructor(listOfStrings, value) {
|
678 | super('Fn::Contains', [listOfStrings, value]);
|
679 | }
|
680 | }
|
681 | /**
|
682 | * Returns true if a specified string matches all values in a list.
|
683 | */
|
684 | class FnEachMemberEquals extends FnConditionBase {
|
685 | /**
|
686 | * Creates an ``Fn::EachMemberEquals`` function.
|
687 | * @param listOfStrings A list of strings, such as "A", "B", "C".
|
688 | * @param value A string, such as "A", that you want to compare against a list of strings.
|
689 | */
|
690 | constructor(listOfStrings, value) {
|
691 | super('Fn::EachMemberEquals', [listOfStrings, value]);
|
692 | }
|
693 | }
|
694 | /**
|
695 | * Returns true if each member in a list of strings matches at least one value in a second
|
696 | * list of strings.
|
697 | */
|
698 | class FnEachMemberIn extends FnConditionBase {
|
699 | /**
|
700 | * Creates an ``Fn::EachMemberIn`` function.
|
701 | * @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.
|
702 | * @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.
|
703 | */
|
704 | constructor(stringsToCheck, stringsToMatch) {
|
705 | super('Fn::EachMemberIn', [stringsToCheck, stringsToMatch]);
|
706 | }
|
707 | }
|
708 | /**
|
709 | * Returns all values for a specified parameter type.
|
710 | */
|
711 | class FnRefAll extends FnBase {
|
712 | /**
|
713 | * Creates an ``Fn::RefAll`` function.
|
714 | * @param parameterType An AWS-specific parameter type, such as AWS::EC2::SecurityGroup::Id or
|
715 | * AWS::EC2::VPC::Id. For more information, see Parameters in the AWS
|
716 | * CloudFormation User Guide.
|
717 | */
|
718 | constructor(parameterType) {
|
719 | super('Fn::RefAll', parameterType);
|
720 | }
|
721 | }
|
722 | /**
|
723 | * Returns an attribute value or list of values for a specific parameter and attribute.
|
724 | */
|
725 | class FnValueOf extends FnBase {
|
726 | /**
|
727 | * Creates an ``Fn::ValueOf`` function.
|
728 | * @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.
|
729 | * @param attribute The name of an attribute from which you want to retrieve a value.
|
730 | */
|
731 | constructor(parameterOrLogicalId, attribute) {
|
732 | super('Fn::ValueOf', [parameterOrLogicalId, attribute]);
|
733 | }
|
734 | }
|
735 | /**
|
736 | * Returns a list of all attribute values for a given parameter type and attribute.
|
737 | */
|
738 | class FnValueOfAll extends FnBase {
|
739 | /**
|
740 | * Creates an ``Fn::ValueOfAll`` function.
|
741 | * @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.
|
742 | * @param attribute The name of an attribute from which you want to retrieve a value. For more information about attributes, see Supported Attributes.
|
743 | */
|
744 | constructor(parameterType, attribute) {
|
745 | super('Fn::ValueOfAll', [parameterType, attribute]);
|
746 | }
|
747 | }
|
748 | /**
|
749 | * The intrinsic function ``Fn::Join`` appends a set of values into a single value, separated by
|
750 | * the specified delimiter. If a delimiter is the empty string, the set of values are concatenated
|
751 | * with no delimiter.
|
752 | */
|
753 | class FnJoin {
|
754 | /**
|
755 | * Creates an ``Fn::Join`` function.
|
756 | * @param delimiter The value you want to occur between fragments. The delimiter will occur between fragments only.
|
757 | * It will not terminate the final value.
|
758 | * @param listOfValues The list of values you want combined.
|
759 | */
|
760 | constructor(delimiter, listOfValues) {
|
761 | if (listOfValues.length === 0) {
|
762 | throw new Error('FnJoin requires at least one value to be provided');
|
763 | }
|
764 | this.delimiter = delimiter;
|
765 | this.listOfValues = listOfValues;
|
766 | this.creationStack = stack_trace_1.captureStackTrace();
|
767 | }
|
768 | resolve(context) {
|
769 | if (token_1.Token.isUnresolved(this.listOfValues)) {
|
770 | // This is a list token, don't try to do smart things with it.
|
771 | return { 'Fn::Join': [this.delimiter, this.listOfValues] };
|
772 | }
|
773 | const resolved = this.resolveValues(context);
|
774 | if (resolved.length === 1) {
|
775 | return resolved[0];
|
776 | }
|
777 | return { 'Fn::Join': [this.delimiter, resolved] };
|
778 | }
|
779 | toString() {
|
780 | return token_1.Token.asString(this, { displayHint: 'Fn::Join' });
|
781 | }
|
782 | toJSON() {
|
783 | return '<Fn::Join>';
|
784 | }
|
785 | /**
|
786 | * Optimization: if an Fn::Join is nested in another one and they share the same delimiter, then flatten it up. Also,
|
787 | * if two concatenated elements are literal strings (not tokens), then pre-concatenate them with the delimiter, to
|
788 | * generate shorter output.
|
789 | */
|
790 | resolveValues(context) {
|
791 | const resolvedValues = this.listOfValues.map(x => reference_1.Reference.isReference(x) ? x : context.resolve(x));
|
792 | return cloudformation_lang_1.minimalCloudFormationJoin(this.delimiter, resolvedValues);
|
793 | }
|
794 | }
|
795 | function _inGroupsOf(array, maxGroup) {
|
796 | const result = new Array();
|
797 | for (let i = 0; i < array.length; i += maxGroup) {
|
798 | result.push(array.slice(i, i + maxGroup));
|
799 | }
|
800 | return result;
|
801 | }
|
802 | function range(n) {
|
803 | const ret = [];
|
804 | for (let i = 0; i < n; i++) {
|
805 | ret.push(i);
|
806 | }
|
807 | return ret;
|
808 | }
|
809 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cfn-fn.js","sourceRoot":"","sources":["cfn-fn.ts"],"names":[],"mappings":"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","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/resource reference defined in a ``CfnInclude`` template.\n   * @param logicalName The logical name of a parameter/resource for which you want to retrieve its value.\n   */\n  public static ref(logicalName: string): string {\n    return new FnRef(logicalName).toString();\n  }\n\n  /**\n   * The ``Fn::GetAtt`` intrinsic function returns the value of an attribute\n   * from a resource in the template.\n   * @param logicalNameOfResource The logical name (also called logical ID) of\n   * the resource that contains the attribute that you want.\n   * @param attributeName The name of the resource-specific attribute whose\n   * value you want. See the resource's reference page for details about the\n   * attributes available for that resource type.\n   * @returns an IResolvable object\n   */\n  public static getAtt(logicalNameOfResource: string, attributeName: string): IResolvable {\n    return new FnGetAtt(logicalNameOfResource, attributeName);\n  }\n\n  /**\n   * The intrinsic function ``Fn::Join`` appends a set of values into a single\n   * value, separated by the specified delimiter. If a delimiter is the empty\n   * string, the set of values are concatenated with no delimiter.\n   * @param delimiter The value you want to occur between fragments. The\n   * delimiter will occur between fragments only. It will not terminate the\n   * final value.\n   * @param listOfValues The list of values you want combined.\n   * @returns a token represented as a string\n   */\n  public static join(delimiter: string, listOfValues: string[]): string {\n    if (listOfValues.length === 0) {\n      throw new Error('FnJoin requires at least one value to be provided');\n    }\n\n    return new FnJoin(delimiter, listOfValues).toString();\n  }\n\n  /**\n   * Split a string token into a token list of string values.\n   *\n   * Specify the location of splits with a delimiter such as ',' (a comma).\n   * Renders to the `Fn::Split` intrinsic function.\n   *\n   * Lists with unknown lengths (default)\n   * -------------------------------------\n   *\n   * Since this function is used to work with deploy-time values, if `assumedLength`\n   * is not given the CDK cannot know the length of the resulting list at synthesis time.\n   * This brings the following restrictions:\n   *\n   * - You must use `Fn.select(i, list)` to pick elements out of the list (you must not use\n   *   `list[i]`).\n   * - You cannot add elements to the list, remove elements from the list,\n   *   combine two such lists together, or take a slice of the list.\n   * - You cannot pass the list to constructs that do any of the above.\n   *\n   * The only valid operation with such a tokenized list is to pass it unmodified to a\n   * CloudFormation Resource construct.\n   *\n   * Lists with assumed lengths\n   * --------------------------\n   *\n   * Pass `assumedLength` if you know the length of the list that will be\n   * produced by splitting. The actual list length at deploy time may be\n   * *longer* than the number you pass, but not *shorter*.\n   *\n   * The returned list will look like:\n   *\n   * ```\n   * [Fn.select(0, split), Fn.select(1, split), Fn.select(2, split), ...]\n   * ```\n   *\n   * The restrictions from the section \"Lists with unknown lengths\" will now be lifted,\n   * at the expense of having to know and fix the length of the list.\n   *\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   * @param assumedLength The length of the list that will be produced by splitting\n   * @returns a token represented as a string array\n   */\n  public static split(delimiter: string, source: string, assumedLength?: number): string[] {\n    // short-circut if source is not a token\n    if (!Token.isUnresolved(source)) {\n      return source.split(delimiter);\n    }\n\n    if (Token.isUnresolved(delimiter)) {\n      // Limitation of CloudFormation\n      throw new Error('Fn.split: \\'delimiter\\' may not be a token value');\n    }\n\n    const split = Token.asList(new FnSplit(delimiter, source));\n    if (assumedLength === undefined) {\n      return split;\n    }\n\n    if (Token.isUnresolved(assumedLength)) {\n      throw new Error('Fn.split: \\'assumedLength\\' may not be a token value');\n    }\n\n    return range(assumedLength).map(i => Fn.select(i, split));\n  }\n\n  /**\n   * The intrinsic function ``Fn::Select`` returns a single object from a list of objects by index.\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   * @returns a token represented as a string\n   */\n  public static select(index: number, array: string[]): string {\n    if (!Token.isUnresolved(index) && !Token.isUnresolved(array) && !array.some(Token.isUnresolved)) {\n      return array[index];\n    }\n\n    return new FnSelect(index, array).toString();\n  }\n\n  /**\n   * The intrinsic function ``Fn::Sub`` substitutes variables in an input string\n   * with values that you specify. In your templates, you can use this function\n   * to construct commands or outputs that include values that aren't available\n   * until you create or update a stack.\n   * @param body A string with variables that AWS CloudFormation substitutes\n   * with their associated values at runtime. Write variables as ${MyVarName}.\n   * Variables can be template parameter names, resource logical IDs, resource\n   * attributes, or a variable in a key-value map. If you specify only template\n   * parameter names, resource logical IDs, and resource attributes, don't\n   * specify a key-value map.\n   * @param variables The name of a variable that you included in the String\n   * parameter. The value that AWS CloudFormation substitutes for the associated\n   * variable name at runtime.\n   * @returns a token represented as a string\n   */\n  public static sub(body: string, variables?: { [key: string]: string }): string {\n    return new FnSub(body, variables).toString();\n  }\n\n  /**\n   * The intrinsic function ``Fn::Base64`` returns the Base64 representation of\n   * the input string. This function is typically used to pass encoded data to\n   * Amazon EC2 instances by way of the UserData property.\n   * @param data The string value you want to convert to Base64.\n   * @returns a token represented as a string\n   */\n  public static base64(data: string): string {\n    return new FnBase64(data).toString();\n  }\n\n  /**\n   * The intrinsic function ``Fn::Cidr`` returns the specified Cidr address block.\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   * @returns a token represented as a string\n   */\n  public static cidr(ipBlock: string, count: number, sizeMask?: string): string[] {\n    return Token.asList(new FnCidr(ipBlock, count, sizeMask));\n  }\n\n  /**\n   * Given an url, parse the domain name\n   * @param url the url to parse\n   */\n  public static parseDomainName(url: string): string {\n    const noHttps = Fn.select(1, Fn.split('//', url));\n    return Fn.select(0, Fn.split('/', noHttps));\n  }\n\n  /**\n   * The intrinsic function ``Fn::GetAZs`` returns an array that lists\n   * Availability Zones for a specified region. Because customers have access to\n   * different Availability Zones, the intrinsic function ``Fn::GetAZs`` enables\n   * template authors to write templates that adapt to the calling user's\n   * access. That way you don't have to hard-code a full list of Availability\n   * Zones for a specified region.\n   * @param region The name of the region for which you want to get the\n   * Availability Zones. You can use the AWS::Region pseudo parameter to specify\n   * the region in which the stack is created. Specifying an empty string is\n   * equivalent to specifying AWS::Region.\n   * @returns a token represented as a string array\n   */\n  public static getAzs(region?: string): string[] {\n    return Token.asList(new FnGetAZs(region));\n  }\n\n  /**\n   * The intrinsic function ``Fn::ImportValue`` returns the value of an output\n   * exported by another stack. You typically use this function to create\n   * cross-stack references. In the following example template snippets, Stack A\n   * exports VPC security group values and Stack B imports them.\n   * @param sharedValueToImport The stack output value that you want to import.\n   * @returns a token represented as a string\n   */\n  public static importValue(sharedValueToImport: string): string {\n    return new FnImportValue(sharedValueToImport).toString();\n  }\n\n  /**\n   * Like `Fn.importValue`, but import a list with a known length\n   *\n   * If you explicitly want a list with an unknown length, call `Fn.split(',',\n   * Fn.importValue(exportName))`. See the documentation of `Fn.split` to read\n   * more about the limitations of using lists of unknown length.\n   *\n   * `Fn.importListValue(exportName, assumedLength)` is the same as\n   * `Fn.split(',', Fn.importValue(exportName), assumedLength)`,\n   * but easier to read and impossible to forget to pass `assumedLength`.\n   */\n  public static importListValue(sharedValueToImport: string, assumedLength: number, delimiter = ','): string[] {\n    return Fn.split(delimiter, Fn.importValue(sharedValueToImport), assumedLength);\n  }\n\n  /**\n   * The intrinsic function ``Fn::FindInMap`` returns the value corresponding to\n   * keys in a two-level map that is declared in the Mappings section.\n   * @returns a token represented as a string\n   */\n  public static findInMap(mapName: string, topLevelKey: string, secondLevelKey: string): string {\n    return Fn._findInMap(mapName, topLevelKey, secondLevelKey).toString();\n  }\n\n  /**\n   * An additional function used in CfnParser,\n   * as Fn::FindInMap does not always return a string.\n   *\n   * @internal\n   */\n  public static _findInMap(mapName: string, topLevelKey: string, secondLevelKey: string): IResolvable {\n    return new FnFindInMap(mapName, topLevelKey, secondLevelKey);\n  }\n\n  /**\n   * Creates a token representing the ``Fn::Transform`` expression\n   * @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/intrinsic-function-reference-transform.html\n   * @param macroName The name of the macro to perform the processing\n   * @param parameters The parameters to be passed to the macro\n   * @returns a token representing the transform expression\n   */\n  public static transform(macroName: string, parameters: { [name: string]: any }): IResolvable {\n    return new FnTransform(macroName, parameters);\n  }\n\n  /**\n   * Returns true if all the specified conditions evaluate to true, or returns\n   * false if any one of the conditions evaluates to false. ``Fn::And`` acts as\n   * an AND operator. The minimum number of conditions that you can include is\n   * 1.\n   * @param conditions conditions to AND\n   * @returns an FnCondition token\n   */\n  public static conditionAnd(...conditions: ICfnConditionExpression[]): ICfnRuleConditionExpression {\n    if (conditions.length === 0) {\n      throw new Error('Fn.conditionAnd() needs at least one argument');\n    }\n    if (conditions.length === 1) {\n      return conditions[0] as ICfnRuleConditionExpression;\n    }\n    return Fn.conditionAnd(..._inGroupsOf(conditions, 10).map(group => new FnAnd(...group)));\n  }\n\n  /**\n   * Compares if two values are equal. Returns true if the two values are equal\n   * or false if they aren't.\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   * @returns an FnCondition token\n   */\n  public static conditionEquals(lhs: any, rhs: any): ICfnRuleConditionExpression {\n    return new FnEquals(lhs, rhs);\n  }\n\n  /**\n   * Returns one value if the specified condition evaluates to true and another\n   * value if the specified condition evaluates to false. Currently, AWS\n   * CloudFormation supports the ``Fn::If`` intrinsic function in the metadata\n   * attribute, update policy attribute, and property values in the Resources\n   * 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   * @param conditionId A reference to a condition in the Conditions section. Use\n   * the condition's name to reference it.\n   * @param valueIfTrue A value to be returned if the specified condition\n   * evaluates to true.\n   * @param valueIfFalse A value to be returned if the specified condition\n   * evaluates to false.\n   * @returns an FnCondition token\n   */\n  public static conditionIf(conditionId: string, valueIfTrue: any, valueIfFalse: any): ICfnRuleConditionExpression {\n    return new FnIf(conditionId, valueIfTrue, valueIfFalse);\n  }\n\n  /**\n   * Returns true for a condition that evaluates to false or returns false for a\n   * condition that evaluates to true. ``Fn::Not`` acts as a NOT operator.\n   * @param condition A condition such as ``Fn::Equals`` that evaluates to true\n   * or false.\n   * @returns an FnCondition token\n   */\n  public static conditionNot(condition: ICfnConditionExpression): ICfnRuleConditionExpression {\n    return new FnNot(condition);\n  }\n\n  /**\n   * Returns true if any one of the specified conditions evaluate to true, or\n   * returns false if all of the conditions evaluates to false. ``Fn::Or`` acts\n   * as an OR operator. The minimum number of conditions that you can include is\n   * 1.\n   * @param conditions conditions that evaluates to true or false.\n   * @returns an FnCondition token\n   */\n  public static conditionOr(...conditions: ICfnConditionExpression[]): ICfnRuleConditionExpression {\n    if (conditions.length === 0) {\n      throw new Error('Fn.conditionOr() needs at least one argument');\n    }\n    if (conditions.length === 1) {\n      return conditions[0] as ICfnRuleConditionExpression;\n    }\n    return Fn.conditionOr(..._inGroupsOf(conditions, 10).map(group => new FnOr(...group)));\n  }\n\n  /**\n   * Returns true if a specified string matches at least one value in a list of\n   * strings.\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   * @returns an FnCondition token\n   */\n  public static conditionContains(listOfStrings: string[], value: string): ICfnRuleConditionExpression {\n    return new FnContains(listOfStrings, value);\n  }\n\n  /**\n   * Returns true if a specified string matches all values in a list.\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\n   * of strings.\n   * @returns an FnCondition token\n   */\n  public static conditionEachMemberEquals(listOfStrings: string[], value: string): ICfnRuleConditionExpression {\n    return new FnEachMemberEquals(listOfStrings, value);\n  }\n\n  /**\n   * Returns true if each member in a list of strings matches at least one value\n   * in a second list of strings.\n   * @param stringsToCheck A list of strings, such as \"A\", \"B\", \"C\". AWS\n   * CloudFormation checks whether each member in the strings_to_check parameter\n   * is in the strings_to_match parameter.\n   * @param stringsToMatch A list of strings, such as \"A\", \"B\", \"C\". Each member\n   * in the strings_to_match parameter is compared against the members of the\n   * strings_to_check parameter.\n   * @returns an FnCondition token\n   */\n  public static conditionEachMemberIn(stringsToCheck: string[], stringsToMatch: string[]): ICfnRuleConditionExpression {\n    return new FnEachMemberIn(stringsToCheck, stringsToMatch);\n  }\n\n  /**\n   * Returns all values for a specified parameter type.\n   * @param parameterType An AWS-specific parameter type, such as\n   * AWS::EC2::SecurityGroup::Id or AWS::EC2::VPC::Id. For more information, see\n   * Parameters in the AWS CloudFormation User Guide.\n   * @returns a token represented as a string array\n   */\n  public static refAll(parameterType: string): string[] {\n    return Token.asList(new FnRefAll(parameterType));\n  }\n\n  /**\n   * Returns an attribute value or list of values for a specific parameter and\n   * attribute.\n   * @param parameterOrLogicalId The name of a parameter for which you want to\n   * retrieve attribute values. The parameter must be declared in the Parameters\n   * section of the template.\n   * @param attribute The name of an attribute from which you want to retrieve a\n   * value.\n   * @returns a token represented as a string\n   */\n  public static valueOf(parameterOrLogicalId: string, attribute: string): string {\n    return new FnValueOf(parameterOrLogicalId, attribute).toString();\n  }\n\n  /**\n   * Returns a list of all attribute values for a given parameter type and\n   * attribute.\n   * @param parameterType An AWS-specific parameter type, such as\n   * AWS::EC2::SecurityGroup::Id or AWS::EC2::VPC::Id. For more information, see\n   * Parameters in the AWS CloudFormation User Guide.\n   * @param attribute The name of an attribute from which you want to retrieve a\n   * value. For more information about attributes, see Supported Attributes.\n   * @returns a token represented as a string array\n   */\n  public static valueOfAll(parameterType: string, attribute: string): string[] {\n    return Token.asList(new FnValueOfAll(parameterType, attribute));\n  }\n\n  private constructor() { }\n}\n\n/**\n * Base class for tokens that represent CloudFormation intrinsic functions.\n */\nclass FnBase extends Intrinsic {\n  constructor(name: string, value: any) {\n    super({ [name]: value });\n  }\n}\n\n/**\n * The intrinsic function ``Ref`` returns the value of the specified parameter or resource.\n * When you specify a parameter's logical name, it returns the value of the parameter.\n * 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.\n */\nclass FnRef extends FnBase {\n  /**\n   * Creates an ``Ref`` function.\n   * @param logicalName The logical name of a parameter/resource for which you want to retrieve its value.\n   */\n  constructor(logicalName: string) {\n    super('Ref', logicalName);\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 */\nclass FnFindInMap extends FnBase {\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 intrinsic function ``Fn::Transform`` specifies a macro to perform custom processing on part of a stack template.\n */\nclass FnTransform extends FnBase {\n  /**\n   * creates an ``Fn::Transform`` function.\n   * @param macroName The name of the macro to be invoked\n   * @param parameters the parameters to pass to it\n   */\n  constructor(macroName: string, parameters: { [name: string]: any }) {\n    super('Fn::Transform', { Name: macroName, Parameters: parameters });\n  }\n}\n\n/**\n * The ``Fn::GetAtt`` intrinsic function returns the value of an attribute from a resource in the template.\n */\nclass FnGetAtt extends FnBase {\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 */\nclass FnGetAZs extends FnBase {\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 */\nclass FnImportValue extends FnBase {\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::Select`` returns a single object from a list of objects by index.\n */\nclass FnSelect extends FnBase {\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 */\nclass FnSplit extends FnBase {\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 */\nclass FnSub extends FnBase {\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 */\nclass FnBase64 extends FnBase {\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 */\nclass FnCidr extends FnBase {\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\nclass FnConditionBase extends Intrinsic implements ICfnRuleConditionExpression {\n  readonly disambiguator = true;\n  constructor(type: string, value: any) {\n    super({ [type]: value });\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 */\nclass FnAnd extends FnConditionBase {\n  constructor(...condition: ICfnConditionExpression[]) {\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 */\nclass FnEquals extends FnConditionBase {\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 */\nclass FnIf extends FnConditionBase {\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 */\nclass FnNot extends FnConditionBase {\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: ICfnConditionExpression) {\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 */\nclass FnOr extends FnConditionBase {\n  /**\n   * Creates an ``Fn::Or`` condition function.\n   * @param condition A condition that evaluates to true or false.\n   */\n  constructor(...condition: ICfnConditionExpression[]) {\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 */\nclass FnContains extends FnConditionBase {\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 */\nclass FnEachMemberEquals extends FnConditionBase {\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 */\nclass FnEachMemberIn extends FnConditionBase {\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: string[], stringsToMatch: string[]) {\n    super('Fn::EachMemberIn', [stringsToCheck, stringsToMatch]);\n  }\n}\n\n/**\n * Returns all values for a specified parameter type.\n */\nclass FnRefAll extends FnBase {\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 */\nclass FnValueOf extends FnBase {\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 */\nclass FnValueOfAll extends FnBase {\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\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 */\nclass FnJoin implements IResolvable {\n  public readonly creationStack: string[];\n\n  private readonly delimiter: string;\n  private readonly listOfValues: any[];\n\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\n    this.delimiter = delimiter;\n    this.listOfValues = listOfValues;\n    this.creationStack = captureStackTrace();\n  }\n\n  public resolve(context: IResolveContext): any {\n    if (Token.isUnresolved(this.listOfValues)) {\n      // This is a list token, don't try to do smart things with it.\n      return { 'Fn::Join': [this.delimiter, this.listOfValues] };\n    }\n    const resolved = this.resolveValues(context);\n    if (resolved.length === 1) {\n      return resolved[0];\n    }\n    return { 'Fn::Join': [this.delimiter, resolved] };\n  }\n\n  public toString() {\n    return Token.asString(this, { displayHint: 'Fn::Join' });\n  }\n\n  public toJSON() {\n    return '<Fn::Join>';\n  }\n\n  /**\n   * Optimization: if an Fn::Join is nested in another one and they share the same delimiter, then flatten it up. Also,\n   * if two concatenated elements are literal strings (not tokens), then pre-concatenate them with the delimiter, to\n   * generate shorter output.\n   */\n  private resolveValues(context: IResolveContext) {\n    const resolvedValues = this.listOfValues.map(x => Reference.isReference(x) ? x : context.resolve(x));\n    return minimalCloudFormationJoin(this.delimiter, resolvedValues);\n  }\n}\n\nfunction _inGroupsOf<T>(array: T[], maxGroup: number): T[][] {\n  const result = new Array<T[]>();\n  for (let i = 0; i < array.length; i += maxGroup) {\n    result.push(array.slice(i, i + maxGroup));\n  }\n  return result;\n}\n\nfunction range(n: number): number[] {\n  const ret = [];\n  for (let i = 0; i < n; i++) {\n    ret.push(i);\n  }\n  return ret;\n}"]} |
\ | No newline at end of file |