@aws-cdk/core
Version:
AWS Cloud Development Kit Core Library
111 lines • 14.5 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const cfn_element_1 = require("./cfn-element");
const cfn_reference_1 = require("./private/cfn-reference");
const token_1 = require("./token");
/**
* A CloudFormation parameter.
*
* Use the optional Parameters section to customize your templates.
* Parameters enable you to input custom values to your template each time you create or
* update a stack.
*/
class CfnParameter extends cfn_element_1.CfnElement {
/**
* Creates a parameter construct.
* Note that the name (logical ID) of the parameter will derive from it's `coname` and location
* within the stack. Therefore, it is recommended that parameters are defined at the stack level.
*
* @param scope The parent construct.
* @param props The parameter properties.
*/
constructor(scope, id, props = {}) {
super(scope, id);
this.props = props;
this.type = props.type || 'String';
}
/**
* Indicates if this parameter is configured with "NoEcho" enabled.
*/
get noEcho() {
return !!this.props.noEcho;
}
/**
* The parameter value as a Token
*/
get value() {
return cfn_reference_1.CfnReference.for(this, 'Ref');
}
/**
* The parameter value, if it represents a string.
*/
get valueAsString() {
if (!isStringType(this.type)) {
throw new Error(`Parameter type (${this.type}) is not a string type`);
}
return token_1.Token.asString(this.value);
}
/**
* The parameter value, if it represents a string list.
*/
get valueAsList() {
if (!isListType(this.type)) {
throw new Error(`Parameter type (${this.type}) is not a string list type`);
}
return token_1.Token.asList(this.value);
}
/**
* The parameter value, if it represents a number.
*/
get valueAsNumber() {
if (!isNumberType(this.type)) {
throw new Error(`Parameter type (${this.type}) is not a number type`);
}
return token_1.Token.asNumber(this.value);
}
/**
* @internal
*/
_toCloudFormation() {
return {
Parameters: {
[this.logicalId]: {
Type: this.type,
Default: this.props.default,
AllowedPattern: this.props.allowedPattern,
AllowedValues: this.props.allowedValues,
ConstraintDescription: this.props.constraintDescription,
Description: this.props.description,
MaxLength: this.props.maxLength,
MaxValue: this.props.maxValue,
MinLength: this.props.minLength,
MinValue: this.props.minValue,
NoEcho: this.props.noEcho
}
}
};
}
resolve(_context) {
return this.value;
}
}
exports.CfnParameter = CfnParameter;
/**
* Whether the given parameter type looks like a list type
*/
function isListType(type) {
return type.indexOf('List<') >= 0 || type.indexOf('CommaDelimitedList') >= 0;
}
/**
* Whether the given parameter type looks like a number type
*/
function isNumberType(type) {
return type === 'Number';
}
/**
* Whether the given parameter type looks like a string type
*/
function isStringType(type) {
return !isListType(type) && !isNumberType(type);
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cfn-parameter.js","sourceRoot":"","sources":["cfn-parameter.ts"],"names":[],"mappings":"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","sourcesContent":["import { CfnElement } from './cfn-element';\nimport { Construct } from './construct-compat';\nimport { CfnReference } from './private/cfn-reference';\nimport { IResolvable, IResolveContext } from './resolvable';\nimport { Token } from './token';\n\nexport interface CfnParameterProps {\n  /**\n   * The data type for the parameter (DataType).\n   *\n   * @default String\n   */\n  readonly type?: string;\n\n  /**\n   * A value of the appropriate type for the template to use if no value is specified\n   * when a stack is created. If you define constraints for the parameter, you must specify\n   * a value that adheres to those constraints.\n   *\n   * @default - No default value for parameter.\n   */\n  readonly default?: any;\n\n  /**\n   * A regular expression that represents the patterns to allow for String types.\n   *\n   * @default - No constraints on patterns allowed for parameter.\n   */\n  readonly allowedPattern?: string;\n\n  /**\n   * An array containing the list of values allowed for the parameter.\n   *\n   * @default - No constraints on values allowed for parameter.\n   */\n  readonly allowedValues?: string[];\n\n  /**\n   * A string that explains a constraint when the constraint is violated.\n   * For example, without a constraint description, a parameter that has an allowed\n   * pattern of [A-Za-z0-9]+ displays the following error message when the user specifies\n   * an invalid value:\n   *\n   * @default - No description with customized error message when user specifies invalid values.\n   */\n  readonly constraintDescription?: string;\n\n  /**\n   * A string of up to 4000 characters that describes the parameter.\n   *\n   * @default - No description for the parameter.\n   */\n  readonly description?: string;\n\n  /**\n   * An integer value that determines the largest number of characters you want to allow for String types.\n   *\n   * @default - None.\n   */\n  readonly maxLength?: number;\n\n  /**\n   * A numeric value that determines the largest numeric value you want to allow for Number types.\n   *\n   * @default - None.\n   */\n  readonly maxValue?: number;\n\n  /**\n   * An integer value that determines the smallest number of characters you want to allow for String types.\n   *\n   * @default - None.\n   */\n  readonly minLength?: number;\n\n  /**\n   * A numeric value that determines the smallest numeric value you want to allow for Number types.\n   *\n   * @default - None.\n   */\n  readonly minValue?: number;\n\n  /**\n   * Whether to mask the parameter value when anyone makes a call that describes the stack.\n   * If you set the value to ``true``, the parameter value is masked with asterisks (``*****``).\n   *\n   * @default - Parameter values are not masked.\n   */\n  readonly noEcho?: boolean;\n}\n\n/**\n * A CloudFormation parameter.\n *\n * Use the optional Parameters section to customize your templates.\n * Parameters enable you to input custom values to your template each time you create or\n * update a stack.\n */\nexport class CfnParameter extends CfnElement {\n  private readonly type: string;\n\n  /**\n   * Creates a parameter construct.\n   * Note that the name (logical ID) of the parameter will derive from it's `coname` and location\n   * within the stack. Therefore, it is recommended that parameters are defined at the stack level.\n   *\n   * @param scope The parent construct.\n   * @param props The parameter properties.\n   */\n  constructor(scope: Construct, id: string, private readonly props: CfnParameterProps = {}) {\n    super(scope, id);\n\n    this.type = props.type || 'String';\n  }\n\n  /**\n   * Indicates if this parameter is configured with \"NoEcho\" enabled.\n   */\n  public get noEcho(): boolean {\n    return !!this.props.noEcho;\n  }\n\n  /**\n   * The parameter value as a Token\n   */\n  public get value(): IResolvable {\n    return CfnReference.for(this, 'Ref');\n  }\n\n  /**\n   * The parameter value, if it represents a string.\n   */\n  public get valueAsString(): string {\n    if (!isStringType(this.type)) {\n      throw new Error(`Parameter type (${this.type}) is not a string type`);\n    }\n    return Token.asString(this.value);\n  }\n\n  /**\n   * The parameter value, if it represents a string list.\n   */\n  public get valueAsList(): string[] {\n    if (!isListType(this.type)) {\n      throw new Error(`Parameter type (${this.type}) is not a string list type`);\n    }\n    return Token.asList(this.value);\n  }\n\n  /**\n   * The parameter value, if it represents a number.\n   */\n  public get valueAsNumber(): number {\n    if (!isNumberType(this.type)) {\n      throw new Error(`Parameter type (${this.type}) is not a number type`);\n    }\n    return Token.asNumber(this.value);\n  }\n\n  /**\n   * @internal\n   */\n  public _toCloudFormation(): object {\n    return {\n      Parameters: {\n        [this.logicalId]: {\n          Type: this.type,\n          Default: this.props.default,\n          AllowedPattern: this.props.allowedPattern,\n          AllowedValues: this.props.allowedValues,\n          ConstraintDescription: this.props.constraintDescription,\n          Description: this.props.description,\n          MaxLength: this.props.maxLength,\n          MaxValue: this.props.maxValue,\n          MinLength: this.props.minLength,\n          MinValue: this.props.minValue,\n          NoEcho: this.props.noEcho\n        }\n      }\n    };\n  }\n\n  public resolve(_context: IResolveContext): any {\n    return this.value;\n  }\n}\n\n/**\n * Whether the given parameter type looks like a list type\n */\nfunction isListType(type: string) {\n  return type.indexOf('List<') >= 0 || type.indexOf('CommaDelimitedList') >= 0;\n}\n\n/**\n * Whether the given parameter type looks like a number type\n */\nfunction isNumberType(type: string) {\n  return type === 'Number';\n}\n\n/**\n * Whether the given parameter type looks like a string type\n */\nfunction isStringType(type: string) {\n  return !isListType(type) && !isNumberType(type);\n}\n"]}