1 | ;
|
2 | var _a;
|
3 | Object.defineProperty(exports, "__esModule", { value: true });
|
4 | exports.CfnParameter = void 0;
|
5 | const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
|
6 | const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
7 | const cfn_element_1 = require("./cfn-element");
|
8 | const cfn_reference_1 = require("./private/cfn-reference");
|
9 | const token_1 = require("./token");
|
10 | /**
|
11 | * A CloudFormation parameter.
|
12 | *
|
13 | * Use the optional Parameters section to customize your templates.
|
14 | * Parameters enable you to input custom values to your template each time you create or
|
15 | * update a stack.
|
16 | */
|
17 | class CfnParameter extends cfn_element_1.CfnElement {
|
18 | /**
|
19 | * Creates a parameter construct.
|
20 | * Note that the name (logical ID) of the parameter will derive from it's `coname` and location
|
21 | * within the stack. Therefore, it is recommended that parameters are defined at the stack level.
|
22 | *
|
23 | * @param scope The parent construct.
|
24 | * @param props The parameter properties.
|
25 | */
|
26 | constructor(scope, id, props = {}) {
|
27 | super(scope, id);
|
28 | try {
|
29 | jsiiDeprecationWarnings._aws_cdk_core_CfnParameterProps(props);
|
30 | }
|
31 | catch (error) {
|
32 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
33 | Error.captureStackTrace(error, CfnParameter);
|
34 | }
|
35 | throw error;
|
36 | }
|
37 | this._type = props.type || 'String';
|
38 | this._default = props.default;
|
39 | this._allowedPattern = props.allowedPattern;
|
40 | this._allowedValues = props.allowedValues;
|
41 | this._constraintDescription = props.constraintDescription;
|
42 | this._description = props.description;
|
43 | this._maxLength = props.maxLength;
|
44 | this._maxValue = props.maxValue;
|
45 | this._minLength = props.minLength;
|
46 | this._minValue = props.minValue;
|
47 | this._noEcho = props.noEcho;
|
48 | }
|
49 | /**
|
50 | * The data type for the parameter (DataType).
|
51 | *
|
52 | * @default String
|
53 | */
|
54 | get type() {
|
55 | return this._type;
|
56 | }
|
57 | set type(type) {
|
58 | this._type = type;
|
59 | }
|
60 | /**
|
61 | * A value of the appropriate type for the template to use if no value is specified
|
62 | * when a stack is created. If you define constraints for the parameter, you must specify
|
63 | * a value that adheres to those constraints.
|
64 | *
|
65 | * @default - No default value for parameter.
|
66 | */
|
67 | get default() {
|
68 | return this._default;
|
69 | }
|
70 | set default(value) {
|
71 | this._default = value;
|
72 | }
|
73 | /**
|
74 | * A regular expression that represents the patterns to allow for String types.
|
75 | *
|
76 | * @default - No constraints on patterns allowed for parameter.
|
77 | */
|
78 | get allowedPattern() {
|
79 | return this._allowedPattern;
|
80 | }
|
81 | set allowedPattern(pattern) {
|
82 | this._allowedPattern = pattern;
|
83 | }
|
84 | /**
|
85 | * An array containing the list of values allowed for the parameter.
|
86 | *
|
87 | * @default - No constraints on values allowed for parameter.
|
88 | */
|
89 | get allowedValues() {
|
90 | return this._allowedValues;
|
91 | }
|
92 | set allowedValues(values) {
|
93 | this._allowedValues = values;
|
94 | }
|
95 | /**
|
96 | * A string that explains a constraint when the constraint is violated.
|
97 | * For example, without a constraint description, a parameter that has an allowed
|
98 | * pattern of [A-Za-z0-9]+ displays the following error message when the user specifies
|
99 | * an invalid value:
|
100 | *
|
101 | * @default - No description with customized error message when user specifies invalid values.
|
102 | */
|
103 | get constraintDescription() {
|
104 | return this._constraintDescription;
|
105 | }
|
106 | set constraintDescription(desc) {
|
107 | this._constraintDescription = desc;
|
108 | }
|
109 | /**
|
110 | * A string of up to 4000 characters that describes the parameter.
|
111 | *
|
112 | * @default - No description for the parameter.
|
113 | */
|
114 | get description() {
|
115 | return this._description;
|
116 | }
|
117 | set description(desc) {
|
118 | this._description = desc;
|
119 | }
|
120 | /**
|
121 | * An integer value that determines the largest number of characters you want to allow for String types.
|
122 | *
|
123 | * @default - None.
|
124 | */
|
125 | get maxLength() {
|
126 | return this._maxLength;
|
127 | }
|
128 | set maxLength(len) {
|
129 | this._maxLength = len;
|
130 | }
|
131 | /**
|
132 | * An integer value that determines the smallest number of characters you want to allow for String types.
|
133 | *
|
134 | * @default - None.
|
135 | */
|
136 | get minLength() {
|
137 | return this._minLength;
|
138 | }
|
139 | set minLength(len) {
|
140 | this._minLength = len;
|
141 | }
|
142 | /**
|
143 | * A numeric value that determines the largest numeric value you want to allow for Number types.
|
144 | *
|
145 | * @default - None.
|
146 | */
|
147 | get maxValue() {
|
148 | return this._maxValue;
|
149 | }
|
150 | set maxValue(len) {
|
151 | this._maxValue = len;
|
152 | }
|
153 | /**
|
154 | * A numeric value that determines the smallest numeric value you want to allow for Number types.
|
155 | *
|
156 | * @default - None.
|
157 | */
|
158 | get minValue() {
|
159 | return this._minValue;
|
160 | }
|
161 | set minValue(len) {
|
162 | this._minValue = len;
|
163 | }
|
164 | /**
|
165 | * Indicates if this parameter is configured with "NoEcho" enabled.
|
166 | */
|
167 | get noEcho() {
|
168 | return !!this._noEcho;
|
169 | }
|
170 | set noEcho(echo) {
|
171 | this._noEcho = echo;
|
172 | }
|
173 | /**
|
174 | * The parameter value as a Token
|
175 | */
|
176 | get value() {
|
177 | return cfn_reference_1.CfnReference.for(this, 'Ref');
|
178 | }
|
179 | /**
|
180 | * The parameter value, if it represents a string.
|
181 | */
|
182 | get valueAsString() {
|
183 | if (!isStringType(this.type) && !isNumberType(this.type)) {
|
184 | throw new Error(`Parameter type (${this.type}) is not a string or number type`);
|
185 | }
|
186 | return token_1.Token.asString(this.value);
|
187 | }
|
188 | /**
|
189 | * The parameter value, if it represents a string list.
|
190 | */
|
191 | get valueAsList() {
|
192 | if (!isListType(this.type)) {
|
193 | throw new Error(`Parameter type (${this.type}) is not a string list type`);
|
194 | }
|
195 | return token_1.Token.asList(this.value);
|
196 | }
|
197 | /**
|
198 | * The parameter value, if it represents a number.
|
199 | */
|
200 | get valueAsNumber() {
|
201 | if (!isNumberType(this.type)) {
|
202 | throw new Error(`Parameter type (${this.type}) is not a number type`);
|
203 | }
|
204 | return token_1.Token.asNumber(this.value);
|
205 | }
|
206 | /**
|
207 | * @internal
|
208 | */
|
209 | _toCloudFormation() {
|
210 | return {
|
211 | Parameters: {
|
212 | [this.logicalId]: {
|
213 | Type: this.type,
|
214 | Default: this.default,
|
215 | AllowedPattern: this.allowedPattern,
|
216 | AllowedValues: this.allowedValues,
|
217 | ConstraintDescription: this.constraintDescription,
|
218 | Description: this.description,
|
219 | MaxLength: this.maxLength,
|
220 | MaxValue: this.maxValue,
|
221 | MinLength: this.minLength,
|
222 | MinValue: this.minValue,
|
223 | NoEcho: this._noEcho,
|
224 | },
|
225 | },
|
226 | };
|
227 | }
|
228 | resolve(_context) {
|
229 | try {
|
230 | jsiiDeprecationWarnings._aws_cdk_core_IResolveContext(_context);
|
231 | }
|
232 | catch (error) {
|
233 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
234 | Error.captureStackTrace(error, this.resolve);
|
235 | }
|
236 | throw error;
|
237 | }
|
238 | return this.value;
|
239 | }
|
240 | }
|
241 | exports.CfnParameter = CfnParameter;
|
242 | _a = JSII_RTTI_SYMBOL_1;
|
243 | CfnParameter[_a] = { fqn: "@aws-cdk/core.CfnParameter", version: "1.204.0" };
|
244 | /**
|
245 | * Whether the given parameter type looks like a list type
|
246 | */
|
247 | function isListType(type) {
|
248 | return type.indexOf('List<') >= 0 || type.indexOf('CommaDelimitedList') >= 0;
|
249 | }
|
250 | /**
|
251 | * Whether the given parameter type looks like a number type
|
252 | */
|
253 | function isNumberType(type) {
|
254 | return type === 'Number';
|
255 | }
|
256 | /**
|
257 | * Whether the given parameter type looks like a string type
|
258 | */
|
259 | function isStringType(type) {
|
260 | return !isListType(type) && !isNumberType(type);
|
261 | }
|
262 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cfn-parameter.js","sourceRoot":"","sources":["cfn-parameter.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct } from 'constructs';\nimport { CfnElement } from './cfn-element';\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 _type: string;\n  private _default?: any;\n  private _allowedPattern?: string;\n  private _allowedValues?: string[];\n  private _constraintDescription?: string;\n  private _description?: string;\n  private _maxLength?: number;\n  private _maxValue?: number;\n  private _minLength?: number;\n  private _minValue?: number;\n  private _noEcho?: boolean;\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, props: CfnParameterProps = {}) {\n    super(scope, id);\n\n    this._type = props.type || 'String';\n    this._default = props.default;\n    this._allowedPattern = props.allowedPattern;\n    this._allowedValues = props.allowedValues;\n    this._constraintDescription = props.constraintDescription;\n    this._description = props.description;\n    this._maxLength = props.maxLength;\n    this._maxValue = props.maxValue;\n    this._minLength = props.minLength;\n    this._minValue = props.minValue;\n    this._noEcho = props.noEcho;\n  }\n\n  /**\n   * The data type for the parameter (DataType).\n   *\n   * @default String\n   */\n  public get type(): string {\n    return this._type;\n  }\n\n  public set type(type: string) {\n    this._type = type;\n  }\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  public get default(): any {\n    return this._default;\n  }\n\n  public set default(value: any) {\n    this._default = value;\n  }\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  public get allowedPattern(): string | undefined {\n    return this._allowedPattern;\n  }\n\n  public set allowedPattern(pattern: string | undefined) {\n    this._allowedPattern = pattern;\n  }\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  public get allowedValues(): string[] | undefined {\n    return this._allowedValues;\n  }\n\n  public set allowedValues(values: string[] | undefined) {\n    this._allowedValues = values;\n  }\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  public get constraintDescription(): string | undefined {\n    return this._constraintDescription;\n  }\n\n  public set constraintDescription(desc: string | undefined) {\n    this._constraintDescription = desc;\n  }\n\n  /**\n   * A string of up to 4000 characters that describes the parameter.\n   *\n   * @default - No description for the parameter.\n   */\n  public get description(): string | undefined {\n    return this._description;\n  }\n\n  public set description(desc: string | undefined) {\n    this._description = desc;\n  }\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  public get maxLength(): number | undefined {\n    return this._maxLength;\n  }\n\n  public set maxLength(len: number | undefined) {\n    this._maxLength = len;\n  }\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  public get minLength(): number | undefined {\n    return this._minLength;\n  }\n\n  public set minLength(len: number | undefined) {\n    this._minLength = len;\n  }\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  public get maxValue(): number | undefined {\n    return this._maxValue;\n  }\n\n  public set maxValue(len: number | undefined) {\n    this._maxValue = len;\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  public get minValue(): number | undefined {\n    return this._minValue;\n  }\n\n  public set minValue(len: number | undefined) {\n    this._minValue = len;\n  }\n\n  /**\n   * Indicates if this parameter is configured with \"NoEcho\" enabled.\n   */\n  public get noEcho(): boolean {\n    return !!this._noEcho;\n  }\n\n  public set noEcho(echo: boolean) {\n    this._noEcho = echo;\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) && !isNumberType(this.type)) {\n      throw new Error(`Parameter type (${this.type}) is not a string or number 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.default,\n          AllowedPattern: this.allowedPattern,\n          AllowedValues: this.allowedValues,\n          ConstraintDescription: this.constraintDescription,\n          Description: this.description,\n          MaxLength: this.maxLength,\n          MaxValue: this.maxValue,\n          MinLength: this.minLength,\n          MinValue: this.minValue,\n          NoEcho: this._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"]} |
\ | No newline at end of file |