UNPKG

583 kBJavaScriptView Raw
1"use strict";
2var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r;
3Object.defineProperty(exports, "__esModule", { value: true });
4exports.CfnWaitConditionHandle = exports.CfnWaitCondition = exports.CfnTypeActivation = exports.CfnStackSet = exports.CfnStack = exports.CfnResourceVersion = exports.CfnResourceDefaultVersion = exports.CfnPublisher = exports.CfnPublicTypeVersion = exports.CfnModuleVersion = exports.CfnModuleDefaultVersion = exports.CfnMacro = exports.CfnHookVersion = exports.CfnHookTypeConfig = exports.CfnHookDefaultVersion = exports.CfnCustomResource = void 0;
5const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
6const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
7// Copyright 2012-2022 Amazon.com, Inc. or its affiliates. All Rights Reserved.
8// Generated from the AWS CloudFormation Resource Specification
9// See: docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/cfn-resource-specification.html
10// @cfn2ts:meta@ {"generated":"2022-05-13T00:24:44.574Z","fingerprint":"schANqcaMLRpaxmk9lx2rbv78Epyd5CHho0EXijYaDM="}
11/* eslint-disable max-len */ // This is generated code - line lengths are difficult to control
12const cdk = require(".");
13const cfn_parse = require("./helpers-internal");
14/**
15 * Determine whether the given properties match those of a `CfnCustomResourceProps`
16 *
17 * @param properties - the TypeScript properties of a `CfnCustomResourceProps`
18 *
19 * @returns the result of the validation.
20 */
21function CfnCustomResourcePropsValidator(properties) {
22 if (!cdk.canInspect(properties)) {
23 return cdk.VALIDATION_SUCCESS;
24 }
25 const errors = new cdk.ValidationResults();
26 if (typeof properties !== 'object') {
27 errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));
28 }
29 errors.collect(cdk.propertyValidator('serviceToken', cdk.requiredValidator)(properties.serviceToken));
30 errors.collect(cdk.propertyValidator('serviceToken', cdk.validateString)(properties.serviceToken));
31 return errors.wrap('supplied properties not correct for "CfnCustomResourceProps"');
32}
33/**
34 * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::CustomResource` resource
35 *
36 * @param properties - the TypeScript properties of a `CfnCustomResourceProps`
37 *
38 * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::CustomResource` resource.
39 */
40// @ts-ignore TS6133
41function cfnCustomResourcePropsToCloudFormation(properties) {
42 if (!cdk.canInspect(properties)) {
43 return properties;
44 }
45 CfnCustomResourcePropsValidator(properties).assertSuccess();
46 return {
47 ServiceToken: cdk.stringToCloudFormation(properties.serviceToken),
48 };
49}
50// @ts-ignore TS6133
51function CfnCustomResourcePropsFromCloudFormation(properties) {
52 properties = properties == null ? {} : properties;
53 if (typeof properties !== 'object') {
54 return new cfn_parse.FromCloudFormationResult(properties);
55 }
56 const ret = new cfn_parse.FromCloudFormationPropertyObject();
57 ret.addPropertyResult('serviceToken', 'ServiceToken', cfn_parse.FromCloudFormation.getString(properties.ServiceToken));
58 ret.addUnrecognizedPropertiesAsExtra(properties);
59 return ret;
60}
61/**
62 * A CloudFormation `AWS::CloudFormation::CustomResource`
63 *
64 * In a CloudFormation template, you use the `AWS::CloudFormation::CustomResource` or `Custom:: *String*` resource type to specify custom resources.
65 *
66 * Custom resources provide a way for you to write custom provisioning logic in CloudFormation template and have CloudFormation run it during a stack operation, such as when you create, update or delete a stack. For more information, see [Custom resources](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/template-custom-resources.html) .
67 *
68 * > If you use the [VPC endpoints](https://docs.aws.amazon.com/vpc/latest/userguide/vpc-endpoints.html) feature, custom resources in the VPC must have access to CloudFormation -specific Amazon Simple Storage Service ( Amazon S3 ) buckets. Custom resources must send responses to a presigned Amazon S3 URL. If they can't send responses to Amazon S3 , CloudFormation won't receive a response and the stack operation fails. For more information, see [Setting up VPC endpoints for AWS CloudFormation](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/cfn-vpce-bucketnames.html) .
69 *
70 * @cloudformationResource AWS::CloudFormation::CustomResource
71 * @stability external
72 *
73 * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cfn-customresource.html
74 */
75class CfnCustomResource extends cdk.CfnResource {
76 /**
77 * Create a new `AWS::CloudFormation::CustomResource`.
78 *
79 * @param scope - scope in which this resource is defined
80 * @param id - scoped id of the resource
81 * @param props - resource properties
82 */
83 constructor(scope, id, props) {
84 super(scope, id, { type: CfnCustomResource.CFN_RESOURCE_TYPE_NAME, properties: props });
85 try {
86 jsiiDeprecationWarnings._aws_cdk_core_Construct(scope);
87 jsiiDeprecationWarnings._aws_cdk_core_CfnCustomResourceProps(props);
88 }
89 catch (error) {
90 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
91 Error.captureStackTrace(error, this.constructor);
92 }
93 throw error;
94 }
95 cdk.requireProperty(props, 'serviceToken', this);
96 this.serviceToken = props.serviceToken;
97 }
98 /**
99 * A factory method that creates a new instance of this class from an object
100 * containing the CloudFormation properties of this resource.
101 * Used in the @aws-cdk/cloudformation-include module.
102 *
103 * @internal
104 */
105 static _fromCloudFormation(scope, id, resourceAttributes, options) {
106 resourceAttributes = resourceAttributes || {};
107 const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);
108 const propsResult = CfnCustomResourcePropsFromCloudFormation(resourceProperties);
109 const ret = new CfnCustomResource(scope, id, propsResult.value);
110 for (const [propKey, propVal] of Object.entries(propsResult.extraProperties)) {
111 ret.addPropertyOverride(propKey, propVal);
112 }
113 options.parser.handleAttributes(ret, resourceAttributes, id);
114 return ret;
115 }
116 /**
117 * Examines the CloudFormation resource and discloses attributes.
118 *
119 * @param inspector - tree inspector to collect and process attributes
120 *
121 */
122 inspect(inspector) {
123 try {
124 jsiiDeprecationWarnings._aws_cdk_core_TreeInspector(inspector);
125 }
126 catch (error) {
127 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
128 Error.captureStackTrace(error, this.inspect);
129 }
130 throw error;
131 }
132 inspector.addAttribute("aws:cdk:cloudformation:type", CfnCustomResource.CFN_RESOURCE_TYPE_NAME);
133 inspector.addAttribute("aws:cdk:cloudformation:props", this.cfnProperties);
134 }
135 get cfnProperties() {
136 return {
137 serviceToken: this.serviceToken,
138 };
139 }
140 renderProperties(props) {
141 return cfnCustomResourcePropsToCloudFormation(props);
142 }
143}
144exports.CfnCustomResource = CfnCustomResource;
145_a = JSII_RTTI_SYMBOL_1;
146CfnCustomResource[_a] = { fqn: "@aws-cdk/core.CfnCustomResource", version: "1.156.1" };
147/**
148 * The CloudFormation resource type name for this resource class.
149 */
150CfnCustomResource.CFN_RESOURCE_TYPE_NAME = "AWS::CloudFormation::CustomResource";
151/**
152 * Determine whether the given properties match those of a `CfnHookDefaultVersionProps`
153 *
154 * @param properties - the TypeScript properties of a `CfnHookDefaultVersionProps`
155 *
156 * @returns the result of the validation.
157 */
158function CfnHookDefaultVersionPropsValidator(properties) {
159 if (!cdk.canInspect(properties)) {
160 return cdk.VALIDATION_SUCCESS;
161 }
162 const errors = new cdk.ValidationResults();
163 if (typeof properties !== 'object') {
164 errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));
165 }
166 errors.collect(cdk.propertyValidator('typeName', cdk.validateString)(properties.typeName));
167 errors.collect(cdk.propertyValidator('typeVersionArn', cdk.validateString)(properties.typeVersionArn));
168 errors.collect(cdk.propertyValidator('versionId', cdk.validateString)(properties.versionId));
169 return errors.wrap('supplied properties not correct for "CfnHookDefaultVersionProps"');
170}
171/**
172 * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::HookDefaultVersion` resource
173 *
174 * @param properties - the TypeScript properties of a `CfnHookDefaultVersionProps`
175 *
176 * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::HookDefaultVersion` resource.
177 */
178// @ts-ignore TS6133
179function cfnHookDefaultVersionPropsToCloudFormation(properties) {
180 if (!cdk.canInspect(properties)) {
181 return properties;
182 }
183 CfnHookDefaultVersionPropsValidator(properties).assertSuccess();
184 return {
185 TypeName: cdk.stringToCloudFormation(properties.typeName),
186 TypeVersionArn: cdk.stringToCloudFormation(properties.typeVersionArn),
187 VersionId: cdk.stringToCloudFormation(properties.versionId),
188 };
189}
190// @ts-ignore TS6133
191function CfnHookDefaultVersionPropsFromCloudFormation(properties) {
192 properties = properties == null ? {} : properties;
193 if (typeof properties !== 'object') {
194 return new cfn_parse.FromCloudFormationResult(properties);
195 }
196 const ret = new cfn_parse.FromCloudFormationPropertyObject();
197 ret.addPropertyResult('typeName', 'TypeName', properties.TypeName != null ? cfn_parse.FromCloudFormation.getString(properties.TypeName) : undefined);
198 ret.addPropertyResult('typeVersionArn', 'TypeVersionArn', properties.TypeVersionArn != null ? cfn_parse.FromCloudFormation.getString(properties.TypeVersionArn) : undefined);
199 ret.addPropertyResult('versionId', 'VersionId', properties.VersionId != null ? cfn_parse.FromCloudFormation.getString(properties.VersionId) : undefined);
200 ret.addUnrecognizedPropertiesAsExtra(properties);
201 return ret;
202}
203/**
204 * A CloudFormation `AWS::CloudFormation::HookDefaultVersion`
205 *
206 * The `HookDefaultVersion` resource specifies the default version of the hook. The default version of the hook is used in CloudFormation operations for this AWS account and AWS Region .
207 *
208 * @cloudformationResource AWS::CloudFormation::HookDefaultVersion
209 * @stability external
210 *
211 * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hookdefaultversion.html
212 */
213class CfnHookDefaultVersion extends cdk.CfnResource {
214 /**
215 * Create a new `AWS::CloudFormation::HookDefaultVersion`.
216 *
217 * @param scope - scope in which this resource is defined
218 * @param id - scoped id of the resource
219 * @param props - resource properties
220 */
221 constructor(scope, id, props = {}) {
222 super(scope, id, { type: CfnHookDefaultVersion.CFN_RESOURCE_TYPE_NAME, properties: props });
223 try {
224 jsiiDeprecationWarnings._aws_cdk_core_Construct(scope);
225 jsiiDeprecationWarnings._aws_cdk_core_CfnHookDefaultVersionProps(props);
226 }
227 catch (error) {
228 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
229 Error.captureStackTrace(error, this.constructor);
230 }
231 throw error;
232 }
233 this.attrArn = cdk.Token.asString(this.getAtt('Arn'));
234 this.typeName = props.typeName;
235 this.typeVersionArn = props.typeVersionArn;
236 this.versionId = props.versionId;
237 }
238 /**
239 * A factory method that creates a new instance of this class from an object
240 * containing the CloudFormation properties of this resource.
241 * Used in the @aws-cdk/cloudformation-include module.
242 *
243 * @internal
244 */
245 static _fromCloudFormation(scope, id, resourceAttributes, options) {
246 resourceAttributes = resourceAttributes || {};
247 const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);
248 const propsResult = CfnHookDefaultVersionPropsFromCloudFormation(resourceProperties);
249 const ret = new CfnHookDefaultVersion(scope, id, propsResult.value);
250 for (const [propKey, propVal] of Object.entries(propsResult.extraProperties)) {
251 ret.addPropertyOverride(propKey, propVal);
252 }
253 options.parser.handleAttributes(ret, resourceAttributes, id);
254 return ret;
255 }
256 /**
257 * Examines the CloudFormation resource and discloses attributes.
258 *
259 * @param inspector - tree inspector to collect and process attributes
260 *
261 */
262 inspect(inspector) {
263 try {
264 jsiiDeprecationWarnings._aws_cdk_core_TreeInspector(inspector);
265 }
266 catch (error) {
267 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
268 Error.captureStackTrace(error, this.inspect);
269 }
270 throw error;
271 }
272 inspector.addAttribute("aws:cdk:cloudformation:type", CfnHookDefaultVersion.CFN_RESOURCE_TYPE_NAME);
273 inspector.addAttribute("aws:cdk:cloudformation:props", this.cfnProperties);
274 }
275 get cfnProperties() {
276 return {
277 typeName: this.typeName,
278 typeVersionArn: this.typeVersionArn,
279 versionId: this.versionId,
280 };
281 }
282 renderProperties(props) {
283 return cfnHookDefaultVersionPropsToCloudFormation(props);
284 }
285}
286exports.CfnHookDefaultVersion = CfnHookDefaultVersion;
287_b = JSII_RTTI_SYMBOL_1;
288CfnHookDefaultVersion[_b] = { fqn: "@aws-cdk/core.CfnHookDefaultVersion", version: "1.156.1" };
289/**
290 * The CloudFormation resource type name for this resource class.
291 */
292CfnHookDefaultVersion.CFN_RESOURCE_TYPE_NAME = "AWS::CloudFormation::HookDefaultVersion";
293/**
294 * Determine whether the given properties match those of a `CfnHookTypeConfigProps`
295 *
296 * @param properties - the TypeScript properties of a `CfnHookTypeConfigProps`
297 *
298 * @returns the result of the validation.
299 */
300function CfnHookTypeConfigPropsValidator(properties) {
301 if (!cdk.canInspect(properties)) {
302 return cdk.VALIDATION_SUCCESS;
303 }
304 const errors = new cdk.ValidationResults();
305 if (typeof properties !== 'object') {
306 errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));
307 }
308 errors.collect(cdk.propertyValidator('configuration', cdk.requiredValidator)(properties.configuration));
309 errors.collect(cdk.propertyValidator('configuration', cdk.validateString)(properties.configuration));
310 errors.collect(cdk.propertyValidator('configurationAlias', cdk.validateString)(properties.configurationAlias));
311 errors.collect(cdk.propertyValidator('typeArn', cdk.validateString)(properties.typeArn));
312 errors.collect(cdk.propertyValidator('typeName', cdk.validateString)(properties.typeName));
313 return errors.wrap('supplied properties not correct for "CfnHookTypeConfigProps"');
314}
315/**
316 * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::HookTypeConfig` resource
317 *
318 * @param properties - the TypeScript properties of a `CfnHookTypeConfigProps`
319 *
320 * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::HookTypeConfig` resource.
321 */
322// @ts-ignore TS6133
323function cfnHookTypeConfigPropsToCloudFormation(properties) {
324 if (!cdk.canInspect(properties)) {
325 return properties;
326 }
327 CfnHookTypeConfigPropsValidator(properties).assertSuccess();
328 return {
329 Configuration: cdk.stringToCloudFormation(properties.configuration),
330 ConfigurationAlias: cdk.stringToCloudFormation(properties.configurationAlias),
331 TypeArn: cdk.stringToCloudFormation(properties.typeArn),
332 TypeName: cdk.stringToCloudFormation(properties.typeName),
333 };
334}
335// @ts-ignore TS6133
336function CfnHookTypeConfigPropsFromCloudFormation(properties) {
337 properties = properties == null ? {} : properties;
338 if (typeof properties !== 'object') {
339 return new cfn_parse.FromCloudFormationResult(properties);
340 }
341 const ret = new cfn_parse.FromCloudFormationPropertyObject();
342 ret.addPropertyResult('configuration', 'Configuration', cfn_parse.FromCloudFormation.getString(properties.Configuration));
343 ret.addPropertyResult('configurationAlias', 'ConfigurationAlias', properties.ConfigurationAlias != null ? cfn_parse.FromCloudFormation.getString(properties.ConfigurationAlias) : undefined);
344 ret.addPropertyResult('typeArn', 'TypeArn', properties.TypeArn != null ? cfn_parse.FromCloudFormation.getString(properties.TypeArn) : undefined);
345 ret.addPropertyResult('typeName', 'TypeName', properties.TypeName != null ? cfn_parse.FromCloudFormation.getString(properties.TypeName) : undefined);
346 ret.addUnrecognizedPropertiesAsExtra(properties);
347 return ret;
348}
349/**
350 * A CloudFormation `AWS::CloudFormation::HookTypeConfig`
351 *
352 * The `HookTypeConfig` resource specifies the configuration of a hook.
353 *
354 * @cloudformationResource AWS::CloudFormation::HookTypeConfig
355 * @stability external
356 *
357 * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hooktypeconfig.html
358 */
359class CfnHookTypeConfig extends cdk.CfnResource {
360 /**
361 * Create a new `AWS::CloudFormation::HookTypeConfig`.
362 *
363 * @param scope - scope in which this resource is defined
364 * @param id - scoped id of the resource
365 * @param props - resource properties
366 */
367 constructor(scope, id, props) {
368 super(scope, id, { type: CfnHookTypeConfig.CFN_RESOURCE_TYPE_NAME, properties: props });
369 try {
370 jsiiDeprecationWarnings._aws_cdk_core_Construct(scope);
371 jsiiDeprecationWarnings._aws_cdk_core_CfnHookTypeConfigProps(props);
372 }
373 catch (error) {
374 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
375 Error.captureStackTrace(error, this.constructor);
376 }
377 throw error;
378 }
379 cdk.requireProperty(props, 'configuration', this);
380 this.attrConfigurationArn = cdk.Token.asString(this.getAtt('ConfigurationArn'));
381 this.configuration = props.configuration;
382 this.configurationAlias = props.configurationAlias;
383 this.typeArn = props.typeArn;
384 this.typeName = props.typeName;
385 }
386 /**
387 * A factory method that creates a new instance of this class from an object
388 * containing the CloudFormation properties of this resource.
389 * Used in the @aws-cdk/cloudformation-include module.
390 *
391 * @internal
392 */
393 static _fromCloudFormation(scope, id, resourceAttributes, options) {
394 resourceAttributes = resourceAttributes || {};
395 const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);
396 const propsResult = CfnHookTypeConfigPropsFromCloudFormation(resourceProperties);
397 const ret = new CfnHookTypeConfig(scope, id, propsResult.value);
398 for (const [propKey, propVal] of Object.entries(propsResult.extraProperties)) {
399 ret.addPropertyOverride(propKey, propVal);
400 }
401 options.parser.handleAttributes(ret, resourceAttributes, id);
402 return ret;
403 }
404 /**
405 * Examines the CloudFormation resource and discloses attributes.
406 *
407 * @param inspector - tree inspector to collect and process attributes
408 *
409 */
410 inspect(inspector) {
411 try {
412 jsiiDeprecationWarnings._aws_cdk_core_TreeInspector(inspector);
413 }
414 catch (error) {
415 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
416 Error.captureStackTrace(error, this.inspect);
417 }
418 throw error;
419 }
420 inspector.addAttribute("aws:cdk:cloudformation:type", CfnHookTypeConfig.CFN_RESOURCE_TYPE_NAME);
421 inspector.addAttribute("aws:cdk:cloudformation:props", this.cfnProperties);
422 }
423 get cfnProperties() {
424 return {
425 configuration: this.configuration,
426 configurationAlias: this.configurationAlias,
427 typeArn: this.typeArn,
428 typeName: this.typeName,
429 };
430 }
431 renderProperties(props) {
432 return cfnHookTypeConfigPropsToCloudFormation(props);
433 }
434}
435exports.CfnHookTypeConfig = CfnHookTypeConfig;
436_c = JSII_RTTI_SYMBOL_1;
437CfnHookTypeConfig[_c] = { fqn: "@aws-cdk/core.CfnHookTypeConfig", version: "1.156.1" };
438/**
439 * The CloudFormation resource type name for this resource class.
440 */
441CfnHookTypeConfig.CFN_RESOURCE_TYPE_NAME = "AWS::CloudFormation::HookTypeConfig";
442/**
443 * Determine whether the given properties match those of a `CfnHookVersionProps`
444 *
445 * @param properties - the TypeScript properties of a `CfnHookVersionProps`
446 *
447 * @returns the result of the validation.
448 */
449function CfnHookVersionPropsValidator(properties) {
450 if (!cdk.canInspect(properties)) {
451 return cdk.VALIDATION_SUCCESS;
452 }
453 const errors = new cdk.ValidationResults();
454 if (typeof properties !== 'object') {
455 errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));
456 }
457 errors.collect(cdk.propertyValidator('executionRoleArn', cdk.validateString)(properties.executionRoleArn));
458 errors.collect(cdk.propertyValidator('loggingConfig', CfnHookVersion_LoggingConfigPropertyValidator)(properties.loggingConfig));
459 errors.collect(cdk.propertyValidator('schemaHandlerPackage', cdk.requiredValidator)(properties.schemaHandlerPackage));
460 errors.collect(cdk.propertyValidator('schemaHandlerPackage', cdk.validateString)(properties.schemaHandlerPackage));
461 errors.collect(cdk.propertyValidator('typeName', cdk.requiredValidator)(properties.typeName));
462 errors.collect(cdk.propertyValidator('typeName', cdk.validateString)(properties.typeName));
463 return errors.wrap('supplied properties not correct for "CfnHookVersionProps"');
464}
465/**
466 * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::HookVersion` resource
467 *
468 * @param properties - the TypeScript properties of a `CfnHookVersionProps`
469 *
470 * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::HookVersion` resource.
471 */
472// @ts-ignore TS6133
473function cfnHookVersionPropsToCloudFormation(properties) {
474 if (!cdk.canInspect(properties)) {
475 return properties;
476 }
477 CfnHookVersionPropsValidator(properties).assertSuccess();
478 return {
479 SchemaHandlerPackage: cdk.stringToCloudFormation(properties.schemaHandlerPackage),
480 TypeName: cdk.stringToCloudFormation(properties.typeName),
481 ExecutionRoleArn: cdk.stringToCloudFormation(properties.executionRoleArn),
482 LoggingConfig: cfnHookVersionLoggingConfigPropertyToCloudFormation(properties.loggingConfig),
483 };
484}
485// @ts-ignore TS6133
486function CfnHookVersionPropsFromCloudFormation(properties) {
487 properties = properties == null ? {} : properties;
488 if (typeof properties !== 'object') {
489 return new cfn_parse.FromCloudFormationResult(properties);
490 }
491 const ret = new cfn_parse.FromCloudFormationPropertyObject();
492 ret.addPropertyResult('schemaHandlerPackage', 'SchemaHandlerPackage', cfn_parse.FromCloudFormation.getString(properties.SchemaHandlerPackage));
493 ret.addPropertyResult('typeName', 'TypeName', cfn_parse.FromCloudFormation.getString(properties.TypeName));
494 ret.addPropertyResult('executionRoleArn', 'ExecutionRoleArn', properties.ExecutionRoleArn != null ? cfn_parse.FromCloudFormation.getString(properties.ExecutionRoleArn) : undefined);
495 ret.addPropertyResult('loggingConfig', 'LoggingConfig', properties.LoggingConfig != null ? CfnHookVersionLoggingConfigPropertyFromCloudFormation(properties.LoggingConfig) : undefined);
496 ret.addUnrecognizedPropertiesAsExtra(properties);
497 return ret;
498}
499/**
500 * A CloudFormation `AWS::CloudFormation::HookVersion`
501 *
502 * The `HookVersion` resource publishes new or first hook version to the AWS CloudFormation registry.
503 *
504 * @cloudformationResource AWS::CloudFormation::HookVersion
505 * @stability external
506 *
507 * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hookversion.html
508 */
509class CfnHookVersion extends cdk.CfnResource {
510 /**
511 * Create a new `AWS::CloudFormation::HookVersion`.
512 *
513 * @param scope - scope in which this resource is defined
514 * @param id - scoped id of the resource
515 * @param props - resource properties
516 */
517 constructor(scope, id, props) {
518 super(scope, id, { type: CfnHookVersion.CFN_RESOURCE_TYPE_NAME, properties: props });
519 try {
520 jsiiDeprecationWarnings._aws_cdk_core_Construct(scope);
521 jsiiDeprecationWarnings._aws_cdk_core_CfnHookVersionProps(props);
522 }
523 catch (error) {
524 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
525 Error.captureStackTrace(error, this.constructor);
526 }
527 throw error;
528 }
529 cdk.requireProperty(props, 'schemaHandlerPackage', this);
530 cdk.requireProperty(props, 'typeName', this);
531 this.attrArn = cdk.Token.asString(this.getAtt('Arn'));
532 this.attrIsDefaultVersion = this.getAtt('IsDefaultVersion');
533 this.attrTypeArn = cdk.Token.asString(this.getAtt('TypeArn'));
534 this.attrVersionId = cdk.Token.asString(this.getAtt('VersionId'));
535 this.attrVisibility = cdk.Token.asString(this.getAtt('Visibility'));
536 this.schemaHandlerPackage = props.schemaHandlerPackage;
537 this.typeName = props.typeName;
538 this.executionRoleArn = props.executionRoleArn;
539 this.loggingConfig = props.loggingConfig;
540 }
541 /**
542 * A factory method that creates a new instance of this class from an object
543 * containing the CloudFormation properties of this resource.
544 * Used in the @aws-cdk/cloudformation-include module.
545 *
546 * @internal
547 */
548 static _fromCloudFormation(scope, id, resourceAttributes, options) {
549 resourceAttributes = resourceAttributes || {};
550 const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);
551 const propsResult = CfnHookVersionPropsFromCloudFormation(resourceProperties);
552 const ret = new CfnHookVersion(scope, id, propsResult.value);
553 for (const [propKey, propVal] of Object.entries(propsResult.extraProperties)) {
554 ret.addPropertyOverride(propKey, propVal);
555 }
556 options.parser.handleAttributes(ret, resourceAttributes, id);
557 return ret;
558 }
559 /**
560 * Examines the CloudFormation resource and discloses attributes.
561 *
562 * @param inspector - tree inspector to collect and process attributes
563 *
564 */
565 inspect(inspector) {
566 try {
567 jsiiDeprecationWarnings._aws_cdk_core_TreeInspector(inspector);
568 }
569 catch (error) {
570 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
571 Error.captureStackTrace(error, this.inspect);
572 }
573 throw error;
574 }
575 inspector.addAttribute("aws:cdk:cloudformation:type", CfnHookVersion.CFN_RESOURCE_TYPE_NAME);
576 inspector.addAttribute("aws:cdk:cloudformation:props", this.cfnProperties);
577 }
578 get cfnProperties() {
579 return {
580 schemaHandlerPackage: this.schemaHandlerPackage,
581 typeName: this.typeName,
582 executionRoleArn: this.executionRoleArn,
583 loggingConfig: this.loggingConfig,
584 };
585 }
586 renderProperties(props) {
587 return cfnHookVersionPropsToCloudFormation(props);
588 }
589}
590exports.CfnHookVersion = CfnHookVersion;
591_d = JSII_RTTI_SYMBOL_1;
592CfnHookVersion[_d] = { fqn: "@aws-cdk/core.CfnHookVersion", version: "1.156.1" };
593/**
594 * The CloudFormation resource type name for this resource class.
595 */
596CfnHookVersion.CFN_RESOURCE_TYPE_NAME = "AWS::CloudFormation::HookVersion";
597/**
598 * Determine whether the given properties match those of a `LoggingConfigProperty`
599 *
600 * @param properties - the TypeScript properties of a `LoggingConfigProperty`
601 *
602 * @returns the result of the validation.
603 */
604function CfnHookVersion_LoggingConfigPropertyValidator(properties) {
605 if (!cdk.canInspect(properties)) {
606 return cdk.VALIDATION_SUCCESS;
607 }
608 const errors = new cdk.ValidationResults();
609 if (typeof properties !== 'object') {
610 errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));
611 }
612 errors.collect(cdk.propertyValidator('logGroupName', cdk.validateString)(properties.logGroupName));
613 errors.collect(cdk.propertyValidator('logRoleArn', cdk.validateString)(properties.logRoleArn));
614 return errors.wrap('supplied properties not correct for "LoggingConfigProperty"');
615}
616/**
617 * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::HookVersion.LoggingConfig` resource
618 *
619 * @param properties - the TypeScript properties of a `LoggingConfigProperty`
620 *
621 * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::HookVersion.LoggingConfig` resource.
622 */
623// @ts-ignore TS6133
624function cfnHookVersionLoggingConfigPropertyToCloudFormation(properties) {
625 if (!cdk.canInspect(properties)) {
626 return properties;
627 }
628 CfnHookVersion_LoggingConfigPropertyValidator(properties).assertSuccess();
629 return {
630 LogGroupName: cdk.stringToCloudFormation(properties.logGroupName),
631 LogRoleArn: cdk.stringToCloudFormation(properties.logRoleArn),
632 };
633}
634// @ts-ignore TS6133
635function CfnHookVersionLoggingConfigPropertyFromCloudFormation(properties) {
636 if (cdk.isResolvableObject(properties)) {
637 return new cfn_parse.FromCloudFormationResult(properties);
638 }
639 properties = properties == null ? {} : properties;
640 if (typeof properties !== 'object') {
641 return new cfn_parse.FromCloudFormationResult(properties);
642 }
643 const ret = new cfn_parse.FromCloudFormationPropertyObject();
644 ret.addPropertyResult('logGroupName', 'LogGroupName', properties.LogGroupName != null ? cfn_parse.FromCloudFormation.getString(properties.LogGroupName) : undefined);
645 ret.addPropertyResult('logRoleArn', 'LogRoleArn', properties.LogRoleArn != null ? cfn_parse.FromCloudFormation.getString(properties.LogRoleArn) : undefined);
646 ret.addUnrecognizedPropertiesAsExtra(properties);
647 return ret;
648}
649/**
650 * Determine whether the given properties match those of a `CfnMacroProps`
651 *
652 * @param properties - the TypeScript properties of a `CfnMacroProps`
653 *
654 * @returns the result of the validation.
655 */
656function CfnMacroPropsValidator(properties) {
657 if (!cdk.canInspect(properties)) {
658 return cdk.VALIDATION_SUCCESS;
659 }
660 const errors = new cdk.ValidationResults();
661 if (typeof properties !== 'object') {
662 errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));
663 }
664 errors.collect(cdk.propertyValidator('description', cdk.validateString)(properties.description));
665 errors.collect(cdk.propertyValidator('functionName', cdk.requiredValidator)(properties.functionName));
666 errors.collect(cdk.propertyValidator('functionName', cdk.validateString)(properties.functionName));
667 errors.collect(cdk.propertyValidator('logGroupName', cdk.validateString)(properties.logGroupName));
668 errors.collect(cdk.propertyValidator('logRoleArn', cdk.validateString)(properties.logRoleArn));
669 errors.collect(cdk.propertyValidator('name', cdk.requiredValidator)(properties.name));
670 errors.collect(cdk.propertyValidator('name', cdk.validateString)(properties.name));
671 return errors.wrap('supplied properties not correct for "CfnMacroProps"');
672}
673/**
674 * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::Macro` resource
675 *
676 * @param properties - the TypeScript properties of a `CfnMacroProps`
677 *
678 * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::Macro` resource.
679 */
680// @ts-ignore TS6133
681function cfnMacroPropsToCloudFormation(properties) {
682 if (!cdk.canInspect(properties)) {
683 return properties;
684 }
685 CfnMacroPropsValidator(properties).assertSuccess();
686 return {
687 FunctionName: cdk.stringToCloudFormation(properties.functionName),
688 Name: cdk.stringToCloudFormation(properties.name),
689 Description: cdk.stringToCloudFormation(properties.description),
690 LogGroupName: cdk.stringToCloudFormation(properties.logGroupName),
691 LogRoleARN: cdk.stringToCloudFormation(properties.logRoleArn),
692 };
693}
694// @ts-ignore TS6133
695function CfnMacroPropsFromCloudFormation(properties) {
696 properties = properties == null ? {} : properties;
697 if (typeof properties !== 'object') {
698 return new cfn_parse.FromCloudFormationResult(properties);
699 }
700 const ret = new cfn_parse.FromCloudFormationPropertyObject();
701 ret.addPropertyResult('functionName', 'FunctionName', cfn_parse.FromCloudFormation.getString(properties.FunctionName));
702 ret.addPropertyResult('name', 'Name', cfn_parse.FromCloudFormation.getString(properties.Name));
703 ret.addPropertyResult('description', 'Description', properties.Description != null ? cfn_parse.FromCloudFormation.getString(properties.Description) : undefined);
704 ret.addPropertyResult('logGroupName', 'LogGroupName', properties.LogGroupName != null ? cfn_parse.FromCloudFormation.getString(properties.LogGroupName) : undefined);
705 ret.addPropertyResult('logRoleArn', 'LogRoleARN', properties.LogRoleARN != null ? cfn_parse.FromCloudFormation.getString(properties.LogRoleARN) : undefined);
706 ret.addUnrecognizedPropertiesAsExtra(properties);
707 return ret;
708}
709/**
710 * A CloudFormation `AWS::CloudFormation::Macro`
711 *
712 * The `AWS::CloudFormation::Macro` resource is a CloudFormation resource type that creates a CloudFormation macro to perform custom processing on CloudFormation templates. For more information, see [Using AWS CloudFormation macros to perform custom processing on templates](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/template-macros.html) .
713 *
714 * @cloudformationResource AWS::CloudFormation::Macro
715 * @stability external
716 *
717 * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-macro.html
718 */
719class CfnMacro extends cdk.CfnResource {
720 /**
721 * Create a new `AWS::CloudFormation::Macro`.
722 *
723 * @param scope - scope in which this resource is defined
724 * @param id - scoped id of the resource
725 * @param props - resource properties
726 */
727 constructor(scope, id, props) {
728 super(scope, id, { type: CfnMacro.CFN_RESOURCE_TYPE_NAME, properties: props });
729 try {
730 jsiiDeprecationWarnings._aws_cdk_core_Construct(scope);
731 jsiiDeprecationWarnings._aws_cdk_core_CfnMacroProps(props);
732 }
733 catch (error) {
734 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
735 Error.captureStackTrace(error, this.constructor);
736 }
737 throw error;
738 }
739 cdk.requireProperty(props, 'functionName', this);
740 cdk.requireProperty(props, 'name', this);
741 this.functionName = props.functionName;
742 this.name = props.name;
743 this.description = props.description;
744 this.logGroupName = props.logGroupName;
745 this.logRoleArn = props.logRoleArn;
746 }
747 /**
748 * A factory method that creates a new instance of this class from an object
749 * containing the CloudFormation properties of this resource.
750 * Used in the @aws-cdk/cloudformation-include module.
751 *
752 * @internal
753 */
754 static _fromCloudFormation(scope, id, resourceAttributes, options) {
755 resourceAttributes = resourceAttributes || {};
756 const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);
757 const propsResult = CfnMacroPropsFromCloudFormation(resourceProperties);
758 const ret = new CfnMacro(scope, id, propsResult.value);
759 for (const [propKey, propVal] of Object.entries(propsResult.extraProperties)) {
760 ret.addPropertyOverride(propKey, propVal);
761 }
762 options.parser.handleAttributes(ret, resourceAttributes, id);
763 return ret;
764 }
765 /**
766 * Examines the CloudFormation resource and discloses attributes.
767 *
768 * @param inspector - tree inspector to collect and process attributes
769 *
770 */
771 inspect(inspector) {
772 try {
773 jsiiDeprecationWarnings._aws_cdk_core_TreeInspector(inspector);
774 }
775 catch (error) {
776 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
777 Error.captureStackTrace(error, this.inspect);
778 }
779 throw error;
780 }
781 inspector.addAttribute("aws:cdk:cloudformation:type", CfnMacro.CFN_RESOURCE_TYPE_NAME);
782 inspector.addAttribute("aws:cdk:cloudformation:props", this.cfnProperties);
783 }
784 get cfnProperties() {
785 return {
786 functionName: this.functionName,
787 name: this.name,
788 description: this.description,
789 logGroupName: this.logGroupName,
790 logRoleArn: this.logRoleArn,
791 };
792 }
793 renderProperties(props) {
794 return cfnMacroPropsToCloudFormation(props);
795 }
796}
797exports.CfnMacro = CfnMacro;
798_e = JSII_RTTI_SYMBOL_1;
799CfnMacro[_e] = { fqn: "@aws-cdk/core.CfnMacro", version: "1.156.1" };
800/**
801 * The CloudFormation resource type name for this resource class.
802 */
803CfnMacro.CFN_RESOURCE_TYPE_NAME = "AWS::CloudFormation::Macro";
804/**
805 * Determine whether the given properties match those of a `CfnModuleDefaultVersionProps`
806 *
807 * @param properties - the TypeScript properties of a `CfnModuleDefaultVersionProps`
808 *
809 * @returns the result of the validation.
810 */
811function CfnModuleDefaultVersionPropsValidator(properties) {
812 if (!cdk.canInspect(properties)) {
813 return cdk.VALIDATION_SUCCESS;
814 }
815 const errors = new cdk.ValidationResults();
816 if (typeof properties !== 'object') {
817 errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));
818 }
819 errors.collect(cdk.propertyValidator('arn', cdk.validateString)(properties.arn));
820 errors.collect(cdk.propertyValidator('moduleName', cdk.validateString)(properties.moduleName));
821 errors.collect(cdk.propertyValidator('versionId', cdk.validateString)(properties.versionId));
822 return errors.wrap('supplied properties not correct for "CfnModuleDefaultVersionProps"');
823}
824/**
825 * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::ModuleDefaultVersion` resource
826 *
827 * @param properties - the TypeScript properties of a `CfnModuleDefaultVersionProps`
828 *
829 * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::ModuleDefaultVersion` resource.
830 */
831// @ts-ignore TS6133
832function cfnModuleDefaultVersionPropsToCloudFormation(properties) {
833 if (!cdk.canInspect(properties)) {
834 return properties;
835 }
836 CfnModuleDefaultVersionPropsValidator(properties).assertSuccess();
837 return {
838 Arn: cdk.stringToCloudFormation(properties.arn),
839 ModuleName: cdk.stringToCloudFormation(properties.moduleName),
840 VersionId: cdk.stringToCloudFormation(properties.versionId),
841 };
842}
843// @ts-ignore TS6133
844function CfnModuleDefaultVersionPropsFromCloudFormation(properties) {
845 properties = properties == null ? {} : properties;
846 if (typeof properties !== 'object') {
847 return new cfn_parse.FromCloudFormationResult(properties);
848 }
849 const ret = new cfn_parse.FromCloudFormationPropertyObject();
850 ret.addPropertyResult('arn', 'Arn', properties.Arn != null ? cfn_parse.FromCloudFormation.getString(properties.Arn) : undefined);
851 ret.addPropertyResult('moduleName', 'ModuleName', properties.ModuleName != null ? cfn_parse.FromCloudFormation.getString(properties.ModuleName) : undefined);
852 ret.addPropertyResult('versionId', 'VersionId', properties.VersionId != null ? cfn_parse.FromCloudFormation.getString(properties.VersionId) : undefined);
853 ret.addUnrecognizedPropertiesAsExtra(properties);
854 return ret;
855}
856/**
857 * A CloudFormation `AWS::CloudFormation::ModuleDefaultVersion`
858 *
859 * Specifies the default version of a module. The default version of the module will be used in CloudFormation operations for this account and Region.
860 *
861 * To register a module version, use the `[AWS::CloudFormation::ModuleVersion](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-moduleversion.html)` resource.
862 *
863 * For more information using modules, see [Using modules to encapsulate and reuse resource configurations](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/modules.html) and [Registering extensions](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/registry.html#registry-register) in the *CloudFormation User Guide* . For information on developing modules, see [Developing modules](https://docs.aws.amazon.com/cloudformation-cli/latest/userguide/modules.html) in the *CloudFormation CLI User Guide* .
864 *
865 * @cloudformationResource AWS::CloudFormation::ModuleDefaultVersion
866 * @stability external
867 *
868 * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-moduledefaultversion.html
869 */
870class CfnModuleDefaultVersion extends cdk.CfnResource {
871 /**
872 * Create a new `AWS::CloudFormation::ModuleDefaultVersion`.
873 *
874 * @param scope - scope in which this resource is defined
875 * @param id - scoped id of the resource
876 * @param props - resource properties
877 */
878 constructor(scope, id, props = {}) {
879 super(scope, id, { type: CfnModuleDefaultVersion.CFN_RESOURCE_TYPE_NAME, properties: props });
880 try {
881 jsiiDeprecationWarnings._aws_cdk_core_Construct(scope);
882 jsiiDeprecationWarnings._aws_cdk_core_CfnModuleDefaultVersionProps(props);
883 }
884 catch (error) {
885 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
886 Error.captureStackTrace(error, this.constructor);
887 }
888 throw error;
889 }
890 this.arn = props.arn;
891 this.moduleName = props.moduleName;
892 this.versionId = props.versionId;
893 }
894 /**
895 * A factory method that creates a new instance of this class from an object
896 * containing the CloudFormation properties of this resource.
897 * Used in the @aws-cdk/cloudformation-include module.
898 *
899 * @internal
900 */
901 static _fromCloudFormation(scope, id, resourceAttributes, options) {
902 resourceAttributes = resourceAttributes || {};
903 const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);
904 const propsResult = CfnModuleDefaultVersionPropsFromCloudFormation(resourceProperties);
905 const ret = new CfnModuleDefaultVersion(scope, id, propsResult.value);
906 for (const [propKey, propVal] of Object.entries(propsResult.extraProperties)) {
907 ret.addPropertyOverride(propKey, propVal);
908 }
909 options.parser.handleAttributes(ret, resourceAttributes, id);
910 return ret;
911 }
912 /**
913 * Examines the CloudFormation resource and discloses attributes.
914 *
915 * @param inspector - tree inspector to collect and process attributes
916 *
917 */
918 inspect(inspector) {
919 try {
920 jsiiDeprecationWarnings._aws_cdk_core_TreeInspector(inspector);
921 }
922 catch (error) {
923 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
924 Error.captureStackTrace(error, this.inspect);
925 }
926 throw error;
927 }
928 inspector.addAttribute("aws:cdk:cloudformation:type", CfnModuleDefaultVersion.CFN_RESOURCE_TYPE_NAME);
929 inspector.addAttribute("aws:cdk:cloudformation:props", this.cfnProperties);
930 }
931 get cfnProperties() {
932 return {
933 arn: this.arn,
934 moduleName: this.moduleName,
935 versionId: this.versionId,
936 };
937 }
938 renderProperties(props) {
939 return cfnModuleDefaultVersionPropsToCloudFormation(props);
940 }
941}
942exports.CfnModuleDefaultVersion = CfnModuleDefaultVersion;
943_f = JSII_RTTI_SYMBOL_1;
944CfnModuleDefaultVersion[_f] = { fqn: "@aws-cdk/core.CfnModuleDefaultVersion", version: "1.156.1" };
945/**
946 * The CloudFormation resource type name for this resource class.
947 */
948CfnModuleDefaultVersion.CFN_RESOURCE_TYPE_NAME = "AWS::CloudFormation::ModuleDefaultVersion";
949/**
950 * Determine whether the given properties match those of a `CfnModuleVersionProps`
951 *
952 * @param properties - the TypeScript properties of a `CfnModuleVersionProps`
953 *
954 * @returns the result of the validation.
955 */
956function CfnModuleVersionPropsValidator(properties) {
957 if (!cdk.canInspect(properties)) {
958 return cdk.VALIDATION_SUCCESS;
959 }
960 const errors = new cdk.ValidationResults();
961 if (typeof properties !== 'object') {
962 errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));
963 }
964 errors.collect(cdk.propertyValidator('moduleName', cdk.requiredValidator)(properties.moduleName));
965 errors.collect(cdk.propertyValidator('moduleName', cdk.validateString)(properties.moduleName));
966 errors.collect(cdk.propertyValidator('modulePackage', cdk.requiredValidator)(properties.modulePackage));
967 errors.collect(cdk.propertyValidator('modulePackage', cdk.validateString)(properties.modulePackage));
968 return errors.wrap('supplied properties not correct for "CfnModuleVersionProps"');
969}
970/**
971 * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::ModuleVersion` resource
972 *
973 * @param properties - the TypeScript properties of a `CfnModuleVersionProps`
974 *
975 * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::ModuleVersion` resource.
976 */
977// @ts-ignore TS6133
978function cfnModuleVersionPropsToCloudFormation(properties) {
979 if (!cdk.canInspect(properties)) {
980 return properties;
981 }
982 CfnModuleVersionPropsValidator(properties).assertSuccess();
983 return {
984 ModuleName: cdk.stringToCloudFormation(properties.moduleName),
985 ModulePackage: cdk.stringToCloudFormation(properties.modulePackage),
986 };
987}
988// @ts-ignore TS6133
989function CfnModuleVersionPropsFromCloudFormation(properties) {
990 properties = properties == null ? {} : properties;
991 if (typeof properties !== 'object') {
992 return new cfn_parse.FromCloudFormationResult(properties);
993 }
994 const ret = new cfn_parse.FromCloudFormationPropertyObject();
995 ret.addPropertyResult('moduleName', 'ModuleName', cfn_parse.FromCloudFormation.getString(properties.ModuleName));
996 ret.addPropertyResult('modulePackage', 'ModulePackage', cfn_parse.FromCloudFormation.getString(properties.ModulePackage));
997 ret.addUnrecognizedPropertiesAsExtra(properties);
998 return ret;
999}
1000/**
1001 * A CloudFormation `AWS::CloudFormation::ModuleVersion`
1002 *
1003 * Registers the specified version of the module with the CloudFormation service. Registering a module makes it available for use in CloudFormation templates in your AWS account and Region.
1004 *
1005 * To specify a module version as the default version, use the `[AWS::CloudFormation::ModuleDefaultVersion](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-moduledefaultversion.html)` resource.
1006 *
1007 * For more information using modules, see [Using modules to encapsulate and reuse resource configurations](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/modules.html) and [Registering extensions](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/registry.html#registry-register) in the *CloudFormation User Guide* . For information on developing modules, see [Developing modules](https://docs.aws.amazon.com/cloudformation-cli/latest/userguide/modules.html) in the *CloudFormation CLI User Guide* .
1008 *
1009 * @cloudformationResource AWS::CloudFormation::ModuleVersion
1010 * @stability external
1011 *
1012 * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-moduleversion.html
1013 */
1014class CfnModuleVersion extends cdk.CfnResource {
1015 /**
1016 * Create a new `AWS::CloudFormation::ModuleVersion`.
1017 *
1018 * @param scope - scope in which this resource is defined
1019 * @param id - scoped id of the resource
1020 * @param props - resource properties
1021 */
1022 constructor(scope, id, props) {
1023 super(scope, id, { type: CfnModuleVersion.CFN_RESOURCE_TYPE_NAME, properties: props });
1024 try {
1025 jsiiDeprecationWarnings._aws_cdk_core_Construct(scope);
1026 jsiiDeprecationWarnings._aws_cdk_core_CfnModuleVersionProps(props);
1027 }
1028 catch (error) {
1029 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
1030 Error.captureStackTrace(error, this.constructor);
1031 }
1032 throw error;
1033 }
1034 cdk.requireProperty(props, 'moduleName', this);
1035 cdk.requireProperty(props, 'modulePackage', this);
1036 this.attrArn = cdk.Token.asString(this.getAtt('Arn'));
1037 this.attrDescription = cdk.Token.asString(this.getAtt('Description'));
1038 this.attrDocumentationUrl = cdk.Token.asString(this.getAtt('DocumentationUrl'));
1039 this.attrIsDefaultVersion = this.getAtt('IsDefaultVersion');
1040 this.attrSchema = cdk.Token.asString(this.getAtt('Schema'));
1041 this.attrTimeCreated = cdk.Token.asString(this.getAtt('TimeCreated'));
1042 this.attrVersionId = cdk.Token.asString(this.getAtt('VersionId'));
1043 this.attrVisibility = cdk.Token.asString(this.getAtt('Visibility'));
1044 this.moduleName = props.moduleName;
1045 this.modulePackage = props.modulePackage;
1046 }
1047 /**
1048 * A factory method that creates a new instance of this class from an object
1049 * containing the CloudFormation properties of this resource.
1050 * Used in the @aws-cdk/cloudformation-include module.
1051 *
1052 * @internal
1053 */
1054 static _fromCloudFormation(scope, id, resourceAttributes, options) {
1055 resourceAttributes = resourceAttributes || {};
1056 const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);
1057 const propsResult = CfnModuleVersionPropsFromCloudFormation(resourceProperties);
1058 const ret = new CfnModuleVersion(scope, id, propsResult.value);
1059 for (const [propKey, propVal] of Object.entries(propsResult.extraProperties)) {
1060 ret.addPropertyOverride(propKey, propVal);
1061 }
1062 options.parser.handleAttributes(ret, resourceAttributes, id);
1063 return ret;
1064 }
1065 /**
1066 * Examines the CloudFormation resource and discloses attributes.
1067 *
1068 * @param inspector - tree inspector to collect and process attributes
1069 *
1070 */
1071 inspect(inspector) {
1072 try {
1073 jsiiDeprecationWarnings._aws_cdk_core_TreeInspector(inspector);
1074 }
1075 catch (error) {
1076 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
1077 Error.captureStackTrace(error, this.inspect);
1078 }
1079 throw error;
1080 }
1081 inspector.addAttribute("aws:cdk:cloudformation:type", CfnModuleVersion.CFN_RESOURCE_TYPE_NAME);
1082 inspector.addAttribute("aws:cdk:cloudformation:props", this.cfnProperties);
1083 }
1084 get cfnProperties() {
1085 return {
1086 moduleName: this.moduleName,
1087 modulePackage: this.modulePackage,
1088 };
1089 }
1090 renderProperties(props) {
1091 return cfnModuleVersionPropsToCloudFormation(props);
1092 }
1093}
1094exports.CfnModuleVersion = CfnModuleVersion;
1095_g = JSII_RTTI_SYMBOL_1;
1096CfnModuleVersion[_g] = { fqn: "@aws-cdk/core.CfnModuleVersion", version: "1.156.1" };
1097/**
1098 * The CloudFormation resource type name for this resource class.
1099 */
1100CfnModuleVersion.CFN_RESOURCE_TYPE_NAME = "AWS::CloudFormation::ModuleVersion";
1101/**
1102 * Determine whether the given properties match those of a `CfnPublicTypeVersionProps`
1103 *
1104 * @param properties - the TypeScript properties of a `CfnPublicTypeVersionProps`
1105 *
1106 * @returns the result of the validation.
1107 */
1108function CfnPublicTypeVersionPropsValidator(properties) {
1109 if (!cdk.canInspect(properties)) {
1110 return cdk.VALIDATION_SUCCESS;
1111 }
1112 const errors = new cdk.ValidationResults();
1113 if (typeof properties !== 'object') {
1114 errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));
1115 }
1116 errors.collect(cdk.propertyValidator('arn', cdk.validateString)(properties.arn));
1117 errors.collect(cdk.propertyValidator('logDeliveryBucket', cdk.validateString)(properties.logDeliveryBucket));
1118 errors.collect(cdk.propertyValidator('publicVersionNumber', cdk.validateString)(properties.publicVersionNumber));
1119 errors.collect(cdk.propertyValidator('type', cdk.validateString)(properties.type));
1120 errors.collect(cdk.propertyValidator('typeName', cdk.validateString)(properties.typeName));
1121 return errors.wrap('supplied properties not correct for "CfnPublicTypeVersionProps"');
1122}
1123/**
1124 * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::PublicTypeVersion` resource
1125 *
1126 * @param properties - the TypeScript properties of a `CfnPublicTypeVersionProps`
1127 *
1128 * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::PublicTypeVersion` resource.
1129 */
1130// @ts-ignore TS6133
1131function cfnPublicTypeVersionPropsToCloudFormation(properties) {
1132 if (!cdk.canInspect(properties)) {
1133 return properties;
1134 }
1135 CfnPublicTypeVersionPropsValidator(properties).assertSuccess();
1136 return {
1137 Arn: cdk.stringToCloudFormation(properties.arn),
1138 LogDeliveryBucket: cdk.stringToCloudFormation(properties.logDeliveryBucket),
1139 PublicVersionNumber: cdk.stringToCloudFormation(properties.publicVersionNumber),
1140 Type: cdk.stringToCloudFormation(properties.type),
1141 TypeName: cdk.stringToCloudFormation(properties.typeName),
1142 };
1143}
1144// @ts-ignore TS6133
1145function CfnPublicTypeVersionPropsFromCloudFormation(properties) {
1146 properties = properties == null ? {} : properties;
1147 if (typeof properties !== 'object') {
1148 return new cfn_parse.FromCloudFormationResult(properties);
1149 }
1150 const ret = new cfn_parse.FromCloudFormationPropertyObject();
1151 ret.addPropertyResult('arn', 'Arn', properties.Arn != null ? cfn_parse.FromCloudFormation.getString(properties.Arn) : undefined);
1152 ret.addPropertyResult('logDeliveryBucket', 'LogDeliveryBucket', properties.LogDeliveryBucket != null ? cfn_parse.FromCloudFormation.getString(properties.LogDeliveryBucket) : undefined);
1153 ret.addPropertyResult('publicVersionNumber', 'PublicVersionNumber', properties.PublicVersionNumber != null ? cfn_parse.FromCloudFormation.getString(properties.PublicVersionNumber) : undefined);
1154 ret.addPropertyResult('type', 'Type', properties.Type != null ? cfn_parse.FromCloudFormation.getString(properties.Type) : undefined);
1155 ret.addPropertyResult('typeName', 'TypeName', properties.TypeName != null ? cfn_parse.FromCloudFormation.getString(properties.TypeName) : undefined);
1156 ret.addUnrecognizedPropertiesAsExtra(properties);
1157 return ret;
1158}
1159/**
1160 * A CloudFormation `AWS::CloudFormation::PublicTypeVersion`
1161 *
1162 * Tests and publishes a registered extension as a public, third-party extension.
1163 *
1164 * CloudFormation first tests the extension to make sure it meets all necessary requirements for being published in the CloudFormation registry. If it does, CloudFormation then publishes it to the registry as a public third-party extension in this Region. Public extensions are available for use by all CloudFormation users.
1165 *
1166 * - For resource types, testing includes passing all contracts tests defined for the type.
1167 * - For modules, testing includes determining if the module's model meets all necessary requirements.
1168 *
1169 * For more information, see [Testing your public extension prior to publishing](https://docs.aws.amazon.com/cloudformation-cli/latest/userguide/publish-extension.html#publish-extension-testing) in the *CloudFormation CLI User Guide* .
1170 *
1171 * If you don't specify a version, CloudFormation uses the default version of the extension in your account and Region for testing.
1172 *
1173 * To perform testing, CloudFormation assumes the execution role specified when the type was registered.
1174 *
1175 * An extension must have a test status of `PASSED` before it can be published. For more information, see [Publishing extensions to make them available for public use](https://docs.aws.amazon.com/cloudformation-cli/latest/userguide/resource-type-publish.html) in the *CloudFormation CLI User Guide* .
1176 *
1177 * @cloudformationResource AWS::CloudFormation::PublicTypeVersion
1178 * @stability external
1179 *
1180 * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-publictypeversion.html
1181 */
1182class CfnPublicTypeVersion extends cdk.CfnResource {
1183 /**
1184 * Create a new `AWS::CloudFormation::PublicTypeVersion`.
1185 *
1186 * @param scope - scope in which this resource is defined
1187 * @param id - scoped id of the resource
1188 * @param props - resource properties
1189 */
1190 constructor(scope, id, props = {}) {
1191 super(scope, id, { type: CfnPublicTypeVersion.CFN_RESOURCE_TYPE_NAME, properties: props });
1192 try {
1193 jsiiDeprecationWarnings._aws_cdk_core_Construct(scope);
1194 jsiiDeprecationWarnings._aws_cdk_core_CfnPublicTypeVersionProps(props);
1195 }
1196 catch (error) {
1197 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
1198 Error.captureStackTrace(error, this.constructor);
1199 }
1200 throw error;
1201 }
1202 this.attrPublicTypeArn = cdk.Token.asString(this.getAtt('PublicTypeArn'));
1203 this.attrPublisherId = cdk.Token.asString(this.getAtt('PublisherId'));
1204 this.attrTypeVersionArn = cdk.Token.asString(this.getAtt('TypeVersionArn'));
1205 this.arn = props.arn;
1206 this.logDeliveryBucket = props.logDeliveryBucket;
1207 this.publicVersionNumber = props.publicVersionNumber;
1208 this.type = props.type;
1209 this.typeName = props.typeName;
1210 }
1211 /**
1212 * A factory method that creates a new instance of this class from an object
1213 * containing the CloudFormation properties of this resource.
1214 * Used in the @aws-cdk/cloudformation-include module.
1215 *
1216 * @internal
1217 */
1218 static _fromCloudFormation(scope, id, resourceAttributes, options) {
1219 resourceAttributes = resourceAttributes || {};
1220 const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);
1221 const propsResult = CfnPublicTypeVersionPropsFromCloudFormation(resourceProperties);
1222 const ret = new CfnPublicTypeVersion(scope, id, propsResult.value);
1223 for (const [propKey, propVal] of Object.entries(propsResult.extraProperties)) {
1224 ret.addPropertyOverride(propKey, propVal);
1225 }
1226 options.parser.handleAttributes(ret, resourceAttributes, id);
1227 return ret;
1228 }
1229 /**
1230 * Examines the CloudFormation resource and discloses attributes.
1231 *
1232 * @param inspector - tree inspector to collect and process attributes
1233 *
1234 */
1235 inspect(inspector) {
1236 try {
1237 jsiiDeprecationWarnings._aws_cdk_core_TreeInspector(inspector);
1238 }
1239 catch (error) {
1240 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
1241 Error.captureStackTrace(error, this.inspect);
1242 }
1243 throw error;
1244 }
1245 inspector.addAttribute("aws:cdk:cloudformation:type", CfnPublicTypeVersion.CFN_RESOURCE_TYPE_NAME);
1246 inspector.addAttribute("aws:cdk:cloudformation:props", this.cfnProperties);
1247 }
1248 get cfnProperties() {
1249 return {
1250 arn: this.arn,
1251 logDeliveryBucket: this.logDeliveryBucket,
1252 publicVersionNumber: this.publicVersionNumber,
1253 type: this.type,
1254 typeName: this.typeName,
1255 };
1256 }
1257 renderProperties(props) {
1258 return cfnPublicTypeVersionPropsToCloudFormation(props);
1259 }
1260}
1261exports.CfnPublicTypeVersion = CfnPublicTypeVersion;
1262_h = JSII_RTTI_SYMBOL_1;
1263CfnPublicTypeVersion[_h] = { fqn: "@aws-cdk/core.CfnPublicTypeVersion", version: "1.156.1" };
1264/**
1265 * The CloudFormation resource type name for this resource class.
1266 */
1267CfnPublicTypeVersion.CFN_RESOURCE_TYPE_NAME = "AWS::CloudFormation::PublicTypeVersion";
1268/**
1269 * Determine whether the given properties match those of a `CfnPublisherProps`
1270 *
1271 * @param properties - the TypeScript properties of a `CfnPublisherProps`
1272 *
1273 * @returns the result of the validation.
1274 */
1275function CfnPublisherPropsValidator(properties) {
1276 if (!cdk.canInspect(properties)) {
1277 return cdk.VALIDATION_SUCCESS;
1278 }
1279 const errors = new cdk.ValidationResults();
1280 if (typeof properties !== 'object') {
1281 errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));
1282 }
1283 errors.collect(cdk.propertyValidator('acceptTermsAndConditions', cdk.requiredValidator)(properties.acceptTermsAndConditions));
1284 errors.collect(cdk.propertyValidator('acceptTermsAndConditions', cdk.validateBoolean)(properties.acceptTermsAndConditions));
1285 errors.collect(cdk.propertyValidator('connectionArn', cdk.validateString)(properties.connectionArn));
1286 return errors.wrap('supplied properties not correct for "CfnPublisherProps"');
1287}
1288/**
1289 * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::Publisher` resource
1290 *
1291 * @param properties - the TypeScript properties of a `CfnPublisherProps`
1292 *
1293 * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::Publisher` resource.
1294 */
1295// @ts-ignore TS6133
1296function cfnPublisherPropsToCloudFormation(properties) {
1297 if (!cdk.canInspect(properties)) {
1298 return properties;
1299 }
1300 CfnPublisherPropsValidator(properties).assertSuccess();
1301 return {
1302 AcceptTermsAndConditions: cdk.booleanToCloudFormation(properties.acceptTermsAndConditions),
1303 ConnectionArn: cdk.stringToCloudFormation(properties.connectionArn),
1304 };
1305}
1306// @ts-ignore TS6133
1307function CfnPublisherPropsFromCloudFormation(properties) {
1308 properties = properties == null ? {} : properties;
1309 if (typeof properties !== 'object') {
1310 return new cfn_parse.FromCloudFormationResult(properties);
1311 }
1312 const ret = new cfn_parse.FromCloudFormationPropertyObject();
1313 ret.addPropertyResult('acceptTermsAndConditions', 'AcceptTermsAndConditions', cfn_parse.FromCloudFormation.getBoolean(properties.AcceptTermsAndConditions));
1314 ret.addPropertyResult('connectionArn', 'ConnectionArn', properties.ConnectionArn != null ? cfn_parse.FromCloudFormation.getString(properties.ConnectionArn) : undefined);
1315 ret.addUnrecognizedPropertiesAsExtra(properties);
1316 return ret;
1317}
1318/**
1319 * A CloudFormation `AWS::CloudFormation::Publisher`
1320 *
1321 * Registers your account as a publisher of public extensions in the CloudFormation registry. Public extensions are available for use by all CloudFormation users.
1322 *
1323 * For information on requirements for registering as a public extension publisher, see [Registering your account to publish CloudFormation extensions](https://docs.aws.amazon.com/cloudformation-cli/latest/userguide/publish-extension.html#publish-extension-prereqs) in the *CloudFormation CLI User Guide* .
1324 *
1325 * @cloudformationResource AWS::CloudFormation::Publisher
1326 * @stability external
1327 *
1328 * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-publisher.html
1329 */
1330class CfnPublisher extends cdk.CfnResource {
1331 /**
1332 * Create a new `AWS::CloudFormation::Publisher`.
1333 *
1334 * @param scope - scope in which this resource is defined
1335 * @param id - scoped id of the resource
1336 * @param props - resource properties
1337 */
1338 constructor(scope, id, props) {
1339 super(scope, id, { type: CfnPublisher.CFN_RESOURCE_TYPE_NAME, properties: props });
1340 try {
1341 jsiiDeprecationWarnings._aws_cdk_core_Construct(scope);
1342 jsiiDeprecationWarnings._aws_cdk_core_CfnPublisherProps(props);
1343 }
1344 catch (error) {
1345 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
1346 Error.captureStackTrace(error, this.constructor);
1347 }
1348 throw error;
1349 }
1350 cdk.requireProperty(props, 'acceptTermsAndConditions', this);
1351 this.attrIdentityProvider = cdk.Token.asString(this.getAtt('IdentityProvider'));
1352 this.attrPublisherId = cdk.Token.asString(this.getAtt('PublisherId'));
1353 this.attrPublisherProfile = cdk.Token.asString(this.getAtt('PublisherProfile'));
1354 this.attrPublisherStatus = cdk.Token.asString(this.getAtt('PublisherStatus'));
1355 this.acceptTermsAndConditions = props.acceptTermsAndConditions;
1356 this.connectionArn = props.connectionArn;
1357 }
1358 /**
1359 * A factory method that creates a new instance of this class from an object
1360 * containing the CloudFormation properties of this resource.
1361 * Used in the @aws-cdk/cloudformation-include module.
1362 *
1363 * @internal
1364 */
1365 static _fromCloudFormation(scope, id, resourceAttributes, options) {
1366 resourceAttributes = resourceAttributes || {};
1367 const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);
1368 const propsResult = CfnPublisherPropsFromCloudFormation(resourceProperties);
1369 const ret = new CfnPublisher(scope, id, propsResult.value);
1370 for (const [propKey, propVal] of Object.entries(propsResult.extraProperties)) {
1371 ret.addPropertyOverride(propKey, propVal);
1372 }
1373 options.parser.handleAttributes(ret, resourceAttributes, id);
1374 return ret;
1375 }
1376 /**
1377 * Examines the CloudFormation resource and discloses attributes.
1378 *
1379 * @param inspector - tree inspector to collect and process attributes
1380 *
1381 */
1382 inspect(inspector) {
1383 try {
1384 jsiiDeprecationWarnings._aws_cdk_core_TreeInspector(inspector);
1385 }
1386 catch (error) {
1387 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
1388 Error.captureStackTrace(error, this.inspect);
1389 }
1390 throw error;
1391 }
1392 inspector.addAttribute("aws:cdk:cloudformation:type", CfnPublisher.CFN_RESOURCE_TYPE_NAME);
1393 inspector.addAttribute("aws:cdk:cloudformation:props", this.cfnProperties);
1394 }
1395 get cfnProperties() {
1396 return {
1397 acceptTermsAndConditions: this.acceptTermsAndConditions,
1398 connectionArn: this.connectionArn,
1399 };
1400 }
1401 renderProperties(props) {
1402 return cfnPublisherPropsToCloudFormation(props);
1403 }
1404}
1405exports.CfnPublisher = CfnPublisher;
1406_j = JSII_RTTI_SYMBOL_1;
1407CfnPublisher[_j] = { fqn: "@aws-cdk/core.CfnPublisher", version: "1.156.1" };
1408/**
1409 * The CloudFormation resource type name for this resource class.
1410 */
1411CfnPublisher.CFN_RESOURCE_TYPE_NAME = "AWS::CloudFormation::Publisher";
1412/**
1413 * Determine whether the given properties match those of a `CfnResourceDefaultVersionProps`
1414 *
1415 * @param properties - the TypeScript properties of a `CfnResourceDefaultVersionProps`
1416 *
1417 * @returns the result of the validation.
1418 */
1419function CfnResourceDefaultVersionPropsValidator(properties) {
1420 if (!cdk.canInspect(properties)) {
1421 return cdk.VALIDATION_SUCCESS;
1422 }
1423 const errors = new cdk.ValidationResults();
1424 if (typeof properties !== 'object') {
1425 errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));
1426 }
1427 errors.collect(cdk.propertyValidator('typeName', cdk.validateString)(properties.typeName));
1428 errors.collect(cdk.propertyValidator('typeVersionArn', cdk.validateString)(properties.typeVersionArn));
1429 errors.collect(cdk.propertyValidator('versionId', cdk.validateString)(properties.versionId));
1430 return errors.wrap('supplied properties not correct for "CfnResourceDefaultVersionProps"');
1431}
1432/**
1433 * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::ResourceDefaultVersion` resource
1434 *
1435 * @param properties - the TypeScript properties of a `CfnResourceDefaultVersionProps`
1436 *
1437 * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::ResourceDefaultVersion` resource.
1438 */
1439// @ts-ignore TS6133
1440function cfnResourceDefaultVersionPropsToCloudFormation(properties) {
1441 if (!cdk.canInspect(properties)) {
1442 return properties;
1443 }
1444 CfnResourceDefaultVersionPropsValidator(properties).assertSuccess();
1445 return {
1446 TypeName: cdk.stringToCloudFormation(properties.typeName),
1447 TypeVersionArn: cdk.stringToCloudFormation(properties.typeVersionArn),
1448 VersionId: cdk.stringToCloudFormation(properties.versionId),
1449 };
1450}
1451// @ts-ignore TS6133
1452function CfnResourceDefaultVersionPropsFromCloudFormation(properties) {
1453 properties = properties == null ? {} : properties;
1454 if (typeof properties !== 'object') {
1455 return new cfn_parse.FromCloudFormationResult(properties);
1456 }
1457 const ret = new cfn_parse.FromCloudFormationPropertyObject();
1458 ret.addPropertyResult('typeName', 'TypeName', properties.TypeName != null ? cfn_parse.FromCloudFormation.getString(properties.TypeName) : undefined);
1459 ret.addPropertyResult('typeVersionArn', 'TypeVersionArn', properties.TypeVersionArn != null ? cfn_parse.FromCloudFormation.getString(properties.TypeVersionArn) : undefined);
1460 ret.addPropertyResult('versionId', 'VersionId', properties.VersionId != null ? cfn_parse.FromCloudFormation.getString(properties.VersionId) : undefined);
1461 ret.addUnrecognizedPropertiesAsExtra(properties);
1462 return ret;
1463}
1464/**
1465 * A CloudFormation `AWS::CloudFormation::ResourceDefaultVersion`
1466 *
1467 * Specifies the default version of a resource. The default version of a resource will be used in CloudFormation operations.
1468 *
1469 * @cloudformationResource AWS::CloudFormation::ResourceDefaultVersion
1470 * @stability external
1471 *
1472 * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-resourcedefaultversion.html
1473 */
1474class CfnResourceDefaultVersion extends cdk.CfnResource {
1475 /**
1476 * Create a new `AWS::CloudFormation::ResourceDefaultVersion`.
1477 *
1478 * @param scope - scope in which this resource is defined
1479 * @param id - scoped id of the resource
1480 * @param props - resource properties
1481 */
1482 constructor(scope, id, props = {}) {
1483 super(scope, id, { type: CfnResourceDefaultVersion.CFN_RESOURCE_TYPE_NAME, properties: props });
1484 try {
1485 jsiiDeprecationWarnings._aws_cdk_core_Construct(scope);
1486 jsiiDeprecationWarnings._aws_cdk_core_CfnResourceDefaultVersionProps(props);
1487 }
1488 catch (error) {
1489 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
1490 Error.captureStackTrace(error, this.constructor);
1491 }
1492 throw error;
1493 }
1494 this.attrArn = cdk.Token.asString(this.getAtt('Arn'));
1495 this.typeName = props.typeName;
1496 this.typeVersionArn = props.typeVersionArn;
1497 this.versionId = props.versionId;
1498 }
1499 /**
1500 * A factory method that creates a new instance of this class from an object
1501 * containing the CloudFormation properties of this resource.
1502 * Used in the @aws-cdk/cloudformation-include module.
1503 *
1504 * @internal
1505 */
1506 static _fromCloudFormation(scope, id, resourceAttributes, options) {
1507 resourceAttributes = resourceAttributes || {};
1508 const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);
1509 const propsResult = CfnResourceDefaultVersionPropsFromCloudFormation(resourceProperties);
1510 const ret = new CfnResourceDefaultVersion(scope, id, propsResult.value);
1511 for (const [propKey, propVal] of Object.entries(propsResult.extraProperties)) {
1512 ret.addPropertyOverride(propKey, propVal);
1513 }
1514 options.parser.handleAttributes(ret, resourceAttributes, id);
1515 return ret;
1516 }
1517 /**
1518 * Examines the CloudFormation resource and discloses attributes.
1519 *
1520 * @param inspector - tree inspector to collect and process attributes
1521 *
1522 */
1523 inspect(inspector) {
1524 try {
1525 jsiiDeprecationWarnings._aws_cdk_core_TreeInspector(inspector);
1526 }
1527 catch (error) {
1528 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
1529 Error.captureStackTrace(error, this.inspect);
1530 }
1531 throw error;
1532 }
1533 inspector.addAttribute("aws:cdk:cloudformation:type", CfnResourceDefaultVersion.CFN_RESOURCE_TYPE_NAME);
1534 inspector.addAttribute("aws:cdk:cloudformation:props", this.cfnProperties);
1535 }
1536 get cfnProperties() {
1537 return {
1538 typeName: this.typeName,
1539 typeVersionArn: this.typeVersionArn,
1540 versionId: this.versionId,
1541 };
1542 }
1543 renderProperties(props) {
1544 return cfnResourceDefaultVersionPropsToCloudFormation(props);
1545 }
1546}
1547exports.CfnResourceDefaultVersion = CfnResourceDefaultVersion;
1548_k = JSII_RTTI_SYMBOL_1;
1549CfnResourceDefaultVersion[_k] = { fqn: "@aws-cdk/core.CfnResourceDefaultVersion", version: "1.156.1" };
1550/**
1551 * The CloudFormation resource type name for this resource class.
1552 */
1553CfnResourceDefaultVersion.CFN_RESOURCE_TYPE_NAME = "AWS::CloudFormation::ResourceDefaultVersion";
1554/**
1555 * Determine whether the given properties match those of a `CfnResourceVersionProps`
1556 *
1557 * @param properties - the TypeScript properties of a `CfnResourceVersionProps`
1558 *
1559 * @returns the result of the validation.
1560 */
1561function CfnResourceVersionPropsValidator(properties) {
1562 if (!cdk.canInspect(properties)) {
1563 return cdk.VALIDATION_SUCCESS;
1564 }
1565 const errors = new cdk.ValidationResults();
1566 if (typeof properties !== 'object') {
1567 errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));
1568 }
1569 errors.collect(cdk.propertyValidator('executionRoleArn', cdk.validateString)(properties.executionRoleArn));
1570 errors.collect(cdk.propertyValidator('loggingConfig', CfnResourceVersion_LoggingConfigPropertyValidator)(properties.loggingConfig));
1571 errors.collect(cdk.propertyValidator('schemaHandlerPackage', cdk.requiredValidator)(properties.schemaHandlerPackage));
1572 errors.collect(cdk.propertyValidator('schemaHandlerPackage', cdk.validateString)(properties.schemaHandlerPackage));
1573 errors.collect(cdk.propertyValidator('typeName', cdk.requiredValidator)(properties.typeName));
1574 errors.collect(cdk.propertyValidator('typeName', cdk.validateString)(properties.typeName));
1575 return errors.wrap('supplied properties not correct for "CfnResourceVersionProps"');
1576}
1577/**
1578 * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::ResourceVersion` resource
1579 *
1580 * @param properties - the TypeScript properties of a `CfnResourceVersionProps`
1581 *
1582 * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::ResourceVersion` resource.
1583 */
1584// @ts-ignore TS6133
1585function cfnResourceVersionPropsToCloudFormation(properties) {
1586 if (!cdk.canInspect(properties)) {
1587 return properties;
1588 }
1589 CfnResourceVersionPropsValidator(properties).assertSuccess();
1590 return {
1591 SchemaHandlerPackage: cdk.stringToCloudFormation(properties.schemaHandlerPackage),
1592 TypeName: cdk.stringToCloudFormation(properties.typeName),
1593 ExecutionRoleArn: cdk.stringToCloudFormation(properties.executionRoleArn),
1594 LoggingConfig: cfnResourceVersionLoggingConfigPropertyToCloudFormation(properties.loggingConfig),
1595 };
1596}
1597// @ts-ignore TS6133
1598function CfnResourceVersionPropsFromCloudFormation(properties) {
1599 properties = properties == null ? {} : properties;
1600 if (typeof properties !== 'object') {
1601 return new cfn_parse.FromCloudFormationResult(properties);
1602 }
1603 const ret = new cfn_parse.FromCloudFormationPropertyObject();
1604 ret.addPropertyResult('schemaHandlerPackage', 'SchemaHandlerPackage', cfn_parse.FromCloudFormation.getString(properties.SchemaHandlerPackage));
1605 ret.addPropertyResult('typeName', 'TypeName', cfn_parse.FromCloudFormation.getString(properties.TypeName));
1606 ret.addPropertyResult('executionRoleArn', 'ExecutionRoleArn', properties.ExecutionRoleArn != null ? cfn_parse.FromCloudFormation.getString(properties.ExecutionRoleArn) : undefined);
1607 ret.addPropertyResult('loggingConfig', 'LoggingConfig', properties.LoggingConfig != null ? CfnResourceVersionLoggingConfigPropertyFromCloudFormation(properties.LoggingConfig) : undefined);
1608 ret.addUnrecognizedPropertiesAsExtra(properties);
1609 return ret;
1610}
1611/**
1612 * A CloudFormation `AWS::CloudFormation::ResourceVersion`
1613 *
1614 * Registers a resource version with the CloudFormation service. Registering a resource version makes it available for use in CloudFormation templates in your AWS account , and includes:
1615 *
1616 * - Validating the resource schema.
1617 * - Determining which handlers, if any, have been specified for the resource.
1618 * - Making the resource available for use in your account.
1619 *
1620 * For more information on how to develop resources and ready them for registration, see [Creating Resource Providers](https://docs.aws.amazon.com/cloudformation-cli/latest/userguide/resource-types.html) in the *CloudFormation CLI User Guide* .
1621 *
1622 * You can have a maximum of 50 resource versions registered at a time. This maximum is per account and per Region.
1623 *
1624 * @cloudformationResource AWS::CloudFormation::ResourceVersion
1625 * @stability external
1626 *
1627 * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-resourceversion.html
1628 */
1629class CfnResourceVersion extends cdk.CfnResource {
1630 /**
1631 * Create a new `AWS::CloudFormation::ResourceVersion`.
1632 *
1633 * @param scope - scope in which this resource is defined
1634 * @param id - scoped id of the resource
1635 * @param props - resource properties
1636 */
1637 constructor(scope, id, props) {
1638 super(scope, id, { type: CfnResourceVersion.CFN_RESOURCE_TYPE_NAME, properties: props });
1639 try {
1640 jsiiDeprecationWarnings._aws_cdk_core_Construct(scope);
1641 jsiiDeprecationWarnings._aws_cdk_core_CfnResourceVersionProps(props);
1642 }
1643 catch (error) {
1644 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
1645 Error.captureStackTrace(error, this.constructor);
1646 }
1647 throw error;
1648 }
1649 cdk.requireProperty(props, 'schemaHandlerPackage', this);
1650 cdk.requireProperty(props, 'typeName', this);
1651 this.attrArn = cdk.Token.asString(this.getAtt('Arn'));
1652 this.attrIsDefaultVersion = this.getAtt('IsDefaultVersion');
1653 this.attrProvisioningType = cdk.Token.asString(this.getAtt('ProvisioningType'));
1654 this.attrTypeArn = cdk.Token.asString(this.getAtt('TypeArn'));
1655 this.attrVersionId = cdk.Token.asString(this.getAtt('VersionId'));
1656 this.attrVisibility = cdk.Token.asString(this.getAtt('Visibility'));
1657 this.schemaHandlerPackage = props.schemaHandlerPackage;
1658 this.typeName = props.typeName;
1659 this.executionRoleArn = props.executionRoleArn;
1660 this.loggingConfig = props.loggingConfig;
1661 }
1662 /**
1663 * A factory method that creates a new instance of this class from an object
1664 * containing the CloudFormation properties of this resource.
1665 * Used in the @aws-cdk/cloudformation-include module.
1666 *
1667 * @internal
1668 */
1669 static _fromCloudFormation(scope, id, resourceAttributes, options) {
1670 resourceAttributes = resourceAttributes || {};
1671 const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);
1672 const propsResult = CfnResourceVersionPropsFromCloudFormation(resourceProperties);
1673 const ret = new CfnResourceVersion(scope, id, propsResult.value);
1674 for (const [propKey, propVal] of Object.entries(propsResult.extraProperties)) {
1675 ret.addPropertyOverride(propKey, propVal);
1676 }
1677 options.parser.handleAttributes(ret, resourceAttributes, id);
1678 return ret;
1679 }
1680 /**
1681 * Examines the CloudFormation resource and discloses attributes.
1682 *
1683 * @param inspector - tree inspector to collect and process attributes
1684 *
1685 */
1686 inspect(inspector) {
1687 try {
1688 jsiiDeprecationWarnings._aws_cdk_core_TreeInspector(inspector);
1689 }
1690 catch (error) {
1691 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
1692 Error.captureStackTrace(error, this.inspect);
1693 }
1694 throw error;
1695 }
1696 inspector.addAttribute("aws:cdk:cloudformation:type", CfnResourceVersion.CFN_RESOURCE_TYPE_NAME);
1697 inspector.addAttribute("aws:cdk:cloudformation:props", this.cfnProperties);
1698 }
1699 get cfnProperties() {
1700 return {
1701 schemaHandlerPackage: this.schemaHandlerPackage,
1702 typeName: this.typeName,
1703 executionRoleArn: this.executionRoleArn,
1704 loggingConfig: this.loggingConfig,
1705 };
1706 }
1707 renderProperties(props) {
1708 return cfnResourceVersionPropsToCloudFormation(props);
1709 }
1710}
1711exports.CfnResourceVersion = CfnResourceVersion;
1712_l = JSII_RTTI_SYMBOL_1;
1713CfnResourceVersion[_l] = { fqn: "@aws-cdk/core.CfnResourceVersion", version: "1.156.1" };
1714/**
1715 * The CloudFormation resource type name for this resource class.
1716 */
1717CfnResourceVersion.CFN_RESOURCE_TYPE_NAME = "AWS::CloudFormation::ResourceVersion";
1718/**
1719 * Determine whether the given properties match those of a `LoggingConfigProperty`
1720 *
1721 * @param properties - the TypeScript properties of a `LoggingConfigProperty`
1722 *
1723 * @returns the result of the validation.
1724 */
1725function CfnResourceVersion_LoggingConfigPropertyValidator(properties) {
1726 if (!cdk.canInspect(properties)) {
1727 return cdk.VALIDATION_SUCCESS;
1728 }
1729 const errors = new cdk.ValidationResults();
1730 if (typeof properties !== 'object') {
1731 errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));
1732 }
1733 errors.collect(cdk.propertyValidator('logGroupName', cdk.validateString)(properties.logGroupName));
1734 errors.collect(cdk.propertyValidator('logRoleArn', cdk.validateString)(properties.logRoleArn));
1735 return errors.wrap('supplied properties not correct for "LoggingConfigProperty"');
1736}
1737/**
1738 * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::ResourceVersion.LoggingConfig` resource
1739 *
1740 * @param properties - the TypeScript properties of a `LoggingConfigProperty`
1741 *
1742 * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::ResourceVersion.LoggingConfig` resource.
1743 */
1744// @ts-ignore TS6133
1745function cfnResourceVersionLoggingConfigPropertyToCloudFormation(properties) {
1746 if (!cdk.canInspect(properties)) {
1747 return properties;
1748 }
1749 CfnResourceVersion_LoggingConfigPropertyValidator(properties).assertSuccess();
1750 return {
1751 LogGroupName: cdk.stringToCloudFormation(properties.logGroupName),
1752 LogRoleArn: cdk.stringToCloudFormation(properties.logRoleArn),
1753 };
1754}
1755// @ts-ignore TS6133
1756function CfnResourceVersionLoggingConfigPropertyFromCloudFormation(properties) {
1757 if (cdk.isResolvableObject(properties)) {
1758 return new cfn_parse.FromCloudFormationResult(properties);
1759 }
1760 properties = properties == null ? {} : properties;
1761 if (typeof properties !== 'object') {
1762 return new cfn_parse.FromCloudFormationResult(properties);
1763 }
1764 const ret = new cfn_parse.FromCloudFormationPropertyObject();
1765 ret.addPropertyResult('logGroupName', 'LogGroupName', properties.LogGroupName != null ? cfn_parse.FromCloudFormation.getString(properties.LogGroupName) : undefined);
1766 ret.addPropertyResult('logRoleArn', 'LogRoleArn', properties.LogRoleArn != null ? cfn_parse.FromCloudFormation.getString(properties.LogRoleArn) : undefined);
1767 ret.addUnrecognizedPropertiesAsExtra(properties);
1768 return ret;
1769}
1770/**
1771 * Determine whether the given properties match those of a `CfnStackProps`
1772 *
1773 * @param properties - the TypeScript properties of a `CfnStackProps`
1774 *
1775 * @returns the result of the validation.
1776 */
1777function CfnStackPropsValidator(properties) {
1778 if (!cdk.canInspect(properties)) {
1779 return cdk.VALIDATION_SUCCESS;
1780 }
1781 const errors = new cdk.ValidationResults();
1782 if (typeof properties !== 'object') {
1783 errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));
1784 }
1785 errors.collect(cdk.propertyValidator('notificationArns', cdk.listValidator(cdk.validateString))(properties.notificationArns));
1786 errors.collect(cdk.propertyValidator('parameters', cdk.hashValidator(cdk.validateString))(properties.parameters));
1787 errors.collect(cdk.propertyValidator('tags', cdk.listValidator(cdk.validateCfnTag))(properties.tags));
1788 errors.collect(cdk.propertyValidator('templateUrl', cdk.requiredValidator)(properties.templateUrl));
1789 errors.collect(cdk.propertyValidator('templateUrl', cdk.validateString)(properties.templateUrl));
1790 errors.collect(cdk.propertyValidator('timeoutInMinutes', cdk.validateNumber)(properties.timeoutInMinutes));
1791 return errors.wrap('supplied properties not correct for "CfnStackProps"');
1792}
1793/**
1794 * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::Stack` resource
1795 *
1796 * @param properties - the TypeScript properties of a `CfnStackProps`
1797 *
1798 * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::Stack` resource.
1799 */
1800// @ts-ignore TS6133
1801function cfnStackPropsToCloudFormation(properties) {
1802 if (!cdk.canInspect(properties)) {
1803 return properties;
1804 }
1805 CfnStackPropsValidator(properties).assertSuccess();
1806 return {
1807 TemplateURL: cdk.stringToCloudFormation(properties.templateUrl),
1808 NotificationARNs: cdk.listMapper(cdk.stringToCloudFormation)(properties.notificationArns),
1809 Parameters: cdk.hashMapper(cdk.stringToCloudFormation)(properties.parameters),
1810 Tags: cdk.listMapper(cdk.cfnTagToCloudFormation)(properties.tags),
1811 TimeoutInMinutes: cdk.numberToCloudFormation(properties.timeoutInMinutes),
1812 };
1813}
1814// @ts-ignore TS6133
1815function CfnStackPropsFromCloudFormation(properties) {
1816 properties = properties == null ? {} : properties;
1817 if (typeof properties !== 'object') {
1818 return new cfn_parse.FromCloudFormationResult(properties);
1819 }
1820 const ret = new cfn_parse.FromCloudFormationPropertyObject();
1821 ret.addPropertyResult('templateUrl', 'TemplateURL', cfn_parse.FromCloudFormation.getString(properties.TemplateURL));
1822 ret.addPropertyResult('notificationArns', 'NotificationARNs', properties.NotificationARNs != null ? cfn_parse.FromCloudFormation.getStringArray(properties.NotificationARNs) : undefined);
1823 ret.addPropertyResult('parameters', 'Parameters', properties.Parameters != null ? cfn_parse.FromCloudFormation.getMap(cfn_parse.FromCloudFormation.getString)(properties.Parameters) : undefined);
1824 ret.addPropertyResult('tags', 'Tags', properties.Tags != null ? cfn_parse.FromCloudFormation.getArray(cfn_parse.FromCloudFormation.getCfnTag)(properties.Tags) : undefined);
1825 ret.addPropertyResult('timeoutInMinutes', 'TimeoutInMinutes', properties.TimeoutInMinutes != null ? cfn_parse.FromCloudFormation.getNumber(properties.TimeoutInMinutes) : undefined);
1826 ret.addUnrecognizedPropertiesAsExtra(properties);
1827 return ret;
1828}
1829/**
1830 * A CloudFormation `AWS::CloudFormation::Stack`
1831 *
1832 * The `AWS::CloudFormation::Stack` resource nests a stack as a resource in a top-level template.
1833 *
1834 * You can add output values from a nested stack within the containing template. You use the [GetAtt](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/intrinsic-function-reference-getatt.html) function with the nested stack's logical name and the name of the output value in the nested stack in the format `Outputs. *NestedStackOutputName*` .
1835 *
1836 * > We strongly recommend that updates to nested stacks are run from the parent stack.
1837 *
1838 * When you apply template changes to update a top-level stack, CloudFormation updates the top-level stack and initiates an update to its nested stacks. CloudFormation updates the resources of modified nested stacks, but doesn't update the resources of unmodified nested stacks. For more information, see [CloudFormation stack updates](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/using-cfn-updating-stacks.html) .
1839 *
1840 * > You must acknowledge IAM capabilities for nested stacks that contain IAM resources. Also, verify that you have cancel update stack permissions, which is required if an update rolls back. For more information about IAM and CloudFormation , see [Controlling access with AWS Identity and Access Management](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/using-iam-template.html) .
1841 *
1842 * @cloudformationResource AWS::CloudFormation::Stack
1843 * @stability external
1844 *
1845 * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-stack.html
1846 */
1847class CfnStack extends cdk.CfnResource {
1848 /**
1849 * Create a new `AWS::CloudFormation::Stack`.
1850 *
1851 * @param scope - scope in which this resource is defined
1852 * @param id - scoped id of the resource
1853 * @param props - resource properties
1854 */
1855 constructor(scope, id, props) {
1856 super(scope, id, { type: CfnStack.CFN_RESOURCE_TYPE_NAME, properties: props });
1857 try {
1858 jsiiDeprecationWarnings._aws_cdk_core_Construct(scope);
1859 jsiiDeprecationWarnings._aws_cdk_core_CfnStackProps(props);
1860 }
1861 catch (error) {
1862 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
1863 Error.captureStackTrace(error, this.constructor);
1864 }
1865 throw error;
1866 }
1867 cdk.requireProperty(props, 'templateUrl', this);
1868 this.templateUrl = props.templateUrl;
1869 this.notificationArns = props.notificationArns;
1870 this.parameters = props.parameters;
1871 this.tags = new cdk.TagManager(cdk.TagType.STANDARD, "AWS::CloudFormation::Stack", props.tags, { tagPropertyName: 'tags' });
1872 this.timeoutInMinutes = props.timeoutInMinutes;
1873 if (this.node.scope && cdk.Resource.isResource(this.node.scope)) {
1874 this.node.addValidation({ validate: () => this.cfnOptions.deletionPolicy === undefined
1875 ? ['\'AWS::CloudFormation::Stack\' is a stateful resource type, and you must specify a Removal Policy for it. Call \'resource.applyRemovalPolicy()\'.']
1876 : [] });
1877 }
1878 }
1879 /**
1880 * A factory method that creates a new instance of this class from an object
1881 * containing the CloudFormation properties of this resource.
1882 * Used in the @aws-cdk/cloudformation-include module.
1883 *
1884 * @internal
1885 */
1886 static _fromCloudFormation(scope, id, resourceAttributes, options) {
1887 resourceAttributes = resourceAttributes || {};
1888 const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);
1889 const propsResult = CfnStackPropsFromCloudFormation(resourceProperties);
1890 const ret = new CfnStack(scope, id, propsResult.value);
1891 for (const [propKey, propVal] of Object.entries(propsResult.extraProperties)) {
1892 ret.addPropertyOverride(propKey, propVal);
1893 }
1894 options.parser.handleAttributes(ret, resourceAttributes, id);
1895 return ret;
1896 }
1897 /**
1898 * Examines the CloudFormation resource and discloses attributes.
1899 *
1900 * @param inspector - tree inspector to collect and process attributes
1901 *
1902 */
1903 inspect(inspector) {
1904 try {
1905 jsiiDeprecationWarnings._aws_cdk_core_TreeInspector(inspector);
1906 }
1907 catch (error) {
1908 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
1909 Error.captureStackTrace(error, this.inspect);
1910 }
1911 throw error;
1912 }
1913 inspector.addAttribute("aws:cdk:cloudformation:type", CfnStack.CFN_RESOURCE_TYPE_NAME);
1914 inspector.addAttribute("aws:cdk:cloudformation:props", this.cfnProperties);
1915 }
1916 get cfnProperties() {
1917 return {
1918 templateUrl: this.templateUrl,
1919 notificationArns: this.notificationArns,
1920 parameters: this.parameters,
1921 tags: this.tags.renderTags(),
1922 timeoutInMinutes: this.timeoutInMinutes,
1923 };
1924 }
1925 renderProperties(props) {
1926 return cfnStackPropsToCloudFormation(props);
1927 }
1928}
1929exports.CfnStack = CfnStack;
1930_m = JSII_RTTI_SYMBOL_1;
1931CfnStack[_m] = { fqn: "@aws-cdk/core.CfnStack", version: "1.156.1" };
1932/**
1933 * The CloudFormation resource type name for this resource class.
1934 */
1935CfnStack.CFN_RESOURCE_TYPE_NAME = "AWS::CloudFormation::Stack";
1936/**
1937 * Determine whether the given properties match those of a `CfnStackSetProps`
1938 *
1939 * @param properties - the TypeScript properties of a `CfnStackSetProps`
1940 *
1941 * @returns the result of the validation.
1942 */
1943function CfnStackSetPropsValidator(properties) {
1944 if (!cdk.canInspect(properties)) {
1945 return cdk.VALIDATION_SUCCESS;
1946 }
1947 const errors = new cdk.ValidationResults();
1948 if (typeof properties !== 'object') {
1949 errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));
1950 }
1951 errors.collect(cdk.propertyValidator('administrationRoleArn', cdk.validateString)(properties.administrationRoleArn));
1952 errors.collect(cdk.propertyValidator('autoDeployment', CfnStackSet_AutoDeploymentPropertyValidator)(properties.autoDeployment));
1953 errors.collect(cdk.propertyValidator('callAs', cdk.validateString)(properties.callAs));
1954 errors.collect(cdk.propertyValidator('capabilities', cdk.listValidator(cdk.validateString))(properties.capabilities));
1955 errors.collect(cdk.propertyValidator('description', cdk.validateString)(properties.description));
1956 errors.collect(cdk.propertyValidator('executionRoleName', cdk.validateString)(properties.executionRoleName));
1957 errors.collect(cdk.propertyValidator('managedExecution', cdk.validateObject)(properties.managedExecution));
1958 errors.collect(cdk.propertyValidator('operationPreferences', CfnStackSet_OperationPreferencesPropertyValidator)(properties.operationPreferences));
1959 errors.collect(cdk.propertyValidator('parameters', cdk.listValidator(CfnStackSet_ParameterPropertyValidator))(properties.parameters));
1960 errors.collect(cdk.propertyValidator('permissionModel', cdk.requiredValidator)(properties.permissionModel));
1961 errors.collect(cdk.propertyValidator('permissionModel', cdk.validateString)(properties.permissionModel));
1962 errors.collect(cdk.propertyValidator('stackInstancesGroup', cdk.listValidator(CfnStackSet_StackInstancesPropertyValidator))(properties.stackInstancesGroup));
1963 errors.collect(cdk.propertyValidator('stackSetName', cdk.requiredValidator)(properties.stackSetName));
1964 errors.collect(cdk.propertyValidator('stackSetName', cdk.validateString)(properties.stackSetName));
1965 errors.collect(cdk.propertyValidator('tags', cdk.listValidator(cdk.validateCfnTag))(properties.tags));
1966 errors.collect(cdk.propertyValidator('templateBody', cdk.validateString)(properties.templateBody));
1967 errors.collect(cdk.propertyValidator('templateUrl', cdk.validateString)(properties.templateUrl));
1968 return errors.wrap('supplied properties not correct for "CfnStackSetProps"');
1969}
1970/**
1971 * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::StackSet` resource
1972 *
1973 * @param properties - the TypeScript properties of a `CfnStackSetProps`
1974 *
1975 * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::StackSet` resource.
1976 */
1977// @ts-ignore TS6133
1978function cfnStackSetPropsToCloudFormation(properties) {
1979 if (!cdk.canInspect(properties)) {
1980 return properties;
1981 }
1982 CfnStackSetPropsValidator(properties).assertSuccess();
1983 return {
1984 PermissionModel: cdk.stringToCloudFormation(properties.permissionModel),
1985 StackSetName: cdk.stringToCloudFormation(properties.stackSetName),
1986 AdministrationRoleARN: cdk.stringToCloudFormation(properties.administrationRoleArn),
1987 AutoDeployment: cfnStackSetAutoDeploymentPropertyToCloudFormation(properties.autoDeployment),
1988 CallAs: cdk.stringToCloudFormation(properties.callAs),
1989 Capabilities: cdk.listMapper(cdk.stringToCloudFormation)(properties.capabilities),
1990 Description: cdk.stringToCloudFormation(properties.description),
1991 ExecutionRoleName: cdk.stringToCloudFormation(properties.executionRoleName),
1992 ManagedExecution: cdk.objectToCloudFormation(properties.managedExecution),
1993 OperationPreferences: cfnStackSetOperationPreferencesPropertyToCloudFormation(properties.operationPreferences),
1994 Parameters: cdk.listMapper(cfnStackSetParameterPropertyToCloudFormation)(properties.parameters),
1995 StackInstancesGroup: cdk.listMapper(cfnStackSetStackInstancesPropertyToCloudFormation)(properties.stackInstancesGroup),
1996 Tags: cdk.listMapper(cdk.cfnTagToCloudFormation)(properties.tags),
1997 TemplateBody: cdk.stringToCloudFormation(properties.templateBody),
1998 TemplateURL: cdk.stringToCloudFormation(properties.templateUrl),
1999 };
2000}
2001// @ts-ignore TS6133
2002function CfnStackSetPropsFromCloudFormation(properties) {
2003 properties = properties == null ? {} : properties;
2004 if (typeof properties !== 'object') {
2005 return new cfn_parse.FromCloudFormationResult(properties);
2006 }
2007 const ret = new cfn_parse.FromCloudFormationPropertyObject();
2008 ret.addPropertyResult('permissionModel', 'PermissionModel', cfn_parse.FromCloudFormation.getString(properties.PermissionModel));
2009 ret.addPropertyResult('stackSetName', 'StackSetName', cfn_parse.FromCloudFormation.getString(properties.StackSetName));
2010 ret.addPropertyResult('administrationRoleArn', 'AdministrationRoleARN', properties.AdministrationRoleARN != null ? cfn_parse.FromCloudFormation.getString(properties.AdministrationRoleARN) : undefined);
2011 ret.addPropertyResult('autoDeployment', 'AutoDeployment', properties.AutoDeployment != null ? CfnStackSetAutoDeploymentPropertyFromCloudFormation(properties.AutoDeployment) : undefined);
2012 ret.addPropertyResult('callAs', 'CallAs', properties.CallAs != null ? cfn_parse.FromCloudFormation.getString(properties.CallAs) : undefined);
2013 ret.addPropertyResult('capabilities', 'Capabilities', properties.Capabilities != null ? cfn_parse.FromCloudFormation.getStringArray(properties.Capabilities) : undefined);
2014 ret.addPropertyResult('description', 'Description', properties.Description != null ? cfn_parse.FromCloudFormation.getString(properties.Description) : undefined);
2015 ret.addPropertyResult('executionRoleName', 'ExecutionRoleName', properties.ExecutionRoleName != null ? cfn_parse.FromCloudFormation.getString(properties.ExecutionRoleName) : undefined);
2016 ret.addPropertyResult('managedExecution', 'ManagedExecution', properties.ManagedExecution != null ? cfn_parse.FromCloudFormation.getAny(properties.ManagedExecution) : undefined);
2017 ret.addPropertyResult('operationPreferences', 'OperationPreferences', properties.OperationPreferences != null ? CfnStackSetOperationPreferencesPropertyFromCloudFormation(properties.OperationPreferences) : undefined);
2018 ret.addPropertyResult('parameters', 'Parameters', properties.Parameters != null ? cfn_parse.FromCloudFormation.getArray(CfnStackSetParameterPropertyFromCloudFormation)(properties.Parameters) : undefined);
2019 ret.addPropertyResult('stackInstancesGroup', 'StackInstancesGroup', properties.StackInstancesGroup != null ? cfn_parse.FromCloudFormation.getArray(CfnStackSetStackInstancesPropertyFromCloudFormation)(properties.StackInstancesGroup) : undefined);
2020 ret.addPropertyResult('tags', 'Tags', properties.Tags != null ? cfn_parse.FromCloudFormation.getArray(cfn_parse.FromCloudFormation.getCfnTag)(properties.Tags) : undefined);
2021 ret.addPropertyResult('templateBody', 'TemplateBody', properties.TemplateBody != null ? cfn_parse.FromCloudFormation.getString(properties.TemplateBody) : undefined);
2022 ret.addPropertyResult('templateUrl', 'TemplateURL', properties.TemplateURL != null ? cfn_parse.FromCloudFormation.getString(properties.TemplateURL) : undefined);
2023 ret.addUnrecognizedPropertiesAsExtra(properties);
2024 return ret;
2025}
2026/**
2027 * A CloudFormation `AWS::CloudFormation::StackSet`
2028 *
2029 * The `AWS::CloudFormation::StackSet` enables you to provision stacks into AWS accounts and across Regions by using a single CloudFormation template. In the stack set, you specify the template to use, in addition to any parameters and capabilities that the template requires.
2030 *
2031 * @cloudformationResource AWS::CloudFormation::StackSet
2032 * @stability external
2033 *
2034 * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html
2035 */
2036class CfnStackSet extends cdk.CfnResource {
2037 /**
2038 * Create a new `AWS::CloudFormation::StackSet`.
2039 *
2040 * @param scope - scope in which this resource is defined
2041 * @param id - scoped id of the resource
2042 * @param props - resource properties
2043 */
2044 constructor(scope, id, props) {
2045 super(scope, id, { type: CfnStackSet.CFN_RESOURCE_TYPE_NAME, properties: props });
2046 try {
2047 jsiiDeprecationWarnings._aws_cdk_core_Construct(scope);
2048 jsiiDeprecationWarnings._aws_cdk_core_CfnStackSetProps(props);
2049 }
2050 catch (error) {
2051 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
2052 Error.captureStackTrace(error, this.constructor);
2053 }
2054 throw error;
2055 }
2056 cdk.requireProperty(props, 'permissionModel', this);
2057 cdk.requireProperty(props, 'stackSetName', this);
2058 this.attrStackSetId = cdk.Token.asString(this.getAtt('StackSetId'));
2059 this.permissionModel = props.permissionModel;
2060 this.stackSetName = props.stackSetName;
2061 this.administrationRoleArn = props.administrationRoleArn;
2062 this.autoDeployment = props.autoDeployment;
2063 this.callAs = props.callAs;
2064 this.capabilities = props.capabilities;
2065 this.description = props.description;
2066 this.executionRoleName = props.executionRoleName;
2067 this.managedExecution = props.managedExecution;
2068 this.operationPreferences = props.operationPreferences;
2069 this.parameters = props.parameters;
2070 this.stackInstancesGroup = props.stackInstancesGroup;
2071 this.tags = new cdk.TagManager(cdk.TagType.STANDARD, "AWS::CloudFormation::StackSet", props.tags, { tagPropertyName: 'tags' });
2072 this.templateBody = props.templateBody;
2073 this.templateUrl = props.templateUrl;
2074 }
2075 /**
2076 * A factory method that creates a new instance of this class from an object
2077 * containing the CloudFormation properties of this resource.
2078 * Used in the @aws-cdk/cloudformation-include module.
2079 *
2080 * @internal
2081 */
2082 static _fromCloudFormation(scope, id, resourceAttributes, options) {
2083 resourceAttributes = resourceAttributes || {};
2084 const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);
2085 const propsResult = CfnStackSetPropsFromCloudFormation(resourceProperties);
2086 const ret = new CfnStackSet(scope, id, propsResult.value);
2087 for (const [propKey, propVal] of Object.entries(propsResult.extraProperties)) {
2088 ret.addPropertyOverride(propKey, propVal);
2089 }
2090 options.parser.handleAttributes(ret, resourceAttributes, id);
2091 return ret;
2092 }
2093 /**
2094 * Examines the CloudFormation resource and discloses attributes.
2095 *
2096 * @param inspector - tree inspector to collect and process attributes
2097 *
2098 */
2099 inspect(inspector) {
2100 try {
2101 jsiiDeprecationWarnings._aws_cdk_core_TreeInspector(inspector);
2102 }
2103 catch (error) {
2104 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
2105 Error.captureStackTrace(error, this.inspect);
2106 }
2107 throw error;
2108 }
2109 inspector.addAttribute("aws:cdk:cloudformation:type", CfnStackSet.CFN_RESOURCE_TYPE_NAME);
2110 inspector.addAttribute("aws:cdk:cloudformation:props", this.cfnProperties);
2111 }
2112 get cfnProperties() {
2113 return {
2114 permissionModel: this.permissionModel,
2115 stackSetName: this.stackSetName,
2116 administrationRoleArn: this.administrationRoleArn,
2117 autoDeployment: this.autoDeployment,
2118 callAs: this.callAs,
2119 capabilities: this.capabilities,
2120 description: this.description,
2121 executionRoleName: this.executionRoleName,
2122 managedExecution: this.managedExecution,
2123 operationPreferences: this.operationPreferences,
2124 parameters: this.parameters,
2125 stackInstancesGroup: this.stackInstancesGroup,
2126 tags: this.tags.renderTags(),
2127 templateBody: this.templateBody,
2128 templateUrl: this.templateUrl,
2129 };
2130 }
2131 renderProperties(props) {
2132 return cfnStackSetPropsToCloudFormation(props);
2133 }
2134}
2135exports.CfnStackSet = CfnStackSet;
2136_o = JSII_RTTI_SYMBOL_1;
2137CfnStackSet[_o] = { fqn: "@aws-cdk/core.CfnStackSet", version: "1.156.1" };
2138/**
2139 * The CloudFormation resource type name for this resource class.
2140 */
2141CfnStackSet.CFN_RESOURCE_TYPE_NAME = "AWS::CloudFormation::StackSet";
2142/**
2143 * Determine whether the given properties match those of a `AutoDeploymentProperty`
2144 *
2145 * @param properties - the TypeScript properties of a `AutoDeploymentProperty`
2146 *
2147 * @returns the result of the validation.
2148 */
2149function CfnStackSet_AutoDeploymentPropertyValidator(properties) {
2150 if (!cdk.canInspect(properties)) {
2151 return cdk.VALIDATION_SUCCESS;
2152 }
2153 const errors = new cdk.ValidationResults();
2154 if (typeof properties !== 'object') {
2155 errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));
2156 }
2157 errors.collect(cdk.propertyValidator('enabled', cdk.validateBoolean)(properties.enabled));
2158 errors.collect(cdk.propertyValidator('retainStacksOnAccountRemoval', cdk.validateBoolean)(properties.retainStacksOnAccountRemoval));
2159 return errors.wrap('supplied properties not correct for "AutoDeploymentProperty"');
2160}
2161/**
2162 * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::StackSet.AutoDeployment` resource
2163 *
2164 * @param properties - the TypeScript properties of a `AutoDeploymentProperty`
2165 *
2166 * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::StackSet.AutoDeployment` resource.
2167 */
2168// @ts-ignore TS6133
2169function cfnStackSetAutoDeploymentPropertyToCloudFormation(properties) {
2170 if (!cdk.canInspect(properties)) {
2171 return properties;
2172 }
2173 CfnStackSet_AutoDeploymentPropertyValidator(properties).assertSuccess();
2174 return {
2175 Enabled: cdk.booleanToCloudFormation(properties.enabled),
2176 RetainStacksOnAccountRemoval: cdk.booleanToCloudFormation(properties.retainStacksOnAccountRemoval),
2177 };
2178}
2179// @ts-ignore TS6133
2180function CfnStackSetAutoDeploymentPropertyFromCloudFormation(properties) {
2181 if (cdk.isResolvableObject(properties)) {
2182 return new cfn_parse.FromCloudFormationResult(properties);
2183 }
2184 properties = properties == null ? {} : properties;
2185 if (typeof properties !== 'object') {
2186 return new cfn_parse.FromCloudFormationResult(properties);
2187 }
2188 const ret = new cfn_parse.FromCloudFormationPropertyObject();
2189 ret.addPropertyResult('enabled', 'Enabled', properties.Enabled != null ? cfn_parse.FromCloudFormation.getBoolean(properties.Enabled) : undefined);
2190 ret.addPropertyResult('retainStacksOnAccountRemoval', 'RetainStacksOnAccountRemoval', properties.RetainStacksOnAccountRemoval != null ? cfn_parse.FromCloudFormation.getBoolean(properties.RetainStacksOnAccountRemoval) : undefined);
2191 ret.addUnrecognizedPropertiesAsExtra(properties);
2192 return ret;
2193}
2194/**
2195 * Determine whether the given properties match those of a `DeploymentTargetsProperty`
2196 *
2197 * @param properties - the TypeScript properties of a `DeploymentTargetsProperty`
2198 *
2199 * @returns the result of the validation.
2200 */
2201function CfnStackSet_DeploymentTargetsPropertyValidator(properties) {
2202 if (!cdk.canInspect(properties)) {
2203 return cdk.VALIDATION_SUCCESS;
2204 }
2205 const errors = new cdk.ValidationResults();
2206 if (typeof properties !== 'object') {
2207 errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));
2208 }
2209 errors.collect(cdk.propertyValidator('accounts', cdk.listValidator(cdk.validateString))(properties.accounts));
2210 errors.collect(cdk.propertyValidator('organizationalUnitIds', cdk.listValidator(cdk.validateString))(properties.organizationalUnitIds));
2211 return errors.wrap('supplied properties not correct for "DeploymentTargetsProperty"');
2212}
2213/**
2214 * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::StackSet.DeploymentTargets` resource
2215 *
2216 * @param properties - the TypeScript properties of a `DeploymentTargetsProperty`
2217 *
2218 * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::StackSet.DeploymentTargets` resource.
2219 */
2220// @ts-ignore TS6133
2221function cfnStackSetDeploymentTargetsPropertyToCloudFormation(properties) {
2222 if (!cdk.canInspect(properties)) {
2223 return properties;
2224 }
2225 CfnStackSet_DeploymentTargetsPropertyValidator(properties).assertSuccess();
2226 return {
2227 Accounts: cdk.listMapper(cdk.stringToCloudFormation)(properties.accounts),
2228 OrganizationalUnitIds: cdk.listMapper(cdk.stringToCloudFormation)(properties.organizationalUnitIds),
2229 };
2230}
2231// @ts-ignore TS6133
2232function CfnStackSetDeploymentTargetsPropertyFromCloudFormation(properties) {
2233 if (cdk.isResolvableObject(properties)) {
2234 return new cfn_parse.FromCloudFormationResult(properties);
2235 }
2236 properties = properties == null ? {} : properties;
2237 if (typeof properties !== 'object') {
2238 return new cfn_parse.FromCloudFormationResult(properties);
2239 }
2240 const ret = new cfn_parse.FromCloudFormationPropertyObject();
2241 ret.addPropertyResult('accounts', 'Accounts', properties.Accounts != null ? cfn_parse.FromCloudFormation.getStringArray(properties.Accounts) : undefined);
2242 ret.addPropertyResult('organizationalUnitIds', 'OrganizationalUnitIds', properties.OrganizationalUnitIds != null ? cfn_parse.FromCloudFormation.getStringArray(properties.OrganizationalUnitIds) : undefined);
2243 ret.addUnrecognizedPropertiesAsExtra(properties);
2244 return ret;
2245}
2246/**
2247 * Determine whether the given properties match those of a `OperationPreferencesProperty`
2248 *
2249 * @param properties - the TypeScript properties of a `OperationPreferencesProperty`
2250 *
2251 * @returns the result of the validation.
2252 */
2253function CfnStackSet_OperationPreferencesPropertyValidator(properties) {
2254 if (!cdk.canInspect(properties)) {
2255 return cdk.VALIDATION_SUCCESS;
2256 }
2257 const errors = new cdk.ValidationResults();
2258 if (typeof properties !== 'object') {
2259 errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));
2260 }
2261 errors.collect(cdk.propertyValidator('failureToleranceCount', cdk.validateNumber)(properties.failureToleranceCount));
2262 errors.collect(cdk.propertyValidator('failureTolerancePercentage', cdk.validateNumber)(properties.failureTolerancePercentage));
2263 errors.collect(cdk.propertyValidator('maxConcurrentCount', cdk.validateNumber)(properties.maxConcurrentCount));
2264 errors.collect(cdk.propertyValidator('maxConcurrentPercentage', cdk.validateNumber)(properties.maxConcurrentPercentage));
2265 errors.collect(cdk.propertyValidator('regionConcurrencyType', cdk.validateString)(properties.regionConcurrencyType));
2266 errors.collect(cdk.propertyValidator('regionOrder', cdk.listValidator(cdk.validateString))(properties.regionOrder));
2267 return errors.wrap('supplied properties not correct for "OperationPreferencesProperty"');
2268}
2269/**
2270 * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::StackSet.OperationPreferences` resource
2271 *
2272 * @param properties - the TypeScript properties of a `OperationPreferencesProperty`
2273 *
2274 * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::StackSet.OperationPreferences` resource.
2275 */
2276// @ts-ignore TS6133
2277function cfnStackSetOperationPreferencesPropertyToCloudFormation(properties) {
2278 if (!cdk.canInspect(properties)) {
2279 return properties;
2280 }
2281 CfnStackSet_OperationPreferencesPropertyValidator(properties).assertSuccess();
2282 return {
2283 FailureToleranceCount: cdk.numberToCloudFormation(properties.failureToleranceCount),
2284 FailureTolerancePercentage: cdk.numberToCloudFormation(properties.failureTolerancePercentage),
2285 MaxConcurrentCount: cdk.numberToCloudFormation(properties.maxConcurrentCount),
2286 MaxConcurrentPercentage: cdk.numberToCloudFormation(properties.maxConcurrentPercentage),
2287 RegionConcurrencyType: cdk.stringToCloudFormation(properties.regionConcurrencyType),
2288 RegionOrder: cdk.listMapper(cdk.stringToCloudFormation)(properties.regionOrder),
2289 };
2290}
2291// @ts-ignore TS6133
2292function CfnStackSetOperationPreferencesPropertyFromCloudFormation(properties) {
2293 if (cdk.isResolvableObject(properties)) {
2294 return new cfn_parse.FromCloudFormationResult(properties);
2295 }
2296 properties = properties == null ? {} : properties;
2297 if (typeof properties !== 'object') {
2298 return new cfn_parse.FromCloudFormationResult(properties);
2299 }
2300 const ret = new cfn_parse.FromCloudFormationPropertyObject();
2301 ret.addPropertyResult('failureToleranceCount', 'FailureToleranceCount', properties.FailureToleranceCount != null ? cfn_parse.FromCloudFormation.getNumber(properties.FailureToleranceCount) : undefined);
2302 ret.addPropertyResult('failureTolerancePercentage', 'FailureTolerancePercentage', properties.FailureTolerancePercentage != null ? cfn_parse.FromCloudFormation.getNumber(properties.FailureTolerancePercentage) : undefined);
2303 ret.addPropertyResult('maxConcurrentCount', 'MaxConcurrentCount', properties.MaxConcurrentCount != null ? cfn_parse.FromCloudFormation.getNumber(properties.MaxConcurrentCount) : undefined);
2304 ret.addPropertyResult('maxConcurrentPercentage', 'MaxConcurrentPercentage', properties.MaxConcurrentPercentage != null ? cfn_parse.FromCloudFormation.getNumber(properties.MaxConcurrentPercentage) : undefined);
2305 ret.addPropertyResult('regionConcurrencyType', 'RegionConcurrencyType', properties.RegionConcurrencyType != null ? cfn_parse.FromCloudFormation.getString(properties.RegionConcurrencyType) : undefined);
2306 ret.addPropertyResult('regionOrder', 'RegionOrder', properties.RegionOrder != null ? cfn_parse.FromCloudFormation.getStringArray(properties.RegionOrder) : undefined);
2307 ret.addUnrecognizedPropertiesAsExtra(properties);
2308 return ret;
2309}
2310/**
2311 * Determine whether the given properties match those of a `ParameterProperty`
2312 *
2313 * @param properties - the TypeScript properties of a `ParameterProperty`
2314 *
2315 * @returns the result of the validation.
2316 */
2317function CfnStackSet_ParameterPropertyValidator(properties) {
2318 if (!cdk.canInspect(properties)) {
2319 return cdk.VALIDATION_SUCCESS;
2320 }
2321 const errors = new cdk.ValidationResults();
2322 if (typeof properties !== 'object') {
2323 errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));
2324 }
2325 errors.collect(cdk.propertyValidator('parameterKey', cdk.requiredValidator)(properties.parameterKey));
2326 errors.collect(cdk.propertyValidator('parameterKey', cdk.validateString)(properties.parameterKey));
2327 errors.collect(cdk.propertyValidator('parameterValue', cdk.requiredValidator)(properties.parameterValue));
2328 errors.collect(cdk.propertyValidator('parameterValue', cdk.validateString)(properties.parameterValue));
2329 return errors.wrap('supplied properties not correct for "ParameterProperty"');
2330}
2331/**
2332 * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::StackSet.Parameter` resource
2333 *
2334 * @param properties - the TypeScript properties of a `ParameterProperty`
2335 *
2336 * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::StackSet.Parameter` resource.
2337 */
2338// @ts-ignore TS6133
2339function cfnStackSetParameterPropertyToCloudFormation(properties) {
2340 if (!cdk.canInspect(properties)) {
2341 return properties;
2342 }
2343 CfnStackSet_ParameterPropertyValidator(properties).assertSuccess();
2344 return {
2345 ParameterKey: cdk.stringToCloudFormation(properties.parameterKey),
2346 ParameterValue: cdk.stringToCloudFormation(properties.parameterValue),
2347 };
2348}
2349// @ts-ignore TS6133
2350function CfnStackSetParameterPropertyFromCloudFormation(properties) {
2351 if (cdk.isResolvableObject(properties)) {
2352 return new cfn_parse.FromCloudFormationResult(properties);
2353 }
2354 properties = properties == null ? {} : properties;
2355 if (typeof properties !== 'object') {
2356 return new cfn_parse.FromCloudFormationResult(properties);
2357 }
2358 const ret = new cfn_parse.FromCloudFormationPropertyObject();
2359 ret.addPropertyResult('parameterKey', 'ParameterKey', cfn_parse.FromCloudFormation.getString(properties.ParameterKey));
2360 ret.addPropertyResult('parameterValue', 'ParameterValue', cfn_parse.FromCloudFormation.getString(properties.ParameterValue));
2361 ret.addUnrecognizedPropertiesAsExtra(properties);
2362 return ret;
2363}
2364/**
2365 * Determine whether the given properties match those of a `StackInstancesProperty`
2366 *
2367 * @param properties - the TypeScript properties of a `StackInstancesProperty`
2368 *
2369 * @returns the result of the validation.
2370 */
2371function CfnStackSet_StackInstancesPropertyValidator(properties) {
2372 if (!cdk.canInspect(properties)) {
2373 return cdk.VALIDATION_SUCCESS;
2374 }
2375 const errors = new cdk.ValidationResults();
2376 if (typeof properties !== 'object') {
2377 errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));
2378 }
2379 errors.collect(cdk.propertyValidator('deploymentTargets', cdk.requiredValidator)(properties.deploymentTargets));
2380 errors.collect(cdk.propertyValidator('deploymentTargets', CfnStackSet_DeploymentTargetsPropertyValidator)(properties.deploymentTargets));
2381 errors.collect(cdk.propertyValidator('parameterOverrides', cdk.listValidator(CfnStackSet_ParameterPropertyValidator))(properties.parameterOverrides));
2382 errors.collect(cdk.propertyValidator('regions', cdk.requiredValidator)(properties.regions));
2383 errors.collect(cdk.propertyValidator('regions', cdk.listValidator(cdk.validateString))(properties.regions));
2384 return errors.wrap('supplied properties not correct for "StackInstancesProperty"');
2385}
2386/**
2387 * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::StackSet.StackInstances` resource
2388 *
2389 * @param properties - the TypeScript properties of a `StackInstancesProperty`
2390 *
2391 * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::StackSet.StackInstances` resource.
2392 */
2393// @ts-ignore TS6133
2394function cfnStackSetStackInstancesPropertyToCloudFormation(properties) {
2395 if (!cdk.canInspect(properties)) {
2396 return properties;
2397 }
2398 CfnStackSet_StackInstancesPropertyValidator(properties).assertSuccess();
2399 return {
2400 DeploymentTargets: cfnStackSetDeploymentTargetsPropertyToCloudFormation(properties.deploymentTargets),
2401 ParameterOverrides: cdk.listMapper(cfnStackSetParameterPropertyToCloudFormation)(properties.parameterOverrides),
2402 Regions: cdk.listMapper(cdk.stringToCloudFormation)(properties.regions),
2403 };
2404}
2405// @ts-ignore TS6133
2406function CfnStackSetStackInstancesPropertyFromCloudFormation(properties) {
2407 if (cdk.isResolvableObject(properties)) {
2408 return new cfn_parse.FromCloudFormationResult(properties);
2409 }
2410 properties = properties == null ? {} : properties;
2411 if (typeof properties !== 'object') {
2412 return new cfn_parse.FromCloudFormationResult(properties);
2413 }
2414 const ret = new cfn_parse.FromCloudFormationPropertyObject();
2415 ret.addPropertyResult('deploymentTargets', 'DeploymentTargets', CfnStackSetDeploymentTargetsPropertyFromCloudFormation(properties.DeploymentTargets));
2416 ret.addPropertyResult('parameterOverrides', 'ParameterOverrides', properties.ParameterOverrides != null ? cfn_parse.FromCloudFormation.getArray(CfnStackSetParameterPropertyFromCloudFormation)(properties.ParameterOverrides) : undefined);
2417 ret.addPropertyResult('regions', 'Regions', cfn_parse.FromCloudFormation.getStringArray(properties.Regions));
2418 ret.addUnrecognizedPropertiesAsExtra(properties);
2419 return ret;
2420}
2421/**
2422 * Determine whether the given properties match those of a `CfnTypeActivationProps`
2423 *
2424 * @param properties - the TypeScript properties of a `CfnTypeActivationProps`
2425 *
2426 * @returns the result of the validation.
2427 */
2428function CfnTypeActivationPropsValidator(properties) {
2429 if (!cdk.canInspect(properties)) {
2430 return cdk.VALIDATION_SUCCESS;
2431 }
2432 const errors = new cdk.ValidationResults();
2433 if (typeof properties !== 'object') {
2434 errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));
2435 }
2436 errors.collect(cdk.propertyValidator('autoUpdate', cdk.validateBoolean)(properties.autoUpdate));
2437 errors.collect(cdk.propertyValidator('executionRoleArn', cdk.validateString)(properties.executionRoleArn));
2438 errors.collect(cdk.propertyValidator('loggingConfig', CfnTypeActivation_LoggingConfigPropertyValidator)(properties.loggingConfig));
2439 errors.collect(cdk.propertyValidator('majorVersion', cdk.validateString)(properties.majorVersion));
2440 errors.collect(cdk.propertyValidator('publicTypeArn', cdk.validateString)(properties.publicTypeArn));
2441 errors.collect(cdk.propertyValidator('publisherId', cdk.validateString)(properties.publisherId));
2442 errors.collect(cdk.propertyValidator('type', cdk.validateString)(properties.type));
2443 errors.collect(cdk.propertyValidator('typeName', cdk.validateString)(properties.typeName));
2444 errors.collect(cdk.propertyValidator('typeNameAlias', cdk.validateString)(properties.typeNameAlias));
2445 errors.collect(cdk.propertyValidator('versionBump', cdk.validateString)(properties.versionBump));
2446 return errors.wrap('supplied properties not correct for "CfnTypeActivationProps"');
2447}
2448/**
2449 * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::TypeActivation` resource
2450 *
2451 * @param properties - the TypeScript properties of a `CfnTypeActivationProps`
2452 *
2453 * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::TypeActivation` resource.
2454 */
2455// @ts-ignore TS6133
2456function cfnTypeActivationPropsToCloudFormation(properties) {
2457 if (!cdk.canInspect(properties)) {
2458 return properties;
2459 }
2460 CfnTypeActivationPropsValidator(properties).assertSuccess();
2461 return {
2462 AutoUpdate: cdk.booleanToCloudFormation(properties.autoUpdate),
2463 ExecutionRoleArn: cdk.stringToCloudFormation(properties.executionRoleArn),
2464 LoggingConfig: cfnTypeActivationLoggingConfigPropertyToCloudFormation(properties.loggingConfig),
2465 MajorVersion: cdk.stringToCloudFormation(properties.majorVersion),
2466 PublicTypeArn: cdk.stringToCloudFormation(properties.publicTypeArn),
2467 PublisherId: cdk.stringToCloudFormation(properties.publisherId),
2468 Type: cdk.stringToCloudFormation(properties.type),
2469 TypeName: cdk.stringToCloudFormation(properties.typeName),
2470 TypeNameAlias: cdk.stringToCloudFormation(properties.typeNameAlias),
2471 VersionBump: cdk.stringToCloudFormation(properties.versionBump),
2472 };
2473}
2474// @ts-ignore TS6133
2475function CfnTypeActivationPropsFromCloudFormation(properties) {
2476 properties = properties == null ? {} : properties;
2477 if (typeof properties !== 'object') {
2478 return new cfn_parse.FromCloudFormationResult(properties);
2479 }
2480 const ret = new cfn_parse.FromCloudFormationPropertyObject();
2481 ret.addPropertyResult('autoUpdate', 'AutoUpdate', properties.AutoUpdate != null ? cfn_parse.FromCloudFormation.getBoolean(properties.AutoUpdate) : undefined);
2482 ret.addPropertyResult('executionRoleArn', 'ExecutionRoleArn', properties.ExecutionRoleArn != null ? cfn_parse.FromCloudFormation.getString(properties.ExecutionRoleArn) : undefined);
2483 ret.addPropertyResult('loggingConfig', 'LoggingConfig', properties.LoggingConfig != null ? CfnTypeActivationLoggingConfigPropertyFromCloudFormation(properties.LoggingConfig) : undefined);
2484 ret.addPropertyResult('majorVersion', 'MajorVersion', properties.MajorVersion != null ? cfn_parse.FromCloudFormation.getString(properties.MajorVersion) : undefined);
2485 ret.addPropertyResult('publicTypeArn', 'PublicTypeArn', properties.PublicTypeArn != null ? cfn_parse.FromCloudFormation.getString(properties.PublicTypeArn) : undefined);
2486 ret.addPropertyResult('publisherId', 'PublisherId', properties.PublisherId != null ? cfn_parse.FromCloudFormation.getString(properties.PublisherId) : undefined);
2487 ret.addPropertyResult('type', 'Type', properties.Type != null ? cfn_parse.FromCloudFormation.getString(properties.Type) : undefined);
2488 ret.addPropertyResult('typeName', 'TypeName', properties.TypeName != null ? cfn_parse.FromCloudFormation.getString(properties.TypeName) : undefined);
2489 ret.addPropertyResult('typeNameAlias', 'TypeNameAlias', properties.TypeNameAlias != null ? cfn_parse.FromCloudFormation.getString(properties.TypeNameAlias) : undefined);
2490 ret.addPropertyResult('versionBump', 'VersionBump', properties.VersionBump != null ? cfn_parse.FromCloudFormation.getString(properties.VersionBump) : undefined);
2491 ret.addUnrecognizedPropertiesAsExtra(properties);
2492 return ret;
2493}
2494/**
2495 * A CloudFormation `AWS::CloudFormation::TypeActivation`
2496 *
2497 * Activates a public third-party extension, making it available for use in stack templates. For more information, see [Using public extensions](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/registry-public.html) in the *AWS CloudFormation User Guide* .
2498 *
2499 * Once you have activated a public third-party extension in your account and region, use [SetTypeConfiguration](https://docs.aws.amazon.com/AWSCloudFormation/latest/APIReference/API_SetTypeConfiguration.html) to specify configuration properties for the extension. For more information, see [Configuring extensions at the account level](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/registry-register.html#registry-set-configuration) in the *CloudFormation User Guide* .
2500 *
2501 * @cloudformationResource AWS::CloudFormation::TypeActivation
2502 * @stability external
2503 *
2504 * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-typeactivation.html
2505 */
2506class CfnTypeActivation extends cdk.CfnResource {
2507 /**
2508 * Create a new `AWS::CloudFormation::TypeActivation`.
2509 *
2510 * @param scope - scope in which this resource is defined
2511 * @param id - scoped id of the resource
2512 * @param props - resource properties
2513 */
2514 constructor(scope, id, props = {}) {
2515 super(scope, id, { type: CfnTypeActivation.CFN_RESOURCE_TYPE_NAME, properties: props });
2516 try {
2517 jsiiDeprecationWarnings._aws_cdk_core_Construct(scope);
2518 jsiiDeprecationWarnings._aws_cdk_core_CfnTypeActivationProps(props);
2519 }
2520 catch (error) {
2521 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
2522 Error.captureStackTrace(error, this.constructor);
2523 }
2524 throw error;
2525 }
2526 this.attrArn = cdk.Token.asString(this.getAtt('Arn'));
2527 this.autoUpdate = props.autoUpdate;
2528 this.executionRoleArn = props.executionRoleArn;
2529 this.loggingConfig = props.loggingConfig;
2530 this.majorVersion = props.majorVersion;
2531 this.publicTypeArn = props.publicTypeArn;
2532 this.publisherId = props.publisherId;
2533 this.type = props.type;
2534 this.typeName = props.typeName;
2535 this.typeNameAlias = props.typeNameAlias;
2536 this.versionBump = props.versionBump;
2537 }
2538 /**
2539 * A factory method that creates a new instance of this class from an object
2540 * containing the CloudFormation properties of this resource.
2541 * Used in the @aws-cdk/cloudformation-include module.
2542 *
2543 * @internal
2544 */
2545 static _fromCloudFormation(scope, id, resourceAttributes, options) {
2546 resourceAttributes = resourceAttributes || {};
2547 const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);
2548 const propsResult = CfnTypeActivationPropsFromCloudFormation(resourceProperties);
2549 const ret = new CfnTypeActivation(scope, id, propsResult.value);
2550 for (const [propKey, propVal] of Object.entries(propsResult.extraProperties)) {
2551 ret.addPropertyOverride(propKey, propVal);
2552 }
2553 options.parser.handleAttributes(ret, resourceAttributes, id);
2554 return ret;
2555 }
2556 /**
2557 * Examines the CloudFormation resource and discloses attributes.
2558 *
2559 * @param inspector - tree inspector to collect and process attributes
2560 *
2561 */
2562 inspect(inspector) {
2563 try {
2564 jsiiDeprecationWarnings._aws_cdk_core_TreeInspector(inspector);
2565 }
2566 catch (error) {
2567 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
2568 Error.captureStackTrace(error, this.inspect);
2569 }
2570 throw error;
2571 }
2572 inspector.addAttribute("aws:cdk:cloudformation:type", CfnTypeActivation.CFN_RESOURCE_TYPE_NAME);
2573 inspector.addAttribute("aws:cdk:cloudformation:props", this.cfnProperties);
2574 }
2575 get cfnProperties() {
2576 return {
2577 autoUpdate: this.autoUpdate,
2578 executionRoleArn: this.executionRoleArn,
2579 loggingConfig: this.loggingConfig,
2580 majorVersion: this.majorVersion,
2581 publicTypeArn: this.publicTypeArn,
2582 publisherId: this.publisherId,
2583 type: this.type,
2584 typeName: this.typeName,
2585 typeNameAlias: this.typeNameAlias,
2586 versionBump: this.versionBump,
2587 };
2588 }
2589 renderProperties(props) {
2590 return cfnTypeActivationPropsToCloudFormation(props);
2591 }
2592}
2593exports.CfnTypeActivation = CfnTypeActivation;
2594_p = JSII_RTTI_SYMBOL_1;
2595CfnTypeActivation[_p] = { fqn: "@aws-cdk/core.CfnTypeActivation", version: "1.156.1" };
2596/**
2597 * The CloudFormation resource type name for this resource class.
2598 */
2599CfnTypeActivation.CFN_RESOURCE_TYPE_NAME = "AWS::CloudFormation::TypeActivation";
2600/**
2601 * Determine whether the given properties match those of a `LoggingConfigProperty`
2602 *
2603 * @param properties - the TypeScript properties of a `LoggingConfigProperty`
2604 *
2605 * @returns the result of the validation.
2606 */
2607function CfnTypeActivation_LoggingConfigPropertyValidator(properties) {
2608 if (!cdk.canInspect(properties)) {
2609 return cdk.VALIDATION_SUCCESS;
2610 }
2611 const errors = new cdk.ValidationResults();
2612 if (typeof properties !== 'object') {
2613 errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));
2614 }
2615 errors.collect(cdk.propertyValidator('logGroupName', cdk.validateString)(properties.logGroupName));
2616 errors.collect(cdk.propertyValidator('logRoleArn', cdk.validateString)(properties.logRoleArn));
2617 return errors.wrap('supplied properties not correct for "LoggingConfigProperty"');
2618}
2619/**
2620 * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::TypeActivation.LoggingConfig` resource
2621 *
2622 * @param properties - the TypeScript properties of a `LoggingConfigProperty`
2623 *
2624 * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::TypeActivation.LoggingConfig` resource.
2625 */
2626// @ts-ignore TS6133
2627function cfnTypeActivationLoggingConfigPropertyToCloudFormation(properties) {
2628 if (!cdk.canInspect(properties)) {
2629 return properties;
2630 }
2631 CfnTypeActivation_LoggingConfigPropertyValidator(properties).assertSuccess();
2632 return {
2633 LogGroupName: cdk.stringToCloudFormation(properties.logGroupName),
2634 LogRoleArn: cdk.stringToCloudFormation(properties.logRoleArn),
2635 };
2636}
2637// @ts-ignore TS6133
2638function CfnTypeActivationLoggingConfigPropertyFromCloudFormation(properties) {
2639 if (cdk.isResolvableObject(properties)) {
2640 return new cfn_parse.FromCloudFormationResult(properties);
2641 }
2642 properties = properties == null ? {} : properties;
2643 if (typeof properties !== 'object') {
2644 return new cfn_parse.FromCloudFormationResult(properties);
2645 }
2646 const ret = new cfn_parse.FromCloudFormationPropertyObject();
2647 ret.addPropertyResult('logGroupName', 'LogGroupName', properties.LogGroupName != null ? cfn_parse.FromCloudFormation.getString(properties.LogGroupName) : undefined);
2648 ret.addPropertyResult('logRoleArn', 'LogRoleArn', properties.LogRoleArn != null ? cfn_parse.FromCloudFormation.getString(properties.LogRoleArn) : undefined);
2649 ret.addUnrecognizedPropertiesAsExtra(properties);
2650 return ret;
2651}
2652/**
2653 * Determine whether the given properties match those of a `CfnWaitConditionProps`
2654 *
2655 * @param properties - the TypeScript properties of a `CfnWaitConditionProps`
2656 *
2657 * @returns the result of the validation.
2658 */
2659function CfnWaitConditionPropsValidator(properties) {
2660 if (!cdk.canInspect(properties)) {
2661 return cdk.VALIDATION_SUCCESS;
2662 }
2663 const errors = new cdk.ValidationResults();
2664 if (typeof properties !== 'object') {
2665 errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));
2666 }
2667 errors.collect(cdk.propertyValidator('count', cdk.validateNumber)(properties.count));
2668 errors.collect(cdk.propertyValidator('handle', cdk.validateString)(properties.handle));
2669 errors.collect(cdk.propertyValidator('timeout', cdk.validateString)(properties.timeout));
2670 return errors.wrap('supplied properties not correct for "CfnWaitConditionProps"');
2671}
2672/**
2673 * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::WaitCondition` resource
2674 *
2675 * @param properties - the TypeScript properties of a `CfnWaitConditionProps`
2676 *
2677 * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::WaitCondition` resource.
2678 */
2679// @ts-ignore TS6133
2680function cfnWaitConditionPropsToCloudFormation(properties) {
2681 if (!cdk.canInspect(properties)) {
2682 return properties;
2683 }
2684 CfnWaitConditionPropsValidator(properties).assertSuccess();
2685 return {
2686 Count: cdk.numberToCloudFormation(properties.count),
2687 Handle: cdk.stringToCloudFormation(properties.handle),
2688 Timeout: cdk.stringToCloudFormation(properties.timeout),
2689 };
2690}
2691// @ts-ignore TS6133
2692function CfnWaitConditionPropsFromCloudFormation(properties) {
2693 properties = properties == null ? {} : properties;
2694 if (typeof properties !== 'object') {
2695 return new cfn_parse.FromCloudFormationResult(properties);
2696 }
2697 const ret = new cfn_parse.FromCloudFormationPropertyObject();
2698 ret.addPropertyResult('count', 'Count', properties.Count != null ? cfn_parse.FromCloudFormation.getNumber(properties.Count) : undefined);
2699 ret.addPropertyResult('handle', 'Handle', properties.Handle != null ? cfn_parse.FromCloudFormation.getString(properties.Handle) : undefined);
2700 ret.addPropertyResult('timeout', 'Timeout', properties.Timeout != null ? cfn_parse.FromCloudFormation.getString(properties.Timeout) : undefined);
2701 ret.addUnrecognizedPropertiesAsExtra(properties);
2702 return ret;
2703}
2704/**
2705 * A CloudFormation `AWS::CloudFormation::WaitCondition`
2706 *
2707 * > For Amazon EC2 and Auto Scaling resources, we recommend that you use a `CreationPolicy` attribute instead of wait conditions. Add a CreationPolicy attribute to those resources, and use the cfn-signal helper script to signal when an instance creation process has completed successfully.
2708 *
2709 * You can use a wait condition for situations like the following:
2710 *
2711 * - To coordinate stack resource creation with configuration actions that are external to the stack creation.
2712 * - To track the status of a configuration process.
2713 *
2714 * For these situations, we recommend that you associate a [CreationPolicy](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-attribute-creationpolicy.html) attribute with the wait condition so that you don't have to use a wait condition handle. For more information and an example, see [Creating wait conditions in a template](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/using-cfn-waitcondition.html) . If you use a CreationPolicy with a wait condition, don't specify any of the wait condition's properties.
2715 *
2716 * > If you use the [VPC endpoints](https://docs.aws.amazon.com/vpc/latest/userguide/vpc-endpoints.html) feature, resources in the VPC that respond to wait conditions must have access to CloudFormation , specific Amazon Simple Storage Service ( Amazon S3 ) buckets. Resources must send wait condition responses to a presigned Amazon S3 URL. If they can't send responses to Amazon S3 , CloudFormation won't receive a response and the stack operation fails. For more information, see [Setting up VPC endpoints for AWS CloudFormation](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/cfn-vpce-bucketnames.html) .
2717 *
2718 * @cloudformationResource AWS::CloudFormation::WaitCondition
2719 * @stability external
2720 *
2721 * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-waitcondition.html
2722 */
2723class CfnWaitCondition extends cdk.CfnResource {
2724 /**
2725 * Create a new `AWS::CloudFormation::WaitCondition`.
2726 *
2727 * @param scope - scope in which this resource is defined
2728 * @param id - scoped id of the resource
2729 * @param props - resource properties
2730 */
2731 constructor(scope, id, props = {}) {
2732 super(scope, id, { type: CfnWaitCondition.CFN_RESOURCE_TYPE_NAME, properties: props });
2733 try {
2734 jsiiDeprecationWarnings._aws_cdk_core_Construct(scope);
2735 jsiiDeprecationWarnings._aws_cdk_core_CfnWaitConditionProps(props);
2736 }
2737 catch (error) {
2738 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
2739 Error.captureStackTrace(error, this.constructor);
2740 }
2741 throw error;
2742 }
2743 this.attrData = this.getAtt('Data');
2744 this.count = props.count;
2745 this.handle = props.handle;
2746 this.timeout = props.timeout;
2747 }
2748 /**
2749 * A factory method that creates a new instance of this class from an object
2750 * containing the CloudFormation properties of this resource.
2751 * Used in the @aws-cdk/cloudformation-include module.
2752 *
2753 * @internal
2754 */
2755 static _fromCloudFormation(scope, id, resourceAttributes, options) {
2756 resourceAttributes = resourceAttributes || {};
2757 const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);
2758 const propsResult = CfnWaitConditionPropsFromCloudFormation(resourceProperties);
2759 const ret = new CfnWaitCondition(scope, id, propsResult.value);
2760 for (const [propKey, propVal] of Object.entries(propsResult.extraProperties)) {
2761 ret.addPropertyOverride(propKey, propVal);
2762 }
2763 options.parser.handleAttributes(ret, resourceAttributes, id);
2764 return ret;
2765 }
2766 /**
2767 * Examines the CloudFormation resource and discloses attributes.
2768 *
2769 * @param inspector - tree inspector to collect and process attributes
2770 *
2771 */
2772 inspect(inspector) {
2773 try {
2774 jsiiDeprecationWarnings._aws_cdk_core_TreeInspector(inspector);
2775 }
2776 catch (error) {
2777 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
2778 Error.captureStackTrace(error, this.inspect);
2779 }
2780 throw error;
2781 }
2782 inspector.addAttribute("aws:cdk:cloudformation:type", CfnWaitCondition.CFN_RESOURCE_TYPE_NAME);
2783 inspector.addAttribute("aws:cdk:cloudformation:props", this.cfnProperties);
2784 }
2785 get cfnProperties() {
2786 return {
2787 count: this.count,
2788 handle: this.handle,
2789 timeout: this.timeout,
2790 };
2791 }
2792 renderProperties(props) {
2793 return cfnWaitConditionPropsToCloudFormation(props);
2794 }
2795}
2796exports.CfnWaitCondition = CfnWaitCondition;
2797_q = JSII_RTTI_SYMBOL_1;
2798CfnWaitCondition[_q] = { fqn: "@aws-cdk/core.CfnWaitCondition", version: "1.156.1" };
2799/**
2800 * The CloudFormation resource type name for this resource class.
2801 */
2802CfnWaitCondition.CFN_RESOURCE_TYPE_NAME = "AWS::CloudFormation::WaitCondition";
2803/**
2804 * A CloudFormation `AWS::CloudFormation::WaitConditionHandle`
2805 *
2806 * > For Amazon EC2 and Auto Scaling resources, we recommend that you use a `CreationPolicy` attribute instead of wait conditions. Add a `CreationPolicy` attribute to those resources, and use the cfn-signal helper script to signal when an instance creation process has completed successfully.
2807 * >
2808 * > For more information, see [Deploying applications on Amazon EC2 with AWS CloudFormation](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/deploying.applications.html) .
2809 *
2810 * The `AWS::CloudFormation::WaitConditionHandle` type has no properties. When you reference the `WaitConditionHandle` resource by using the Ref function, AWS CloudFormation returns a presigned URL. You pass this URL to applications or scripts that are running on your Amazon EC2 instances to send signals to that URL. An associated `AWS::CloudFormation::WaitCondition` resource checks the URL for the required number of success signals or for a failure signal.
2811 *
2812 * > Anytime you add a `WaitCondition` resource during a stack update or update a resource with a wait condition, you must associate the wait condition with a new `WaitConditionHandle` resource. Don't reuse an old wait condition handle that has already been defined in the template. If you reuse a wait condition handle, the wait condition might evaluate old signals from a previous create or update stack command. > Updates aren't supported for this resource.
2813 *
2814 * @cloudformationResource AWS::CloudFormation::WaitConditionHandle
2815 * @stability external
2816 *
2817 * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-waitconditionhandle.html
2818 */
2819class CfnWaitConditionHandle extends cdk.CfnResource {
2820 /**
2821 * Create a new `AWS::CloudFormation::WaitConditionHandle`.
2822 *
2823 * @param scope - scope in which this resource is defined
2824 * @param id - scoped id of the resource
2825 * @param props - resource properties
2826 */
2827 constructor(scope, id) {
2828 super(scope, id, { type: CfnWaitConditionHandle.CFN_RESOURCE_TYPE_NAME });
2829 try {
2830 jsiiDeprecationWarnings._aws_cdk_core_Construct(scope);
2831 }
2832 catch (error) {
2833 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
2834 Error.captureStackTrace(error, this.constructor);
2835 }
2836 throw error;
2837 }
2838 }
2839 /**
2840 * A factory method that creates a new instance of this class from an object
2841 * containing the CloudFormation properties of this resource.
2842 * Used in the @aws-cdk/cloudformation-include module.
2843 *
2844 * @internal
2845 */
2846 static _fromCloudFormation(scope, id, resourceAttributes, options) {
2847 resourceAttributes = resourceAttributes || {};
2848 const ret = new CfnWaitConditionHandle(scope, id);
2849 options.parser.handleAttributes(ret, resourceAttributes, id);
2850 return ret;
2851 }
2852 /**
2853 * Examines the CloudFormation resource and discloses attributes.
2854 *
2855 * @param inspector - tree inspector to collect and process attributes
2856 *
2857 */
2858 inspect(inspector) {
2859 try {
2860 jsiiDeprecationWarnings._aws_cdk_core_TreeInspector(inspector);
2861 }
2862 catch (error) {
2863 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
2864 Error.captureStackTrace(error, this.inspect);
2865 }
2866 throw error;
2867 }
2868 inspector.addAttribute("aws:cdk:cloudformation:type", CfnWaitConditionHandle.CFN_RESOURCE_TYPE_NAME);
2869 inspector.addAttribute("aws:cdk:cloudformation:props", this.cfnProperties);
2870 }
2871}
2872exports.CfnWaitConditionHandle = CfnWaitConditionHandle;
2873_r = JSII_RTTI_SYMBOL_1;
2874CfnWaitConditionHandle[_r] = { fqn: "@aws-cdk/core.CfnWaitConditionHandle", version: "1.156.1" };
2875/**
2876 * The CloudFormation resource type name for this resource class.
2877 */
2878CfnWaitConditionHandle.CFN_RESOURCE_TYPE_NAME = "AWS::CloudFormation::WaitConditionHandle";
2879//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cloudformation.generated.js","sourceRoot":"","sources":["cloudformation.generated.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright 2012-2022 Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// Generated from the AWS CloudFormation Resource Specification\n// See: docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/cfn-resource-specification.html\n// @cfn2ts:meta@ {\"generated\":\"2022-05-13T00:24:44.574Z\",\"fingerprint\":\"schANqcaMLRpaxmk9lx2rbv78Epyd5CHho0EXijYaDM=\"}\n\n/* eslint-disable max-len */ // This is generated code - line lengths are difficult to control\n\nimport * as cdk from '.';\nimport * as cfn_parse from './helpers-internal';\n\n/**\n * Properties for defining a `CfnCustomResource`\n *\n * @struct\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cfn-customresource.html\n */\nexport interface CfnCustomResourceProps {\n\n    /**\n     * > Only one property is defined by AWS for a custom resource: `ServiceToken` . All other properties are defined by the service provider.\n     *\n     * The service token that was given to the template developer by the service provider to access the service, such as an Amazon SNS topic ARN or Lambda function ARN. The service token must be from the same Region in which you are creating the stack.\n     *\n     * Updates aren't supported.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cfn-customresource.html#cfn-customresource-servicetoken\n     */\n    readonly serviceToken: string;\n}\n\n/**\n * Determine whether the given properties match those of a `CfnCustomResourceProps`\n *\n * @param properties - the TypeScript properties of a `CfnCustomResourceProps`\n *\n * @returns the result of the validation.\n */\nfunction CfnCustomResourcePropsValidator(properties: any): cdk.ValidationResult {\n    if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n    const errors = new cdk.ValidationResults();\n    if (typeof properties !== 'object') {\n        errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));\n    }\n    errors.collect(cdk.propertyValidator('serviceToken', cdk.requiredValidator)(properties.serviceToken));\n    errors.collect(cdk.propertyValidator('serviceToken', cdk.validateString)(properties.serviceToken));\n    return errors.wrap('supplied properties not correct for \"CfnCustomResourceProps\"');\n}\n\n/**\n * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::CustomResource` resource\n *\n * @param properties - the TypeScript properties of a `CfnCustomResourceProps`\n *\n * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::CustomResource` resource.\n */\n// @ts-ignore TS6133\nfunction cfnCustomResourcePropsToCloudFormation(properties: any): any {\n    if (!cdk.canInspect(properties)) { return properties; }\n    CfnCustomResourcePropsValidator(properties).assertSuccess();\n    return {\n        ServiceToken: cdk.stringToCloudFormation(properties.serviceToken),\n    };\n}\n\n// @ts-ignore TS6133\nfunction CfnCustomResourcePropsFromCloudFormation(properties: any): cfn_parse.FromCloudFormationResult<CfnCustomResourceProps> {\n    properties = properties == null ? {} : properties;\n    if (typeof properties !== 'object') {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    const ret = new cfn_parse.FromCloudFormationPropertyObject<CfnCustomResourceProps>();\n    ret.addPropertyResult('serviceToken', 'ServiceToken', cfn_parse.FromCloudFormation.getString(properties.ServiceToken));\n    ret.addUnrecognizedPropertiesAsExtra(properties);\n    return ret;\n}\n\n/**\n * A CloudFormation `AWS::CloudFormation::CustomResource`\n *\n * In a CloudFormation template, you use the `AWS::CloudFormation::CustomResource` or `Custom:: *String*` resource type to specify custom resources.\n *\n * Custom resources provide a way for you to write custom provisioning logic in CloudFormation template and have CloudFormation run it during a stack operation, such as when you create, update or delete a stack. For more information, see [Custom resources](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/template-custom-resources.html) .\n *\n * > If you use the [VPC endpoints](https://docs.aws.amazon.com/vpc/latest/userguide/vpc-endpoints.html) feature, custom resources in the VPC must have access to CloudFormation -specific Amazon Simple Storage Service ( Amazon S3 ) buckets. Custom resources must send responses to a presigned Amazon S3 URL. If they can't send responses to Amazon S3 , CloudFormation won't receive a response and the stack operation fails. For more information, see [Setting up VPC endpoints for AWS CloudFormation](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/cfn-vpce-bucketnames.html) .\n *\n * @cloudformationResource AWS::CloudFormation::CustomResource\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cfn-customresource.html\n */\nexport class CfnCustomResource extends cdk.CfnResource implements cdk.IInspectable {\n    /**\n     * The CloudFormation resource type name for this resource class.\n     */\n    public static readonly CFN_RESOURCE_TYPE_NAME = \"AWS::CloudFormation::CustomResource\";\n\n    /**\n     * A factory method that creates a new instance of this class from an object\n     * containing the CloudFormation properties of this resource.\n     * Used in the @aws-cdk/cloudformation-include module.\n     *\n     * @internal\n     */\n    public static _fromCloudFormation(scope: cdk.Construct, id: string, resourceAttributes: any, options: cfn_parse.FromCloudFormationOptions): CfnCustomResource {\n        resourceAttributes = resourceAttributes || {};\n        const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);\n        const propsResult = CfnCustomResourcePropsFromCloudFormation(resourceProperties);\n        const ret = new CfnCustomResource(scope, id, propsResult.value);\n        for (const [propKey, propVal] of Object.entries(propsResult.extraProperties))  {\n            ret.addPropertyOverride(propKey, propVal);\n        }\n        options.parser.handleAttributes(ret, resourceAttributes, id);\n        return ret;\n    }\n\n    /**\n     * > Only one property is defined by AWS for a custom resource: `ServiceToken` . All other properties are defined by the service provider.\n     *\n     * The service token that was given to the template developer by the service provider to access the service, such as an Amazon SNS topic ARN or Lambda function ARN. The service token must be from the same Region in which you are creating the stack.\n     *\n     * Updates aren't supported.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cfn-customresource.html#cfn-customresource-servicetoken\n     */\n    public serviceToken: string;\n\n    /**\n     * Create a new `AWS::CloudFormation::CustomResource`.\n     *\n     * @param scope - scope in which this resource is defined\n     * @param id    - scoped id of the resource\n     * @param props - resource properties\n     */\n    constructor(scope: cdk.Construct, id: string, props: CfnCustomResourceProps) {\n        super(scope, id, { type: CfnCustomResource.CFN_RESOURCE_TYPE_NAME, properties: props });\n        cdk.requireProperty(props, 'serviceToken', this);\n\n        this.serviceToken = props.serviceToken;\n    }\n\n    /**\n     * Examines the CloudFormation resource and discloses attributes.\n     *\n     * @param inspector - tree inspector to collect and process attributes\n     *\n     */\n    public inspect(inspector: cdk.TreeInspector) {\n        inspector.addAttribute(\"aws:cdk:cloudformation:type\", CfnCustomResource.CFN_RESOURCE_TYPE_NAME);\n        inspector.addAttribute(\"aws:cdk:cloudformation:props\", this.cfnProperties);\n    }\n\n    protected get cfnProperties(): { [key: string]: any }  {\n        return {\n            serviceToken: this.serviceToken,\n        };\n    }\n\n    protected renderProperties(props: {[key: string]: any}): { [key: string]: any }  {\n        return cfnCustomResourcePropsToCloudFormation(props);\n    }\n}\n\n/**\n * Properties for defining a `CfnHookDefaultVersion`\n *\n * @struct\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hookdefaultversion.html\n */\nexport interface CfnHookDefaultVersionProps {\n\n    /**\n     * The name of the hook.\n     *\n     * You must specify either `TypeVersionArn` , or `TypeName` and `VersionId` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hookdefaultversion.html#cfn-cloudformation-hookdefaultversion-typename\n     */\n    readonly typeName?: string;\n\n    /**\n     * The version ID of the type configuration.\n     *\n     * You must specify either `TypeVersionArn` , or `TypeName` and `VersionId` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hookdefaultversion.html#cfn-cloudformation-hookdefaultversion-typeversionarn\n     */\n    readonly typeVersionArn?: string;\n\n    /**\n     * The version ID of the type specified.\n     *\n     * You must specify either `TypeVersionArn` , or `TypeName` and `VersionId` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hookdefaultversion.html#cfn-cloudformation-hookdefaultversion-versionid\n     */\n    readonly versionId?: string;\n}\n\n/**\n * Determine whether the given properties match those of a `CfnHookDefaultVersionProps`\n *\n * @param properties - the TypeScript properties of a `CfnHookDefaultVersionProps`\n *\n * @returns the result of the validation.\n */\nfunction CfnHookDefaultVersionPropsValidator(properties: any): cdk.ValidationResult {\n    if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n    const errors = new cdk.ValidationResults();\n    if (typeof properties !== 'object') {\n        errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));\n    }\n    errors.collect(cdk.propertyValidator('typeName', cdk.validateString)(properties.typeName));\n    errors.collect(cdk.propertyValidator('typeVersionArn', cdk.validateString)(properties.typeVersionArn));\n    errors.collect(cdk.propertyValidator('versionId', cdk.validateString)(properties.versionId));\n    return errors.wrap('supplied properties not correct for \"CfnHookDefaultVersionProps\"');\n}\n\n/**\n * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::HookDefaultVersion` resource\n *\n * @param properties - the TypeScript properties of a `CfnHookDefaultVersionProps`\n *\n * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::HookDefaultVersion` resource.\n */\n// @ts-ignore TS6133\nfunction cfnHookDefaultVersionPropsToCloudFormation(properties: any): any {\n    if (!cdk.canInspect(properties)) { return properties; }\n    CfnHookDefaultVersionPropsValidator(properties).assertSuccess();\n    return {\n        TypeName: cdk.stringToCloudFormation(properties.typeName),\n        TypeVersionArn: cdk.stringToCloudFormation(properties.typeVersionArn),\n        VersionId: cdk.stringToCloudFormation(properties.versionId),\n    };\n}\n\n// @ts-ignore TS6133\nfunction CfnHookDefaultVersionPropsFromCloudFormation(properties: any): cfn_parse.FromCloudFormationResult<CfnHookDefaultVersionProps> {\n    properties = properties == null ? {} : properties;\n    if (typeof properties !== 'object') {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    const ret = new cfn_parse.FromCloudFormationPropertyObject<CfnHookDefaultVersionProps>();\n    ret.addPropertyResult('typeName', 'TypeName', properties.TypeName != null ? cfn_parse.FromCloudFormation.getString(properties.TypeName) : undefined);\n    ret.addPropertyResult('typeVersionArn', 'TypeVersionArn', properties.TypeVersionArn != null ? cfn_parse.FromCloudFormation.getString(properties.TypeVersionArn) : undefined);\n    ret.addPropertyResult('versionId', 'VersionId', properties.VersionId != null ? cfn_parse.FromCloudFormation.getString(properties.VersionId) : undefined);\n    ret.addUnrecognizedPropertiesAsExtra(properties);\n    return ret;\n}\n\n/**\n * A CloudFormation `AWS::CloudFormation::HookDefaultVersion`\n *\n * The `HookDefaultVersion` resource specifies the default version of the hook. The default version of the hook is used in CloudFormation operations for this AWS account and AWS Region .\n *\n * @cloudformationResource AWS::CloudFormation::HookDefaultVersion\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hookdefaultversion.html\n */\nexport class CfnHookDefaultVersion extends cdk.CfnResource implements cdk.IInspectable {\n    /**\n     * The CloudFormation resource type name for this resource class.\n     */\n    public static readonly CFN_RESOURCE_TYPE_NAME = \"AWS::CloudFormation::HookDefaultVersion\";\n\n    /**\n     * A factory method that creates a new instance of this class from an object\n     * containing the CloudFormation properties of this resource.\n     * Used in the @aws-cdk/cloudformation-include module.\n     *\n     * @internal\n     */\n    public static _fromCloudFormation(scope: cdk.Construct, id: string, resourceAttributes: any, options: cfn_parse.FromCloudFormationOptions): CfnHookDefaultVersion {\n        resourceAttributes = resourceAttributes || {};\n        const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);\n        const propsResult = CfnHookDefaultVersionPropsFromCloudFormation(resourceProperties);\n        const ret = new CfnHookDefaultVersion(scope, id, propsResult.value);\n        for (const [propKey, propVal] of Object.entries(propsResult.extraProperties))  {\n            ret.addPropertyOverride(propKey, propVal);\n        }\n        options.parser.handleAttributes(ret, resourceAttributes, id);\n        return ret;\n    }\n\n    /**\n     * The Amazon Resource Number (ARN) of the activated extension, in this account and Region.\n     * @cloudformationAttribute Arn\n     */\n    public readonly attrArn: string;\n\n    /**\n     * The name of the hook.\n     *\n     * You must specify either `TypeVersionArn` , or `TypeName` and `VersionId` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hookdefaultversion.html#cfn-cloudformation-hookdefaultversion-typename\n     */\n    public typeName: string | undefined;\n\n    /**\n     * The version ID of the type configuration.\n     *\n     * You must specify either `TypeVersionArn` , or `TypeName` and `VersionId` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hookdefaultversion.html#cfn-cloudformation-hookdefaultversion-typeversionarn\n     */\n    public typeVersionArn: string | undefined;\n\n    /**\n     * The version ID of the type specified.\n     *\n     * You must specify either `TypeVersionArn` , or `TypeName` and `VersionId` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hookdefaultversion.html#cfn-cloudformation-hookdefaultversion-versionid\n     */\n    public versionId: string | undefined;\n\n    /**\n     * Create a new `AWS::CloudFormation::HookDefaultVersion`.\n     *\n     * @param scope - scope in which this resource is defined\n     * @param id    - scoped id of the resource\n     * @param props - resource properties\n     */\n    constructor(scope: cdk.Construct, id: string, props: CfnHookDefaultVersionProps = {}) {\n        super(scope, id, { type: CfnHookDefaultVersion.CFN_RESOURCE_TYPE_NAME, properties: props });\n        this.attrArn = cdk.Token.asString(this.getAtt('Arn'));\n\n        this.typeName = props.typeName;\n        this.typeVersionArn = props.typeVersionArn;\n        this.versionId = props.versionId;\n    }\n\n    /**\n     * Examines the CloudFormation resource and discloses attributes.\n     *\n     * @param inspector - tree inspector to collect and process attributes\n     *\n     */\n    public inspect(inspector: cdk.TreeInspector) {\n        inspector.addAttribute(\"aws:cdk:cloudformation:type\", CfnHookDefaultVersion.CFN_RESOURCE_TYPE_NAME);\n        inspector.addAttribute(\"aws:cdk:cloudformation:props\", this.cfnProperties);\n    }\n\n    protected get cfnProperties(): { [key: string]: any }  {\n        return {\n            typeName: this.typeName,\n            typeVersionArn: this.typeVersionArn,\n            versionId: this.versionId,\n        };\n    }\n\n    protected renderProperties(props: {[key: string]: any}): { [key: string]: any }  {\n        return cfnHookDefaultVersionPropsToCloudFormation(props);\n    }\n}\n\n/**\n * Properties for defining a `CfnHookTypeConfig`\n *\n * @struct\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hooktypeconfig.html\n */\nexport interface CfnHookTypeConfigProps {\n\n    /**\n     * Specifies the activated hook type configuration, in this AWS account and AWS Region .\n     *\n     * You must specify either `TypeName` and `Configuration` or `TypeARN` and `Configuration` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hooktypeconfig.html#cfn-cloudformation-hooktypeconfig-configuration\n     */\n    readonly configuration: string;\n\n    /**\n     * Specifies the activated hook type configuration, in this AWS account and AWS Region .\n     *\n     * Defaults to `default` alias. Hook types currently support default configuration alias.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hooktypeconfig.html#cfn-cloudformation-hooktypeconfig-configurationalias\n     */\n    readonly configurationAlias?: string;\n\n    /**\n     * The Amazon Resource Number (ARN) for the hook to set `Configuration` for.\n     *\n     * You must specify either `TypeName` and `Configuration` or `TypeARN` and `Configuration` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hooktypeconfig.html#cfn-cloudformation-hooktypeconfig-typearn\n     */\n    readonly typeArn?: string;\n\n    /**\n     * The unique name for your hook. Specifies a three-part namespace for your hook, with a recommended pattern of `Organization::Service::Hook` .\n     *\n     * You must specify either `TypeName` and `Configuration` or `TypeARN` and `Configuration` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hooktypeconfig.html#cfn-cloudformation-hooktypeconfig-typename\n     */\n    readonly typeName?: string;\n}\n\n/**\n * Determine whether the given properties match those of a `CfnHookTypeConfigProps`\n *\n * @param properties - the TypeScript properties of a `CfnHookTypeConfigProps`\n *\n * @returns the result of the validation.\n */\nfunction CfnHookTypeConfigPropsValidator(properties: any): cdk.ValidationResult {\n    if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n    const errors = new cdk.ValidationResults();\n    if (typeof properties !== 'object') {\n        errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));\n    }\n    errors.collect(cdk.propertyValidator('configuration', cdk.requiredValidator)(properties.configuration));\n    errors.collect(cdk.propertyValidator('configuration', cdk.validateString)(properties.configuration));\n    errors.collect(cdk.propertyValidator('configurationAlias', cdk.validateString)(properties.configurationAlias));\n    errors.collect(cdk.propertyValidator('typeArn', cdk.validateString)(properties.typeArn));\n    errors.collect(cdk.propertyValidator('typeName', cdk.validateString)(properties.typeName));\n    return errors.wrap('supplied properties not correct for \"CfnHookTypeConfigProps\"');\n}\n\n/**\n * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::HookTypeConfig` resource\n *\n * @param properties - the TypeScript properties of a `CfnHookTypeConfigProps`\n *\n * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::HookTypeConfig` resource.\n */\n// @ts-ignore TS6133\nfunction cfnHookTypeConfigPropsToCloudFormation(properties: any): any {\n    if (!cdk.canInspect(properties)) { return properties; }\n    CfnHookTypeConfigPropsValidator(properties).assertSuccess();\n    return {\n        Configuration: cdk.stringToCloudFormation(properties.configuration),\n        ConfigurationAlias: cdk.stringToCloudFormation(properties.configurationAlias),\n        TypeArn: cdk.stringToCloudFormation(properties.typeArn),\n        TypeName: cdk.stringToCloudFormation(properties.typeName),\n    };\n}\n\n// @ts-ignore TS6133\nfunction CfnHookTypeConfigPropsFromCloudFormation(properties: any): cfn_parse.FromCloudFormationResult<CfnHookTypeConfigProps> {\n    properties = properties == null ? {} : properties;\n    if (typeof properties !== 'object') {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    const ret = new cfn_parse.FromCloudFormationPropertyObject<CfnHookTypeConfigProps>();\n    ret.addPropertyResult('configuration', 'Configuration', cfn_parse.FromCloudFormation.getString(properties.Configuration));\n    ret.addPropertyResult('configurationAlias', 'ConfigurationAlias', properties.ConfigurationAlias != null ? cfn_parse.FromCloudFormation.getString(properties.ConfigurationAlias) : undefined);\n    ret.addPropertyResult('typeArn', 'TypeArn', properties.TypeArn != null ? cfn_parse.FromCloudFormation.getString(properties.TypeArn) : undefined);\n    ret.addPropertyResult('typeName', 'TypeName', properties.TypeName != null ? cfn_parse.FromCloudFormation.getString(properties.TypeName) : undefined);\n    ret.addUnrecognizedPropertiesAsExtra(properties);\n    return ret;\n}\n\n/**\n * A CloudFormation `AWS::CloudFormation::HookTypeConfig`\n *\n * The `HookTypeConfig` resource specifies the configuration of a hook.\n *\n * @cloudformationResource AWS::CloudFormation::HookTypeConfig\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hooktypeconfig.html\n */\nexport class CfnHookTypeConfig extends cdk.CfnResource implements cdk.IInspectable {\n    /**\n     * The CloudFormation resource type name for this resource class.\n     */\n    public static readonly CFN_RESOURCE_TYPE_NAME = \"AWS::CloudFormation::HookTypeConfig\";\n\n    /**\n     * A factory method that creates a new instance of this class from an object\n     * containing the CloudFormation properties of this resource.\n     * Used in the @aws-cdk/cloudformation-include module.\n     *\n     * @internal\n     */\n    public static _fromCloudFormation(scope: cdk.Construct, id: string, resourceAttributes: any, options: cfn_parse.FromCloudFormationOptions): CfnHookTypeConfig {\n        resourceAttributes = resourceAttributes || {};\n        const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);\n        const propsResult = CfnHookTypeConfigPropsFromCloudFormation(resourceProperties);\n        const ret = new CfnHookTypeConfig(scope, id, propsResult.value);\n        for (const [propKey, propVal] of Object.entries(propsResult.extraProperties))  {\n            ret.addPropertyOverride(propKey, propVal);\n        }\n        options.parser.handleAttributes(ret, resourceAttributes, id);\n        return ret;\n    }\n\n    /**\n     * The Amazon Resource Number (ARN) of the activated hook type configuration, in this account and Region.\n     * @cloudformationAttribute ConfigurationArn\n     */\n    public readonly attrConfigurationArn: string;\n\n    /**\n     * Specifies the activated hook type configuration, in this AWS account and AWS Region .\n     *\n     * You must specify either `TypeName` and `Configuration` or `TypeARN` and `Configuration` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hooktypeconfig.html#cfn-cloudformation-hooktypeconfig-configuration\n     */\n    public configuration: string;\n\n    /**\n     * Specifies the activated hook type configuration, in this AWS account and AWS Region .\n     *\n     * Defaults to `default` alias. Hook types currently support default configuration alias.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hooktypeconfig.html#cfn-cloudformation-hooktypeconfig-configurationalias\n     */\n    public configurationAlias: string | undefined;\n\n    /**\n     * The Amazon Resource Number (ARN) for the hook to set `Configuration` for.\n     *\n     * You must specify either `TypeName` and `Configuration` or `TypeARN` and `Configuration` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hooktypeconfig.html#cfn-cloudformation-hooktypeconfig-typearn\n     */\n    public typeArn: string | undefined;\n\n    /**\n     * The unique name for your hook. Specifies a three-part namespace for your hook, with a recommended pattern of `Organization::Service::Hook` .\n     *\n     * You must specify either `TypeName` and `Configuration` or `TypeARN` and `Configuration` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hooktypeconfig.html#cfn-cloudformation-hooktypeconfig-typename\n     */\n    public typeName: string | undefined;\n\n    /**\n     * Create a new `AWS::CloudFormation::HookTypeConfig`.\n     *\n     * @param scope - scope in which this resource is defined\n     * @param id    - scoped id of the resource\n     * @param props - resource properties\n     */\n    constructor(scope: cdk.Construct, id: string, props: CfnHookTypeConfigProps) {\n        super(scope, id, { type: CfnHookTypeConfig.CFN_RESOURCE_TYPE_NAME, properties: props });\n        cdk.requireProperty(props, 'configuration', this);\n        this.attrConfigurationArn = cdk.Token.asString(this.getAtt('ConfigurationArn'));\n\n        this.configuration = props.configuration;\n        this.configurationAlias = props.configurationAlias;\n        this.typeArn = props.typeArn;\n        this.typeName = props.typeName;\n    }\n\n    /**\n     * Examines the CloudFormation resource and discloses attributes.\n     *\n     * @param inspector - tree inspector to collect and process attributes\n     *\n     */\n    public inspect(inspector: cdk.TreeInspector) {\n        inspector.addAttribute(\"aws:cdk:cloudformation:type\", CfnHookTypeConfig.CFN_RESOURCE_TYPE_NAME);\n        inspector.addAttribute(\"aws:cdk:cloudformation:props\", this.cfnProperties);\n    }\n\n    protected get cfnProperties(): { [key: string]: any }  {\n        return {\n            configuration: this.configuration,\n            configurationAlias: this.configurationAlias,\n            typeArn: this.typeArn,\n            typeName: this.typeName,\n        };\n    }\n\n    protected renderProperties(props: {[key: string]: any}): { [key: string]: any }  {\n        return cfnHookTypeConfigPropsToCloudFormation(props);\n    }\n}\n\n/**\n * Properties for defining a `CfnHookVersion`\n *\n * @struct\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hookversion.html\n */\nexport interface CfnHookVersionProps {\n\n    /**\n     * A URL to the Amazon S3 bucket containing the hook project package that contains the necessary files for the hook you want to register.\n     *\n     * For information on generating a schema handler package for the resource you want to register, see [submit](https://docs.aws.amazon.com/cloudformation-cli/latest/userguide/resource-type-cli-submit.html) in the *CloudFormation CLI User Guide for Extension Development* .\n     *\n     * > The user registering the resource must be able to access the package in the S3 bucket. That's, the user must have [GetObject](https://docs.aws.amazon.com/AmazonS3/latest/API/API_GetObject.html) permissions for the schema handler package. For more information, see [Actions, Resources, and Condition Keys for Amazon S3](https://docs.aws.amazon.com/IAM/latest/UserGuide/list_amazons3.html) in the *AWS Identity and Access Management User Guide* .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hookversion.html#cfn-cloudformation-hookversion-schemahandlerpackage\n     */\n    readonly schemaHandlerPackage: string;\n\n    /**\n     * The unique name for your hook. Specifies a three-part namespace for your hook, with a recommended pattern of `Organization::Service::Hook` .\n     *\n     * > The following organization namespaces are reserved and can't be used in your hook type names:\n     * >\n     * > - `Alexa`\n     * > - `AMZN`\n     * > - `Amazon`\n     * > - `ASK`\n     * > - `AWS`\n     * > - `Custom`\n     * > - `Dev`\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hookversion.html#cfn-cloudformation-hookversion-typename\n     */\n    readonly typeName: string;\n\n    /**\n     * The Amazon Resource Name (ARN) of the task execution role that grants the hook permission.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hookversion.html#cfn-cloudformation-hookversion-executionrolearn\n     */\n    readonly executionRoleArn?: string;\n\n    /**\n     * Contains logging configuration information for an extension.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hookversion.html#cfn-cloudformation-hookversion-loggingconfig\n     */\n    readonly loggingConfig?: CfnHookVersion.LoggingConfigProperty | cdk.IResolvable;\n}\n\n/**\n * Determine whether the given properties match those of a `CfnHookVersionProps`\n *\n * @param properties - the TypeScript properties of a `CfnHookVersionProps`\n *\n * @returns the result of the validation.\n */\nfunction CfnHookVersionPropsValidator(properties: any): cdk.ValidationResult {\n    if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n    const errors = new cdk.ValidationResults();\n    if (typeof properties !== 'object') {\n        errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));\n    }\n    errors.collect(cdk.propertyValidator('executionRoleArn', cdk.validateString)(properties.executionRoleArn));\n    errors.collect(cdk.propertyValidator('loggingConfig', CfnHookVersion_LoggingConfigPropertyValidator)(properties.loggingConfig));\n    errors.collect(cdk.propertyValidator('schemaHandlerPackage', cdk.requiredValidator)(properties.schemaHandlerPackage));\n    errors.collect(cdk.propertyValidator('schemaHandlerPackage', cdk.validateString)(properties.schemaHandlerPackage));\n    errors.collect(cdk.propertyValidator('typeName', cdk.requiredValidator)(properties.typeName));\n    errors.collect(cdk.propertyValidator('typeName', cdk.validateString)(properties.typeName));\n    return errors.wrap('supplied properties not correct for \"CfnHookVersionProps\"');\n}\n\n/**\n * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::HookVersion` resource\n *\n * @param properties - the TypeScript properties of a `CfnHookVersionProps`\n *\n * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::HookVersion` resource.\n */\n// @ts-ignore TS6133\nfunction cfnHookVersionPropsToCloudFormation(properties: any): any {\n    if (!cdk.canInspect(properties)) { return properties; }\n    CfnHookVersionPropsValidator(properties).assertSuccess();\n    return {\n        SchemaHandlerPackage: cdk.stringToCloudFormation(properties.schemaHandlerPackage),\n        TypeName: cdk.stringToCloudFormation(properties.typeName),\n        ExecutionRoleArn: cdk.stringToCloudFormation(properties.executionRoleArn),\n        LoggingConfig: cfnHookVersionLoggingConfigPropertyToCloudFormation(properties.loggingConfig),\n    };\n}\n\n// @ts-ignore TS6133\nfunction CfnHookVersionPropsFromCloudFormation(properties: any): cfn_parse.FromCloudFormationResult<CfnHookVersionProps> {\n    properties = properties == null ? {} : properties;\n    if (typeof properties !== 'object') {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    const ret = new cfn_parse.FromCloudFormationPropertyObject<CfnHookVersionProps>();\n    ret.addPropertyResult('schemaHandlerPackage', 'SchemaHandlerPackage', cfn_parse.FromCloudFormation.getString(properties.SchemaHandlerPackage));\n    ret.addPropertyResult('typeName', 'TypeName', cfn_parse.FromCloudFormation.getString(properties.TypeName));\n    ret.addPropertyResult('executionRoleArn', 'ExecutionRoleArn', properties.ExecutionRoleArn != null ? cfn_parse.FromCloudFormation.getString(properties.ExecutionRoleArn) : undefined);\n    ret.addPropertyResult('loggingConfig', 'LoggingConfig', properties.LoggingConfig != null ? CfnHookVersionLoggingConfigPropertyFromCloudFormation(properties.LoggingConfig) : undefined);\n    ret.addUnrecognizedPropertiesAsExtra(properties);\n    return ret;\n}\n\n/**\n * A CloudFormation `AWS::CloudFormation::HookVersion`\n *\n * The `HookVersion` resource publishes new or first hook version to the AWS CloudFormation registry.\n *\n * @cloudformationResource AWS::CloudFormation::HookVersion\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hookversion.html\n */\nexport class CfnHookVersion extends cdk.CfnResource implements cdk.IInspectable {\n    /**\n     * The CloudFormation resource type name for this resource class.\n     */\n    public static readonly CFN_RESOURCE_TYPE_NAME = \"AWS::CloudFormation::HookVersion\";\n\n    /**\n     * A factory method that creates a new instance of this class from an object\n     * containing the CloudFormation properties of this resource.\n     * Used in the @aws-cdk/cloudformation-include module.\n     *\n     * @internal\n     */\n    public static _fromCloudFormation(scope: cdk.Construct, id: string, resourceAttributes: any, options: cfn_parse.FromCloudFormationOptions): CfnHookVersion {\n        resourceAttributes = resourceAttributes || {};\n        const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);\n        const propsResult = CfnHookVersionPropsFromCloudFormation(resourceProperties);\n        const ret = new CfnHookVersion(scope, id, propsResult.value);\n        for (const [propKey, propVal] of Object.entries(propsResult.extraProperties))  {\n            ret.addPropertyOverride(propKey, propVal);\n        }\n        options.parser.handleAttributes(ret, resourceAttributes, id);\n        return ret;\n    }\n\n    /**\n     * The Amazon Resource Name (ARN) of the hook.\n     * @cloudformationAttribute Arn\n     */\n    public readonly attrArn: string;\n\n    /**\n     * Whether the specified hook version is set as the default version.\n     * @cloudformationAttribute IsDefaultVersion\n     */\n    public readonly attrIsDefaultVersion: cdk.IResolvable;\n\n    /**\n     * The Amazon Resource Number (ARN) assigned to this version of the hook.\n     * @cloudformationAttribute TypeArn\n     */\n    public readonly attrTypeArn: string;\n\n    /**\n     * The ID of this version of the hook.\n     * @cloudformationAttribute VersionId\n     */\n    public readonly attrVersionId: string;\n\n    /**\n     * The scope at which the resource is visible and usable in CloudFormation operations.\n     *\n     * Valid values include:\n     *\n     * - `PRIVATE` : The resource is only visible and usable within the account in which it's registered. CloudFormation marks any resources you register as `PRIVATE` .\n     * - `PUBLIC` : The resource is publicly visible and usable within any Amazon account.\n     * @cloudformationAttribute Visibility\n     */\n    public readonly attrVisibility: string;\n\n    /**\n     * A URL to the Amazon S3 bucket containing the hook project package that contains the necessary files for the hook you want to register.\n     *\n     * For information on generating a schema handler package for the resource you want to register, see [submit](https://docs.aws.amazon.com/cloudformation-cli/latest/userguide/resource-type-cli-submit.html) in the *CloudFormation CLI User Guide for Extension Development* .\n     *\n     * > The user registering the resource must be able to access the package in the S3 bucket. That's, the user must have [GetObject](https://docs.aws.amazon.com/AmazonS3/latest/API/API_GetObject.html) permissions for the schema handler package. For more information, see [Actions, Resources, and Condition Keys for Amazon S3](https://docs.aws.amazon.com/IAM/latest/UserGuide/list_amazons3.html) in the *AWS Identity and Access Management User Guide* .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hookversion.html#cfn-cloudformation-hookversion-schemahandlerpackage\n     */\n    public schemaHandlerPackage: string;\n\n    /**\n     * The unique name for your hook. Specifies a three-part namespace for your hook, with a recommended pattern of `Organization::Service::Hook` .\n     *\n     * > The following organization namespaces are reserved and can't be used in your hook type names:\n     * >\n     * > - `Alexa`\n     * > - `AMZN`\n     * > - `Amazon`\n     * > - `ASK`\n     * > - `AWS`\n     * > - `Custom`\n     * > - `Dev`\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hookversion.html#cfn-cloudformation-hookversion-typename\n     */\n    public typeName: string;\n\n    /**\n     * The Amazon Resource Name (ARN) of the task execution role that grants the hook permission.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hookversion.html#cfn-cloudformation-hookversion-executionrolearn\n     */\n    public executionRoleArn: string | undefined;\n\n    /**\n     * Contains logging configuration information for an extension.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-hookversion.html#cfn-cloudformation-hookversion-loggingconfig\n     */\n    public loggingConfig: CfnHookVersion.LoggingConfigProperty | cdk.IResolvable | undefined;\n\n    /**\n     * Create a new `AWS::CloudFormation::HookVersion`.\n     *\n     * @param scope - scope in which this resource is defined\n     * @param id    - scoped id of the resource\n     * @param props - resource properties\n     */\n    constructor(scope: cdk.Construct, id: string, props: CfnHookVersionProps) {\n        super(scope, id, { type: CfnHookVersion.CFN_RESOURCE_TYPE_NAME, properties: props });\n        cdk.requireProperty(props, 'schemaHandlerPackage', this);\n        cdk.requireProperty(props, 'typeName', this);\n        this.attrArn = cdk.Token.asString(this.getAtt('Arn'));\n        this.attrIsDefaultVersion = this.getAtt('IsDefaultVersion');\n        this.attrTypeArn = cdk.Token.asString(this.getAtt('TypeArn'));\n        this.attrVersionId = cdk.Token.asString(this.getAtt('VersionId'));\n        this.attrVisibility = cdk.Token.asString(this.getAtt('Visibility'));\n\n        this.schemaHandlerPackage = props.schemaHandlerPackage;\n        this.typeName = props.typeName;\n        this.executionRoleArn = props.executionRoleArn;\n        this.loggingConfig = props.loggingConfig;\n    }\n\n    /**\n     * Examines the CloudFormation resource and discloses attributes.\n     *\n     * @param inspector - tree inspector to collect and process attributes\n     *\n     */\n    public inspect(inspector: cdk.TreeInspector) {\n        inspector.addAttribute(\"aws:cdk:cloudformation:type\", CfnHookVersion.CFN_RESOURCE_TYPE_NAME);\n        inspector.addAttribute(\"aws:cdk:cloudformation:props\", this.cfnProperties);\n    }\n\n    protected get cfnProperties(): { [key: string]: any }  {\n        return {\n            schemaHandlerPackage: this.schemaHandlerPackage,\n            typeName: this.typeName,\n            executionRoleArn: this.executionRoleArn,\n            loggingConfig: this.loggingConfig,\n        };\n    }\n\n    protected renderProperties(props: {[key: string]: any}): { [key: string]: any }  {\n        return cfnHookVersionPropsToCloudFormation(props);\n    }\n}\n\nexport namespace CfnHookVersion {\n    /**\n     * The `LoggingConfig` property type specifies logging configuration information for an extension.\n     *\n     * @struct\n     * @stability external\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-hookversion-loggingconfig.html\n     */\n    export interface LoggingConfigProperty {\n        /**\n         * The Amazon CloudWatch Logs group to which CloudFormation sends error logging information when invoking the extension's handlers.\n         *\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-hookversion-loggingconfig.html#cfn-cloudformation-hookversion-loggingconfig-loggroupname\n         */\n        readonly logGroupName?: string;\n        /**\n         * The Amazon Resource Name (ARN) of the role that CloudFormation should assume when sending log entries to CloudWatch Logs.\n         *\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-hookversion-loggingconfig.html#cfn-cloudformation-hookversion-loggingconfig-logrolearn\n         */\n        readonly logRoleArn?: string;\n    }\n}\n\n/**\n * Determine whether the given properties match those of a `LoggingConfigProperty`\n *\n * @param properties - the TypeScript properties of a `LoggingConfigProperty`\n *\n * @returns the result of the validation.\n */\nfunction CfnHookVersion_LoggingConfigPropertyValidator(properties: any): cdk.ValidationResult {\n    if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n    const errors = new cdk.ValidationResults();\n    if (typeof properties !== 'object') {\n        errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));\n    }\n    errors.collect(cdk.propertyValidator('logGroupName', cdk.validateString)(properties.logGroupName));\n    errors.collect(cdk.propertyValidator('logRoleArn', cdk.validateString)(properties.logRoleArn));\n    return errors.wrap('supplied properties not correct for \"LoggingConfigProperty\"');\n}\n\n/**\n * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::HookVersion.LoggingConfig` resource\n *\n * @param properties - the TypeScript properties of a `LoggingConfigProperty`\n *\n * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::HookVersion.LoggingConfig` resource.\n */\n// @ts-ignore TS6133\nfunction cfnHookVersionLoggingConfigPropertyToCloudFormation(properties: any): any {\n    if (!cdk.canInspect(properties)) { return properties; }\n    CfnHookVersion_LoggingConfigPropertyValidator(properties).assertSuccess();\n    return {\n        LogGroupName: cdk.stringToCloudFormation(properties.logGroupName),\n        LogRoleArn: cdk.stringToCloudFormation(properties.logRoleArn),\n    };\n}\n\n// @ts-ignore TS6133\nfunction CfnHookVersionLoggingConfigPropertyFromCloudFormation(properties: any): cfn_parse.FromCloudFormationResult<CfnHookVersion.LoggingConfigProperty | cdk.IResolvable> {\n    if (cdk.isResolvableObject(properties)) {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    properties = properties == null ? {} : properties;\n    if (typeof properties !== 'object') {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    const ret = new cfn_parse.FromCloudFormationPropertyObject<CfnHookVersion.LoggingConfigProperty>();\n    ret.addPropertyResult('logGroupName', 'LogGroupName', properties.LogGroupName != null ? cfn_parse.FromCloudFormation.getString(properties.LogGroupName) : undefined);\n    ret.addPropertyResult('logRoleArn', 'LogRoleArn', properties.LogRoleArn != null ? cfn_parse.FromCloudFormation.getString(properties.LogRoleArn) : undefined);\n    ret.addUnrecognizedPropertiesAsExtra(properties);\n    return ret;\n}\n\n/**\n * Properties for defining a `CfnMacro`\n *\n * @struct\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-macro.html\n */\nexport interface CfnMacroProps {\n\n    /**\n     * The Amazon Resource Name (ARN) of the underlying AWS Lambda function that you want AWS CloudFormation to invoke when the macro is run.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-macro.html#cfn-cloudformation-macro-functionname\n     */\n    readonly functionName: string;\n\n    /**\n     * The name of the macro. The name of the macro must be unique across all macros in the account.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-macro.html#cfn-cloudformation-macro-name\n     */\n    readonly name: string;\n\n    /**\n     * A description of the macro.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-macro.html#cfn-cloudformation-macro-description\n     */\n    readonly description?: string;\n\n    /**\n     * The CloudWatch Logs group to which AWS CloudFormation sends error logging information when invoking the macro's underlying AWS Lambda function.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-macro.html#cfn-cloudformation-macro-loggroupname\n     */\n    readonly logGroupName?: string;\n\n    /**\n     * The ARN of the role AWS CloudFormation should assume when sending log entries to CloudWatch Logs .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-macro.html#cfn-cloudformation-macro-logrolearn\n     */\n    readonly logRoleArn?: string;\n}\n\n/**\n * Determine whether the given properties match those of a `CfnMacroProps`\n *\n * @param properties - the TypeScript properties of a `CfnMacroProps`\n *\n * @returns the result of the validation.\n */\nfunction CfnMacroPropsValidator(properties: any): cdk.ValidationResult {\n    if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n    const errors = new cdk.ValidationResults();\n    if (typeof properties !== 'object') {\n        errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));\n    }\n    errors.collect(cdk.propertyValidator('description', cdk.validateString)(properties.description));\n    errors.collect(cdk.propertyValidator('functionName', cdk.requiredValidator)(properties.functionName));\n    errors.collect(cdk.propertyValidator('functionName', cdk.validateString)(properties.functionName));\n    errors.collect(cdk.propertyValidator('logGroupName', cdk.validateString)(properties.logGroupName));\n    errors.collect(cdk.propertyValidator('logRoleArn', cdk.validateString)(properties.logRoleArn));\n    errors.collect(cdk.propertyValidator('name', cdk.requiredValidator)(properties.name));\n    errors.collect(cdk.propertyValidator('name', cdk.validateString)(properties.name));\n    return errors.wrap('supplied properties not correct for \"CfnMacroProps\"');\n}\n\n/**\n * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::Macro` resource\n *\n * @param properties - the TypeScript properties of a `CfnMacroProps`\n *\n * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::Macro` resource.\n */\n// @ts-ignore TS6133\nfunction cfnMacroPropsToCloudFormation(properties: any): any {\n    if (!cdk.canInspect(properties)) { return properties; }\n    CfnMacroPropsValidator(properties).assertSuccess();\n    return {\n        FunctionName: cdk.stringToCloudFormation(properties.functionName),\n        Name: cdk.stringToCloudFormation(properties.name),\n        Description: cdk.stringToCloudFormation(properties.description),\n        LogGroupName: cdk.stringToCloudFormation(properties.logGroupName),\n        LogRoleARN: cdk.stringToCloudFormation(properties.logRoleArn),\n    };\n}\n\n// @ts-ignore TS6133\nfunction CfnMacroPropsFromCloudFormation(properties: any): cfn_parse.FromCloudFormationResult<CfnMacroProps> {\n    properties = properties == null ? {} : properties;\n    if (typeof properties !== 'object') {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    const ret = new cfn_parse.FromCloudFormationPropertyObject<CfnMacroProps>();\n    ret.addPropertyResult('functionName', 'FunctionName', cfn_parse.FromCloudFormation.getString(properties.FunctionName));\n    ret.addPropertyResult('name', 'Name', cfn_parse.FromCloudFormation.getString(properties.Name));\n    ret.addPropertyResult('description', 'Description', properties.Description != null ? cfn_parse.FromCloudFormation.getString(properties.Description) : undefined);\n    ret.addPropertyResult('logGroupName', 'LogGroupName', properties.LogGroupName != null ? cfn_parse.FromCloudFormation.getString(properties.LogGroupName) : undefined);\n    ret.addPropertyResult('logRoleArn', 'LogRoleARN', properties.LogRoleARN != null ? cfn_parse.FromCloudFormation.getString(properties.LogRoleARN) : undefined);\n    ret.addUnrecognizedPropertiesAsExtra(properties);\n    return ret;\n}\n\n/**\n * A CloudFormation `AWS::CloudFormation::Macro`\n *\n * The `AWS::CloudFormation::Macro` resource is a CloudFormation resource type that creates a CloudFormation macro to perform custom processing on CloudFormation templates. For more information, see [Using AWS CloudFormation macros to perform custom processing on templates](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/template-macros.html) .\n *\n * @cloudformationResource AWS::CloudFormation::Macro\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-macro.html\n */\nexport class CfnMacro extends cdk.CfnResource implements cdk.IInspectable {\n    /**\n     * The CloudFormation resource type name for this resource class.\n     */\n    public static readonly CFN_RESOURCE_TYPE_NAME = \"AWS::CloudFormation::Macro\";\n\n    /**\n     * A factory method that creates a new instance of this class from an object\n     * containing the CloudFormation properties of this resource.\n     * Used in the @aws-cdk/cloudformation-include module.\n     *\n     * @internal\n     */\n    public static _fromCloudFormation(scope: cdk.Construct, id: string, resourceAttributes: any, options: cfn_parse.FromCloudFormationOptions): CfnMacro {\n        resourceAttributes = resourceAttributes || {};\n        const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);\n        const propsResult = CfnMacroPropsFromCloudFormation(resourceProperties);\n        const ret = new CfnMacro(scope, id, propsResult.value);\n        for (const [propKey, propVal] of Object.entries(propsResult.extraProperties))  {\n            ret.addPropertyOverride(propKey, propVal);\n        }\n        options.parser.handleAttributes(ret, resourceAttributes, id);\n        return ret;\n    }\n\n    /**\n     * The Amazon Resource Name (ARN) of the underlying AWS Lambda function that you want AWS CloudFormation to invoke when the macro is run.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-macro.html#cfn-cloudformation-macro-functionname\n     */\n    public functionName: string;\n\n    /**\n     * The name of the macro. The name of the macro must be unique across all macros in the account.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-macro.html#cfn-cloudformation-macro-name\n     */\n    public name: string;\n\n    /**\n     * A description of the macro.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-macro.html#cfn-cloudformation-macro-description\n     */\n    public description: string | undefined;\n\n    /**\n     * The CloudWatch Logs group to which AWS CloudFormation sends error logging information when invoking the macro's underlying AWS Lambda function.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-macro.html#cfn-cloudformation-macro-loggroupname\n     */\n    public logGroupName: string | undefined;\n\n    /**\n     * The ARN of the role AWS CloudFormation should assume when sending log entries to CloudWatch Logs .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-macro.html#cfn-cloudformation-macro-logrolearn\n     */\n    public logRoleArn: string | undefined;\n\n    /**\n     * Create a new `AWS::CloudFormation::Macro`.\n     *\n     * @param scope - scope in which this resource is defined\n     * @param id    - scoped id of the resource\n     * @param props - resource properties\n     */\n    constructor(scope: cdk.Construct, id: string, props: CfnMacroProps) {\n        super(scope, id, { type: CfnMacro.CFN_RESOURCE_TYPE_NAME, properties: props });\n        cdk.requireProperty(props, 'functionName', this);\n        cdk.requireProperty(props, 'name', this);\n\n        this.functionName = props.functionName;\n        this.name = props.name;\n        this.description = props.description;\n        this.logGroupName = props.logGroupName;\n        this.logRoleArn = props.logRoleArn;\n    }\n\n    /**\n     * Examines the CloudFormation resource and discloses attributes.\n     *\n     * @param inspector - tree inspector to collect and process attributes\n     *\n     */\n    public inspect(inspector: cdk.TreeInspector) {\n        inspector.addAttribute(\"aws:cdk:cloudformation:type\", CfnMacro.CFN_RESOURCE_TYPE_NAME);\n        inspector.addAttribute(\"aws:cdk:cloudformation:props\", this.cfnProperties);\n    }\n\n    protected get cfnProperties(): { [key: string]: any }  {\n        return {\n            functionName: this.functionName,\n            name: this.name,\n            description: this.description,\n            logGroupName: this.logGroupName,\n            logRoleArn: this.logRoleArn,\n        };\n    }\n\n    protected renderProperties(props: {[key: string]: any}): { [key: string]: any }  {\n        return cfnMacroPropsToCloudFormation(props);\n    }\n}\n\n/**\n * Properties for defining a `CfnModuleDefaultVersion`\n *\n * @struct\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-moduledefaultversion.html\n */\nexport interface CfnModuleDefaultVersionProps {\n\n    /**\n     * The Amazon Resource Name (ARN) of the module version to set as the default version.\n     *\n     * Conditional: You must specify either `Arn` , or `ModuleName` and `VersionId` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-moduledefaultversion.html#cfn-cloudformation-moduledefaultversion-arn\n     */\n    readonly arn?: string;\n\n    /**\n     * The name of the module.\n     *\n     * Conditional: You must specify either `Arn` , or `ModuleName` and `VersionId` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-moduledefaultversion.html#cfn-cloudformation-moduledefaultversion-modulename\n     */\n    readonly moduleName?: string;\n\n    /**\n     * The ID for the specific version of the module.\n     *\n     * Conditional: You must specify either `Arn` , or `ModuleName` and `VersionId` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-moduledefaultversion.html#cfn-cloudformation-moduledefaultversion-versionid\n     */\n    readonly versionId?: string;\n}\n\n/**\n * Determine whether the given properties match those of a `CfnModuleDefaultVersionProps`\n *\n * @param properties - the TypeScript properties of a `CfnModuleDefaultVersionProps`\n *\n * @returns the result of the validation.\n */\nfunction CfnModuleDefaultVersionPropsValidator(properties: any): cdk.ValidationResult {\n    if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n    const errors = new cdk.ValidationResults();\n    if (typeof properties !== 'object') {\n        errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));\n    }\n    errors.collect(cdk.propertyValidator('arn', cdk.validateString)(properties.arn));\n    errors.collect(cdk.propertyValidator('moduleName', cdk.validateString)(properties.moduleName));\n    errors.collect(cdk.propertyValidator('versionId', cdk.validateString)(properties.versionId));\n    return errors.wrap('supplied properties not correct for \"CfnModuleDefaultVersionProps\"');\n}\n\n/**\n * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::ModuleDefaultVersion` resource\n *\n * @param properties - the TypeScript properties of a `CfnModuleDefaultVersionProps`\n *\n * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::ModuleDefaultVersion` resource.\n */\n// @ts-ignore TS6133\nfunction cfnModuleDefaultVersionPropsToCloudFormation(properties: any): any {\n    if (!cdk.canInspect(properties)) { return properties; }\n    CfnModuleDefaultVersionPropsValidator(properties).assertSuccess();\n    return {\n        Arn: cdk.stringToCloudFormation(properties.arn),\n        ModuleName: cdk.stringToCloudFormation(properties.moduleName),\n        VersionId: cdk.stringToCloudFormation(properties.versionId),\n    };\n}\n\n// @ts-ignore TS6133\nfunction CfnModuleDefaultVersionPropsFromCloudFormation(properties: any): cfn_parse.FromCloudFormationResult<CfnModuleDefaultVersionProps> {\n    properties = properties == null ? {} : properties;\n    if (typeof properties !== 'object') {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    const ret = new cfn_parse.FromCloudFormationPropertyObject<CfnModuleDefaultVersionProps>();\n    ret.addPropertyResult('arn', 'Arn', properties.Arn != null ? cfn_parse.FromCloudFormation.getString(properties.Arn) : undefined);\n    ret.addPropertyResult('moduleName', 'ModuleName', properties.ModuleName != null ? cfn_parse.FromCloudFormation.getString(properties.ModuleName) : undefined);\n    ret.addPropertyResult('versionId', 'VersionId', properties.VersionId != null ? cfn_parse.FromCloudFormation.getString(properties.VersionId) : undefined);\n    ret.addUnrecognizedPropertiesAsExtra(properties);\n    return ret;\n}\n\n/**\n * A CloudFormation `AWS::CloudFormation::ModuleDefaultVersion`\n *\n * Specifies the default version of a module. The default version of the module will be used in CloudFormation operations for this account and Region.\n *\n * To register a module version, use the `[AWS::CloudFormation::ModuleVersion](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-moduleversion.html)` resource.\n *\n * For more information using modules, see [Using modules to encapsulate and reuse resource configurations](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/modules.html) and [Registering extensions](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/registry.html#registry-register) in the *CloudFormation User Guide* . For information on developing modules, see [Developing modules](https://docs.aws.amazon.com/cloudformation-cli/latest/userguide/modules.html) in the *CloudFormation CLI User Guide* .\n *\n * @cloudformationResource AWS::CloudFormation::ModuleDefaultVersion\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-moduledefaultversion.html\n */\nexport class CfnModuleDefaultVersion extends cdk.CfnResource implements cdk.IInspectable {\n    /**\n     * The CloudFormation resource type name for this resource class.\n     */\n    public static readonly CFN_RESOURCE_TYPE_NAME = \"AWS::CloudFormation::ModuleDefaultVersion\";\n\n    /**\n     * A factory method that creates a new instance of this class from an object\n     * containing the CloudFormation properties of this resource.\n     * Used in the @aws-cdk/cloudformation-include module.\n     *\n     * @internal\n     */\n    public static _fromCloudFormation(scope: cdk.Construct, id: string, resourceAttributes: any, options: cfn_parse.FromCloudFormationOptions): CfnModuleDefaultVersion {\n        resourceAttributes = resourceAttributes || {};\n        const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);\n        const propsResult = CfnModuleDefaultVersionPropsFromCloudFormation(resourceProperties);\n        const ret = new CfnModuleDefaultVersion(scope, id, propsResult.value);\n        for (const [propKey, propVal] of Object.entries(propsResult.extraProperties))  {\n            ret.addPropertyOverride(propKey, propVal);\n        }\n        options.parser.handleAttributes(ret, resourceAttributes, id);\n        return ret;\n    }\n\n    /**\n     * The Amazon Resource Name (ARN) of the module version to set as the default version.\n     *\n     * Conditional: You must specify either `Arn` , or `ModuleName` and `VersionId` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-moduledefaultversion.html#cfn-cloudformation-moduledefaultversion-arn\n     */\n    public arn: string | undefined;\n\n    /**\n     * The name of the module.\n     *\n     * Conditional: You must specify either `Arn` , or `ModuleName` and `VersionId` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-moduledefaultversion.html#cfn-cloudformation-moduledefaultversion-modulename\n     */\n    public moduleName: string | undefined;\n\n    /**\n     * The ID for the specific version of the module.\n     *\n     * Conditional: You must specify either `Arn` , or `ModuleName` and `VersionId` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-moduledefaultversion.html#cfn-cloudformation-moduledefaultversion-versionid\n     */\n    public versionId: string | undefined;\n\n    /**\n     * Create a new `AWS::CloudFormation::ModuleDefaultVersion`.\n     *\n     * @param scope - scope in which this resource is defined\n     * @param id    - scoped id of the resource\n     * @param props - resource properties\n     */\n    constructor(scope: cdk.Construct, id: string, props: CfnModuleDefaultVersionProps = {}) {\n        super(scope, id, { type: CfnModuleDefaultVersion.CFN_RESOURCE_TYPE_NAME, properties: props });\n\n        this.arn = props.arn;\n        this.moduleName = props.moduleName;\n        this.versionId = props.versionId;\n    }\n\n    /**\n     * Examines the CloudFormation resource and discloses attributes.\n     *\n     * @param inspector - tree inspector to collect and process attributes\n     *\n     */\n    public inspect(inspector: cdk.TreeInspector) {\n        inspector.addAttribute(\"aws:cdk:cloudformation:type\", CfnModuleDefaultVersion.CFN_RESOURCE_TYPE_NAME);\n        inspector.addAttribute(\"aws:cdk:cloudformation:props\", this.cfnProperties);\n    }\n\n    protected get cfnProperties(): { [key: string]: any }  {\n        return {\n            arn: this.arn,\n            moduleName: this.moduleName,\n            versionId: this.versionId,\n        };\n    }\n\n    protected renderProperties(props: {[key: string]: any}): { [key: string]: any }  {\n        return cfnModuleDefaultVersionPropsToCloudFormation(props);\n    }\n}\n\n/**\n * Properties for defining a `CfnModuleVersion`\n *\n * @struct\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-moduleversion.html\n */\nexport interface CfnModuleVersionProps {\n\n    /**\n     * The name of the module being registered.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-moduleversion.html#cfn-cloudformation-moduleversion-modulename\n     */\n    readonly moduleName: string;\n\n    /**\n     * A URL to the S3 bucket containing the package that contains the template fragment and schema files for the module version to register.\n     *\n     * > The user registering the module version must be able to access the module package in the S3 bucket. That's, the user needs to have [GetObject](https://docs.aws.amazon.com/AmazonS3/latest/API/API_GetObject.html) permissions for the package. For more information, see [Actions, Resources, and Condition Keys for Amazon S3](https://docs.aws.amazon.com/IAM/latest/UserGuide/list_amazons3.html) in the *AWS Identity and Access Management User Guide* .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-moduleversion.html#cfn-cloudformation-moduleversion-modulepackage\n     */\n    readonly modulePackage: string;\n}\n\n/**\n * Determine whether the given properties match those of a `CfnModuleVersionProps`\n *\n * @param properties - the TypeScript properties of a `CfnModuleVersionProps`\n *\n * @returns the result of the validation.\n */\nfunction CfnModuleVersionPropsValidator(properties: any): cdk.ValidationResult {\n    if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n    const errors = new cdk.ValidationResults();\n    if (typeof properties !== 'object') {\n        errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));\n    }\n    errors.collect(cdk.propertyValidator('moduleName', cdk.requiredValidator)(properties.moduleName));\n    errors.collect(cdk.propertyValidator('moduleName', cdk.validateString)(properties.moduleName));\n    errors.collect(cdk.propertyValidator('modulePackage', cdk.requiredValidator)(properties.modulePackage));\n    errors.collect(cdk.propertyValidator('modulePackage', cdk.validateString)(properties.modulePackage));\n    return errors.wrap('supplied properties not correct for \"CfnModuleVersionProps\"');\n}\n\n/**\n * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::ModuleVersion` resource\n *\n * @param properties - the TypeScript properties of a `CfnModuleVersionProps`\n *\n * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::ModuleVersion` resource.\n */\n// @ts-ignore TS6133\nfunction cfnModuleVersionPropsToCloudFormation(properties: any): any {\n    if (!cdk.canInspect(properties)) { return properties; }\n    CfnModuleVersionPropsValidator(properties).assertSuccess();\n    return {\n        ModuleName: cdk.stringToCloudFormation(properties.moduleName),\n        ModulePackage: cdk.stringToCloudFormation(properties.modulePackage),\n    };\n}\n\n// @ts-ignore TS6133\nfunction CfnModuleVersionPropsFromCloudFormation(properties: any): cfn_parse.FromCloudFormationResult<CfnModuleVersionProps> {\n    properties = properties == null ? {} : properties;\n    if (typeof properties !== 'object') {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    const ret = new cfn_parse.FromCloudFormationPropertyObject<CfnModuleVersionProps>();\n    ret.addPropertyResult('moduleName', 'ModuleName', cfn_parse.FromCloudFormation.getString(properties.ModuleName));\n    ret.addPropertyResult('modulePackage', 'ModulePackage', cfn_parse.FromCloudFormation.getString(properties.ModulePackage));\n    ret.addUnrecognizedPropertiesAsExtra(properties);\n    return ret;\n}\n\n/**\n * A CloudFormation `AWS::CloudFormation::ModuleVersion`\n *\n * Registers the specified version of the module with the CloudFormation service. Registering a module makes it available for use in CloudFormation templates in your AWS account and Region.\n *\n * To specify a module version as the default version, use the `[AWS::CloudFormation::ModuleDefaultVersion](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-moduledefaultversion.html)` resource.\n *\n * For more information using modules, see [Using modules to encapsulate and reuse resource configurations](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/modules.html) and [Registering extensions](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/registry.html#registry-register) in the *CloudFormation User Guide* . For information on developing modules, see [Developing modules](https://docs.aws.amazon.com/cloudformation-cli/latest/userguide/modules.html) in the *CloudFormation CLI User Guide* .\n *\n * @cloudformationResource AWS::CloudFormation::ModuleVersion\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-moduleversion.html\n */\nexport class CfnModuleVersion extends cdk.CfnResource implements cdk.IInspectable {\n    /**\n     * The CloudFormation resource type name for this resource class.\n     */\n    public static readonly CFN_RESOURCE_TYPE_NAME = \"AWS::CloudFormation::ModuleVersion\";\n\n    /**\n     * A factory method that creates a new instance of this class from an object\n     * containing the CloudFormation properties of this resource.\n     * Used in the @aws-cdk/cloudformation-include module.\n     *\n     * @internal\n     */\n    public static _fromCloudFormation(scope: cdk.Construct, id: string, resourceAttributes: any, options: cfn_parse.FromCloudFormationOptions): CfnModuleVersion {\n        resourceAttributes = resourceAttributes || {};\n        const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);\n        const propsResult = CfnModuleVersionPropsFromCloudFormation(resourceProperties);\n        const ret = new CfnModuleVersion(scope, id, propsResult.value);\n        for (const [propKey, propVal] of Object.entries(propsResult.extraProperties))  {\n            ret.addPropertyOverride(propKey, propVal);\n        }\n        options.parser.handleAttributes(ret, resourceAttributes, id);\n        return ret;\n    }\n\n    /**\n     * The Amazon Resource Name (ARN) of the module.\n     * @cloudformationAttribute Arn\n     */\n    public readonly attrArn: string;\n\n    /**\n     * The description of the module.\n     * @cloudformationAttribute Description\n     */\n    public readonly attrDescription: string;\n\n    /**\n     * The URL of a page providing detailed documentation for this module.\n     * @cloudformationAttribute DocumentationUrl\n     */\n    public readonly attrDocumentationUrl: string;\n\n    /**\n     * Whether the specified module version is set as the default version.\n     * @cloudformationAttribute IsDefaultVersion\n     */\n    public readonly attrIsDefaultVersion: cdk.IResolvable;\n\n    /**\n     * The schema that defines the module.\n     * @cloudformationAttribute Schema\n     */\n    public readonly attrSchema: string;\n\n    /**\n     * When the specified module version was registered.\n     * @cloudformationAttribute TimeCreated\n     */\n    public readonly attrTimeCreated: string;\n\n    /**\n     * The ID of this version of the module.\n     * @cloudformationAttribute VersionId\n     */\n    public readonly attrVersionId: string;\n\n    /**\n     * The scope at which the module is visible and usable in CloudFormation operations.\n     *\n     * Valid values include:\n     *\n     * - `PRIVATE` : The module is only visible and usable within the account in which it's registered.\n     * - `PUBLIC` : The module is publicly visible and usable within any Amazon account.\n     * @cloudformationAttribute Visibility\n     */\n    public readonly attrVisibility: string;\n\n    /**\n     * The name of the module being registered.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-moduleversion.html#cfn-cloudformation-moduleversion-modulename\n     */\n    public moduleName: string;\n\n    /**\n     * A URL to the S3 bucket containing the package that contains the template fragment and schema files for the module version to register.\n     *\n     * > The user registering the module version must be able to access the module package in the S3 bucket. That's, the user needs to have [GetObject](https://docs.aws.amazon.com/AmazonS3/latest/API/API_GetObject.html) permissions for the package. For more information, see [Actions, Resources, and Condition Keys for Amazon S3](https://docs.aws.amazon.com/IAM/latest/UserGuide/list_amazons3.html) in the *AWS Identity and Access Management User Guide* .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-moduleversion.html#cfn-cloudformation-moduleversion-modulepackage\n     */\n    public modulePackage: string;\n\n    /**\n     * Create a new `AWS::CloudFormation::ModuleVersion`.\n     *\n     * @param scope - scope in which this resource is defined\n     * @param id    - scoped id of the resource\n     * @param props - resource properties\n     */\n    constructor(scope: cdk.Construct, id: string, props: CfnModuleVersionProps) {\n        super(scope, id, { type: CfnModuleVersion.CFN_RESOURCE_TYPE_NAME, properties: props });\n        cdk.requireProperty(props, 'moduleName', this);\n        cdk.requireProperty(props, 'modulePackage', this);\n        this.attrArn = cdk.Token.asString(this.getAtt('Arn'));\n        this.attrDescription = cdk.Token.asString(this.getAtt('Description'));\n        this.attrDocumentationUrl = cdk.Token.asString(this.getAtt('DocumentationUrl'));\n        this.attrIsDefaultVersion = this.getAtt('IsDefaultVersion');\n        this.attrSchema = cdk.Token.asString(this.getAtt('Schema'));\n        this.attrTimeCreated = cdk.Token.asString(this.getAtt('TimeCreated'));\n        this.attrVersionId = cdk.Token.asString(this.getAtt('VersionId'));\n        this.attrVisibility = cdk.Token.asString(this.getAtt('Visibility'));\n\n        this.moduleName = props.moduleName;\n        this.modulePackage = props.modulePackage;\n    }\n\n    /**\n     * Examines the CloudFormation resource and discloses attributes.\n     *\n     * @param inspector - tree inspector to collect and process attributes\n     *\n     */\n    public inspect(inspector: cdk.TreeInspector) {\n        inspector.addAttribute(\"aws:cdk:cloudformation:type\", CfnModuleVersion.CFN_RESOURCE_TYPE_NAME);\n        inspector.addAttribute(\"aws:cdk:cloudformation:props\", this.cfnProperties);\n    }\n\n    protected get cfnProperties(): { [key: string]: any }  {\n        return {\n            moduleName: this.moduleName,\n            modulePackage: this.modulePackage,\n        };\n    }\n\n    protected renderProperties(props: {[key: string]: any}): { [key: string]: any }  {\n        return cfnModuleVersionPropsToCloudFormation(props);\n    }\n}\n\n/**\n * Properties for defining a `CfnPublicTypeVersion`\n *\n * @struct\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-publictypeversion.html\n */\nexport interface CfnPublicTypeVersionProps {\n\n    /**\n     * The Amazon Resource Number (ARN) of the extension.\n     *\n     * Conditional: You must specify `Arn` , or `TypeName` and `Type` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-publictypeversion.html#cfn-cloudformation-publictypeversion-arn\n     */\n    readonly arn?: string;\n\n    /**\n     * The S3 bucket to which CloudFormation delivers the contract test execution logs.\n     *\n     * CloudFormation delivers the logs by the time contract testing has completed and the extension has been assigned a test type status of `PASSED` or `FAILED` .\n     *\n     * The user initiating the stack operation must be able to access items in the specified S3 bucket. Specifically, the user needs the following permissions:\n     *\n     * - GetObject\n     * - PutObject\n     *\n     * For more information, see [Actions, Resources, and Condition Keys for Amazon S3](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazons3.html) in the *AWS Identity and Access Management User Guide* .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-publictypeversion.html#cfn-cloudformation-publictypeversion-logdeliverybucket\n     */\n    readonly logDeliveryBucket?: string;\n\n    /**\n     * The version number to assign to this version of the extension.\n     *\n     * Use the following format, and adhere to semantic versioning when assigning a version number to your extension:\n     *\n     * `MAJOR.MINOR.PATCH`\n     *\n     * For more information, see [Semantic Versioning 2.0.0](https://docs.aws.amazon.com/https://semver.org/) .\n     *\n     * If you don't specify a version number, CloudFormation increments the version number by one minor version release.\n     *\n     * You cannot specify a version number the first time you publish a type. AWS CloudFormation automatically sets the first version number to be `1.0.0` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-publictypeversion.html#cfn-cloudformation-publictypeversion-publicversionnumber\n     */\n    readonly publicVersionNumber?: string;\n\n    /**\n     * The type of the extension to test.\n     *\n     * Conditional: You must specify `Arn` , or `TypeName` and `Type` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-publictypeversion.html#cfn-cloudformation-publictypeversion-type\n     */\n    readonly type?: string;\n\n    /**\n     * The name of the extension to test.\n     *\n     * Conditional: You must specify `Arn` , or `TypeName` and `Type` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-publictypeversion.html#cfn-cloudformation-publictypeversion-typename\n     */\n    readonly typeName?: string;\n}\n\n/**\n * Determine whether the given properties match those of a `CfnPublicTypeVersionProps`\n *\n * @param properties - the TypeScript properties of a `CfnPublicTypeVersionProps`\n *\n * @returns the result of the validation.\n */\nfunction CfnPublicTypeVersionPropsValidator(properties: any): cdk.ValidationResult {\n    if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n    const errors = new cdk.ValidationResults();\n    if (typeof properties !== 'object') {\n        errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));\n    }\n    errors.collect(cdk.propertyValidator('arn', cdk.validateString)(properties.arn));\n    errors.collect(cdk.propertyValidator('logDeliveryBucket', cdk.validateString)(properties.logDeliveryBucket));\n    errors.collect(cdk.propertyValidator('publicVersionNumber', cdk.validateString)(properties.publicVersionNumber));\n    errors.collect(cdk.propertyValidator('type', cdk.validateString)(properties.type));\n    errors.collect(cdk.propertyValidator('typeName', cdk.validateString)(properties.typeName));\n    return errors.wrap('supplied properties not correct for \"CfnPublicTypeVersionProps\"');\n}\n\n/**\n * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::PublicTypeVersion` resource\n *\n * @param properties - the TypeScript properties of a `CfnPublicTypeVersionProps`\n *\n * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::PublicTypeVersion` resource.\n */\n// @ts-ignore TS6133\nfunction cfnPublicTypeVersionPropsToCloudFormation(properties: any): any {\n    if (!cdk.canInspect(properties)) { return properties; }\n    CfnPublicTypeVersionPropsValidator(properties).assertSuccess();\n    return {\n        Arn: cdk.stringToCloudFormation(properties.arn),\n        LogDeliveryBucket: cdk.stringToCloudFormation(properties.logDeliveryBucket),\n        PublicVersionNumber: cdk.stringToCloudFormation(properties.publicVersionNumber),\n        Type: cdk.stringToCloudFormation(properties.type),\n        TypeName: cdk.stringToCloudFormation(properties.typeName),\n    };\n}\n\n// @ts-ignore TS6133\nfunction CfnPublicTypeVersionPropsFromCloudFormation(properties: any): cfn_parse.FromCloudFormationResult<CfnPublicTypeVersionProps> {\n    properties = properties == null ? {} : properties;\n    if (typeof properties !== 'object') {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    const ret = new cfn_parse.FromCloudFormationPropertyObject<CfnPublicTypeVersionProps>();\n    ret.addPropertyResult('arn', 'Arn', properties.Arn != null ? cfn_parse.FromCloudFormation.getString(properties.Arn) : undefined);\n    ret.addPropertyResult('logDeliveryBucket', 'LogDeliveryBucket', properties.LogDeliveryBucket != null ? cfn_parse.FromCloudFormation.getString(properties.LogDeliveryBucket) : undefined);\n    ret.addPropertyResult('publicVersionNumber', 'PublicVersionNumber', properties.PublicVersionNumber != null ? cfn_parse.FromCloudFormation.getString(properties.PublicVersionNumber) : undefined);\n    ret.addPropertyResult('type', 'Type', properties.Type != null ? cfn_parse.FromCloudFormation.getString(properties.Type) : undefined);\n    ret.addPropertyResult('typeName', 'TypeName', properties.TypeName != null ? cfn_parse.FromCloudFormation.getString(properties.TypeName) : undefined);\n    ret.addUnrecognizedPropertiesAsExtra(properties);\n    return ret;\n}\n\n/**\n * A CloudFormation `AWS::CloudFormation::PublicTypeVersion`\n *\n * Tests and publishes a registered extension as a public, third-party extension.\n *\n * CloudFormation first tests the extension to make sure it meets all necessary requirements for being published in the CloudFormation registry. If it does, CloudFormation then publishes it to the registry as a public third-party extension in this Region. Public extensions are available for use by all CloudFormation users.\n *\n * - For resource types, testing includes passing all contracts tests defined for the type.\n * - For modules, testing includes determining if the module's model meets all necessary requirements.\n *\n * For more information, see [Testing your public extension prior to publishing](https://docs.aws.amazon.com/cloudformation-cli/latest/userguide/publish-extension.html#publish-extension-testing) in the *CloudFormation CLI User Guide* .\n *\n * If you don't specify a version, CloudFormation uses the default version of the extension in your account and Region for testing.\n *\n * To perform testing, CloudFormation assumes the execution role specified when the type was registered.\n *\n * An extension must have a test status of `PASSED` before it can be published. For more information, see [Publishing extensions to make them available for public use](https://docs.aws.amazon.com/cloudformation-cli/latest/userguide/resource-type-publish.html) in the *CloudFormation CLI User Guide* .\n *\n * @cloudformationResource AWS::CloudFormation::PublicTypeVersion\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-publictypeversion.html\n */\nexport class CfnPublicTypeVersion extends cdk.CfnResource implements cdk.IInspectable {\n    /**\n     * The CloudFormation resource type name for this resource class.\n     */\n    public static readonly CFN_RESOURCE_TYPE_NAME = \"AWS::CloudFormation::PublicTypeVersion\";\n\n    /**\n     * A factory method that creates a new instance of this class from an object\n     * containing the CloudFormation properties of this resource.\n     * Used in the @aws-cdk/cloudformation-include module.\n     *\n     * @internal\n     */\n    public static _fromCloudFormation(scope: cdk.Construct, id: string, resourceAttributes: any, options: cfn_parse.FromCloudFormationOptions): CfnPublicTypeVersion {\n        resourceAttributes = resourceAttributes || {};\n        const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);\n        const propsResult = CfnPublicTypeVersionPropsFromCloudFormation(resourceProperties);\n        const ret = new CfnPublicTypeVersion(scope, id, propsResult.value);\n        for (const [propKey, propVal] of Object.entries(propsResult.extraProperties))  {\n            ret.addPropertyOverride(propKey, propVal);\n        }\n        options.parser.handleAttributes(ret, resourceAttributes, id);\n        return ret;\n    }\n\n    /**\n     * The Amazon Resource Number (ARN) assigned to the public extension upon publication.\n     * @cloudformationAttribute PublicTypeArn\n     */\n    public readonly attrPublicTypeArn: string;\n\n    /**\n     * The publisher ID of the extension publisher.\n     * @cloudformationAttribute PublisherId\n     */\n    public readonly attrPublisherId: string;\n\n    /**\n     * The Amazon Resource Number (ARN) assigned to this version of the extension.\n     * @cloudformationAttribute TypeVersionArn\n     */\n    public readonly attrTypeVersionArn: string;\n\n    /**\n     * The Amazon Resource Number (ARN) of the extension.\n     *\n     * Conditional: You must specify `Arn` , or `TypeName` and `Type` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-publictypeversion.html#cfn-cloudformation-publictypeversion-arn\n     */\n    public arn: string | undefined;\n\n    /**\n     * The S3 bucket to which CloudFormation delivers the contract test execution logs.\n     *\n     * CloudFormation delivers the logs by the time contract testing has completed and the extension has been assigned a test type status of `PASSED` or `FAILED` .\n     *\n     * The user initiating the stack operation must be able to access items in the specified S3 bucket. Specifically, the user needs the following permissions:\n     *\n     * - GetObject\n     * - PutObject\n     *\n     * For more information, see [Actions, Resources, and Condition Keys for Amazon S3](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazons3.html) in the *AWS Identity and Access Management User Guide* .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-publictypeversion.html#cfn-cloudformation-publictypeversion-logdeliverybucket\n     */\n    public logDeliveryBucket: string | undefined;\n\n    /**\n     * The version number to assign to this version of the extension.\n     *\n     * Use the following format, and adhere to semantic versioning when assigning a version number to your extension:\n     *\n     * `MAJOR.MINOR.PATCH`\n     *\n     * For more information, see [Semantic Versioning 2.0.0](https://docs.aws.amazon.com/https://semver.org/) .\n     *\n     * If you don't specify a version number, CloudFormation increments the version number by one minor version release.\n     *\n     * You cannot specify a version number the first time you publish a type. AWS CloudFormation automatically sets the first version number to be `1.0.0` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-publictypeversion.html#cfn-cloudformation-publictypeversion-publicversionnumber\n     */\n    public publicVersionNumber: string | undefined;\n\n    /**\n     * The type of the extension to test.\n     *\n     * Conditional: You must specify `Arn` , or `TypeName` and `Type` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-publictypeversion.html#cfn-cloudformation-publictypeversion-type\n     */\n    public type: string | undefined;\n\n    /**\n     * The name of the extension to test.\n     *\n     * Conditional: You must specify `Arn` , or `TypeName` and `Type` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-publictypeversion.html#cfn-cloudformation-publictypeversion-typename\n     */\n    public typeName: string | undefined;\n\n    /**\n     * Create a new `AWS::CloudFormation::PublicTypeVersion`.\n     *\n     * @param scope - scope in which this resource is defined\n     * @param id    - scoped id of the resource\n     * @param props - resource properties\n     */\n    constructor(scope: cdk.Construct, id: string, props: CfnPublicTypeVersionProps = {}) {\n        super(scope, id, { type: CfnPublicTypeVersion.CFN_RESOURCE_TYPE_NAME, properties: props });\n        this.attrPublicTypeArn = cdk.Token.asString(this.getAtt('PublicTypeArn'));\n        this.attrPublisherId = cdk.Token.asString(this.getAtt('PublisherId'));\n        this.attrTypeVersionArn = cdk.Token.asString(this.getAtt('TypeVersionArn'));\n\n        this.arn = props.arn;\n        this.logDeliveryBucket = props.logDeliveryBucket;\n        this.publicVersionNumber = props.publicVersionNumber;\n        this.type = props.type;\n        this.typeName = props.typeName;\n    }\n\n    /**\n     * Examines the CloudFormation resource and discloses attributes.\n     *\n     * @param inspector - tree inspector to collect and process attributes\n     *\n     */\n    public inspect(inspector: cdk.TreeInspector) {\n        inspector.addAttribute(\"aws:cdk:cloudformation:type\", CfnPublicTypeVersion.CFN_RESOURCE_TYPE_NAME);\n        inspector.addAttribute(\"aws:cdk:cloudformation:props\", this.cfnProperties);\n    }\n\n    protected get cfnProperties(): { [key: string]: any }  {\n        return {\n            arn: this.arn,\n            logDeliveryBucket: this.logDeliveryBucket,\n            publicVersionNumber: this.publicVersionNumber,\n            type: this.type,\n            typeName: this.typeName,\n        };\n    }\n\n    protected renderProperties(props: {[key: string]: any}): { [key: string]: any }  {\n        return cfnPublicTypeVersionPropsToCloudFormation(props);\n    }\n}\n\n/**\n * Properties for defining a `CfnPublisher`\n *\n * @struct\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-publisher.html\n */\nexport interface CfnPublisherProps {\n\n    /**\n     * Whether you accept the [Terms and Conditions](https://docs.aws.amazon.com/https://cloudformation-registry-documents.s3.amazonaws.com/Terms_and_Conditions_for_AWS_CloudFormation_Registry_Publishers.pdf) for publishing extensions in the CloudFormation registry. You must accept the terms and conditions in order to register to publish public extensions to the CloudFormation registry.\n     *\n     * The default is `false` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-publisher.html#cfn-cloudformation-publisher-accepttermsandconditions\n     */\n    readonly acceptTermsAndConditions: boolean | cdk.IResolvable;\n\n    /**\n     * If you are using a Bitbucket or GitHub account for identity verification, the Amazon Resource Name (ARN) for your connection to that account.\n     *\n     * For more information, see [Registering your account to publish CloudFormation extensions](https://docs.aws.amazon.com/cloudformation-cli/latest/userguide/publish-extension.html#publish-extension-prereqs) in the *CloudFormation CLI User Guide* .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-publisher.html#cfn-cloudformation-publisher-connectionarn\n     */\n    readonly connectionArn?: string;\n}\n\n/**\n * Determine whether the given properties match those of a `CfnPublisherProps`\n *\n * @param properties - the TypeScript properties of a `CfnPublisherProps`\n *\n * @returns the result of the validation.\n */\nfunction CfnPublisherPropsValidator(properties: any): cdk.ValidationResult {\n    if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n    const errors = new cdk.ValidationResults();\n    if (typeof properties !== 'object') {\n        errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));\n    }\n    errors.collect(cdk.propertyValidator('acceptTermsAndConditions', cdk.requiredValidator)(properties.acceptTermsAndConditions));\n    errors.collect(cdk.propertyValidator('acceptTermsAndConditions', cdk.validateBoolean)(properties.acceptTermsAndConditions));\n    errors.collect(cdk.propertyValidator('connectionArn', cdk.validateString)(properties.connectionArn));\n    return errors.wrap('supplied properties not correct for \"CfnPublisherProps\"');\n}\n\n/**\n * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::Publisher` resource\n *\n * @param properties - the TypeScript properties of a `CfnPublisherProps`\n *\n * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::Publisher` resource.\n */\n// @ts-ignore TS6133\nfunction cfnPublisherPropsToCloudFormation(properties: any): any {\n    if (!cdk.canInspect(properties)) { return properties; }\n    CfnPublisherPropsValidator(properties).assertSuccess();\n    return {\n        AcceptTermsAndConditions: cdk.booleanToCloudFormation(properties.acceptTermsAndConditions),\n        ConnectionArn: cdk.stringToCloudFormation(properties.connectionArn),\n    };\n}\n\n// @ts-ignore TS6133\nfunction CfnPublisherPropsFromCloudFormation(properties: any): cfn_parse.FromCloudFormationResult<CfnPublisherProps> {\n    properties = properties == null ? {} : properties;\n    if (typeof properties !== 'object') {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    const ret = new cfn_parse.FromCloudFormationPropertyObject<CfnPublisherProps>();\n    ret.addPropertyResult('acceptTermsAndConditions', 'AcceptTermsAndConditions', cfn_parse.FromCloudFormation.getBoolean(properties.AcceptTermsAndConditions));\n    ret.addPropertyResult('connectionArn', 'ConnectionArn', properties.ConnectionArn != null ? cfn_parse.FromCloudFormation.getString(properties.ConnectionArn) : undefined);\n    ret.addUnrecognizedPropertiesAsExtra(properties);\n    return ret;\n}\n\n/**\n * A CloudFormation `AWS::CloudFormation::Publisher`\n *\n * Registers your account as a publisher of public extensions in the CloudFormation registry. Public extensions are available for use by all CloudFormation users.\n *\n * For information on requirements for registering as a public extension publisher, see [Registering your account to publish CloudFormation extensions](https://docs.aws.amazon.com/cloudformation-cli/latest/userguide/publish-extension.html#publish-extension-prereqs) in the *CloudFormation CLI User Guide* .\n *\n * @cloudformationResource AWS::CloudFormation::Publisher\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-publisher.html\n */\nexport class CfnPublisher extends cdk.CfnResource implements cdk.IInspectable {\n    /**\n     * The CloudFormation resource type name for this resource class.\n     */\n    public static readonly CFN_RESOURCE_TYPE_NAME = \"AWS::CloudFormation::Publisher\";\n\n    /**\n     * A factory method that creates a new instance of this class from an object\n     * containing the CloudFormation properties of this resource.\n     * Used in the @aws-cdk/cloudformation-include module.\n     *\n     * @internal\n     */\n    public static _fromCloudFormation(scope: cdk.Construct, id: string, resourceAttributes: any, options: cfn_parse.FromCloudFormationOptions): CfnPublisher {\n        resourceAttributes = resourceAttributes || {};\n        const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);\n        const propsResult = CfnPublisherPropsFromCloudFormation(resourceProperties);\n        const ret = new CfnPublisher(scope, id, propsResult.value);\n        for (const [propKey, propVal] of Object.entries(propsResult.extraProperties))  {\n            ret.addPropertyOverride(propKey, propVal);\n        }\n        options.parser.handleAttributes(ret, resourceAttributes, id);\n        return ret;\n    }\n\n    /**\n     * The type of account used as the identity provider when registering this publisher with CloudFormation .\n     *\n     * Values include: `AWS_Marketplace` | `Bitbucket` | `GitHub` .\n     * @cloudformationAttribute IdentityProvider\n     */\n    public readonly attrIdentityProvider: string;\n\n    /**\n     * The ID of the extension publisher. This publisher ID applies to your account in all AWS Regions .\n     * @cloudformationAttribute PublisherId\n     */\n    public readonly attrPublisherId: string;\n\n    /**\n     * The URL to the publisher's profile with the identity provider.\n     * @cloudformationAttribute PublisherProfile\n     */\n    public readonly attrPublisherProfile: string;\n\n    /**\n     * Whether the publisher is verified.\n     * @cloudformationAttribute PublisherStatus\n     */\n    public readonly attrPublisherStatus: string;\n\n    /**\n     * Whether you accept the [Terms and Conditions](https://docs.aws.amazon.com/https://cloudformation-registry-documents.s3.amazonaws.com/Terms_and_Conditions_for_AWS_CloudFormation_Registry_Publishers.pdf) for publishing extensions in the CloudFormation registry. You must accept the terms and conditions in order to register to publish public extensions to the CloudFormation registry.\n     *\n     * The default is `false` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-publisher.html#cfn-cloudformation-publisher-accepttermsandconditions\n     */\n    public acceptTermsAndConditions: boolean | cdk.IResolvable;\n\n    /**\n     * If you are using a Bitbucket or GitHub account for identity verification, the Amazon Resource Name (ARN) for your connection to that account.\n     *\n     * For more information, see [Registering your account to publish CloudFormation extensions](https://docs.aws.amazon.com/cloudformation-cli/latest/userguide/publish-extension.html#publish-extension-prereqs) in the *CloudFormation CLI User Guide* .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-publisher.html#cfn-cloudformation-publisher-connectionarn\n     */\n    public connectionArn: string | undefined;\n\n    /**\n     * Create a new `AWS::CloudFormation::Publisher`.\n     *\n     * @param scope - scope in which this resource is defined\n     * @param id    - scoped id of the resource\n     * @param props - resource properties\n     */\n    constructor(scope: cdk.Construct, id: string, props: CfnPublisherProps) {\n        super(scope, id, { type: CfnPublisher.CFN_RESOURCE_TYPE_NAME, properties: props });\n        cdk.requireProperty(props, 'acceptTermsAndConditions', this);\n        this.attrIdentityProvider = cdk.Token.asString(this.getAtt('IdentityProvider'));\n        this.attrPublisherId = cdk.Token.asString(this.getAtt('PublisherId'));\n        this.attrPublisherProfile = cdk.Token.asString(this.getAtt('PublisherProfile'));\n        this.attrPublisherStatus = cdk.Token.asString(this.getAtt('PublisherStatus'));\n\n        this.acceptTermsAndConditions = props.acceptTermsAndConditions;\n        this.connectionArn = props.connectionArn;\n    }\n\n    /**\n     * Examines the CloudFormation resource and discloses attributes.\n     *\n     * @param inspector - tree inspector to collect and process attributes\n     *\n     */\n    public inspect(inspector: cdk.TreeInspector) {\n        inspector.addAttribute(\"aws:cdk:cloudformation:type\", CfnPublisher.CFN_RESOURCE_TYPE_NAME);\n        inspector.addAttribute(\"aws:cdk:cloudformation:props\", this.cfnProperties);\n    }\n\n    protected get cfnProperties(): { [key: string]: any }  {\n        return {\n            acceptTermsAndConditions: this.acceptTermsAndConditions,\n            connectionArn: this.connectionArn,\n        };\n    }\n\n    protected renderProperties(props: {[key: string]: any}): { [key: string]: any }  {\n        return cfnPublisherPropsToCloudFormation(props);\n    }\n}\n\n/**\n * Properties for defining a `CfnResourceDefaultVersion`\n *\n * @struct\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-resourcedefaultversion.html\n */\nexport interface CfnResourceDefaultVersionProps {\n\n    /**\n     * The name of the resource.\n     *\n     * Conditional: You must specify either `TypeVersionArn` , or `TypeName` and `VersionId` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-resourcedefaultversion.html#cfn-cloudformation-resourcedefaultversion-typename\n     */\n    readonly typeName?: string;\n\n    /**\n     * The Amazon Resource Name (ARN) of the resource version.\n     *\n     * Conditional: You must specify either `TypeVersionArn` , or `TypeName` and `VersionId` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-resourcedefaultversion.html#cfn-cloudformation-resourcedefaultversion-typeversionarn\n     */\n    readonly typeVersionArn?: string;\n\n    /**\n     * The ID of a specific version of the resource. The version ID is the value at the end of the Amazon Resource Name (ARN) assigned to the resource version when it's registered.\n     *\n     * Conditional: You must specify either `TypeVersionArn` , or `TypeName` and `VersionId` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-resourcedefaultversion.html#cfn-cloudformation-resourcedefaultversion-versionid\n     */\n    readonly versionId?: string;\n}\n\n/**\n * Determine whether the given properties match those of a `CfnResourceDefaultVersionProps`\n *\n * @param properties - the TypeScript properties of a `CfnResourceDefaultVersionProps`\n *\n * @returns the result of the validation.\n */\nfunction CfnResourceDefaultVersionPropsValidator(properties: any): cdk.ValidationResult {\n    if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n    const errors = new cdk.ValidationResults();\n    if (typeof properties !== 'object') {\n        errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));\n    }\n    errors.collect(cdk.propertyValidator('typeName', cdk.validateString)(properties.typeName));\n    errors.collect(cdk.propertyValidator('typeVersionArn', cdk.validateString)(properties.typeVersionArn));\n    errors.collect(cdk.propertyValidator('versionId', cdk.validateString)(properties.versionId));\n    return errors.wrap('supplied properties not correct for \"CfnResourceDefaultVersionProps\"');\n}\n\n/**\n * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::ResourceDefaultVersion` resource\n *\n * @param properties - the TypeScript properties of a `CfnResourceDefaultVersionProps`\n *\n * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::ResourceDefaultVersion` resource.\n */\n// @ts-ignore TS6133\nfunction cfnResourceDefaultVersionPropsToCloudFormation(properties: any): any {\n    if (!cdk.canInspect(properties)) { return properties; }\n    CfnResourceDefaultVersionPropsValidator(properties).assertSuccess();\n    return {\n        TypeName: cdk.stringToCloudFormation(properties.typeName),\n        TypeVersionArn: cdk.stringToCloudFormation(properties.typeVersionArn),\n        VersionId: cdk.stringToCloudFormation(properties.versionId),\n    };\n}\n\n// @ts-ignore TS6133\nfunction CfnResourceDefaultVersionPropsFromCloudFormation(properties: any): cfn_parse.FromCloudFormationResult<CfnResourceDefaultVersionProps> {\n    properties = properties == null ? {} : properties;\n    if (typeof properties !== 'object') {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    const ret = new cfn_parse.FromCloudFormationPropertyObject<CfnResourceDefaultVersionProps>();\n    ret.addPropertyResult('typeName', 'TypeName', properties.TypeName != null ? cfn_parse.FromCloudFormation.getString(properties.TypeName) : undefined);\n    ret.addPropertyResult('typeVersionArn', 'TypeVersionArn', properties.TypeVersionArn != null ? cfn_parse.FromCloudFormation.getString(properties.TypeVersionArn) : undefined);\n    ret.addPropertyResult('versionId', 'VersionId', properties.VersionId != null ? cfn_parse.FromCloudFormation.getString(properties.VersionId) : undefined);\n    ret.addUnrecognizedPropertiesAsExtra(properties);\n    return ret;\n}\n\n/**\n * A CloudFormation `AWS::CloudFormation::ResourceDefaultVersion`\n *\n * Specifies the default version of a resource. The default version of a resource will be used in CloudFormation operations.\n *\n * @cloudformationResource AWS::CloudFormation::ResourceDefaultVersion\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-resourcedefaultversion.html\n */\nexport class CfnResourceDefaultVersion extends cdk.CfnResource implements cdk.IInspectable {\n    /**\n     * The CloudFormation resource type name for this resource class.\n     */\n    public static readonly CFN_RESOURCE_TYPE_NAME = \"AWS::CloudFormation::ResourceDefaultVersion\";\n\n    /**\n     * A factory method that creates a new instance of this class from an object\n     * containing the CloudFormation properties of this resource.\n     * Used in the @aws-cdk/cloudformation-include module.\n     *\n     * @internal\n     */\n    public static _fromCloudFormation(scope: cdk.Construct, id: string, resourceAttributes: any, options: cfn_parse.FromCloudFormationOptions): CfnResourceDefaultVersion {\n        resourceAttributes = resourceAttributes || {};\n        const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);\n        const propsResult = CfnResourceDefaultVersionPropsFromCloudFormation(resourceProperties);\n        const ret = new CfnResourceDefaultVersion(scope, id, propsResult.value);\n        for (const [propKey, propVal] of Object.entries(propsResult.extraProperties))  {\n            ret.addPropertyOverride(propKey, propVal);\n        }\n        options.parser.handleAttributes(ret, resourceAttributes, id);\n        return ret;\n    }\n\n    /**\n     * The Amazon Resource Name (ARN) of the resource.\n     * @cloudformationAttribute Arn\n     */\n    public readonly attrArn: string;\n\n    /**\n     * The name of the resource.\n     *\n     * Conditional: You must specify either `TypeVersionArn` , or `TypeName` and `VersionId` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-resourcedefaultversion.html#cfn-cloudformation-resourcedefaultversion-typename\n     */\n    public typeName: string | undefined;\n\n    /**\n     * The Amazon Resource Name (ARN) of the resource version.\n     *\n     * Conditional: You must specify either `TypeVersionArn` , or `TypeName` and `VersionId` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-resourcedefaultversion.html#cfn-cloudformation-resourcedefaultversion-typeversionarn\n     */\n    public typeVersionArn: string | undefined;\n\n    /**\n     * The ID of a specific version of the resource. The version ID is the value at the end of the Amazon Resource Name (ARN) assigned to the resource version when it's registered.\n     *\n     * Conditional: You must specify either `TypeVersionArn` , or `TypeName` and `VersionId` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-resourcedefaultversion.html#cfn-cloudformation-resourcedefaultversion-versionid\n     */\n    public versionId: string | undefined;\n\n    /**\n     * Create a new `AWS::CloudFormation::ResourceDefaultVersion`.\n     *\n     * @param scope - scope in which this resource is defined\n     * @param id    - scoped id of the resource\n     * @param props - resource properties\n     */\n    constructor(scope: cdk.Construct, id: string, props: CfnResourceDefaultVersionProps = {}) {\n        super(scope, id, { type: CfnResourceDefaultVersion.CFN_RESOURCE_TYPE_NAME, properties: props });\n        this.attrArn = cdk.Token.asString(this.getAtt('Arn'));\n\n        this.typeName = props.typeName;\n        this.typeVersionArn = props.typeVersionArn;\n        this.versionId = props.versionId;\n    }\n\n    /**\n     * Examines the CloudFormation resource and discloses attributes.\n     *\n     * @param inspector - tree inspector to collect and process attributes\n     *\n     */\n    public inspect(inspector: cdk.TreeInspector) {\n        inspector.addAttribute(\"aws:cdk:cloudformation:type\", CfnResourceDefaultVersion.CFN_RESOURCE_TYPE_NAME);\n        inspector.addAttribute(\"aws:cdk:cloudformation:props\", this.cfnProperties);\n    }\n\n    protected get cfnProperties(): { [key: string]: any }  {\n        return {\n            typeName: this.typeName,\n            typeVersionArn: this.typeVersionArn,\n            versionId: this.versionId,\n        };\n    }\n\n    protected renderProperties(props: {[key: string]: any}): { [key: string]: any }  {\n        return cfnResourceDefaultVersionPropsToCloudFormation(props);\n    }\n}\n\n/**\n * Properties for defining a `CfnResourceVersion`\n *\n * @struct\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-resourceversion.html\n */\nexport interface CfnResourceVersionProps {\n\n    /**\n     * A URL to the S3 bucket containing the resource project package that contains the necessary files for the resource you want to register.\n     *\n     * For information on generating a schema handler package for the resource you want to register, see [submit](https://docs.aws.amazon.com/cloudformation-cli/latest/userguide/resource-type-cli-submit.html) in the *CloudFormation CLI User Guide* .\n     *\n     * > The user registering the resource must be able to access the package in the S3 bucket. That is, the user needs to have [GetObject](https://docs.aws.amazon.com/AmazonS3/latest/API/API_GetObject.html) permissions for the schema handler package. For more information, see [Actions, Resources, and Condition Keys for Amazon S3](https://docs.aws.amazon.com/IAM/latest/UserGuide/list_amazons3.html) in the *AWS Identity and Access Management User Guide* .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-resourceversion.html#cfn-cloudformation-resourceversion-schemahandlerpackage\n     */\n    readonly schemaHandlerPackage: string;\n\n    /**\n     * The name of the resource being registered.\n     *\n     * We recommend that resource names adhere to the following pattern: *company_or_organization* :: *service* :: *type* .\n     *\n     * > The following organization namespaces are reserved and can't be used in your resource names:\n     * >\n     * > - `Alexa`\n     * > - `AMZN`\n     * > - `Amazon`\n     * > - `AWS`\n     * > - `Custom`\n     * > - `Dev`\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-resourceversion.html#cfn-cloudformation-resourceversion-typename\n     */\n    readonly typeName: string;\n\n    /**\n     * The Amazon Resource Name (ARN) of the IAM role for CloudFormation to assume when invoking the resource. If your resource calls AWS APIs in any of its handlers, you must create an *[IAM execution role](https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles.html)* that includes the necessary permissions to call those AWS APIs, and provision that execution role in your account. When CloudFormation needs to invoke the resource type handler, CloudFormation assumes this execution role to create a temporary session token, which it then passes to the resource type handler, thereby supplying your resource type with the appropriate credentials.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-resourceversion.html#cfn-cloudformation-resourceversion-executionrolearn\n     */\n    readonly executionRoleArn?: string;\n\n    /**\n     * Logging configuration information for a resource.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-resourceversion.html#cfn-cloudformation-resourceversion-loggingconfig\n     */\n    readonly loggingConfig?: CfnResourceVersion.LoggingConfigProperty | cdk.IResolvable;\n}\n\n/**\n * Determine whether the given properties match those of a `CfnResourceVersionProps`\n *\n * @param properties - the TypeScript properties of a `CfnResourceVersionProps`\n *\n * @returns the result of the validation.\n */\nfunction CfnResourceVersionPropsValidator(properties: any): cdk.ValidationResult {\n    if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n    const errors = new cdk.ValidationResults();\n    if (typeof properties !== 'object') {\n        errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));\n    }\n    errors.collect(cdk.propertyValidator('executionRoleArn', cdk.validateString)(properties.executionRoleArn));\n    errors.collect(cdk.propertyValidator('loggingConfig', CfnResourceVersion_LoggingConfigPropertyValidator)(properties.loggingConfig));\n    errors.collect(cdk.propertyValidator('schemaHandlerPackage', cdk.requiredValidator)(properties.schemaHandlerPackage));\n    errors.collect(cdk.propertyValidator('schemaHandlerPackage', cdk.validateString)(properties.schemaHandlerPackage));\n    errors.collect(cdk.propertyValidator('typeName', cdk.requiredValidator)(properties.typeName));\n    errors.collect(cdk.propertyValidator('typeName', cdk.validateString)(properties.typeName));\n    return errors.wrap('supplied properties not correct for \"CfnResourceVersionProps\"');\n}\n\n/**\n * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::ResourceVersion` resource\n *\n * @param properties - the TypeScript properties of a `CfnResourceVersionProps`\n *\n * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::ResourceVersion` resource.\n */\n// @ts-ignore TS6133\nfunction cfnResourceVersionPropsToCloudFormation(properties: any): any {\n    if (!cdk.canInspect(properties)) { return properties; }\n    CfnResourceVersionPropsValidator(properties).assertSuccess();\n    return {\n        SchemaHandlerPackage: cdk.stringToCloudFormation(properties.schemaHandlerPackage),\n        TypeName: cdk.stringToCloudFormation(properties.typeName),\n        ExecutionRoleArn: cdk.stringToCloudFormation(properties.executionRoleArn),\n        LoggingConfig: cfnResourceVersionLoggingConfigPropertyToCloudFormation(properties.loggingConfig),\n    };\n}\n\n// @ts-ignore TS6133\nfunction CfnResourceVersionPropsFromCloudFormation(properties: any): cfn_parse.FromCloudFormationResult<CfnResourceVersionProps> {\n    properties = properties == null ? {} : properties;\n    if (typeof properties !== 'object') {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    const ret = new cfn_parse.FromCloudFormationPropertyObject<CfnResourceVersionProps>();\n    ret.addPropertyResult('schemaHandlerPackage', 'SchemaHandlerPackage', cfn_parse.FromCloudFormation.getString(properties.SchemaHandlerPackage));\n    ret.addPropertyResult('typeName', 'TypeName', cfn_parse.FromCloudFormation.getString(properties.TypeName));\n    ret.addPropertyResult('executionRoleArn', 'ExecutionRoleArn', properties.ExecutionRoleArn != null ? cfn_parse.FromCloudFormation.getString(properties.ExecutionRoleArn) : undefined);\n    ret.addPropertyResult('loggingConfig', 'LoggingConfig', properties.LoggingConfig != null ? CfnResourceVersionLoggingConfigPropertyFromCloudFormation(properties.LoggingConfig) : undefined);\n    ret.addUnrecognizedPropertiesAsExtra(properties);\n    return ret;\n}\n\n/**\n * A CloudFormation `AWS::CloudFormation::ResourceVersion`\n *\n * Registers a resource version with the CloudFormation service. Registering a resource version makes it available for use in CloudFormation templates in your AWS account , and includes:\n *\n * - Validating the resource schema.\n * - Determining which handlers, if any, have been specified for the resource.\n * - Making the resource available for use in your account.\n *\n * For more information on how to develop resources and ready them for registration, see [Creating Resource Providers](https://docs.aws.amazon.com/cloudformation-cli/latest/userguide/resource-types.html) in the *CloudFormation CLI User Guide* .\n *\n * You can have a maximum of 50 resource versions registered at a time. This maximum is per account and per Region.\n *\n * @cloudformationResource AWS::CloudFormation::ResourceVersion\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-resourceversion.html\n */\nexport class CfnResourceVersion extends cdk.CfnResource implements cdk.IInspectable {\n    /**\n     * The CloudFormation resource type name for this resource class.\n     */\n    public static readonly CFN_RESOURCE_TYPE_NAME = \"AWS::CloudFormation::ResourceVersion\";\n\n    /**\n     * A factory method that creates a new instance of this class from an object\n     * containing the CloudFormation properties of this resource.\n     * Used in the @aws-cdk/cloudformation-include module.\n     *\n     * @internal\n     */\n    public static _fromCloudFormation(scope: cdk.Construct, id: string, resourceAttributes: any, options: cfn_parse.FromCloudFormationOptions): CfnResourceVersion {\n        resourceAttributes = resourceAttributes || {};\n        const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);\n        const propsResult = CfnResourceVersionPropsFromCloudFormation(resourceProperties);\n        const ret = new CfnResourceVersion(scope, id, propsResult.value);\n        for (const [propKey, propVal] of Object.entries(propsResult.extraProperties))  {\n            ret.addPropertyOverride(propKey, propVal);\n        }\n        options.parser.handleAttributes(ret, resourceAttributes, id);\n        return ret;\n    }\n\n    /**\n     * The Amazon Resource Name (ARN) of the resource version.\n     * @cloudformationAttribute Arn\n     */\n    public readonly attrArn: string;\n\n    /**\n     * Whether the resource version is set as the default version.\n     * @cloudformationAttribute IsDefaultVersion\n     */\n    public readonly attrIsDefaultVersion: cdk.IResolvable;\n\n    /**\n     * The provisioning behavior of the resource type. CloudFormation determines the provisioning type during registration, based on the types of handlers in the schema handler package submitted.\n     *\n     * Valid values include:\n     *\n     * - `FULLY_MUTABLE` : The resource type includes an update handler to process updates to the type during stack update operations.\n     * - `IMMUTABLE` : The resource type doesn't include an update handler, so the type can't be updated and must instead be replaced during stack update operations.\n     * - `NON_PROVISIONABLE` : The resource type doesn't include all the following handlers, and therefore can't actually be provisioned.\n     *\n     * - create\n     * - read\n     * - delete\n     * @cloudformationAttribute ProvisioningType\n     */\n    public readonly attrProvisioningType: string;\n\n    /**\n     * The Amazon Resource Name (ARN) of the resource.\n     * @cloudformationAttribute TypeArn\n     */\n    public readonly attrTypeArn: string;\n\n    /**\n     * The ID of a specific version of the resource. The version ID is the value at the end of the Amazon Resource Name (ARN) assigned to the resource version when it is registered.\n     * @cloudformationAttribute VersionId\n     */\n    public readonly attrVersionId: string;\n\n    /**\n     * The scope at which the resource is visible and usable in CloudFormation operations.\n     *\n     * Valid values include:\n     *\n     * - `PRIVATE` : The resource is only visible and usable within the account in which it's registered. CloudFormation marks any resources you register as `PRIVATE` .\n     * - `PUBLIC` : The resource is publicly visible and usable within any Amazon account.\n     * @cloudformationAttribute Visibility\n     */\n    public readonly attrVisibility: string;\n\n    /**\n     * A URL to the S3 bucket containing the resource project package that contains the necessary files for the resource you want to register.\n     *\n     * For information on generating a schema handler package for the resource you want to register, see [submit](https://docs.aws.amazon.com/cloudformation-cli/latest/userguide/resource-type-cli-submit.html) in the *CloudFormation CLI User Guide* .\n     *\n     * > The user registering the resource must be able to access the package in the S3 bucket. That is, the user needs to have [GetObject](https://docs.aws.amazon.com/AmazonS3/latest/API/API_GetObject.html) permissions for the schema handler package. For more information, see [Actions, Resources, and Condition Keys for Amazon S3](https://docs.aws.amazon.com/IAM/latest/UserGuide/list_amazons3.html) in the *AWS Identity and Access Management User Guide* .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-resourceversion.html#cfn-cloudformation-resourceversion-schemahandlerpackage\n     */\n    public schemaHandlerPackage: string;\n\n    /**\n     * The name of the resource being registered.\n     *\n     * We recommend that resource names adhere to the following pattern: *company_or_organization* :: *service* :: *type* .\n     *\n     * > The following organization namespaces are reserved and can't be used in your resource names:\n     * >\n     * > - `Alexa`\n     * > - `AMZN`\n     * > - `Amazon`\n     * > - `AWS`\n     * > - `Custom`\n     * > - `Dev`\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-resourceversion.html#cfn-cloudformation-resourceversion-typename\n     */\n    public typeName: string;\n\n    /**\n     * The Amazon Resource Name (ARN) of the IAM role for CloudFormation to assume when invoking the resource. If your resource calls AWS APIs in any of its handlers, you must create an *[IAM execution role](https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles.html)* that includes the necessary permissions to call those AWS APIs, and provision that execution role in your account. When CloudFormation needs to invoke the resource type handler, CloudFormation assumes this execution role to create a temporary session token, which it then passes to the resource type handler, thereby supplying your resource type with the appropriate credentials.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-resourceversion.html#cfn-cloudformation-resourceversion-executionrolearn\n     */\n    public executionRoleArn: string | undefined;\n\n    /**\n     * Logging configuration information for a resource.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-resourceversion.html#cfn-cloudformation-resourceversion-loggingconfig\n     */\n    public loggingConfig: CfnResourceVersion.LoggingConfigProperty | cdk.IResolvable | undefined;\n\n    /**\n     * Create a new `AWS::CloudFormation::ResourceVersion`.\n     *\n     * @param scope - scope in which this resource is defined\n     * @param id    - scoped id of the resource\n     * @param props - resource properties\n     */\n    constructor(scope: cdk.Construct, id: string, props: CfnResourceVersionProps) {\n        super(scope, id, { type: CfnResourceVersion.CFN_RESOURCE_TYPE_NAME, properties: props });\n        cdk.requireProperty(props, 'schemaHandlerPackage', this);\n        cdk.requireProperty(props, 'typeName', this);\n        this.attrArn = cdk.Token.asString(this.getAtt('Arn'));\n        this.attrIsDefaultVersion = this.getAtt('IsDefaultVersion');\n        this.attrProvisioningType = cdk.Token.asString(this.getAtt('ProvisioningType'));\n        this.attrTypeArn = cdk.Token.asString(this.getAtt('TypeArn'));\n        this.attrVersionId = cdk.Token.asString(this.getAtt('VersionId'));\n        this.attrVisibility = cdk.Token.asString(this.getAtt('Visibility'));\n\n        this.schemaHandlerPackage = props.schemaHandlerPackage;\n        this.typeName = props.typeName;\n        this.executionRoleArn = props.executionRoleArn;\n        this.loggingConfig = props.loggingConfig;\n    }\n\n    /**\n     * Examines the CloudFormation resource and discloses attributes.\n     *\n     * @param inspector - tree inspector to collect and process attributes\n     *\n     */\n    public inspect(inspector: cdk.TreeInspector) {\n        inspector.addAttribute(\"aws:cdk:cloudformation:type\", CfnResourceVersion.CFN_RESOURCE_TYPE_NAME);\n        inspector.addAttribute(\"aws:cdk:cloudformation:props\", this.cfnProperties);\n    }\n\n    protected get cfnProperties(): { [key: string]: any }  {\n        return {\n            schemaHandlerPackage: this.schemaHandlerPackage,\n            typeName: this.typeName,\n            executionRoleArn: this.executionRoleArn,\n            loggingConfig: this.loggingConfig,\n        };\n    }\n\n    protected renderProperties(props: {[key: string]: any}): { [key: string]: any }  {\n        return cfnResourceVersionPropsToCloudFormation(props);\n    }\n}\n\nexport namespace CfnResourceVersion {\n    /**\n     * Logging configuration information for a resource.\n     *\n     * @struct\n     * @stability external\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-resourceversion-loggingconfig.html\n     */\n    export interface LoggingConfigProperty {\n        /**\n         * The Amazon CloudWatch log group to which CloudFormation sends error logging information when invoking the type's handlers.\n         *\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-resourceversion-loggingconfig.html#cfn-cloudformation-resourceversion-loggingconfig-loggroupname\n         */\n        readonly logGroupName?: string;\n        /**\n         * The ARN of the role that CloudFormation should assume when sending log entries to CloudWatch logs.\n         *\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-resourceversion-loggingconfig.html#cfn-cloudformation-resourceversion-loggingconfig-logrolearn\n         */\n        readonly logRoleArn?: string;\n    }\n}\n\n/**\n * Determine whether the given properties match those of a `LoggingConfigProperty`\n *\n * @param properties - the TypeScript properties of a `LoggingConfigProperty`\n *\n * @returns the result of the validation.\n */\nfunction CfnResourceVersion_LoggingConfigPropertyValidator(properties: any): cdk.ValidationResult {\n    if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n    const errors = new cdk.ValidationResults();\n    if (typeof properties !== 'object') {\n        errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));\n    }\n    errors.collect(cdk.propertyValidator('logGroupName', cdk.validateString)(properties.logGroupName));\n    errors.collect(cdk.propertyValidator('logRoleArn', cdk.validateString)(properties.logRoleArn));\n    return errors.wrap('supplied properties not correct for \"LoggingConfigProperty\"');\n}\n\n/**\n * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::ResourceVersion.LoggingConfig` resource\n *\n * @param properties - the TypeScript properties of a `LoggingConfigProperty`\n *\n * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::ResourceVersion.LoggingConfig` resource.\n */\n// @ts-ignore TS6133\nfunction cfnResourceVersionLoggingConfigPropertyToCloudFormation(properties: any): any {\n    if (!cdk.canInspect(properties)) { return properties; }\n    CfnResourceVersion_LoggingConfigPropertyValidator(properties).assertSuccess();\n    return {\n        LogGroupName: cdk.stringToCloudFormation(properties.logGroupName),\n        LogRoleArn: cdk.stringToCloudFormation(properties.logRoleArn),\n    };\n}\n\n// @ts-ignore TS6133\nfunction CfnResourceVersionLoggingConfigPropertyFromCloudFormation(properties: any): cfn_parse.FromCloudFormationResult<CfnResourceVersion.LoggingConfigProperty | cdk.IResolvable> {\n    if (cdk.isResolvableObject(properties)) {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    properties = properties == null ? {} : properties;\n    if (typeof properties !== 'object') {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    const ret = new cfn_parse.FromCloudFormationPropertyObject<CfnResourceVersion.LoggingConfigProperty>();\n    ret.addPropertyResult('logGroupName', 'LogGroupName', properties.LogGroupName != null ? cfn_parse.FromCloudFormation.getString(properties.LogGroupName) : undefined);\n    ret.addPropertyResult('logRoleArn', 'LogRoleArn', properties.LogRoleArn != null ? cfn_parse.FromCloudFormation.getString(properties.LogRoleArn) : undefined);\n    ret.addUnrecognizedPropertiesAsExtra(properties);\n    return ret;\n}\n\n/**\n * Properties for defining a `CfnStack`\n *\n * @struct\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-stack.html\n */\nexport interface CfnStackProps {\n\n    /**\n     * Location of file containing the template body. The URL must point to a template (max size: 460,800 bytes) that's located in an Amazon S3 bucket. For more information, see [Template anatomy](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/template-anatomy.html) .\n     *\n     * Whether an update causes interruptions depends on the resources that are being updated. An update never causes a nested stack to be replaced.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-stack.html#cfn-cloudformation-stack-templateurl\n     */\n    readonly templateUrl: string;\n\n    /**\n     * The Amazon Simple Notification Service (Amazon SNS) topic ARNs to publish stack related events. You can find your Amazon SNS topic ARNs using the Amazon SNS console or your Command Line Interface (CLI).\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-stack.html#cfn-cloudformation-stack-notificationarns\n     */\n    readonly notificationArns?: string[];\n\n    /**\n     * The set value pairs that represent the parameters passed to CloudFormation when this nested stack is created. Each parameter has a name corresponding to a parameter defined in the embedded template and a value representing the value that you want to set for the parameter.\n     *\n     * > If you use the `Ref` function to pass a parameter value to a nested stack, comma-delimited list parameters must be of type `String` . In other words, you can't pass values that are of type `CommaDelimitedList` to nested stacks.\n     *\n     * Conditional. Required if the nested stack requires input parameters.\n     *\n     * Whether an update causes interruptions depends on the resources that are being updated. An update never causes a nested stack to be replaced.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-stack.html#cfn-cloudformation-stack-parameters\n     */\n    readonly parameters?: { [key: string]: (string) } | cdk.IResolvable;\n\n    /**\n     * Key-value pairs to associate with this stack. AWS CloudFormation also propagates these tags to the resources created in the stack. A maximum number of 50 tags can be specified.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-stack.html#cfn-cloudformation-stack-tags\n     */\n    readonly tags?: cdk.CfnTag[];\n\n    /**\n     * The length of time, in minutes, that CloudFormation waits for the nested stack to reach the `CREATE_COMPLETE` state. The default is no timeout. When CloudFormation detects that the nested stack has reached the `CREATE_COMPLETE` state, it marks the nested stack resource as `CREATE_COMPLETE` in the parent stack and resumes creating the parent stack. If the timeout period expires before the nested stack reaches `CREATE_COMPLETE` , CloudFormation marks the nested stack as failed and rolls back both the nested stack and parent stack.\n     *\n     * Updates aren't supported.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-stack.html#cfn-cloudformation-stack-timeoutinminutes\n     */\n    readonly timeoutInMinutes?: number;\n}\n\n/**\n * Determine whether the given properties match those of a `CfnStackProps`\n *\n * @param properties - the TypeScript properties of a `CfnStackProps`\n *\n * @returns the result of the validation.\n */\nfunction CfnStackPropsValidator(properties: any): cdk.ValidationResult {\n    if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n    const errors = new cdk.ValidationResults();\n    if (typeof properties !== 'object') {\n        errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));\n    }\n    errors.collect(cdk.propertyValidator('notificationArns', cdk.listValidator(cdk.validateString))(properties.notificationArns));\n    errors.collect(cdk.propertyValidator('parameters', cdk.hashValidator(cdk.validateString))(properties.parameters));\n    errors.collect(cdk.propertyValidator('tags', cdk.listValidator(cdk.validateCfnTag))(properties.tags));\n    errors.collect(cdk.propertyValidator('templateUrl', cdk.requiredValidator)(properties.templateUrl));\n    errors.collect(cdk.propertyValidator('templateUrl', cdk.validateString)(properties.templateUrl));\n    errors.collect(cdk.propertyValidator('timeoutInMinutes', cdk.validateNumber)(properties.timeoutInMinutes));\n    return errors.wrap('supplied properties not correct for \"CfnStackProps\"');\n}\n\n/**\n * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::Stack` resource\n *\n * @param properties - the TypeScript properties of a `CfnStackProps`\n *\n * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::Stack` resource.\n */\n// @ts-ignore TS6133\nfunction cfnStackPropsToCloudFormation(properties: any): any {\n    if (!cdk.canInspect(properties)) { return properties; }\n    CfnStackPropsValidator(properties).assertSuccess();\n    return {\n        TemplateURL: cdk.stringToCloudFormation(properties.templateUrl),\n        NotificationARNs: cdk.listMapper(cdk.stringToCloudFormation)(properties.notificationArns),\n        Parameters: cdk.hashMapper(cdk.stringToCloudFormation)(properties.parameters),\n        Tags: cdk.listMapper(cdk.cfnTagToCloudFormation)(properties.tags),\n        TimeoutInMinutes: cdk.numberToCloudFormation(properties.timeoutInMinutes),\n    };\n}\n\n// @ts-ignore TS6133\nfunction CfnStackPropsFromCloudFormation(properties: any): cfn_parse.FromCloudFormationResult<CfnStackProps> {\n    properties = properties == null ? {} : properties;\n    if (typeof properties !== 'object') {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    const ret = new cfn_parse.FromCloudFormationPropertyObject<CfnStackProps>();\n    ret.addPropertyResult('templateUrl', 'TemplateURL', cfn_parse.FromCloudFormation.getString(properties.TemplateURL));\n    ret.addPropertyResult('notificationArns', 'NotificationARNs', properties.NotificationARNs != null ? cfn_parse.FromCloudFormation.getStringArray(properties.NotificationARNs) : undefined);\n    ret.addPropertyResult('parameters', 'Parameters', properties.Parameters != null ? cfn_parse.FromCloudFormation.getMap(cfn_parse.FromCloudFormation.getString)(properties.Parameters) : undefined);\n    ret.addPropertyResult('tags', 'Tags', properties.Tags != null ? cfn_parse.FromCloudFormation.getArray(cfn_parse.FromCloudFormation.getCfnTag)(properties.Tags) : undefined as any);\n    ret.addPropertyResult('timeoutInMinutes', 'TimeoutInMinutes', properties.TimeoutInMinutes != null ? cfn_parse.FromCloudFormation.getNumber(properties.TimeoutInMinutes) : undefined);\n    ret.addUnrecognizedPropertiesAsExtra(properties);\n    return ret;\n}\n\n/**\n * A CloudFormation `AWS::CloudFormation::Stack`\n *\n * The `AWS::CloudFormation::Stack` resource nests a stack as a resource in a top-level template.\n *\n * You can add output values from a nested stack within the containing template. You use the [GetAtt](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/intrinsic-function-reference-getatt.html) function with the nested stack's logical name and the name of the output value in the nested stack in the format `Outputs. *NestedStackOutputName*` .\n *\n * > We strongly recommend that updates to nested stacks are run from the parent stack.\n *\n * When you apply template changes to update a top-level stack, CloudFormation updates the top-level stack and initiates an update to its nested stacks. CloudFormation updates the resources of modified nested stacks, but doesn't update the resources of unmodified nested stacks. For more information, see [CloudFormation stack updates](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/using-cfn-updating-stacks.html) .\n *\n * > You must acknowledge IAM capabilities for nested stacks that contain IAM resources. Also, verify that you have cancel update stack permissions, which is required if an update rolls back. For more information about IAM and CloudFormation , see [Controlling access with AWS Identity and Access Management](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/using-iam-template.html) .\n *\n * @cloudformationResource AWS::CloudFormation::Stack\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-stack.html\n */\nexport class CfnStack extends cdk.CfnResource implements cdk.IInspectable {\n    /**\n     * The CloudFormation resource type name for this resource class.\n     */\n    public static readonly CFN_RESOURCE_TYPE_NAME = \"AWS::CloudFormation::Stack\";\n\n    /**\n     * A factory method that creates a new instance of this class from an object\n     * containing the CloudFormation properties of this resource.\n     * Used in the @aws-cdk/cloudformation-include module.\n     *\n     * @internal\n     */\n    public static _fromCloudFormation(scope: cdk.Construct, id: string, resourceAttributes: any, options: cfn_parse.FromCloudFormationOptions): CfnStack {\n        resourceAttributes = resourceAttributes || {};\n        const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);\n        const propsResult = CfnStackPropsFromCloudFormation(resourceProperties);\n        const ret = new CfnStack(scope, id, propsResult.value);\n        for (const [propKey, propVal] of Object.entries(propsResult.extraProperties))  {\n            ret.addPropertyOverride(propKey, propVal);\n        }\n        options.parser.handleAttributes(ret, resourceAttributes, id);\n        return ret;\n    }\n\n    /**\n     * Location of file containing the template body. The URL must point to a template (max size: 460,800 bytes) that's located in an Amazon S3 bucket. For more information, see [Template anatomy](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/template-anatomy.html) .\n     *\n     * Whether an update causes interruptions depends on the resources that are being updated. An update never causes a nested stack to be replaced.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-stack.html#cfn-cloudformation-stack-templateurl\n     */\n    public templateUrl: string;\n\n    /**\n     * The Amazon Simple Notification Service (Amazon SNS) topic ARNs to publish stack related events. You can find your Amazon SNS topic ARNs using the Amazon SNS console or your Command Line Interface (CLI).\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-stack.html#cfn-cloudformation-stack-notificationarns\n     */\n    public notificationArns: string[] | undefined;\n\n    /**\n     * The set value pairs that represent the parameters passed to CloudFormation when this nested stack is created. Each parameter has a name corresponding to a parameter defined in the embedded template and a value representing the value that you want to set for the parameter.\n     *\n     * > If you use the `Ref` function to pass a parameter value to a nested stack, comma-delimited list parameters must be of type `String` . In other words, you can't pass values that are of type `CommaDelimitedList` to nested stacks.\n     *\n     * Conditional. Required if the nested stack requires input parameters.\n     *\n     * Whether an update causes interruptions depends on the resources that are being updated. An update never causes a nested stack to be replaced.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-stack.html#cfn-cloudformation-stack-parameters\n     */\n    public parameters: { [key: string]: (string) } | cdk.IResolvable | undefined;\n\n    /**\n     * Key-value pairs to associate with this stack. AWS CloudFormation also propagates these tags to the resources created in the stack. A maximum number of 50 tags can be specified.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-stack.html#cfn-cloudformation-stack-tags\n     */\n    public readonly tags: cdk.TagManager;\n\n    /**\n     * The length of time, in minutes, that CloudFormation waits for the nested stack to reach the `CREATE_COMPLETE` state. The default is no timeout. When CloudFormation detects that the nested stack has reached the `CREATE_COMPLETE` state, it marks the nested stack resource as `CREATE_COMPLETE` in the parent stack and resumes creating the parent stack. If the timeout period expires before the nested stack reaches `CREATE_COMPLETE` , CloudFormation marks the nested stack as failed and rolls back both the nested stack and parent stack.\n     *\n     * Updates aren't supported.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-stack.html#cfn-cloudformation-stack-timeoutinminutes\n     */\n    public timeoutInMinutes: number | undefined;\n\n    /**\n     * Create a new `AWS::CloudFormation::Stack`.\n     *\n     * @param scope - scope in which this resource is defined\n     * @param id    - scoped id of the resource\n     * @param props - resource properties\n     */\n    constructor(scope: cdk.Construct, id: string, props: CfnStackProps) {\n        super(scope, id, { type: CfnStack.CFN_RESOURCE_TYPE_NAME, properties: props });\n        cdk.requireProperty(props, 'templateUrl', this);\n\n        this.templateUrl = props.templateUrl;\n        this.notificationArns = props.notificationArns;\n        this.parameters = props.parameters;\n        this.tags = new cdk.TagManager(cdk.TagType.STANDARD, \"AWS::CloudFormation::Stack\", props.tags, { tagPropertyName: 'tags' });\n        this.timeoutInMinutes = props.timeoutInMinutes;\n        if (this.node.scope && cdk.Resource.isResource(this.node.scope)) {\n            this.node.addValidation({ validate: () => this.cfnOptions.deletionPolicy === undefined\n              ? ['\\'AWS::CloudFormation::Stack\\' is a stateful resource type, and you must specify a Removal Policy for it. Call \\'resource.applyRemovalPolicy()\\'.']\n              : [] });\n        }\n    }\n\n    /**\n     * Examines the CloudFormation resource and discloses attributes.\n     *\n     * @param inspector - tree inspector to collect and process attributes\n     *\n     */\n    public inspect(inspector: cdk.TreeInspector) {\n        inspector.addAttribute(\"aws:cdk:cloudformation:type\", CfnStack.CFN_RESOURCE_TYPE_NAME);\n        inspector.addAttribute(\"aws:cdk:cloudformation:props\", this.cfnProperties);\n    }\n\n    protected get cfnProperties(): { [key: string]: any }  {\n        return {\n            templateUrl: this.templateUrl,\n            notificationArns: this.notificationArns,\n            parameters: this.parameters,\n            tags: this.tags.renderTags(),\n            timeoutInMinutes: this.timeoutInMinutes,\n        };\n    }\n\n    protected renderProperties(props: {[key: string]: any}): { [key: string]: any }  {\n        return cfnStackPropsToCloudFormation(props);\n    }\n}\n\n/**\n * Properties for defining a `CfnStackSet`\n *\n * @struct\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html\n */\nexport interface CfnStackSetProps {\n\n    /**\n     * Describes how the IAM roles required for stack set operations are created.\n     *\n     * - With `SELF_MANAGED` permissions, you must create the administrator and execution roles required to deploy to target accounts. For more information, see [Grant Self-Managed Stack Set Permissions](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/stacksets-prereqs-self-managed.html) .\n     * - With `SERVICE_MANAGED` permissions, StackSets automatically creates the IAM roles required to deploy to accounts managed by AWS Organizations . For more information, see [Grant Service-Managed Stack Set Permissions](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/stacksets-prereqs-service-managed.html) .\n     *\n     * *Allowed Values* : `SERVICE_MANAGED` | `SELF_MANAGED`\n     *\n     * > The `PermissionModel` property is required.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-permissionmodel\n     */\n    readonly permissionModel: string;\n\n    /**\n     * The name to associate with the stack set. The name must be unique in the Region where you create your stack set.\n     *\n     * *Maximum* : `128`\n     *\n     * *Pattern* : `^[a-zA-Z][a-zA-Z0-9-]{0,127}$`\n     *\n     * > The `StackSetName` property is required.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-stacksetname\n     */\n    readonly stackSetName: string;\n\n    /**\n     * The Amazon Resource Number (ARN) of the IAM role to use to create this stack set. Specify an IAM role only if you are using customized administrator roles to control which users or groups can manage specific stack sets within the same administrator account.\n     *\n     * Use customized administrator roles to control which users or groups can manage specific stack sets within the same administrator account. For more information, see [Prerequisites: Granting Permissions for Stack Set Operations](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/stacksets-prereqs.html) in the *AWS CloudFormation User Guide* .\n     *\n     * *Minimum* : `20`\n     *\n     * *Maximum* : `2048`\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-administrationrolearn\n     */\n    readonly administrationRoleArn?: string;\n\n    /**\n     * [ `Service-managed` permissions] Describes whether StackSets automatically deploys to AWS Organizations accounts that are added to a target organization or organizational unit (OU).\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-autodeployment\n     */\n    readonly autoDeployment?: CfnStackSet.AutoDeploymentProperty | cdk.IResolvable;\n\n    /**\n     * [Service-managed permissions] Specifies whether you are acting as an account administrator in the organization's management account or as a delegated administrator in a member account.\n     *\n     * By default, `SELF` is specified. Use `SELF` for stack sets with self-managed permissions.\n     *\n     * - To create a stack set with service-managed permissions while signed in to the management account, specify `SELF` .\n     * - To create a stack set with service-managed permissions while signed in to a delegated administrator account, specify `DELEGATED_ADMIN` .\n     *\n     * Your AWS account must be registered as a delegated admin in the management account. For more information, see [Register a delegated administrator](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/stacksets-orgs-delegated-admin.html) in the *AWS CloudFormation User Guide* .\n     *\n     * Stack sets with service-managed permissions are created in the management account, including stack sets that are created by delegated administrators.\n     *\n     * *Valid Values* : `SELF` | `DELEGATED_ADMIN`\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-callas\n     */\n    readonly callAs?: string;\n\n    /**\n     * The capabilities that are allowed in the stack set. Some stack set templates might include resources that can affect permissions in your AWS account —for example, by creating new AWS Identity and Access Management ( IAM ) users. For more information, see [Acknowledging IAM Resources in AWS CloudFormation Templates](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/using-iam-template.html#capabilities) .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-capabilities\n     */\n    readonly capabilities?: string[];\n\n    /**\n     * A description of the stack set.\n     *\n     * *Minimum* : `1`\n     *\n     * *Maximum* : `1024`\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-description\n     */\n    readonly description?: string;\n\n    /**\n     * The name of the IAM execution role to use to create the stack set. If you don't specify an execution role, AWS CloudFormation uses the `AWSCloudFormationStackSetExecutionRole` role for the stack set operation.\n     *\n     * *Minimum* : `1`\n     *\n     * *Maximum* : `64`\n     *\n     * *Pattern* : `[a-zA-Z_0-9+=,.@-]+`\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-executionrolename\n     */\n    readonly executionRoleName?: string;\n\n    /**\n     * Describes whether StackSets performs non-conflicting operations concurrently and queues conflicting operations.\n     *\n     * When active, StackSets performs non-conflicting operations concurrently and queues conflicting operations. After conflicting operations finish, StackSets starts queued operations in request order.\n     *\n     * > If there are already running or queued operations, StackSets queues all incoming operations even if they are non-conflicting.\n     * >\n     * > You can't modify your stack set's execution configuration while there are running or queued operations for that stack set.\n     *\n     * When inactive (default), StackSets performs one operation at a time in request order.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-managedexecution\n     */\n    readonly managedExecution?: any | cdk.IResolvable;\n\n    /**\n     * The user-specified preferences for how AWS CloudFormation performs a stack set operation.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-operationpreferences\n     */\n    readonly operationPreferences?: CfnStackSet.OperationPreferencesProperty | cdk.IResolvable;\n\n    /**\n     * The input parameters for the stack set template.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-parameters\n     */\n    readonly parameters?: Array<CfnStackSet.ParameterProperty | cdk.IResolvable> | cdk.IResolvable;\n\n    /**\n     * A group of stack instances with parameters in some specific accounts and Regions.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-stackinstancesgroup\n     */\n    readonly stackInstancesGroup?: Array<CfnStackSet.StackInstancesProperty | cdk.IResolvable> | cdk.IResolvable;\n\n    /**\n     * The key-value pairs to associate with this stack set and the stacks created from it. AWS CloudFormation also propagates these tags to supported resources that are created in the stacks. A maximum number of 50 tags can be specified.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-tags\n     */\n    readonly tags?: cdk.CfnTag[];\n\n    /**\n     * The structure that contains the template body, with a minimum length of 1 byte and a maximum length of 51,200 bytes.\n     *\n     * You must include either `TemplateURL` or `TemplateBody` in a StackSet, but you can't use both. Dynamic references in the `TemplateBody` may not work correctly in all cases. It's recommended to pass templates containing dynamic references through `TemplateUrl` instead.\n     *\n     * *Minimum* : `1`\n     *\n     * *Maximum* : `51200`\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-templatebody\n     */\n    readonly templateBody?: string;\n\n    /**\n     * Location of file containing the template body. The URL must point to a template (max size: 460,800 bytes) that's located in an Amazon S3 bucket.\n     *\n     * You must include either `TemplateURL` or `TemplateBody` in a StackSet, but you can't use both.\n     *\n     * *Minimum* : `1`\n     *\n     * *Maximum* : `1024`\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-templateurl\n     */\n    readonly templateUrl?: string;\n}\n\n/**\n * Determine whether the given properties match those of a `CfnStackSetProps`\n *\n * @param properties - the TypeScript properties of a `CfnStackSetProps`\n *\n * @returns the result of the validation.\n */\nfunction CfnStackSetPropsValidator(properties: any): cdk.ValidationResult {\n    if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n    const errors = new cdk.ValidationResults();\n    if (typeof properties !== 'object') {\n        errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));\n    }\n    errors.collect(cdk.propertyValidator('administrationRoleArn', cdk.validateString)(properties.administrationRoleArn));\n    errors.collect(cdk.propertyValidator('autoDeployment', CfnStackSet_AutoDeploymentPropertyValidator)(properties.autoDeployment));\n    errors.collect(cdk.propertyValidator('callAs', cdk.validateString)(properties.callAs));\n    errors.collect(cdk.propertyValidator('capabilities', cdk.listValidator(cdk.validateString))(properties.capabilities));\n    errors.collect(cdk.propertyValidator('description', cdk.validateString)(properties.description));\n    errors.collect(cdk.propertyValidator('executionRoleName', cdk.validateString)(properties.executionRoleName));\n    errors.collect(cdk.propertyValidator('managedExecution', cdk.validateObject)(properties.managedExecution));\n    errors.collect(cdk.propertyValidator('operationPreferences', CfnStackSet_OperationPreferencesPropertyValidator)(properties.operationPreferences));\n    errors.collect(cdk.propertyValidator('parameters', cdk.listValidator(CfnStackSet_ParameterPropertyValidator))(properties.parameters));\n    errors.collect(cdk.propertyValidator('permissionModel', cdk.requiredValidator)(properties.permissionModel));\n    errors.collect(cdk.propertyValidator('permissionModel', cdk.validateString)(properties.permissionModel));\n    errors.collect(cdk.propertyValidator('stackInstancesGroup', cdk.listValidator(CfnStackSet_StackInstancesPropertyValidator))(properties.stackInstancesGroup));\n    errors.collect(cdk.propertyValidator('stackSetName', cdk.requiredValidator)(properties.stackSetName));\n    errors.collect(cdk.propertyValidator('stackSetName', cdk.validateString)(properties.stackSetName));\n    errors.collect(cdk.propertyValidator('tags', cdk.listValidator(cdk.validateCfnTag))(properties.tags));\n    errors.collect(cdk.propertyValidator('templateBody', cdk.validateString)(properties.templateBody));\n    errors.collect(cdk.propertyValidator('templateUrl', cdk.validateString)(properties.templateUrl));\n    return errors.wrap('supplied properties not correct for \"CfnStackSetProps\"');\n}\n\n/**\n * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::StackSet` resource\n *\n * @param properties - the TypeScript properties of a `CfnStackSetProps`\n *\n * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::StackSet` resource.\n */\n// @ts-ignore TS6133\nfunction cfnStackSetPropsToCloudFormation(properties: any): any {\n    if (!cdk.canInspect(properties)) { return properties; }\n    CfnStackSetPropsValidator(properties).assertSuccess();\n    return {\n        PermissionModel: cdk.stringToCloudFormation(properties.permissionModel),\n        StackSetName: cdk.stringToCloudFormation(properties.stackSetName),\n        AdministrationRoleARN: cdk.stringToCloudFormation(properties.administrationRoleArn),\n        AutoDeployment: cfnStackSetAutoDeploymentPropertyToCloudFormation(properties.autoDeployment),\n        CallAs: cdk.stringToCloudFormation(properties.callAs),\n        Capabilities: cdk.listMapper(cdk.stringToCloudFormation)(properties.capabilities),\n        Description: cdk.stringToCloudFormation(properties.description),\n        ExecutionRoleName: cdk.stringToCloudFormation(properties.executionRoleName),\n        ManagedExecution: cdk.objectToCloudFormation(properties.managedExecution),\n        OperationPreferences: cfnStackSetOperationPreferencesPropertyToCloudFormation(properties.operationPreferences),\n        Parameters: cdk.listMapper(cfnStackSetParameterPropertyToCloudFormation)(properties.parameters),\n        StackInstancesGroup: cdk.listMapper(cfnStackSetStackInstancesPropertyToCloudFormation)(properties.stackInstancesGroup),\n        Tags: cdk.listMapper(cdk.cfnTagToCloudFormation)(properties.tags),\n        TemplateBody: cdk.stringToCloudFormation(properties.templateBody),\n        TemplateURL: cdk.stringToCloudFormation(properties.templateUrl),\n    };\n}\n\n// @ts-ignore TS6133\nfunction CfnStackSetPropsFromCloudFormation(properties: any): cfn_parse.FromCloudFormationResult<CfnStackSetProps> {\n    properties = properties == null ? {} : properties;\n    if (typeof properties !== 'object') {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    const ret = new cfn_parse.FromCloudFormationPropertyObject<CfnStackSetProps>();\n    ret.addPropertyResult('permissionModel', 'PermissionModel', cfn_parse.FromCloudFormation.getString(properties.PermissionModel));\n    ret.addPropertyResult('stackSetName', 'StackSetName', cfn_parse.FromCloudFormation.getString(properties.StackSetName));\n    ret.addPropertyResult('administrationRoleArn', 'AdministrationRoleARN', properties.AdministrationRoleARN != null ? cfn_parse.FromCloudFormation.getString(properties.AdministrationRoleARN) : undefined);\n    ret.addPropertyResult('autoDeployment', 'AutoDeployment', properties.AutoDeployment != null ? CfnStackSetAutoDeploymentPropertyFromCloudFormation(properties.AutoDeployment) : undefined);\n    ret.addPropertyResult('callAs', 'CallAs', properties.CallAs != null ? cfn_parse.FromCloudFormation.getString(properties.CallAs) : undefined);\n    ret.addPropertyResult('capabilities', 'Capabilities', properties.Capabilities != null ? cfn_parse.FromCloudFormation.getStringArray(properties.Capabilities) : undefined);\n    ret.addPropertyResult('description', 'Description', properties.Description != null ? cfn_parse.FromCloudFormation.getString(properties.Description) : undefined);\n    ret.addPropertyResult('executionRoleName', 'ExecutionRoleName', properties.ExecutionRoleName != null ? cfn_parse.FromCloudFormation.getString(properties.ExecutionRoleName) : undefined);\n    ret.addPropertyResult('managedExecution', 'ManagedExecution', properties.ManagedExecution != null ? cfn_parse.FromCloudFormation.getAny(properties.ManagedExecution) : undefined);\n    ret.addPropertyResult('operationPreferences', 'OperationPreferences', properties.OperationPreferences != null ? CfnStackSetOperationPreferencesPropertyFromCloudFormation(properties.OperationPreferences) : undefined);\n    ret.addPropertyResult('parameters', 'Parameters', properties.Parameters != null ? cfn_parse.FromCloudFormation.getArray(CfnStackSetParameterPropertyFromCloudFormation)(properties.Parameters) : undefined);\n    ret.addPropertyResult('stackInstancesGroup', 'StackInstancesGroup', properties.StackInstancesGroup != null ? cfn_parse.FromCloudFormation.getArray(CfnStackSetStackInstancesPropertyFromCloudFormation)(properties.StackInstancesGroup) : undefined);\n    ret.addPropertyResult('tags', 'Tags', properties.Tags != null ? cfn_parse.FromCloudFormation.getArray(cfn_parse.FromCloudFormation.getCfnTag)(properties.Tags) : undefined as any);\n    ret.addPropertyResult('templateBody', 'TemplateBody', properties.TemplateBody != null ? cfn_parse.FromCloudFormation.getString(properties.TemplateBody) : undefined);\n    ret.addPropertyResult('templateUrl', 'TemplateURL', properties.TemplateURL != null ? cfn_parse.FromCloudFormation.getString(properties.TemplateURL) : undefined);\n    ret.addUnrecognizedPropertiesAsExtra(properties);\n    return ret;\n}\n\n/**\n * A CloudFormation `AWS::CloudFormation::StackSet`\n *\n * The `AWS::CloudFormation::StackSet` enables you to provision stacks into AWS accounts and across Regions by using a single CloudFormation template. In the stack set, you specify the template to use, in addition to any parameters and capabilities that the template requires.\n *\n * @cloudformationResource AWS::CloudFormation::StackSet\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html\n */\nexport class CfnStackSet extends cdk.CfnResource implements cdk.IInspectable {\n    /**\n     * The CloudFormation resource type name for this resource class.\n     */\n    public static readonly CFN_RESOURCE_TYPE_NAME = \"AWS::CloudFormation::StackSet\";\n\n    /**\n     * A factory method that creates a new instance of this class from an object\n     * containing the CloudFormation properties of this resource.\n     * Used in the @aws-cdk/cloudformation-include module.\n     *\n     * @internal\n     */\n    public static _fromCloudFormation(scope: cdk.Construct, id: string, resourceAttributes: any, options: cfn_parse.FromCloudFormationOptions): CfnStackSet {\n        resourceAttributes = resourceAttributes || {};\n        const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);\n        const propsResult = CfnStackSetPropsFromCloudFormation(resourceProperties);\n        const ret = new CfnStackSet(scope, id, propsResult.value);\n        for (const [propKey, propVal] of Object.entries(propsResult.extraProperties))  {\n            ret.addPropertyOverride(propKey, propVal);\n        }\n        options.parser.handleAttributes(ret, resourceAttributes, id);\n        return ret;\n    }\n\n    /**\n     * The ID of the stack that you're creating.\n     * @cloudformationAttribute StackSetId\n     */\n    public readonly attrStackSetId: string;\n\n    /**\n     * Describes how the IAM roles required for stack set operations are created.\n     *\n     * - With `SELF_MANAGED` permissions, you must create the administrator and execution roles required to deploy to target accounts. For more information, see [Grant Self-Managed Stack Set Permissions](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/stacksets-prereqs-self-managed.html) .\n     * - With `SERVICE_MANAGED` permissions, StackSets automatically creates the IAM roles required to deploy to accounts managed by AWS Organizations . For more information, see [Grant Service-Managed Stack Set Permissions](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/stacksets-prereqs-service-managed.html) .\n     *\n     * *Allowed Values* : `SERVICE_MANAGED` | `SELF_MANAGED`\n     *\n     * > The `PermissionModel` property is required.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-permissionmodel\n     */\n    public permissionModel: string;\n\n    /**\n     * The name to associate with the stack set. The name must be unique in the Region where you create your stack set.\n     *\n     * *Maximum* : `128`\n     *\n     * *Pattern* : `^[a-zA-Z][a-zA-Z0-9-]{0,127}$`\n     *\n     * > The `StackSetName` property is required.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-stacksetname\n     */\n    public stackSetName: string;\n\n    /**\n     * The Amazon Resource Number (ARN) of the IAM role to use to create this stack set. Specify an IAM role only if you are using customized administrator roles to control which users or groups can manage specific stack sets within the same administrator account.\n     *\n     * Use customized administrator roles to control which users or groups can manage specific stack sets within the same administrator account. For more information, see [Prerequisites: Granting Permissions for Stack Set Operations](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/stacksets-prereqs.html) in the *AWS CloudFormation User Guide* .\n     *\n     * *Minimum* : `20`\n     *\n     * *Maximum* : `2048`\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-administrationrolearn\n     */\n    public administrationRoleArn: string | undefined;\n\n    /**\n     * [ `Service-managed` permissions] Describes whether StackSets automatically deploys to AWS Organizations accounts that are added to a target organization or organizational unit (OU).\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-autodeployment\n     */\n    public autoDeployment: CfnStackSet.AutoDeploymentProperty | cdk.IResolvable | undefined;\n\n    /**\n     * [Service-managed permissions] Specifies whether you are acting as an account administrator in the organization's management account or as a delegated administrator in a member account.\n     *\n     * By default, `SELF` is specified. Use `SELF` for stack sets with self-managed permissions.\n     *\n     * - To create a stack set with service-managed permissions while signed in to the management account, specify `SELF` .\n     * - To create a stack set with service-managed permissions while signed in to a delegated administrator account, specify `DELEGATED_ADMIN` .\n     *\n     * Your AWS account must be registered as a delegated admin in the management account. For more information, see [Register a delegated administrator](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/stacksets-orgs-delegated-admin.html) in the *AWS CloudFormation User Guide* .\n     *\n     * Stack sets with service-managed permissions are created in the management account, including stack sets that are created by delegated administrators.\n     *\n     * *Valid Values* : `SELF` | `DELEGATED_ADMIN`\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-callas\n     */\n    public callAs: string | undefined;\n\n    /**\n     * The capabilities that are allowed in the stack set. Some stack set templates might include resources that can affect permissions in your AWS account —for example, by creating new AWS Identity and Access Management ( IAM ) users. For more information, see [Acknowledging IAM Resources in AWS CloudFormation Templates](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/using-iam-template.html#capabilities) .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-capabilities\n     */\n    public capabilities: string[] | undefined;\n\n    /**\n     * A description of the stack set.\n     *\n     * *Minimum* : `1`\n     *\n     * *Maximum* : `1024`\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-description\n     */\n    public description: string | undefined;\n\n    /**\n     * The name of the IAM execution role to use to create the stack set. If you don't specify an execution role, AWS CloudFormation uses the `AWSCloudFormationStackSetExecutionRole` role for the stack set operation.\n     *\n     * *Minimum* : `1`\n     *\n     * *Maximum* : `64`\n     *\n     * *Pattern* : `[a-zA-Z_0-9+=,.@-]+`\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-executionrolename\n     */\n    public executionRoleName: string | undefined;\n\n    /**\n     * Describes whether StackSets performs non-conflicting operations concurrently and queues conflicting operations.\n     *\n     * When active, StackSets performs non-conflicting operations concurrently and queues conflicting operations. After conflicting operations finish, StackSets starts queued operations in request order.\n     *\n     * > If there are already running or queued operations, StackSets queues all incoming operations even if they are non-conflicting.\n     * >\n     * > You can't modify your stack set's execution configuration while there are running or queued operations for that stack set.\n     *\n     * When inactive (default), StackSets performs one operation at a time in request order.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-managedexecution\n     */\n    public managedExecution: any | cdk.IResolvable | undefined;\n\n    /**\n     * The user-specified preferences for how AWS CloudFormation performs a stack set operation.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-operationpreferences\n     */\n    public operationPreferences: CfnStackSet.OperationPreferencesProperty | cdk.IResolvable | undefined;\n\n    /**\n     * The input parameters for the stack set template.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-parameters\n     */\n    public parameters: Array<CfnStackSet.ParameterProperty | cdk.IResolvable> | cdk.IResolvable | undefined;\n\n    /**\n     * A group of stack instances with parameters in some specific accounts and Regions.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-stackinstancesgroup\n     */\n    public stackInstancesGroup: Array<CfnStackSet.StackInstancesProperty | cdk.IResolvable> | cdk.IResolvable | undefined;\n\n    /**\n     * The key-value pairs to associate with this stack set and the stacks created from it. AWS CloudFormation also propagates these tags to supported resources that are created in the stacks. A maximum number of 50 tags can be specified.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-tags\n     */\n    public readonly tags: cdk.TagManager;\n\n    /**\n     * The structure that contains the template body, with a minimum length of 1 byte and a maximum length of 51,200 bytes.\n     *\n     * You must include either `TemplateURL` or `TemplateBody` in a StackSet, but you can't use both. Dynamic references in the `TemplateBody` may not work correctly in all cases. It's recommended to pass templates containing dynamic references through `TemplateUrl` instead.\n     *\n     * *Minimum* : `1`\n     *\n     * *Maximum* : `51200`\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-templatebody\n     */\n    public templateBody: string | undefined;\n\n    /**\n     * Location of file containing the template body. The URL must point to a template (max size: 460,800 bytes) that's located in an Amazon S3 bucket.\n     *\n     * You must include either `TemplateURL` or `TemplateBody` in a StackSet, but you can't use both.\n     *\n     * *Minimum* : `1`\n     *\n     * *Maximum* : `1024`\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-stackset.html#cfn-cloudformation-stackset-templateurl\n     */\n    public templateUrl: string | undefined;\n\n    /**\n     * Create a new `AWS::CloudFormation::StackSet`.\n     *\n     * @param scope - scope in which this resource is defined\n     * @param id    - scoped id of the resource\n     * @param props - resource properties\n     */\n    constructor(scope: cdk.Construct, id: string, props: CfnStackSetProps) {\n        super(scope, id, { type: CfnStackSet.CFN_RESOURCE_TYPE_NAME, properties: props });\n        cdk.requireProperty(props, 'permissionModel', this);\n        cdk.requireProperty(props, 'stackSetName', this);\n        this.attrStackSetId = cdk.Token.asString(this.getAtt('StackSetId'));\n\n        this.permissionModel = props.permissionModel;\n        this.stackSetName = props.stackSetName;\n        this.administrationRoleArn = props.administrationRoleArn;\n        this.autoDeployment = props.autoDeployment;\n        this.callAs = props.callAs;\n        this.capabilities = props.capabilities;\n        this.description = props.description;\n        this.executionRoleName = props.executionRoleName;\n        this.managedExecution = props.managedExecution;\n        this.operationPreferences = props.operationPreferences;\n        this.parameters = props.parameters;\n        this.stackInstancesGroup = props.stackInstancesGroup;\n        this.tags = new cdk.TagManager(cdk.TagType.STANDARD, \"AWS::CloudFormation::StackSet\", props.tags, { tagPropertyName: 'tags' });\n        this.templateBody = props.templateBody;\n        this.templateUrl = props.templateUrl;\n    }\n\n    /**\n     * Examines the CloudFormation resource and discloses attributes.\n     *\n     * @param inspector - tree inspector to collect and process attributes\n     *\n     */\n    public inspect(inspector: cdk.TreeInspector) {\n        inspector.addAttribute(\"aws:cdk:cloudformation:type\", CfnStackSet.CFN_RESOURCE_TYPE_NAME);\n        inspector.addAttribute(\"aws:cdk:cloudformation:props\", this.cfnProperties);\n    }\n\n    protected get cfnProperties(): { [key: string]: any }  {\n        return {\n            permissionModel: this.permissionModel,\n            stackSetName: this.stackSetName,\n            administrationRoleArn: this.administrationRoleArn,\n            autoDeployment: this.autoDeployment,\n            callAs: this.callAs,\n            capabilities: this.capabilities,\n            description: this.description,\n            executionRoleName: this.executionRoleName,\n            managedExecution: this.managedExecution,\n            operationPreferences: this.operationPreferences,\n            parameters: this.parameters,\n            stackInstancesGroup: this.stackInstancesGroup,\n            tags: this.tags.renderTags(),\n            templateBody: this.templateBody,\n            templateUrl: this.templateUrl,\n        };\n    }\n\n    protected renderProperties(props: {[key: string]: any}): { [key: string]: any }  {\n        return cfnStackSetPropsToCloudFormation(props);\n    }\n}\n\nexport namespace CfnStackSet {\n    /**\n     * [ `Service-managed` permissions] Describes whether StackSets automatically deploys to AWS Organizations accounts that are added to a target organizational unit (OU).\n     *\n     * @struct\n     * @stability external\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-stackset-autodeployment.html\n     */\n    export interface AutoDeploymentProperty {\n        /**\n         * If set to `true` , StackSets automatically deploys additional stack instances to AWS Organizations accounts that are added to a target organization or organizational unit (OU) in the specified Regions. If an account is removed from a target organization or OU, StackSets deletes stack instances from the account in the specified Regions.\n         *\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-stackset-autodeployment.html#cfn-cloudformation-stackset-autodeployment-enabled\n         */\n        readonly enabled?: boolean | cdk.IResolvable;\n        /**\n         * If set to `true` , stack resources are retained when an account is removed from a target organization or OU. If set to `false` , stack resources are deleted. Specify only if `Enabled` is set to `True` .\n         *\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-stackset-autodeployment.html#cfn-cloudformation-stackset-autodeployment-retainstacksonaccountremoval\n         */\n        readonly retainStacksOnAccountRemoval?: boolean | cdk.IResolvable;\n    }\n}\n\n/**\n * Determine whether the given properties match those of a `AutoDeploymentProperty`\n *\n * @param properties - the TypeScript properties of a `AutoDeploymentProperty`\n *\n * @returns the result of the validation.\n */\nfunction CfnStackSet_AutoDeploymentPropertyValidator(properties: any): cdk.ValidationResult {\n    if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n    const errors = new cdk.ValidationResults();\n    if (typeof properties !== 'object') {\n        errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));\n    }\n    errors.collect(cdk.propertyValidator('enabled', cdk.validateBoolean)(properties.enabled));\n    errors.collect(cdk.propertyValidator('retainStacksOnAccountRemoval', cdk.validateBoolean)(properties.retainStacksOnAccountRemoval));\n    return errors.wrap('supplied properties not correct for \"AutoDeploymentProperty\"');\n}\n\n/**\n * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::StackSet.AutoDeployment` resource\n *\n * @param properties - the TypeScript properties of a `AutoDeploymentProperty`\n *\n * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::StackSet.AutoDeployment` resource.\n */\n// @ts-ignore TS6133\nfunction cfnStackSetAutoDeploymentPropertyToCloudFormation(properties: any): any {\n    if (!cdk.canInspect(properties)) { return properties; }\n    CfnStackSet_AutoDeploymentPropertyValidator(properties).assertSuccess();\n    return {\n        Enabled: cdk.booleanToCloudFormation(properties.enabled),\n        RetainStacksOnAccountRemoval: cdk.booleanToCloudFormation(properties.retainStacksOnAccountRemoval),\n    };\n}\n\n// @ts-ignore TS6133\nfunction CfnStackSetAutoDeploymentPropertyFromCloudFormation(properties: any): cfn_parse.FromCloudFormationResult<CfnStackSet.AutoDeploymentProperty | cdk.IResolvable> {\n    if (cdk.isResolvableObject(properties)) {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    properties = properties == null ? {} : properties;\n    if (typeof properties !== 'object') {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    const ret = new cfn_parse.FromCloudFormationPropertyObject<CfnStackSet.AutoDeploymentProperty>();\n    ret.addPropertyResult('enabled', 'Enabled', properties.Enabled != null ? cfn_parse.FromCloudFormation.getBoolean(properties.Enabled) : undefined);\n    ret.addPropertyResult('retainStacksOnAccountRemoval', 'RetainStacksOnAccountRemoval', properties.RetainStacksOnAccountRemoval != null ? cfn_parse.FromCloudFormation.getBoolean(properties.RetainStacksOnAccountRemoval) : undefined);\n    ret.addUnrecognizedPropertiesAsExtra(properties);\n    return ret;\n}\n\nexport namespace CfnStackSet {\n    /**\n     * The AWS OrganizationalUnitIds or Accounts for which to create stack instances in the specified Regions.\n     *\n     * @struct\n     * @stability external\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-stackset-deploymenttargets.html\n     */\n    export interface DeploymentTargetsProperty {\n        /**\n         * The names of one or more AWS accounts for which you want to deploy stack set updates.\n         *\n         * *Pattern* : `^[0-9]{12}$`\n         *\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-stackset-deploymenttargets.html#cfn-cloudformation-stackset-deploymenttargets-accounts\n         */\n        readonly accounts?: string[];\n        /**\n         * The organization root ID or organizational unit (OU) IDs to which StackSets deploys.\n         *\n         * *Pattern* : `^(ou-[a-z0-9]{4,32}-[a-z0-9]{8,32}|r-[a-z0-9]{4,32})$`\n         *\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-stackset-deploymenttargets.html#cfn-cloudformation-stackset-deploymenttargets-organizationalunitids\n         */\n        readonly organizationalUnitIds?: string[];\n    }\n}\n\n/**\n * Determine whether the given properties match those of a `DeploymentTargetsProperty`\n *\n * @param properties - the TypeScript properties of a `DeploymentTargetsProperty`\n *\n * @returns the result of the validation.\n */\nfunction CfnStackSet_DeploymentTargetsPropertyValidator(properties: any): cdk.ValidationResult {\n    if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n    const errors = new cdk.ValidationResults();\n    if (typeof properties !== 'object') {\n        errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));\n    }\n    errors.collect(cdk.propertyValidator('accounts', cdk.listValidator(cdk.validateString))(properties.accounts));\n    errors.collect(cdk.propertyValidator('organizationalUnitIds', cdk.listValidator(cdk.validateString))(properties.organizationalUnitIds));\n    return errors.wrap('supplied properties not correct for \"DeploymentTargetsProperty\"');\n}\n\n/**\n * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::StackSet.DeploymentTargets` resource\n *\n * @param properties - the TypeScript properties of a `DeploymentTargetsProperty`\n *\n * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::StackSet.DeploymentTargets` resource.\n */\n// @ts-ignore TS6133\nfunction cfnStackSetDeploymentTargetsPropertyToCloudFormation(properties: any): any {\n    if (!cdk.canInspect(properties)) { return properties; }\n    CfnStackSet_DeploymentTargetsPropertyValidator(properties).assertSuccess();\n    return {\n        Accounts: cdk.listMapper(cdk.stringToCloudFormation)(properties.accounts),\n        OrganizationalUnitIds: cdk.listMapper(cdk.stringToCloudFormation)(properties.organizationalUnitIds),\n    };\n}\n\n// @ts-ignore TS6133\nfunction CfnStackSetDeploymentTargetsPropertyFromCloudFormation(properties: any): cfn_parse.FromCloudFormationResult<CfnStackSet.DeploymentTargetsProperty | cdk.IResolvable> {\n    if (cdk.isResolvableObject(properties)) {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    properties = properties == null ? {} : properties;\n    if (typeof properties !== 'object') {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    const ret = new cfn_parse.FromCloudFormationPropertyObject<CfnStackSet.DeploymentTargetsProperty>();\n    ret.addPropertyResult('accounts', 'Accounts', properties.Accounts != null ? cfn_parse.FromCloudFormation.getStringArray(properties.Accounts) : undefined);\n    ret.addPropertyResult('organizationalUnitIds', 'OrganizationalUnitIds', properties.OrganizationalUnitIds != null ? cfn_parse.FromCloudFormation.getStringArray(properties.OrganizationalUnitIds) : undefined);\n    ret.addUnrecognizedPropertiesAsExtra(properties);\n    return ret;\n}\n\nexport namespace CfnStackSet {\n    /**\n     * The user-specified preferences for how AWS CloudFormation performs a stack set operation. For more information on maximum concurrent accounts and failure tolerance, see [Stack set operation options](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/stacksets-concepts.html#stackset-ops-options) .\n     *\n     * @struct\n     * @stability external\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-stackset-operationpreferences.html\n     */\n    export interface OperationPreferencesProperty {\n        /**\n         * The number of accounts, per Region, for which this operation can fail before AWS CloudFormation stops the operation in that Region. If the operation is stopped in a Region, AWS CloudFormation doesn't attempt the operation in any subsequent Regions.\n         *\n         * Conditional: You must specify either `FailureToleranceCount` or `FailureTolerancePercentage` (but not both).\n         *\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-stackset-operationpreferences.html#cfn-cloudformation-stackset-operationpreferences-failuretolerancecount\n         */\n        readonly failureToleranceCount?: number;\n        /**\n         * The percentage of accounts, per Region, for which this stack operation can fail before AWS CloudFormation stops the operation in that Region. If the operation is stopped in a Region, AWS CloudFormation doesn't attempt the operation in any subsequent Regions.\n         *\n         * When calculating the number of accounts based on the specified percentage, AWS CloudFormation rounds *down* to the next whole number.\n         *\n         * Conditional: You must specify either `FailureToleranceCount` or `FailureTolerancePercentage` , but not both.\n         *\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-stackset-operationpreferences.html#cfn-cloudformation-stackset-operationpreferences-failuretolerancepercentage\n         */\n        readonly failureTolerancePercentage?: number;\n        /**\n         * The maximum number of accounts in which to perform this operation at one time. This is dependent on the value of `FailureToleranceCount` . `MaxConcurrentCount` is at most one more than the `FailureToleranceCount` .\n         *\n         * Note that this setting lets you specify the *maximum* for operations. For large deployments, under certain circumstances the actual number of accounts acted upon concurrently may be lower due to service throttling.\n         *\n         * Conditional: You must specify either `MaxConcurrentCount` or `MaxConcurrentPercentage` , but not both.\n         *\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-stackset-operationpreferences.html#cfn-cloudformation-stackset-operationpreferences-maxconcurrentcount\n         */\n        readonly maxConcurrentCount?: number;\n        /**\n         * The maximum percentage of accounts in which to perform this operation at one time.\n         *\n         * When calculating the number of accounts based on the specified percentage, AWS CloudFormation rounds down to the next whole number. This is true except in cases where rounding down would result is zero. In this case, CloudFormation sets the number as one instead.\n         *\n         * Note that this setting lets you specify the *maximum* for operations. For large deployments, under certain circumstances the actual number of accounts acted upon concurrently may be lower due to service throttling.\n         *\n         * Conditional: You must specify either `MaxConcurrentCount` or `MaxConcurrentPercentage` , but not both.\n         *\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-stackset-operationpreferences.html#cfn-cloudformation-stackset-operationpreferences-maxconcurrentpercentage\n         */\n        readonly maxConcurrentPercentage?: number;\n        /**\n         * The concurrency type of deploying StackSets operations in Regions, could be in parallel or one Region at a time.\n         *\n         * *Allowed values* : `SEQUENTIAL` | `PARALLEL`\n         *\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-stackset-operationpreferences.html#cfn-cloudformation-stackset-operationpreferences-regionconcurrencytype\n         */\n        readonly regionConcurrencyType?: string;\n        /**\n         * The order of the Regions where you want to perform the stack operation.\n         *\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-stackset-operationpreferences.html#cfn-cloudformation-stackset-operationpreferences-regionorder\n         */\n        readonly regionOrder?: string[];\n    }\n}\n\n/**\n * Determine whether the given properties match those of a `OperationPreferencesProperty`\n *\n * @param properties - the TypeScript properties of a `OperationPreferencesProperty`\n *\n * @returns the result of the validation.\n */\nfunction CfnStackSet_OperationPreferencesPropertyValidator(properties: any): cdk.ValidationResult {\n    if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n    const errors = new cdk.ValidationResults();\n    if (typeof properties !== 'object') {\n        errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));\n    }\n    errors.collect(cdk.propertyValidator('failureToleranceCount', cdk.validateNumber)(properties.failureToleranceCount));\n    errors.collect(cdk.propertyValidator('failureTolerancePercentage', cdk.validateNumber)(properties.failureTolerancePercentage));\n    errors.collect(cdk.propertyValidator('maxConcurrentCount', cdk.validateNumber)(properties.maxConcurrentCount));\n    errors.collect(cdk.propertyValidator('maxConcurrentPercentage', cdk.validateNumber)(properties.maxConcurrentPercentage));\n    errors.collect(cdk.propertyValidator('regionConcurrencyType', cdk.validateString)(properties.regionConcurrencyType));\n    errors.collect(cdk.propertyValidator('regionOrder', cdk.listValidator(cdk.validateString))(properties.regionOrder));\n    return errors.wrap('supplied properties not correct for \"OperationPreferencesProperty\"');\n}\n\n/**\n * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::StackSet.OperationPreferences` resource\n *\n * @param properties - the TypeScript properties of a `OperationPreferencesProperty`\n *\n * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::StackSet.OperationPreferences` resource.\n */\n// @ts-ignore TS6133\nfunction cfnStackSetOperationPreferencesPropertyToCloudFormation(properties: any): any {\n    if (!cdk.canInspect(properties)) { return properties; }\n    CfnStackSet_OperationPreferencesPropertyValidator(properties).assertSuccess();\n    return {\n        FailureToleranceCount: cdk.numberToCloudFormation(properties.failureToleranceCount),\n        FailureTolerancePercentage: cdk.numberToCloudFormation(properties.failureTolerancePercentage),\n        MaxConcurrentCount: cdk.numberToCloudFormation(properties.maxConcurrentCount),\n        MaxConcurrentPercentage: cdk.numberToCloudFormation(properties.maxConcurrentPercentage),\n        RegionConcurrencyType: cdk.stringToCloudFormation(properties.regionConcurrencyType),\n        RegionOrder: cdk.listMapper(cdk.stringToCloudFormation)(properties.regionOrder),\n    };\n}\n\n// @ts-ignore TS6133\nfunction CfnStackSetOperationPreferencesPropertyFromCloudFormation(properties: any): cfn_parse.FromCloudFormationResult<CfnStackSet.OperationPreferencesProperty | cdk.IResolvable> {\n    if (cdk.isResolvableObject(properties)) {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    properties = properties == null ? {} : properties;\n    if (typeof properties !== 'object') {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    const ret = new cfn_parse.FromCloudFormationPropertyObject<CfnStackSet.OperationPreferencesProperty>();\n    ret.addPropertyResult('failureToleranceCount', 'FailureToleranceCount', properties.FailureToleranceCount != null ? cfn_parse.FromCloudFormation.getNumber(properties.FailureToleranceCount) : undefined);\n    ret.addPropertyResult('failureTolerancePercentage', 'FailureTolerancePercentage', properties.FailureTolerancePercentage != null ? cfn_parse.FromCloudFormation.getNumber(properties.FailureTolerancePercentage) : undefined);\n    ret.addPropertyResult('maxConcurrentCount', 'MaxConcurrentCount', properties.MaxConcurrentCount != null ? cfn_parse.FromCloudFormation.getNumber(properties.MaxConcurrentCount) : undefined);\n    ret.addPropertyResult('maxConcurrentPercentage', 'MaxConcurrentPercentage', properties.MaxConcurrentPercentage != null ? cfn_parse.FromCloudFormation.getNumber(properties.MaxConcurrentPercentage) : undefined);\n    ret.addPropertyResult('regionConcurrencyType', 'RegionConcurrencyType', properties.RegionConcurrencyType != null ? cfn_parse.FromCloudFormation.getString(properties.RegionConcurrencyType) : undefined);\n    ret.addPropertyResult('regionOrder', 'RegionOrder', properties.RegionOrder != null ? cfn_parse.FromCloudFormation.getStringArray(properties.RegionOrder) : undefined);\n    ret.addUnrecognizedPropertiesAsExtra(properties);\n    return ret;\n}\n\nexport namespace CfnStackSet {\n    /**\n     * The Parameter data type.\n     *\n     * @struct\n     * @stability external\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-stackset-parameter.html\n     */\n    export interface ParameterProperty {\n        /**\n         * The key associated with the parameter. If you don't specify a key and value for a particular parameter, AWS CloudFormation uses the default value that's specified in your template.\n         *\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-stackset-parameter.html#cfn-cloudformation-stackset-parameter-parameterkey\n         */\n        readonly parameterKey: string;\n        /**\n         * The input value associated with the parameter.\n         *\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-stackset-parameter.html#cfn-cloudformation-stackset-parameter-parametervalue\n         */\n        readonly parameterValue: string;\n    }\n}\n\n/**\n * Determine whether the given properties match those of a `ParameterProperty`\n *\n * @param properties - the TypeScript properties of a `ParameterProperty`\n *\n * @returns the result of the validation.\n */\nfunction CfnStackSet_ParameterPropertyValidator(properties: any): cdk.ValidationResult {\n    if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n    const errors = new cdk.ValidationResults();\n    if (typeof properties !== 'object') {\n        errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));\n    }\n    errors.collect(cdk.propertyValidator('parameterKey', cdk.requiredValidator)(properties.parameterKey));\n    errors.collect(cdk.propertyValidator('parameterKey', cdk.validateString)(properties.parameterKey));\n    errors.collect(cdk.propertyValidator('parameterValue', cdk.requiredValidator)(properties.parameterValue));\n    errors.collect(cdk.propertyValidator('parameterValue', cdk.validateString)(properties.parameterValue));\n    return errors.wrap('supplied properties not correct for \"ParameterProperty\"');\n}\n\n/**\n * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::StackSet.Parameter` resource\n *\n * @param properties - the TypeScript properties of a `ParameterProperty`\n *\n * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::StackSet.Parameter` resource.\n */\n// @ts-ignore TS6133\nfunction cfnStackSetParameterPropertyToCloudFormation(properties: any): any {\n    if (!cdk.canInspect(properties)) { return properties; }\n    CfnStackSet_ParameterPropertyValidator(properties).assertSuccess();\n    return {\n        ParameterKey: cdk.stringToCloudFormation(properties.parameterKey),\n        ParameterValue: cdk.stringToCloudFormation(properties.parameterValue),\n    };\n}\n\n// @ts-ignore TS6133\nfunction CfnStackSetParameterPropertyFromCloudFormation(properties: any): cfn_parse.FromCloudFormationResult<CfnStackSet.ParameterProperty | cdk.IResolvable> {\n    if (cdk.isResolvableObject(properties)) {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    properties = properties == null ? {} : properties;\n    if (typeof properties !== 'object') {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    const ret = new cfn_parse.FromCloudFormationPropertyObject<CfnStackSet.ParameterProperty>();\n    ret.addPropertyResult('parameterKey', 'ParameterKey', cfn_parse.FromCloudFormation.getString(properties.ParameterKey));\n    ret.addPropertyResult('parameterValue', 'ParameterValue', cfn_parse.FromCloudFormation.getString(properties.ParameterValue));\n    ret.addUnrecognizedPropertiesAsExtra(properties);\n    return ret;\n}\n\nexport namespace CfnStackSet {\n    /**\n     * Stack instances in some specific accounts and Regions.\n     *\n     * @struct\n     * @stability external\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-stackset-stackinstances.html\n     */\n    export interface StackInstancesProperty {\n        /**\n         * The AWS `OrganizationalUnitIds` or `Accounts` for which to create stack instances in the specified Regions.\n         *\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-stackset-stackinstances.html#cfn-cloudformation-stackset-stackinstances-deploymenttargets\n         */\n        readonly deploymentTargets: CfnStackSet.DeploymentTargetsProperty | cdk.IResolvable;\n        /**\n         * A list of stack set parameters whose values you want to override in the selected stack instances.\n         *\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-stackset-stackinstances.html#cfn-cloudformation-stackset-stackinstances-parameteroverrides\n         */\n        readonly parameterOverrides?: Array<CfnStackSet.ParameterProperty | cdk.IResolvable> | cdk.IResolvable;\n        /**\n         * The names of one or more Regions where you want to create stack instances using the specified AWS accounts .\n         *\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-stackset-stackinstances.html#cfn-cloudformation-stackset-stackinstances-regions\n         */\n        readonly regions: string[];\n    }\n}\n\n/**\n * Determine whether the given properties match those of a `StackInstancesProperty`\n *\n * @param properties - the TypeScript properties of a `StackInstancesProperty`\n *\n * @returns the result of the validation.\n */\nfunction CfnStackSet_StackInstancesPropertyValidator(properties: any): cdk.ValidationResult {\n    if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n    const errors = new cdk.ValidationResults();\n    if (typeof properties !== 'object') {\n        errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));\n    }\n    errors.collect(cdk.propertyValidator('deploymentTargets', cdk.requiredValidator)(properties.deploymentTargets));\n    errors.collect(cdk.propertyValidator('deploymentTargets', CfnStackSet_DeploymentTargetsPropertyValidator)(properties.deploymentTargets));\n    errors.collect(cdk.propertyValidator('parameterOverrides', cdk.listValidator(CfnStackSet_ParameterPropertyValidator))(properties.parameterOverrides));\n    errors.collect(cdk.propertyValidator('regions', cdk.requiredValidator)(properties.regions));\n    errors.collect(cdk.propertyValidator('regions', cdk.listValidator(cdk.validateString))(properties.regions));\n    return errors.wrap('supplied properties not correct for \"StackInstancesProperty\"');\n}\n\n/**\n * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::StackSet.StackInstances` resource\n *\n * @param properties - the TypeScript properties of a `StackInstancesProperty`\n *\n * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::StackSet.StackInstances` resource.\n */\n// @ts-ignore TS6133\nfunction cfnStackSetStackInstancesPropertyToCloudFormation(properties: any): any {\n    if (!cdk.canInspect(properties)) { return properties; }\n    CfnStackSet_StackInstancesPropertyValidator(properties).assertSuccess();\n    return {\n        DeploymentTargets: cfnStackSetDeploymentTargetsPropertyToCloudFormation(properties.deploymentTargets),\n        ParameterOverrides: cdk.listMapper(cfnStackSetParameterPropertyToCloudFormation)(properties.parameterOverrides),\n        Regions: cdk.listMapper(cdk.stringToCloudFormation)(properties.regions),\n    };\n}\n\n// @ts-ignore TS6133\nfunction CfnStackSetStackInstancesPropertyFromCloudFormation(properties: any): cfn_parse.FromCloudFormationResult<CfnStackSet.StackInstancesProperty | cdk.IResolvable> {\n    if (cdk.isResolvableObject(properties)) {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    properties = properties == null ? {} : properties;\n    if (typeof properties !== 'object') {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    const ret = new cfn_parse.FromCloudFormationPropertyObject<CfnStackSet.StackInstancesProperty>();\n    ret.addPropertyResult('deploymentTargets', 'DeploymentTargets', CfnStackSetDeploymentTargetsPropertyFromCloudFormation(properties.DeploymentTargets));\n    ret.addPropertyResult('parameterOverrides', 'ParameterOverrides', properties.ParameterOverrides != null ? cfn_parse.FromCloudFormation.getArray(CfnStackSetParameterPropertyFromCloudFormation)(properties.ParameterOverrides) : undefined);\n    ret.addPropertyResult('regions', 'Regions', cfn_parse.FromCloudFormation.getStringArray(properties.Regions));\n    ret.addUnrecognizedPropertiesAsExtra(properties);\n    return ret;\n}\n\n/**\n * Properties for defining a `CfnTypeActivation`\n *\n * @struct\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-typeactivation.html\n */\nexport interface CfnTypeActivationProps {\n\n    /**\n     * Whether to automatically update the extension in this account and region when a new *minor* version is published by the extension publisher. Major versions released by the publisher must be manually updated.\n     *\n     * The default is `true` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-typeactivation.html#cfn-cloudformation-typeactivation-autoupdate\n     */\n    readonly autoUpdate?: boolean | cdk.IResolvable;\n\n    /**\n     * The name of the IAM execution role to use to activate the extension.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-typeactivation.html#cfn-cloudformation-typeactivation-executionrolearn\n     */\n    readonly executionRoleArn?: string;\n\n    /**\n     * Specifies logging configuration information for an extension.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-typeactivation.html#cfn-cloudformation-typeactivation-loggingconfig\n     */\n    readonly loggingConfig?: CfnTypeActivation.LoggingConfigProperty | cdk.IResolvable;\n\n    /**\n     * The major version of this extension you want to activate, if multiple major versions are available. The default is the latest major version. CloudFormation uses the latest available *minor* version of the major version selected.\n     *\n     * You can specify `MajorVersion` or `VersionBump` , but not both.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-typeactivation.html#cfn-cloudformation-typeactivation-majorversion\n     */\n    readonly majorVersion?: string;\n\n    /**\n     * The Amazon Resource Number (ARN) of the public extension.\n     *\n     * Conditional: You must specify `PublicTypeArn` , or `TypeName` , `Type` , and `PublisherId` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-typeactivation.html#cfn-cloudformation-typeactivation-publictypearn\n     */\n    readonly publicTypeArn?: string;\n\n    /**\n     * The ID of the extension publisher.\n     *\n     * Conditional: You must specify `PublicTypeArn` , or `TypeName` , `Type` , and `PublisherId` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-typeactivation.html#cfn-cloudformation-typeactivation-publisherid\n     */\n    readonly publisherId?: string;\n\n    /**\n     * The extension type.\n     *\n     * Conditional: You must specify `PublicTypeArn` , or `TypeName` , `Type` , and `PublisherId` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-typeactivation.html#cfn-cloudformation-typeactivation-type\n     */\n    readonly type?: string;\n\n    /**\n     * The name of the extension.\n     *\n     * Conditional: You must specify `PublicTypeArn` , or `TypeName` , `Type` , and `PublisherId` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-typeactivation.html#cfn-cloudformation-typeactivation-typename\n     */\n    readonly typeName?: string;\n\n    /**\n     * An alias to assign to the public extension, in this account and region. If you specify an alias for the extension, CloudFormation treats the alias as the extension type name within this account and region. You must use the alias to refer to the extension in your templates, API calls, and CloudFormation console.\n     *\n     * An extension alias must be unique within a given account and region. You can activate the same public resource multiple times in the same account and region, using different type name aliases.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-typeactivation.html#cfn-cloudformation-typeactivation-typenamealias\n     */\n    readonly typeNameAlias?: string;\n\n    /**\n     * Manually updates a previously-activated type to a new major or minor version, if available. You can also use this parameter to update the value of `AutoUpdate` .\n     *\n     * - `MAJOR` : CloudFormation updates the extension to the newest major version, if one is available.\n     * - `MINOR` : CloudFormation updates the extension to the newest minor version, if one is available.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-typeactivation.html#cfn-cloudformation-typeactivation-versionbump\n     */\n    readonly versionBump?: string;\n}\n\n/**\n * Determine whether the given properties match those of a `CfnTypeActivationProps`\n *\n * @param properties - the TypeScript properties of a `CfnTypeActivationProps`\n *\n * @returns the result of the validation.\n */\nfunction CfnTypeActivationPropsValidator(properties: any): cdk.ValidationResult {\n    if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n    const errors = new cdk.ValidationResults();\n    if (typeof properties !== 'object') {\n        errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));\n    }\n    errors.collect(cdk.propertyValidator('autoUpdate', cdk.validateBoolean)(properties.autoUpdate));\n    errors.collect(cdk.propertyValidator('executionRoleArn', cdk.validateString)(properties.executionRoleArn));\n    errors.collect(cdk.propertyValidator('loggingConfig', CfnTypeActivation_LoggingConfigPropertyValidator)(properties.loggingConfig));\n    errors.collect(cdk.propertyValidator('majorVersion', cdk.validateString)(properties.majorVersion));\n    errors.collect(cdk.propertyValidator('publicTypeArn', cdk.validateString)(properties.publicTypeArn));\n    errors.collect(cdk.propertyValidator('publisherId', cdk.validateString)(properties.publisherId));\n    errors.collect(cdk.propertyValidator('type', cdk.validateString)(properties.type));\n    errors.collect(cdk.propertyValidator('typeName', cdk.validateString)(properties.typeName));\n    errors.collect(cdk.propertyValidator('typeNameAlias', cdk.validateString)(properties.typeNameAlias));\n    errors.collect(cdk.propertyValidator('versionBump', cdk.validateString)(properties.versionBump));\n    return errors.wrap('supplied properties not correct for \"CfnTypeActivationProps\"');\n}\n\n/**\n * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::TypeActivation` resource\n *\n * @param properties - the TypeScript properties of a `CfnTypeActivationProps`\n *\n * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::TypeActivation` resource.\n */\n// @ts-ignore TS6133\nfunction cfnTypeActivationPropsToCloudFormation(properties: any): any {\n    if (!cdk.canInspect(properties)) { return properties; }\n    CfnTypeActivationPropsValidator(properties).assertSuccess();\n    return {\n        AutoUpdate: cdk.booleanToCloudFormation(properties.autoUpdate),\n        ExecutionRoleArn: cdk.stringToCloudFormation(properties.executionRoleArn),\n        LoggingConfig: cfnTypeActivationLoggingConfigPropertyToCloudFormation(properties.loggingConfig),\n        MajorVersion: cdk.stringToCloudFormation(properties.majorVersion),\n        PublicTypeArn: cdk.stringToCloudFormation(properties.publicTypeArn),\n        PublisherId: cdk.stringToCloudFormation(properties.publisherId),\n        Type: cdk.stringToCloudFormation(properties.type),\n        TypeName: cdk.stringToCloudFormation(properties.typeName),\n        TypeNameAlias: cdk.stringToCloudFormation(properties.typeNameAlias),\n        VersionBump: cdk.stringToCloudFormation(properties.versionBump),\n    };\n}\n\n// @ts-ignore TS6133\nfunction CfnTypeActivationPropsFromCloudFormation(properties: any): cfn_parse.FromCloudFormationResult<CfnTypeActivationProps> {\n    properties = properties == null ? {} : properties;\n    if (typeof properties !== 'object') {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    const ret = new cfn_parse.FromCloudFormationPropertyObject<CfnTypeActivationProps>();\n    ret.addPropertyResult('autoUpdate', 'AutoUpdate', properties.AutoUpdate != null ? cfn_parse.FromCloudFormation.getBoolean(properties.AutoUpdate) : undefined);\n    ret.addPropertyResult('executionRoleArn', 'ExecutionRoleArn', properties.ExecutionRoleArn != null ? cfn_parse.FromCloudFormation.getString(properties.ExecutionRoleArn) : undefined);\n    ret.addPropertyResult('loggingConfig', 'LoggingConfig', properties.LoggingConfig != null ? CfnTypeActivationLoggingConfigPropertyFromCloudFormation(properties.LoggingConfig) : undefined);\n    ret.addPropertyResult('majorVersion', 'MajorVersion', properties.MajorVersion != null ? cfn_parse.FromCloudFormation.getString(properties.MajorVersion) : undefined);\n    ret.addPropertyResult('publicTypeArn', 'PublicTypeArn', properties.PublicTypeArn != null ? cfn_parse.FromCloudFormation.getString(properties.PublicTypeArn) : undefined);\n    ret.addPropertyResult('publisherId', 'PublisherId', properties.PublisherId != null ? cfn_parse.FromCloudFormation.getString(properties.PublisherId) : undefined);\n    ret.addPropertyResult('type', 'Type', properties.Type != null ? cfn_parse.FromCloudFormation.getString(properties.Type) : undefined);\n    ret.addPropertyResult('typeName', 'TypeName', properties.TypeName != null ? cfn_parse.FromCloudFormation.getString(properties.TypeName) : undefined);\n    ret.addPropertyResult('typeNameAlias', 'TypeNameAlias', properties.TypeNameAlias != null ? cfn_parse.FromCloudFormation.getString(properties.TypeNameAlias) : undefined);\n    ret.addPropertyResult('versionBump', 'VersionBump', properties.VersionBump != null ? cfn_parse.FromCloudFormation.getString(properties.VersionBump) : undefined);\n    ret.addUnrecognizedPropertiesAsExtra(properties);\n    return ret;\n}\n\n/**\n * A CloudFormation `AWS::CloudFormation::TypeActivation`\n *\n * Activates a public third-party extension, making it available for use in stack templates. For more information, see [Using public extensions](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/registry-public.html) in the *AWS CloudFormation User Guide* .\n *\n * Once you have activated a public third-party extension in your account and region, use [SetTypeConfiguration](https://docs.aws.amazon.com/AWSCloudFormation/latest/APIReference/API_SetTypeConfiguration.html) to specify configuration properties for the extension. For more information, see [Configuring extensions at the account level](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/registry-register.html#registry-set-configuration) in the *CloudFormation User Guide* .\n *\n * @cloudformationResource AWS::CloudFormation::TypeActivation\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-typeactivation.html\n */\nexport class CfnTypeActivation extends cdk.CfnResource implements cdk.IInspectable {\n    /**\n     * The CloudFormation resource type name for this resource class.\n     */\n    public static readonly CFN_RESOURCE_TYPE_NAME = \"AWS::CloudFormation::TypeActivation\";\n\n    /**\n     * A factory method that creates a new instance of this class from an object\n     * containing the CloudFormation properties of this resource.\n     * Used in the @aws-cdk/cloudformation-include module.\n     *\n     * @internal\n     */\n    public static _fromCloudFormation(scope: cdk.Construct, id: string, resourceAttributes: any, options: cfn_parse.FromCloudFormationOptions): CfnTypeActivation {\n        resourceAttributes = resourceAttributes || {};\n        const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);\n        const propsResult = CfnTypeActivationPropsFromCloudFormation(resourceProperties);\n        const ret = new CfnTypeActivation(scope, id, propsResult.value);\n        for (const [propKey, propVal] of Object.entries(propsResult.extraProperties))  {\n            ret.addPropertyOverride(propKey, propVal);\n        }\n        options.parser.handleAttributes(ret, resourceAttributes, id);\n        return ret;\n    }\n\n    /**\n     * The Amazon Resource Number (ARN) of the activated extension, in this account and Region.\n     * @cloudformationAttribute Arn\n     */\n    public readonly attrArn: string;\n\n    /**\n     * Whether to automatically update the extension in this account and region when a new *minor* version is published by the extension publisher. Major versions released by the publisher must be manually updated.\n     *\n     * The default is `true` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-typeactivation.html#cfn-cloudformation-typeactivation-autoupdate\n     */\n    public autoUpdate: boolean | cdk.IResolvable | undefined;\n\n    /**\n     * The name of the IAM execution role to use to activate the extension.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-typeactivation.html#cfn-cloudformation-typeactivation-executionrolearn\n     */\n    public executionRoleArn: string | undefined;\n\n    /**\n     * Specifies logging configuration information for an extension.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-typeactivation.html#cfn-cloudformation-typeactivation-loggingconfig\n     */\n    public loggingConfig: CfnTypeActivation.LoggingConfigProperty | cdk.IResolvable | undefined;\n\n    /**\n     * The major version of this extension you want to activate, if multiple major versions are available. The default is the latest major version. CloudFormation uses the latest available *minor* version of the major version selected.\n     *\n     * You can specify `MajorVersion` or `VersionBump` , but not both.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-typeactivation.html#cfn-cloudformation-typeactivation-majorversion\n     */\n    public majorVersion: string | undefined;\n\n    /**\n     * The Amazon Resource Number (ARN) of the public extension.\n     *\n     * Conditional: You must specify `PublicTypeArn` , or `TypeName` , `Type` , and `PublisherId` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-typeactivation.html#cfn-cloudformation-typeactivation-publictypearn\n     */\n    public publicTypeArn: string | undefined;\n\n    /**\n     * The ID of the extension publisher.\n     *\n     * Conditional: You must specify `PublicTypeArn` , or `TypeName` , `Type` , and `PublisherId` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-typeactivation.html#cfn-cloudformation-typeactivation-publisherid\n     */\n    public publisherId: string | undefined;\n\n    /**\n     * The extension type.\n     *\n     * Conditional: You must specify `PublicTypeArn` , or `TypeName` , `Type` , and `PublisherId` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-typeactivation.html#cfn-cloudformation-typeactivation-type\n     */\n    public type: string | undefined;\n\n    /**\n     * The name of the extension.\n     *\n     * Conditional: You must specify `PublicTypeArn` , or `TypeName` , `Type` , and `PublisherId` .\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-typeactivation.html#cfn-cloudformation-typeactivation-typename\n     */\n    public typeName: string | undefined;\n\n    /**\n     * An alias to assign to the public extension, in this account and region. If you specify an alias for the extension, CloudFormation treats the alias as the extension type name within this account and region. You must use the alias to refer to the extension in your templates, API calls, and CloudFormation console.\n     *\n     * An extension alias must be unique within a given account and region. You can activate the same public resource multiple times in the same account and region, using different type name aliases.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-typeactivation.html#cfn-cloudformation-typeactivation-typenamealias\n     */\n    public typeNameAlias: string | undefined;\n\n    /**\n     * Manually updates a previously-activated type to a new major or minor version, if available. You can also use this parameter to update the value of `AutoUpdate` .\n     *\n     * - `MAJOR` : CloudFormation updates the extension to the newest major version, if one is available.\n     * - `MINOR` : CloudFormation updates the extension to the newest minor version, if one is available.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cloudformation-typeactivation.html#cfn-cloudformation-typeactivation-versionbump\n     */\n    public versionBump: string | undefined;\n\n    /**\n     * Create a new `AWS::CloudFormation::TypeActivation`.\n     *\n     * @param scope - scope in which this resource is defined\n     * @param id    - scoped id of the resource\n     * @param props - resource properties\n     */\n    constructor(scope: cdk.Construct, id: string, props: CfnTypeActivationProps = {}) {\n        super(scope, id, { type: CfnTypeActivation.CFN_RESOURCE_TYPE_NAME, properties: props });\n        this.attrArn = cdk.Token.asString(this.getAtt('Arn'));\n\n        this.autoUpdate = props.autoUpdate;\n        this.executionRoleArn = props.executionRoleArn;\n        this.loggingConfig = props.loggingConfig;\n        this.majorVersion = props.majorVersion;\n        this.publicTypeArn = props.publicTypeArn;\n        this.publisherId = props.publisherId;\n        this.type = props.type;\n        this.typeName = props.typeName;\n        this.typeNameAlias = props.typeNameAlias;\n        this.versionBump = props.versionBump;\n    }\n\n    /**\n     * Examines the CloudFormation resource and discloses attributes.\n     *\n     * @param inspector - tree inspector to collect and process attributes\n     *\n     */\n    public inspect(inspector: cdk.TreeInspector) {\n        inspector.addAttribute(\"aws:cdk:cloudformation:type\", CfnTypeActivation.CFN_RESOURCE_TYPE_NAME);\n        inspector.addAttribute(\"aws:cdk:cloudformation:props\", this.cfnProperties);\n    }\n\n    protected get cfnProperties(): { [key: string]: any }  {\n        return {\n            autoUpdate: this.autoUpdate,\n            executionRoleArn: this.executionRoleArn,\n            loggingConfig: this.loggingConfig,\n            majorVersion: this.majorVersion,\n            publicTypeArn: this.publicTypeArn,\n            publisherId: this.publisherId,\n            type: this.type,\n            typeName: this.typeName,\n            typeNameAlias: this.typeNameAlias,\n            versionBump: this.versionBump,\n        };\n    }\n\n    protected renderProperties(props: {[key: string]: any}): { [key: string]: any }  {\n        return cfnTypeActivationPropsToCloudFormation(props);\n    }\n}\n\nexport namespace CfnTypeActivation {\n    /**\n     * Contains logging configuration information for an extension.\n     *\n     * @struct\n     * @stability external\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-typeactivation-loggingconfig.html\n     */\n    export interface LoggingConfigProperty {\n        /**\n         * The Amazon CloudWatch Logs group to which CloudFormation sends error logging information when invoking the extension's handlers.\n         *\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-typeactivation-loggingconfig.html#cfn-cloudformation-typeactivation-loggingconfig-loggroupname\n         */\n        readonly logGroupName?: string;\n        /**\n         * The Amazon Resource Name (ARN) of the role that CloudFormation should assume when sending log entries to CloudWatch Logs.\n         *\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudformation-typeactivation-loggingconfig.html#cfn-cloudformation-typeactivation-loggingconfig-logrolearn\n         */\n        readonly logRoleArn?: string;\n    }\n}\n\n/**\n * Determine whether the given properties match those of a `LoggingConfigProperty`\n *\n * @param properties - the TypeScript properties of a `LoggingConfigProperty`\n *\n * @returns the result of the validation.\n */\nfunction CfnTypeActivation_LoggingConfigPropertyValidator(properties: any): cdk.ValidationResult {\n    if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n    const errors = new cdk.ValidationResults();\n    if (typeof properties !== 'object') {\n        errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));\n    }\n    errors.collect(cdk.propertyValidator('logGroupName', cdk.validateString)(properties.logGroupName));\n    errors.collect(cdk.propertyValidator('logRoleArn', cdk.validateString)(properties.logRoleArn));\n    return errors.wrap('supplied properties not correct for \"LoggingConfigProperty\"');\n}\n\n/**\n * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::TypeActivation.LoggingConfig` resource\n *\n * @param properties - the TypeScript properties of a `LoggingConfigProperty`\n *\n * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::TypeActivation.LoggingConfig` resource.\n */\n// @ts-ignore TS6133\nfunction cfnTypeActivationLoggingConfigPropertyToCloudFormation(properties: any): any {\n    if (!cdk.canInspect(properties)) { return properties; }\n    CfnTypeActivation_LoggingConfigPropertyValidator(properties).assertSuccess();\n    return {\n        LogGroupName: cdk.stringToCloudFormation(properties.logGroupName),\n        LogRoleArn: cdk.stringToCloudFormation(properties.logRoleArn),\n    };\n}\n\n// @ts-ignore TS6133\nfunction CfnTypeActivationLoggingConfigPropertyFromCloudFormation(properties: any): cfn_parse.FromCloudFormationResult<CfnTypeActivation.LoggingConfigProperty | cdk.IResolvable> {\n    if (cdk.isResolvableObject(properties)) {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    properties = properties == null ? {} : properties;\n    if (typeof properties !== 'object') {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    const ret = new cfn_parse.FromCloudFormationPropertyObject<CfnTypeActivation.LoggingConfigProperty>();\n    ret.addPropertyResult('logGroupName', 'LogGroupName', properties.LogGroupName != null ? cfn_parse.FromCloudFormation.getString(properties.LogGroupName) : undefined);\n    ret.addPropertyResult('logRoleArn', 'LogRoleArn', properties.LogRoleArn != null ? cfn_parse.FromCloudFormation.getString(properties.LogRoleArn) : undefined);\n    ret.addUnrecognizedPropertiesAsExtra(properties);\n    return ret;\n}\n\n/**\n * Properties for defining a `CfnWaitCondition`\n *\n * @struct\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-waitcondition.html\n */\nexport interface CfnWaitConditionProps {\n\n    /**\n     * The number of success signals that CloudFormation must receive before it continues the stack creation process. When the wait condition receives the requisite number of success signals, CloudFormation resumes the creation of the stack. If the wait condition doesn't receive the specified number of success signals before the Timeout period expires, CloudFormation assumes that the wait condition has failed and rolls the stack back.\n     *\n     * Updates aren't supported.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-waitcondition.html#cfn-waitcondition-count\n     */\n    readonly count?: number;\n\n    /**\n     * A reference to the wait condition handle used to signal this wait condition. Use the `Ref` intrinsic function to specify an [AWS::CloudFormation::WaitConditionHandle](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-waitconditionhandle.html) resource.\n     *\n     * Anytime you add a WaitCondition resource during a stack update, you must associate the wait condition with a new WaitConditionHandle resource. Don't reuse an old wait condition handle that has already been defined in the template. If you reuse a wait condition handle, the wait condition might evaluate old signals from a previous create or update stack command.\n     *\n     * Updates aren't supported.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-waitcondition.html#cfn-waitcondition-handle\n     */\n    readonly handle?: string;\n\n    /**\n     * The length of time (in seconds) to wait for the number of signals that the `Count` property specifies. `Timeout` is a minimum-bound property, meaning the timeout occurs no sooner than the time you specify, but can occur shortly thereafter. The maximum time that can be specified for this property is 12 hours (43200 seconds).\n     *\n     * Updates aren't supported.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-waitcondition.html#cfn-waitcondition-timeout\n     */\n    readonly timeout?: string;\n}\n\n/**\n * Determine whether the given properties match those of a `CfnWaitConditionProps`\n *\n * @param properties - the TypeScript properties of a `CfnWaitConditionProps`\n *\n * @returns the result of the validation.\n */\nfunction CfnWaitConditionPropsValidator(properties: any): cdk.ValidationResult {\n    if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n    const errors = new cdk.ValidationResults();\n    if (typeof properties !== 'object') {\n        errors.collect(new cdk.ValidationResult('Expected an object, but received: ' + JSON.stringify(properties)));\n    }\n    errors.collect(cdk.propertyValidator('count', cdk.validateNumber)(properties.count));\n    errors.collect(cdk.propertyValidator('handle', cdk.validateString)(properties.handle));\n    errors.collect(cdk.propertyValidator('timeout', cdk.validateString)(properties.timeout));\n    return errors.wrap('supplied properties not correct for \"CfnWaitConditionProps\"');\n}\n\n/**\n * Renders the AWS CloudFormation properties of an `AWS::CloudFormation::WaitCondition` resource\n *\n * @param properties - the TypeScript properties of a `CfnWaitConditionProps`\n *\n * @returns the AWS CloudFormation properties of an `AWS::CloudFormation::WaitCondition` resource.\n */\n// @ts-ignore TS6133\nfunction cfnWaitConditionPropsToCloudFormation(properties: any): any {\n    if (!cdk.canInspect(properties)) { return properties; }\n    CfnWaitConditionPropsValidator(properties).assertSuccess();\n    return {\n        Count: cdk.numberToCloudFormation(properties.count),\n        Handle: cdk.stringToCloudFormation(properties.handle),\n        Timeout: cdk.stringToCloudFormation(properties.timeout),\n    };\n}\n\n// @ts-ignore TS6133\nfunction CfnWaitConditionPropsFromCloudFormation(properties: any): cfn_parse.FromCloudFormationResult<CfnWaitConditionProps> {\n    properties = properties == null ? {} : properties;\n    if (typeof properties !== 'object') {\n        return new cfn_parse.FromCloudFormationResult(properties);\n    }\n    const ret = new cfn_parse.FromCloudFormationPropertyObject<CfnWaitConditionProps>();\n    ret.addPropertyResult('count', 'Count', properties.Count != null ? cfn_parse.FromCloudFormation.getNumber(properties.Count) : undefined);\n    ret.addPropertyResult('handle', 'Handle', properties.Handle != null ? cfn_parse.FromCloudFormation.getString(properties.Handle) : undefined);\n    ret.addPropertyResult('timeout', 'Timeout', properties.Timeout != null ? cfn_parse.FromCloudFormation.getString(properties.Timeout) : undefined);\n    ret.addUnrecognizedPropertiesAsExtra(properties);\n    return ret;\n}\n\n/**\n * A CloudFormation `AWS::CloudFormation::WaitCondition`\n *\n * > For Amazon EC2 and Auto Scaling resources, we recommend that you use a `CreationPolicy` attribute instead of wait conditions. Add a CreationPolicy attribute to those resources, and use the cfn-signal helper script to signal when an instance creation process has completed successfully.\n *\n * You can use a wait condition for situations like the following:\n *\n * - To coordinate stack resource creation with configuration actions that are external to the stack creation.\n * - To track the status of a configuration process.\n *\n * For these situations, we recommend that you associate a [CreationPolicy](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-attribute-creationpolicy.html) attribute with the wait condition so that you don't have to use a wait condition handle. For more information and an example, see [Creating wait conditions in a template](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/using-cfn-waitcondition.html) . If you use a CreationPolicy with a wait condition, don't specify any of the wait condition's properties.\n *\n * > If you use the [VPC endpoints](https://docs.aws.amazon.com/vpc/latest/userguide/vpc-endpoints.html) feature, resources in the VPC that respond to wait conditions must have access to CloudFormation , specific Amazon Simple Storage Service ( Amazon S3 ) buckets. Resources must send wait condition responses to a presigned Amazon S3 URL. If they can't send responses to Amazon S3 , CloudFormation won't receive a response and the stack operation fails. For more information, see [Setting up VPC endpoints for AWS CloudFormation](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/cfn-vpce-bucketnames.html) .\n *\n * @cloudformationResource AWS::CloudFormation::WaitCondition\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-waitcondition.html\n */\nexport class CfnWaitCondition extends cdk.CfnResource implements cdk.IInspectable {\n    /**\n     * The CloudFormation resource type name for this resource class.\n     */\n    public static readonly CFN_RESOURCE_TYPE_NAME = \"AWS::CloudFormation::WaitCondition\";\n\n    /**\n     * A factory method that creates a new instance of this class from an object\n     * containing the CloudFormation properties of this resource.\n     * Used in the @aws-cdk/cloudformation-include module.\n     *\n     * @internal\n     */\n    public static _fromCloudFormation(scope: cdk.Construct, id: string, resourceAttributes: any, options: cfn_parse.FromCloudFormationOptions): CfnWaitCondition {\n        resourceAttributes = resourceAttributes || {};\n        const resourceProperties = options.parser.parseValue(resourceAttributes.Properties);\n        const propsResult = CfnWaitConditionPropsFromCloudFormation(resourceProperties);\n        const ret = new CfnWaitCondition(scope, id, propsResult.value);\n        for (const [propKey, propVal] of Object.entries(propsResult.extraProperties))  {\n            ret.addPropertyOverride(propKey, propVal);\n        }\n        options.parser.handleAttributes(ret, resourceAttributes, id);\n        return ret;\n    }\n\n    /**\n     * A JSON object that contains the `UniqueId` and `Data` values from the wait condition signal(s) for the specified wait condition. For more information about wait condition signals, see [Wait condition signal JSON format](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/using-cfn-waitcondition.html#using-cfn-waitcondition-signaljson) .\n     *\n     * Example return value for a wait condition with 2 signals:\n     *\n     * `{ \"Signal1\" : \"Step 1 complete.\" , \"Signal2\" : \"Step 2 complete.\" }`\n     * @cloudformationAttribute Data\n     */\n    public readonly attrData: cdk.IResolvable;\n\n    /**\n     * The number of success signals that CloudFormation must receive before it continues the stack creation process. When the wait condition receives the requisite number of success signals, CloudFormation resumes the creation of the stack. If the wait condition doesn't receive the specified number of success signals before the Timeout period expires, CloudFormation assumes that the wait condition has failed and rolls the stack back.\n     *\n     * Updates aren't supported.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-waitcondition.html#cfn-waitcondition-count\n     */\n    public count: number | undefined;\n\n    /**\n     * A reference to the wait condition handle used to signal this wait condition. Use the `Ref` intrinsic function to specify an [AWS::CloudFormation::WaitConditionHandle](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-waitconditionhandle.html) resource.\n     *\n     * Anytime you add a WaitCondition resource during a stack update, you must associate the wait condition with a new WaitConditionHandle resource. Don't reuse an old wait condition handle that has already been defined in the template. If you reuse a wait condition handle, the wait condition might evaluate old signals from a previous create or update stack command.\n     *\n     * Updates aren't supported.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-waitcondition.html#cfn-waitcondition-handle\n     */\n    public handle: string | undefined;\n\n    /**\n     * The length of time (in seconds) to wait for the number of signals that the `Count` property specifies. `Timeout` is a minimum-bound property, meaning the timeout occurs no sooner than the time you specify, but can occur shortly thereafter. The maximum time that can be specified for this property is 12 hours (43200 seconds).\n     *\n     * Updates aren't supported.\n     *\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-waitcondition.html#cfn-waitcondition-timeout\n     */\n    public timeout: string | undefined;\n\n    /**\n     * Create a new `AWS::CloudFormation::WaitCondition`.\n     *\n     * @param scope - scope in which this resource is defined\n     * @param id    - scoped id of the resource\n     * @param props - resource properties\n     */\n    constructor(scope: cdk.Construct, id: string, props: CfnWaitConditionProps = {}) {\n        super(scope, id, { type: CfnWaitCondition.CFN_RESOURCE_TYPE_NAME, properties: props });\n        this.attrData = this.getAtt('Data');\n\n        this.count = props.count;\n        this.handle = props.handle;\n        this.timeout = props.timeout;\n    }\n\n    /**\n     * Examines the CloudFormation resource and discloses attributes.\n     *\n     * @param inspector - tree inspector to collect and process attributes\n     *\n     */\n    public inspect(inspector: cdk.TreeInspector) {\n        inspector.addAttribute(\"aws:cdk:cloudformation:type\", CfnWaitCondition.CFN_RESOURCE_TYPE_NAME);\n        inspector.addAttribute(\"aws:cdk:cloudformation:props\", this.cfnProperties);\n    }\n\n    protected get cfnProperties(): { [key: string]: any }  {\n        return {\n            count: this.count,\n            handle: this.handle,\n            timeout: this.timeout,\n        };\n    }\n\n    protected renderProperties(props: {[key: string]: any}): { [key: string]: any }  {\n        return cfnWaitConditionPropsToCloudFormation(props);\n    }\n}\n\n/**\n * A CloudFormation `AWS::CloudFormation::WaitConditionHandle`\n *\n * > For Amazon EC2 and Auto Scaling resources, we recommend that you use a `CreationPolicy` attribute instead of wait conditions. Add a `CreationPolicy` attribute to those resources, and use the cfn-signal helper script to signal when an instance creation process has completed successfully.\n * >\n * > For more information, see [Deploying applications on Amazon EC2 with AWS CloudFormation](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/deploying.applications.html) .\n *\n * The `AWS::CloudFormation::WaitConditionHandle` type has no properties. When you reference the `WaitConditionHandle` resource by using the Ref function, AWS CloudFormation returns a presigned URL. You pass this URL to applications or scripts that are running on your Amazon EC2 instances to send signals to that URL. An associated `AWS::CloudFormation::WaitCondition` resource checks the URL for the required number of success signals or for a failure signal.\n *\n * > Anytime you add a `WaitCondition` resource during a stack update or update a resource with a wait condition, you must associate the wait condition with a new `WaitConditionHandle` resource. Don't reuse an old wait condition handle that has already been defined in the template. If you reuse a wait condition handle, the wait condition might evaluate old signals from a previous create or update stack command. > Updates aren't supported for this resource.\n *\n * @cloudformationResource AWS::CloudFormation::WaitConditionHandle\n * @stability external\n *\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-waitconditionhandle.html\n */\nexport class CfnWaitConditionHandle extends cdk.CfnResource implements cdk.IInspectable {\n    /**\n     * The CloudFormation resource type name for this resource class.\n     */\n    public static readonly CFN_RESOURCE_TYPE_NAME = \"AWS::CloudFormation::WaitConditionHandle\";\n\n    /**\n     * A factory method that creates a new instance of this class from an object\n     * containing the CloudFormation properties of this resource.\n     * Used in the @aws-cdk/cloudformation-include module.\n     *\n     * @internal\n     */\n    public static _fromCloudFormation(scope: cdk.Construct, id: string, resourceAttributes: any, options: cfn_parse.FromCloudFormationOptions): CfnWaitConditionHandle {\n        resourceAttributes = resourceAttributes || {};\n        const ret = new CfnWaitConditionHandle(scope, id);\n        options.parser.handleAttributes(ret, resourceAttributes, id);\n        return ret;\n    }\n\n    /**\n     * Create a new `AWS::CloudFormation::WaitConditionHandle`.\n     *\n     * @param scope - scope in which this resource is defined\n     * @param id    - scoped id of the resource\n     * @param props - resource properties\n     */\n    constructor(scope: cdk.Construct, id: string) {\n        super(scope, id, { type: CfnWaitConditionHandle.CFN_RESOURCE_TYPE_NAME });\n    }\n\n    /**\n     * Examines the CloudFormation resource and discloses attributes.\n     *\n     * @param inspector - tree inspector to collect and process attributes\n     *\n     */\n    public inspect(inspector: cdk.TreeInspector) {\n        inspector.addAttribute(\"aws:cdk:cloudformation:type\", CfnWaitConditionHandle.CFN_RESOURCE_TYPE_NAME);\n        inspector.addAttribute(\"aws:cdk:cloudformation:props\", this.cfnProperties);\n    }\n}\n"]}
\No newline at end of file