@cdktf/provider-acme 2.0.73 → 3.0.1

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,718 @@
1
+ "use strict";
2
+ var _a, _b, _c, _d, _e, _f, _g;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.Certificate = exports.CertificateTlsChallengeOutputReference = exports.certificateTlsChallengeToTerraform = exports.CertificateHttpWebrootChallengeOutputReference = exports.certificateHttpWebrootChallengeToTerraform = exports.CertificateHttpMemcachedChallengeOutputReference = exports.certificateHttpMemcachedChallengeToTerraform = exports.CertificateHttpChallengeOutputReference = exports.certificateHttpChallengeToTerraform = exports.CertificateDnsChallengeList = exports.CertificateDnsChallengeOutputReference = exports.certificateDnsChallengeToTerraform = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ const cdktf = require("cdktf");
7
+ function certificateDnsChallengeToTerraform(struct) {
8
+ if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) {
9
+ return struct;
10
+ }
11
+ if (cdktf.isComplexElement(struct)) {
12
+ throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
13
+ }
14
+ return {
15
+ config: cdktf.hashMapper(cdktf.stringToTerraform)(struct.config),
16
+ provider: cdktf.stringToTerraform(struct.provider),
17
+ };
18
+ }
19
+ exports.certificateDnsChallengeToTerraform = certificateDnsChallengeToTerraform;
20
+ class CertificateDnsChallengeOutputReference extends cdktf.ComplexObject {
21
+ /**
22
+ * @param terraformResource The parent resource
23
+ * @param terraformAttribute The attribute on the parent resource this class is referencing
24
+ * @param complexObjectIndex the index of this item in the list
25
+ * @param complexObjectIsFromSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index)
26
+ */
27
+ constructor(terraformResource, terraformAttribute, complexObjectIndex, complexObjectIsFromSet) {
28
+ super(terraformResource, terraformAttribute, complexObjectIsFromSet, complexObjectIndex);
29
+ this.isEmptyObject = false;
30
+ }
31
+ get internalValue() {
32
+ if (this.resolvableValue) {
33
+ return this.resolvableValue;
34
+ }
35
+ let hasAnyValues = this.isEmptyObject;
36
+ const internalValueResult = {};
37
+ if (this._config !== undefined) {
38
+ hasAnyValues = true;
39
+ internalValueResult.config = this._config;
40
+ }
41
+ if (this._provider !== undefined) {
42
+ hasAnyValues = true;
43
+ internalValueResult.provider = this._provider;
44
+ }
45
+ return hasAnyValues ? internalValueResult : undefined;
46
+ }
47
+ set internalValue(value) {
48
+ if (value === undefined) {
49
+ this.isEmptyObject = false;
50
+ this.resolvableValue = undefined;
51
+ this._config = undefined;
52
+ this._provider = undefined;
53
+ }
54
+ else if (cdktf.Tokenization.isResolvable(value)) {
55
+ this.isEmptyObject = false;
56
+ this.resolvableValue = value;
57
+ }
58
+ else {
59
+ this.isEmptyObject = Object.keys(value).length === 0;
60
+ this.resolvableValue = undefined;
61
+ this._config = value.config;
62
+ this._provider = value.provider;
63
+ }
64
+ }
65
+ get config() {
66
+ return this.getStringMapAttribute('config');
67
+ }
68
+ set config(value) {
69
+ this._config = value;
70
+ }
71
+ resetConfig() {
72
+ this._config = undefined;
73
+ }
74
+ // Temporarily expose input value. Use with caution.
75
+ get configInput() {
76
+ return this._config;
77
+ }
78
+ get provider() {
79
+ return this.getStringAttribute('provider');
80
+ }
81
+ set provider(value) {
82
+ this._provider = value;
83
+ }
84
+ // Temporarily expose input value. Use with caution.
85
+ get providerInput() {
86
+ return this._provider;
87
+ }
88
+ }
89
+ exports.CertificateDnsChallengeOutputReference = CertificateDnsChallengeOutputReference;
90
+ _a = JSII_RTTI_SYMBOL_1;
91
+ CertificateDnsChallengeOutputReference[_a] = { fqn: "@cdktf/provider-acme.certificate.CertificateDnsChallengeOutputReference", version: "3.0.1" };
92
+ class CertificateDnsChallengeList extends cdktf.ComplexList {
93
+ /**
94
+ * @param terraformResource The parent resource
95
+ * @param terraformAttribute The attribute on the parent resource this class is referencing
96
+ * @param wrapsSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index)
97
+ */
98
+ constructor(terraformResource, terraformAttribute, wrapsSet) {
99
+ super(terraformResource, terraformAttribute, wrapsSet);
100
+ this.terraformResource = terraformResource;
101
+ this.terraformAttribute = terraformAttribute;
102
+ this.wrapsSet = wrapsSet;
103
+ }
104
+ /**
105
+ * @param index the index of the item to return
106
+ */
107
+ get(index) {
108
+ return new CertificateDnsChallengeOutputReference(this.terraformResource, this.terraformAttribute, index, this.wrapsSet);
109
+ }
110
+ }
111
+ exports.CertificateDnsChallengeList = CertificateDnsChallengeList;
112
+ _b = JSII_RTTI_SYMBOL_1;
113
+ CertificateDnsChallengeList[_b] = { fqn: "@cdktf/provider-acme.certificate.CertificateDnsChallengeList", version: "3.0.1" };
114
+ function certificateHttpChallengeToTerraform(struct) {
115
+ if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) {
116
+ return struct;
117
+ }
118
+ if (cdktf.isComplexElement(struct)) {
119
+ throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
120
+ }
121
+ return {
122
+ port: cdktf.numberToTerraform(struct.port),
123
+ proxy_header: cdktf.stringToTerraform(struct.proxyHeader),
124
+ };
125
+ }
126
+ exports.certificateHttpChallengeToTerraform = certificateHttpChallengeToTerraform;
127
+ class CertificateHttpChallengeOutputReference extends cdktf.ComplexObject {
128
+ /**
129
+ * @param terraformResource The parent resource
130
+ * @param terraformAttribute The attribute on the parent resource this class is referencing
131
+ */
132
+ constructor(terraformResource, terraformAttribute) {
133
+ super(terraformResource, terraformAttribute, false, 0);
134
+ this.isEmptyObject = false;
135
+ }
136
+ get internalValue() {
137
+ let hasAnyValues = this.isEmptyObject;
138
+ const internalValueResult = {};
139
+ if (this._port !== undefined) {
140
+ hasAnyValues = true;
141
+ internalValueResult.port = this._port;
142
+ }
143
+ if (this._proxyHeader !== undefined) {
144
+ hasAnyValues = true;
145
+ internalValueResult.proxyHeader = this._proxyHeader;
146
+ }
147
+ return hasAnyValues ? internalValueResult : undefined;
148
+ }
149
+ set internalValue(value) {
150
+ if (value === undefined) {
151
+ this.isEmptyObject = false;
152
+ this._port = undefined;
153
+ this._proxyHeader = undefined;
154
+ }
155
+ else {
156
+ this.isEmptyObject = Object.keys(value).length === 0;
157
+ this._port = value.port;
158
+ this._proxyHeader = value.proxyHeader;
159
+ }
160
+ }
161
+ get port() {
162
+ return this.getNumberAttribute('port');
163
+ }
164
+ set port(value) {
165
+ this._port = value;
166
+ }
167
+ resetPort() {
168
+ this._port = undefined;
169
+ }
170
+ // Temporarily expose input value. Use with caution.
171
+ get portInput() {
172
+ return this._port;
173
+ }
174
+ get proxyHeader() {
175
+ return this.getStringAttribute('proxy_header');
176
+ }
177
+ set proxyHeader(value) {
178
+ this._proxyHeader = value;
179
+ }
180
+ resetProxyHeader() {
181
+ this._proxyHeader = undefined;
182
+ }
183
+ // Temporarily expose input value. Use with caution.
184
+ get proxyHeaderInput() {
185
+ return this._proxyHeader;
186
+ }
187
+ }
188
+ exports.CertificateHttpChallengeOutputReference = CertificateHttpChallengeOutputReference;
189
+ _c = JSII_RTTI_SYMBOL_1;
190
+ CertificateHttpChallengeOutputReference[_c] = { fqn: "@cdktf/provider-acme.certificate.CertificateHttpChallengeOutputReference", version: "3.0.1" };
191
+ function certificateHttpMemcachedChallengeToTerraform(struct) {
192
+ if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) {
193
+ return struct;
194
+ }
195
+ if (cdktf.isComplexElement(struct)) {
196
+ throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
197
+ }
198
+ return {
199
+ hosts: cdktf.listMapper(cdktf.stringToTerraform, false)(struct.hosts),
200
+ };
201
+ }
202
+ exports.certificateHttpMemcachedChallengeToTerraform = certificateHttpMemcachedChallengeToTerraform;
203
+ class CertificateHttpMemcachedChallengeOutputReference extends cdktf.ComplexObject {
204
+ /**
205
+ * @param terraformResource The parent resource
206
+ * @param terraformAttribute The attribute on the parent resource this class is referencing
207
+ */
208
+ constructor(terraformResource, terraformAttribute) {
209
+ super(terraformResource, terraformAttribute, false, 0);
210
+ this.isEmptyObject = false;
211
+ }
212
+ get internalValue() {
213
+ let hasAnyValues = this.isEmptyObject;
214
+ const internalValueResult = {};
215
+ if (this._hosts !== undefined) {
216
+ hasAnyValues = true;
217
+ internalValueResult.hosts = this._hosts;
218
+ }
219
+ return hasAnyValues ? internalValueResult : undefined;
220
+ }
221
+ set internalValue(value) {
222
+ if (value === undefined) {
223
+ this.isEmptyObject = false;
224
+ this._hosts = undefined;
225
+ }
226
+ else {
227
+ this.isEmptyObject = Object.keys(value).length === 0;
228
+ this._hosts = value.hosts;
229
+ }
230
+ }
231
+ get hosts() {
232
+ return cdktf.Fn.tolist(this.getListAttribute('hosts'));
233
+ }
234
+ set hosts(value) {
235
+ this._hosts = value;
236
+ }
237
+ // Temporarily expose input value. Use with caution.
238
+ get hostsInput() {
239
+ return this._hosts;
240
+ }
241
+ }
242
+ exports.CertificateHttpMemcachedChallengeOutputReference = CertificateHttpMemcachedChallengeOutputReference;
243
+ _d = JSII_RTTI_SYMBOL_1;
244
+ CertificateHttpMemcachedChallengeOutputReference[_d] = { fqn: "@cdktf/provider-acme.certificate.CertificateHttpMemcachedChallengeOutputReference", version: "3.0.1" };
245
+ function certificateHttpWebrootChallengeToTerraform(struct) {
246
+ if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) {
247
+ return struct;
248
+ }
249
+ if (cdktf.isComplexElement(struct)) {
250
+ throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
251
+ }
252
+ return {
253
+ directory: cdktf.stringToTerraform(struct.directory),
254
+ };
255
+ }
256
+ exports.certificateHttpWebrootChallengeToTerraform = certificateHttpWebrootChallengeToTerraform;
257
+ class CertificateHttpWebrootChallengeOutputReference extends cdktf.ComplexObject {
258
+ /**
259
+ * @param terraformResource The parent resource
260
+ * @param terraformAttribute The attribute on the parent resource this class is referencing
261
+ */
262
+ constructor(terraformResource, terraformAttribute) {
263
+ super(terraformResource, terraformAttribute, false, 0);
264
+ this.isEmptyObject = false;
265
+ }
266
+ get internalValue() {
267
+ let hasAnyValues = this.isEmptyObject;
268
+ const internalValueResult = {};
269
+ if (this._directory !== undefined) {
270
+ hasAnyValues = true;
271
+ internalValueResult.directory = this._directory;
272
+ }
273
+ return hasAnyValues ? internalValueResult : undefined;
274
+ }
275
+ set internalValue(value) {
276
+ if (value === undefined) {
277
+ this.isEmptyObject = false;
278
+ this._directory = undefined;
279
+ }
280
+ else {
281
+ this.isEmptyObject = Object.keys(value).length === 0;
282
+ this._directory = value.directory;
283
+ }
284
+ }
285
+ get directory() {
286
+ return this.getStringAttribute('directory');
287
+ }
288
+ set directory(value) {
289
+ this._directory = value;
290
+ }
291
+ // Temporarily expose input value. Use with caution.
292
+ get directoryInput() {
293
+ return this._directory;
294
+ }
295
+ }
296
+ exports.CertificateHttpWebrootChallengeOutputReference = CertificateHttpWebrootChallengeOutputReference;
297
+ _e = JSII_RTTI_SYMBOL_1;
298
+ CertificateHttpWebrootChallengeOutputReference[_e] = { fqn: "@cdktf/provider-acme.certificate.CertificateHttpWebrootChallengeOutputReference", version: "3.0.1" };
299
+ function certificateTlsChallengeToTerraform(struct) {
300
+ if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) {
301
+ return struct;
302
+ }
303
+ if (cdktf.isComplexElement(struct)) {
304
+ throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
305
+ }
306
+ return {
307
+ port: cdktf.numberToTerraform(struct.port),
308
+ };
309
+ }
310
+ exports.certificateTlsChallengeToTerraform = certificateTlsChallengeToTerraform;
311
+ class CertificateTlsChallengeOutputReference extends cdktf.ComplexObject {
312
+ /**
313
+ * @param terraformResource The parent resource
314
+ * @param terraformAttribute The attribute on the parent resource this class is referencing
315
+ */
316
+ constructor(terraformResource, terraformAttribute) {
317
+ super(terraformResource, terraformAttribute, false, 0);
318
+ this.isEmptyObject = false;
319
+ }
320
+ get internalValue() {
321
+ let hasAnyValues = this.isEmptyObject;
322
+ const internalValueResult = {};
323
+ if (this._port !== undefined) {
324
+ hasAnyValues = true;
325
+ internalValueResult.port = this._port;
326
+ }
327
+ return hasAnyValues ? internalValueResult : undefined;
328
+ }
329
+ set internalValue(value) {
330
+ if (value === undefined) {
331
+ this.isEmptyObject = false;
332
+ this._port = undefined;
333
+ }
334
+ else {
335
+ this.isEmptyObject = Object.keys(value).length === 0;
336
+ this._port = value.port;
337
+ }
338
+ }
339
+ get port() {
340
+ return this.getNumberAttribute('port');
341
+ }
342
+ set port(value) {
343
+ this._port = value;
344
+ }
345
+ resetPort() {
346
+ this._port = undefined;
347
+ }
348
+ // Temporarily expose input value. Use with caution.
349
+ get portInput() {
350
+ return this._port;
351
+ }
352
+ }
353
+ exports.CertificateTlsChallengeOutputReference = CertificateTlsChallengeOutputReference;
354
+ _f = JSII_RTTI_SYMBOL_1;
355
+ CertificateTlsChallengeOutputReference[_f] = { fqn: "@cdktf/provider-acme.certificate.CertificateTlsChallengeOutputReference", version: "3.0.1" };
356
+ /**
357
+ * Represents a {@link https://www.terraform.io/docs/providers/acme/r/certificate acme_certificate}
358
+ */
359
+ class Certificate extends cdktf.TerraformResource {
360
+ // ===========
361
+ // INITIALIZER
362
+ // ===========
363
+ /**
364
+ * Create a new {@link https://www.terraform.io/docs/providers/acme/r/certificate acme_certificate} Resource
365
+ *
366
+ * @param scope The scope in which to define this construct
367
+ * @param id The scoped construct ID. Must be unique amongst siblings in the same scope
368
+ * @param options CertificateConfig
369
+ */
370
+ constructor(scope, id, config) {
371
+ super(scope, id, {
372
+ terraformResourceType: 'acme_certificate',
373
+ terraformGeneratorMetadata: {
374
+ providerName: 'acme',
375
+ providerVersion: '2.10.0',
376
+ providerVersionConstraint: '~> 2.10'
377
+ },
378
+ provider: config.provider,
379
+ dependsOn: config.dependsOn,
380
+ count: config.count,
381
+ lifecycle: config.lifecycle,
382
+ provisioners: config.provisioners,
383
+ connection: config.connection,
384
+ forEach: config.forEach
385
+ });
386
+ // dns_challenge - computed: false, optional: true, required: false
387
+ this._dnsChallenge = new CertificateDnsChallengeList(this, "dns_challenge", false);
388
+ // http_challenge - computed: false, optional: true, required: false
389
+ this._httpChallenge = new CertificateHttpChallengeOutputReference(this, "http_challenge");
390
+ // http_memcached_challenge - computed: false, optional: true, required: false
391
+ this._httpMemcachedChallenge = new CertificateHttpMemcachedChallengeOutputReference(this, "http_memcached_challenge");
392
+ // http_webroot_challenge - computed: false, optional: true, required: false
393
+ this._httpWebrootChallenge = new CertificateHttpWebrootChallengeOutputReference(this, "http_webroot_challenge");
394
+ // tls_challenge - computed: false, optional: true, required: false
395
+ this._tlsChallenge = new CertificateTlsChallengeOutputReference(this, "tls_challenge");
396
+ this._accountKeyPem = config.accountKeyPem;
397
+ this._certificateP12Password = config.certificateP12Password;
398
+ this._certificateRequestPem = config.certificateRequestPem;
399
+ this._commonName = config.commonName;
400
+ this._disableCompletePropagation = config.disableCompletePropagation;
401
+ this._id = config.id;
402
+ this._keyType = config.keyType;
403
+ this._minDaysRemaining = config.minDaysRemaining;
404
+ this._mustStaple = config.mustStaple;
405
+ this._preCheckDelay = config.preCheckDelay;
406
+ this._preferredChain = config.preferredChain;
407
+ this._recursiveNameservers = config.recursiveNameservers;
408
+ this._revokeCertificateOnDestroy = config.revokeCertificateOnDestroy;
409
+ this._subjectAlternativeNames = config.subjectAlternativeNames;
410
+ this._dnsChallenge.internalValue = config.dnsChallenge;
411
+ this._httpChallenge.internalValue = config.httpChallenge;
412
+ this._httpMemcachedChallenge.internalValue = config.httpMemcachedChallenge;
413
+ this._httpWebrootChallenge.internalValue = config.httpWebrootChallenge;
414
+ this._tlsChallenge.internalValue = config.tlsChallenge;
415
+ }
416
+ get accountKeyPem() {
417
+ return this.getStringAttribute('account_key_pem');
418
+ }
419
+ set accountKeyPem(value) {
420
+ this._accountKeyPem = value;
421
+ }
422
+ // Temporarily expose input value. Use with caution.
423
+ get accountKeyPemInput() {
424
+ return this._accountKeyPem;
425
+ }
426
+ // certificate_domain - computed: true, optional: false, required: false
427
+ get certificateDomain() {
428
+ return this.getStringAttribute('certificate_domain');
429
+ }
430
+ // certificate_p12 - computed: true, optional: false, required: false
431
+ get certificateP12() {
432
+ return this.getStringAttribute('certificate_p12');
433
+ }
434
+ get certificateP12Password() {
435
+ return this.getStringAttribute('certificate_p12_password');
436
+ }
437
+ set certificateP12Password(value) {
438
+ this._certificateP12Password = value;
439
+ }
440
+ resetCertificateP12Password() {
441
+ this._certificateP12Password = undefined;
442
+ }
443
+ // Temporarily expose input value. Use with caution.
444
+ get certificateP12PasswordInput() {
445
+ return this._certificateP12Password;
446
+ }
447
+ // certificate_pem - computed: true, optional: false, required: false
448
+ get certificatePem() {
449
+ return this.getStringAttribute('certificate_pem');
450
+ }
451
+ get certificateRequestPem() {
452
+ return this.getStringAttribute('certificate_request_pem');
453
+ }
454
+ set certificateRequestPem(value) {
455
+ this._certificateRequestPem = value;
456
+ }
457
+ resetCertificateRequestPem() {
458
+ this._certificateRequestPem = undefined;
459
+ }
460
+ // Temporarily expose input value. Use with caution.
461
+ get certificateRequestPemInput() {
462
+ return this._certificateRequestPem;
463
+ }
464
+ // certificate_url - computed: true, optional: false, required: false
465
+ get certificateUrl() {
466
+ return this.getStringAttribute('certificate_url');
467
+ }
468
+ get commonName() {
469
+ return this.getStringAttribute('common_name');
470
+ }
471
+ set commonName(value) {
472
+ this._commonName = value;
473
+ }
474
+ resetCommonName() {
475
+ this._commonName = undefined;
476
+ }
477
+ // Temporarily expose input value. Use with caution.
478
+ get commonNameInput() {
479
+ return this._commonName;
480
+ }
481
+ get disableCompletePropagation() {
482
+ return this.getBooleanAttribute('disable_complete_propagation');
483
+ }
484
+ set disableCompletePropagation(value) {
485
+ this._disableCompletePropagation = value;
486
+ }
487
+ resetDisableCompletePropagation() {
488
+ this._disableCompletePropagation = undefined;
489
+ }
490
+ // Temporarily expose input value. Use with caution.
491
+ get disableCompletePropagationInput() {
492
+ return this._disableCompletePropagation;
493
+ }
494
+ get id() {
495
+ return this.getStringAttribute('id');
496
+ }
497
+ set id(value) {
498
+ this._id = value;
499
+ }
500
+ resetId() {
501
+ this._id = undefined;
502
+ }
503
+ // Temporarily expose input value. Use with caution.
504
+ get idInput() {
505
+ return this._id;
506
+ }
507
+ // issuer_pem - computed: true, optional: false, required: false
508
+ get issuerPem() {
509
+ return this.getStringAttribute('issuer_pem');
510
+ }
511
+ get keyType() {
512
+ return this.getStringAttribute('key_type');
513
+ }
514
+ set keyType(value) {
515
+ this._keyType = value;
516
+ }
517
+ resetKeyType() {
518
+ this._keyType = undefined;
519
+ }
520
+ // Temporarily expose input value. Use with caution.
521
+ get keyTypeInput() {
522
+ return this._keyType;
523
+ }
524
+ get minDaysRemaining() {
525
+ return this.getNumberAttribute('min_days_remaining');
526
+ }
527
+ set minDaysRemaining(value) {
528
+ this._minDaysRemaining = value;
529
+ }
530
+ resetMinDaysRemaining() {
531
+ this._minDaysRemaining = undefined;
532
+ }
533
+ // Temporarily expose input value. Use with caution.
534
+ get minDaysRemainingInput() {
535
+ return this._minDaysRemaining;
536
+ }
537
+ get mustStaple() {
538
+ return this.getBooleanAttribute('must_staple');
539
+ }
540
+ set mustStaple(value) {
541
+ this._mustStaple = value;
542
+ }
543
+ resetMustStaple() {
544
+ this._mustStaple = undefined;
545
+ }
546
+ // Temporarily expose input value. Use with caution.
547
+ get mustStapleInput() {
548
+ return this._mustStaple;
549
+ }
550
+ get preCheckDelay() {
551
+ return this.getNumberAttribute('pre_check_delay');
552
+ }
553
+ set preCheckDelay(value) {
554
+ this._preCheckDelay = value;
555
+ }
556
+ resetPreCheckDelay() {
557
+ this._preCheckDelay = undefined;
558
+ }
559
+ // Temporarily expose input value. Use with caution.
560
+ get preCheckDelayInput() {
561
+ return this._preCheckDelay;
562
+ }
563
+ get preferredChain() {
564
+ return this.getStringAttribute('preferred_chain');
565
+ }
566
+ set preferredChain(value) {
567
+ this._preferredChain = value;
568
+ }
569
+ resetPreferredChain() {
570
+ this._preferredChain = undefined;
571
+ }
572
+ // Temporarily expose input value. Use with caution.
573
+ get preferredChainInput() {
574
+ return this._preferredChain;
575
+ }
576
+ // private_key_pem - computed: true, optional: false, required: false
577
+ get privateKeyPem() {
578
+ return this.getStringAttribute('private_key_pem');
579
+ }
580
+ get recursiveNameservers() {
581
+ return this.getListAttribute('recursive_nameservers');
582
+ }
583
+ set recursiveNameservers(value) {
584
+ this._recursiveNameservers = value;
585
+ }
586
+ resetRecursiveNameservers() {
587
+ this._recursiveNameservers = undefined;
588
+ }
589
+ // Temporarily expose input value. Use with caution.
590
+ get recursiveNameserversInput() {
591
+ return this._recursiveNameservers;
592
+ }
593
+ get revokeCertificateOnDestroy() {
594
+ return this.getBooleanAttribute('revoke_certificate_on_destroy');
595
+ }
596
+ set revokeCertificateOnDestroy(value) {
597
+ this._revokeCertificateOnDestroy = value;
598
+ }
599
+ resetRevokeCertificateOnDestroy() {
600
+ this._revokeCertificateOnDestroy = undefined;
601
+ }
602
+ // Temporarily expose input value. Use with caution.
603
+ get revokeCertificateOnDestroyInput() {
604
+ return this._revokeCertificateOnDestroy;
605
+ }
606
+ get subjectAlternativeNames() {
607
+ return cdktf.Fn.tolist(this.getListAttribute('subject_alternative_names'));
608
+ }
609
+ set subjectAlternativeNames(value) {
610
+ this._subjectAlternativeNames = value;
611
+ }
612
+ resetSubjectAlternativeNames() {
613
+ this._subjectAlternativeNames = undefined;
614
+ }
615
+ // Temporarily expose input value. Use with caution.
616
+ get subjectAlternativeNamesInput() {
617
+ return this._subjectAlternativeNames;
618
+ }
619
+ get dnsChallenge() {
620
+ return this._dnsChallenge;
621
+ }
622
+ putDnsChallenge(value) {
623
+ this._dnsChallenge.internalValue = value;
624
+ }
625
+ resetDnsChallenge() {
626
+ this._dnsChallenge.internalValue = undefined;
627
+ }
628
+ // Temporarily expose input value. Use with caution.
629
+ get dnsChallengeInput() {
630
+ return this._dnsChallenge.internalValue;
631
+ }
632
+ get httpChallenge() {
633
+ return this._httpChallenge;
634
+ }
635
+ putHttpChallenge(value) {
636
+ this._httpChallenge.internalValue = value;
637
+ }
638
+ resetHttpChallenge() {
639
+ this._httpChallenge.internalValue = undefined;
640
+ }
641
+ // Temporarily expose input value. Use with caution.
642
+ get httpChallengeInput() {
643
+ return this._httpChallenge.internalValue;
644
+ }
645
+ get httpMemcachedChallenge() {
646
+ return this._httpMemcachedChallenge;
647
+ }
648
+ putHttpMemcachedChallenge(value) {
649
+ this._httpMemcachedChallenge.internalValue = value;
650
+ }
651
+ resetHttpMemcachedChallenge() {
652
+ this._httpMemcachedChallenge.internalValue = undefined;
653
+ }
654
+ // Temporarily expose input value. Use with caution.
655
+ get httpMemcachedChallengeInput() {
656
+ return this._httpMemcachedChallenge.internalValue;
657
+ }
658
+ get httpWebrootChallenge() {
659
+ return this._httpWebrootChallenge;
660
+ }
661
+ putHttpWebrootChallenge(value) {
662
+ this._httpWebrootChallenge.internalValue = value;
663
+ }
664
+ resetHttpWebrootChallenge() {
665
+ this._httpWebrootChallenge.internalValue = undefined;
666
+ }
667
+ // Temporarily expose input value. Use with caution.
668
+ get httpWebrootChallengeInput() {
669
+ return this._httpWebrootChallenge.internalValue;
670
+ }
671
+ get tlsChallenge() {
672
+ return this._tlsChallenge;
673
+ }
674
+ putTlsChallenge(value) {
675
+ this._tlsChallenge.internalValue = value;
676
+ }
677
+ resetTlsChallenge() {
678
+ this._tlsChallenge.internalValue = undefined;
679
+ }
680
+ // Temporarily expose input value. Use with caution.
681
+ get tlsChallengeInput() {
682
+ return this._tlsChallenge.internalValue;
683
+ }
684
+ // =========
685
+ // SYNTHESIS
686
+ // =========
687
+ synthesizeAttributes() {
688
+ return {
689
+ account_key_pem: cdktf.stringToTerraform(this._accountKeyPem),
690
+ certificate_p12_password: cdktf.stringToTerraform(this._certificateP12Password),
691
+ certificate_request_pem: cdktf.stringToTerraform(this._certificateRequestPem),
692
+ common_name: cdktf.stringToTerraform(this._commonName),
693
+ disable_complete_propagation: cdktf.booleanToTerraform(this._disableCompletePropagation),
694
+ id: cdktf.stringToTerraform(this._id),
695
+ key_type: cdktf.stringToTerraform(this._keyType),
696
+ min_days_remaining: cdktf.numberToTerraform(this._minDaysRemaining),
697
+ must_staple: cdktf.booleanToTerraform(this._mustStaple),
698
+ pre_check_delay: cdktf.numberToTerraform(this._preCheckDelay),
699
+ preferred_chain: cdktf.stringToTerraform(this._preferredChain),
700
+ recursive_nameservers: cdktf.listMapper(cdktf.stringToTerraform, false)(this._recursiveNameservers),
701
+ revoke_certificate_on_destroy: cdktf.booleanToTerraform(this._revokeCertificateOnDestroy),
702
+ subject_alternative_names: cdktf.listMapper(cdktf.stringToTerraform, false)(this._subjectAlternativeNames),
703
+ dns_challenge: cdktf.listMapper(certificateDnsChallengeToTerraform, true)(this._dnsChallenge.internalValue),
704
+ http_challenge: certificateHttpChallengeToTerraform(this._httpChallenge.internalValue),
705
+ http_memcached_challenge: certificateHttpMemcachedChallengeToTerraform(this._httpMemcachedChallenge.internalValue),
706
+ http_webroot_challenge: certificateHttpWebrootChallengeToTerraform(this._httpWebrootChallenge.internalValue),
707
+ tls_challenge: certificateTlsChallengeToTerraform(this._tlsChallenge.internalValue),
708
+ };
709
+ }
710
+ }
711
+ exports.Certificate = Certificate;
712
+ _g = JSII_RTTI_SYMBOL_1;
713
+ Certificate[_g] = { fqn: "@cdktf/provider-acme.certificate.Certificate", version: "3.0.1" };
714
+ // =================
715
+ // STATIC PROPERTIES
716
+ // =================
717
+ Certificate.tfResourceType = "acme_certificate";
718
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/certificate/index.ts"],"names":[],"mappings":";;;;;AAIA,+BAA+B;AA0G/B,SAAgB,kCAAkC,CAAC,MAAoD;IACrG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,YAAY,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE;QAAE,OAAO,MAAM,CAAC;KAAE;IAC5F,IAAI,KAAK,CAAC,gBAAgB,CAAC,MAAM,CAAC,EAAE;QAClC,MAAM,IAAI,KAAK,CAAC,oHAAoH,CAAC,CAAC;KACvI;IACD,OAAO;QACL,MAAM,EAAE,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC,MAAO,CAAC,MAAM,CAAC;QACjE,QAAQ,EAAE,KAAK,CAAC,iBAAiB,CAAC,MAAO,CAAC,QAAQ,CAAC;KACpD,CAAA;AACH,CAAC;AATD,gFASC;AAED,MAAa,sCAAuC,SAAQ,KAAK,CAAC,aAAa;IAI7E;;;;;MAKE;IACF,YAAmB,iBAA6C,EAAE,kBAA0B,EAAE,kBAA0B,EAAE,sBAA+B;QACvJ,KAAK,CAAC,iBAAiB,EAAE,kBAAkB,EAAE,sBAAsB,EAAE,kBAAkB,CAAC,CAAC;QAVnF,kBAAa,GAAG,KAAK,CAAC;IAW9B,CAAC;IAED,IAAW,aAAa;QACtB,IAAI,IAAI,CAAC,eAAe,EAAE;YACxB,OAAO,IAAI,CAAC,eAAe,CAAC;SAC7B;QACD,IAAI,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC;QACtC,MAAM,mBAAmB,GAAQ,EAAE,CAAC;QACpC,IAAI,IAAI,CAAC,OAAO,KAAK,SAAS,EAAE;YAC9B,YAAY,GAAG,IAAI,CAAC;YACpB,mBAAmB,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC;SAC3C;QACD,IAAI,IAAI,CAAC,SAAS,KAAK,SAAS,EAAE;YAChC,YAAY,GAAG,IAAI,CAAC;YACpB,mBAAmB,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC;SAC/C;QACD,OAAO,YAAY,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,SAAS,CAAC;IACxD,CAAC;IAED,IAAW,aAAa,CAAC,KAA8D;QACrF,IAAI,KAAK,KAAK,SAAS,EAAE;YACvB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;YAC3B,IAAI,CAAC,eAAe,GAAG,SAAS,CAAC;YACjC,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;YACzB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;SAC5B;aACI,IAAI,KAAK,CAAC,YAAY,CAAC,YAAY,CAAC,KAAK,CAAC,EAAE;YAC/C,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;YAC3B,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;SAC9B;aACI;YACH,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC;YACrD,IAAI,CAAC,eAAe,GAAG,SAAS,CAAC;YACjC,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,MAAM,CAAC;YAC5B,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,QAAQ,CAAC;SACjC;IACH,CAAC;IAID,IAAW,MAAM;QACf,OAAO,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,CAAC;IAC9C,CAAC;IACD,IAAW,MAAM,CAAC,KAAgC;QAChD,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;IACM,WAAW;QAChB,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;IAC3B,CAAC;IACD,oDAAoD;IACpD,IAAW,WAAW;QACpB,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAID,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,CAAC;IAC7C,CAAC;IACD,IAAW,QAAQ,CAAC,KAAa;QAC/B,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACzB,CAAC;IACD,oDAAoD;IACpD,IAAW,aAAa;QACtB,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;;AA7EH,wFA8EC;;;AAED,MAAa,2BAA4B,SAAQ,KAAK,CAAC,WAAW;IAGhE;;;;MAIE;IACF,YAAsB,iBAA6C,EAAY,kBAA0B,EAAY,QAAiB;QACpI,KAAK,CAAC,iBAAiB,EAAE,kBAAkB,EAAE,QAAQ,CAAC,CAAA;QADlC,sBAAiB,GAAjB,iBAAiB,CAA4B;QAAY,uBAAkB,GAAlB,kBAAkB,CAAQ;QAAY,aAAQ,GAAR,QAAQ,CAAS;IAEtI,CAAC;IAED;;MAEE;IACK,GAAG,CAAC,KAAa;QACtB,OAAO,IAAI,sCAAsC,CAAC,IAAI,CAAC,iBAAiB,EAAE,IAAI,CAAC,kBAAkB,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC3H,CAAC;;AAjBH,kEAkBC;;;AAYD,SAAgB,mCAAmC,CAAC,MAA2E;IAC7H,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,YAAY,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE;QAAE,OAAO,MAAM,CAAC;KAAE;IAC5F,IAAI,KAAK,CAAC,gBAAgB,CAAC,MAAM,CAAC,EAAE;QAClC,MAAM,IAAI,KAAK,CAAC,oHAAoH,CAAC,CAAC;KACvI;IACD,OAAO;QACL,IAAI,EAAE,KAAK,CAAC,iBAAiB,CAAC,MAAO,CAAC,IAAI,CAAC;QAC3C,YAAY,EAAE,KAAK,CAAC,iBAAiB,CAAC,MAAO,CAAC,WAAW,CAAC;KAC3D,CAAA;AACH,CAAC;AATD,kFASC;AAED,MAAa,uCAAwC,SAAQ,KAAK,CAAC,aAAa;IAG9E;;;MAGE;IACF,YAAmB,iBAA6C,EAAE,kBAA0B;QAC1F,KAAK,CAAC,iBAAiB,EAAE,kBAAkB,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;QAPjD,kBAAa,GAAG,KAAK,CAAC;IAQ9B,CAAC;IAED,IAAW,aAAa;QACtB,IAAI,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC;QACtC,MAAM,mBAAmB,GAAQ,EAAE,CAAC;QACpC,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,EAAE;YAC5B,YAAY,GAAG,IAAI,CAAC;YACpB,mBAAmB,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC;SACvC;QACD,IAAI,IAAI,CAAC,YAAY,KAAK,SAAS,EAAE;YACnC,YAAY,GAAG,IAAI,CAAC;YACpB,mBAAmB,CAAC,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC;SACrD;QACD,OAAO,YAAY,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,SAAS,CAAC;IACxD,CAAC;IAED,IAAW,aAAa,CAAC,KAA2C;QAClE,IAAI,KAAK,KAAK,SAAS,EAAE;YACvB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;YAC3B,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC;YACvB,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC;SAC/B;aACI;YACH,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC;YACrD,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC;YACxB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,WAAW,CAAC;SACvC;IACH,CAAC;IAID,IAAW,IAAI;QACb,OAAO,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC;IACzC,CAAC;IACD,IAAW,IAAI,CAAC,KAAa;QAC3B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IACM,SAAS;QACd,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC;IACzB,CAAC;IACD,oDAAoD;IACpD,IAAW,SAAS;QAClB,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAID,IAAW,WAAW;QACpB,OAAO,IAAI,CAAC,kBAAkB,CAAC,cAAc,CAAC,CAAC;IACjD,CAAC;IACD,IAAW,WAAW,CAAC,KAAa;QAClC,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;IAC5B,CAAC;IACM,gBAAgB;QACrB,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC;IAChC,CAAC;IACD,oDAAoD;IACpD,IAAW,gBAAgB;QACzB,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;;AApEH,0FAqEC;;;AAQD,SAAgB,4CAA4C,CAAC,MAA6F;IACxJ,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,YAAY,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE;QAAE,OAAO,MAAM,CAAC;KAAE;IAC5F,IAAI,KAAK,CAAC,gBAAgB,CAAC,MAAM,CAAC,EAAE;QAClC,MAAM,IAAI,KAAK,CAAC,oHAAoH,CAAC,CAAC;KACvI;IACD,OAAO;QACL,KAAK,EAAE,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,iBAAiB,EAAE,KAAK,CAAC,CAAC,MAAO,CAAC,KAAK,CAAC;KACvE,CAAA;AACH,CAAC;AARD,oGAQC;AAED,MAAa,gDAAiD,SAAQ,KAAK,CAAC,aAAa;IAGvF;;;MAGE;IACF,YAAmB,iBAA6C,EAAE,kBAA0B;QAC1F,KAAK,CAAC,iBAAiB,EAAE,kBAAkB,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;QAPjD,kBAAa,GAAG,KAAK,CAAC;IAQ9B,CAAC;IAED,IAAW,aAAa;QACtB,IAAI,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC;QACtC,MAAM,mBAAmB,GAAQ,EAAE,CAAC;QACpC,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE;YAC7B,YAAY,GAAG,IAAI,CAAC;YACpB,mBAAmB,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC;SACzC;QACD,OAAO,YAAY,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,SAAS,CAAC;IACxD,CAAC;IAED,IAAW,aAAa,CAAC,KAAoD;QAC3E,IAAI,KAAK,KAAK,SAAS,EAAE;YACvB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;YAC3B,IAAI,CAAC,MAAM,GAAG,SAAS,CAAC;SACzB;aACI;YACH,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC;YACrD,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC;SAC3B;IACH,CAAC;IAID,IAAW,KAAK;QACd,OAAO,KAAK,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAAC;IACzD,CAAC;IACD,IAAW,KAAK,CAAC,KAAe;QAC9B,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACtB,CAAC;IACD,oDAAoD;IACpD,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;;AA3CH,4GA4CC;;;AAQD,SAAgB,0CAA0C,CAAC,MAAyF;IAClJ,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,YAAY,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE;QAAE,OAAO,MAAM,CAAC;KAAE;IAC5F,IAAI,KAAK,CAAC,gBAAgB,CAAC,MAAM,CAAC,EAAE;QAClC,MAAM,IAAI,KAAK,CAAC,oHAAoH,CAAC,CAAC;KACvI;IACD,OAAO;QACL,SAAS,EAAE,KAAK,CAAC,iBAAiB,CAAC,MAAO,CAAC,SAAS,CAAC;KACtD,CAAA;AACH,CAAC;AARD,gGAQC;AAED,MAAa,8CAA+C,SAAQ,KAAK,CAAC,aAAa;IAGrF;;;MAGE;IACF,YAAmB,iBAA6C,EAAE,kBAA0B;QAC1F,KAAK,CAAC,iBAAiB,EAAE,kBAAkB,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;QAPjD,kBAAa,GAAG,KAAK,CAAC;IAQ9B,CAAC;IAED,IAAW,aAAa;QACtB,IAAI,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC;QACtC,MAAM,mBAAmB,GAAQ,EAAE,CAAC;QACpC,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS,EAAE;YACjC,YAAY,GAAG,IAAI,CAAC;YACpB,mBAAmB,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC;SACjD;QACD,OAAO,YAAY,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,SAAS,CAAC;IACxD,CAAC;IAED,IAAW,aAAa,CAAC,KAAkD;QACzE,IAAI,KAAK,KAAK,SAAS,EAAE;YACvB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;YAC3B,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;SAC7B;aACI;YACH,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC;YACrD,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,SAAS,CAAC;SACnC;IACH,CAAC;IAID,IAAW,SAAS;QAClB,OAAO,IAAI,CAAC,kBAAkB,CAAC,WAAW,CAAC,CAAC;IAC9C,CAAC;IACD,IAAW,SAAS,CAAC,KAAa;QAChC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;IAC1B,CAAC;IACD,oDAAoD;IACpD,IAAW,cAAc;QACvB,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;;AA3CH,wGA4CC;;;AAQD,SAAgB,kCAAkC,CAAC,MAAyE;IAC1H,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,YAAY,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE;QAAE,OAAO,MAAM,CAAC;KAAE;IAC5F,IAAI,KAAK,CAAC,gBAAgB,CAAC,MAAM,CAAC,EAAE;QAClC,MAAM,IAAI,KAAK,CAAC,oHAAoH,CAAC,CAAC;KACvI;IACD,OAAO;QACL,IAAI,EAAE,KAAK,CAAC,iBAAiB,CAAC,MAAO,CAAC,IAAI,CAAC;KAC5C,CAAA;AACH,CAAC;AARD,gFAQC;AAED,MAAa,sCAAuC,SAAQ,KAAK,CAAC,aAAa;IAG7E;;;MAGE;IACF,YAAmB,iBAA6C,EAAE,kBAA0B;QAC1F,KAAK,CAAC,iBAAiB,EAAE,kBAAkB,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;QAPjD,kBAAa,GAAG,KAAK,CAAC;IAQ9B,CAAC;IAED,IAAW,aAAa;QACtB,IAAI,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC;QACtC,MAAM,mBAAmB,GAAQ,EAAE,CAAC;QACpC,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,EAAE;YAC5B,YAAY,GAAG,IAAI,CAAC;YACpB,mBAAmB,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC;SACvC;QACD,OAAO,YAAY,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,SAAS,CAAC;IACxD,CAAC;IAED,IAAW,aAAa,CAAC,KAA0C;QACjE,IAAI,KAAK,KAAK,SAAS,EAAE;YACvB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;YAC3B,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC;SACxB;aACI;YACH,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC;YACrD,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC;SACzB;IACH,CAAC;IAID,IAAW,IAAI;QACb,OAAO,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC;IACzC,CAAC;IACD,IAAW,IAAI,CAAC,KAAa;QAC3B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IACM,SAAS;QACd,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC;IACzB,CAAC;IACD,oDAAoD;IACpD,IAAW,SAAS;QAClB,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;;AA9CH,wFA+CC;;;AAED;;EAEE;AACF,MAAa,WAAY,SAAQ,KAAK,CAAC,iBAAiB;IAOtD,cAAc;IACd,cAAc;IACd,cAAc;IAEd;;;;;;MAME;IACF,YAAmB,KAAgB,EAAE,EAAU,EAAE,MAAyB;QACxE,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,qBAAqB,EAAE,kBAAkB;YACzC,0BAA0B,EAAE;gBAC1B,YAAY,EAAE,MAAM;gBACpB,eAAe,EAAE,QAAQ;gBACzB,yBAAyB,EAAE,SAAS;aACrC;YACD,QAAQ,EAAE,MAAM,CAAC,QAAQ;YACzB,SAAS,EAAE,MAAM,CAAC,SAAS;YAC3B,KAAK,EAAE,MAAM,CAAC,KAAK;YACnB,SAAS,EAAE,MAAM,CAAC,SAAS;YAC3B,YAAY,EAAE,MAAM,CAAC,YAAY;YACjC,UAAU,EAAE,MAAM,CAAC,UAAU;YAC7B,OAAO,EAAE,MAAM,CAAC,OAAO;SACxB,CAAC,CAAC;QAqRL,mEAAmE;QAC3D,kBAAa,GAAG,IAAI,2BAA2B,CAAC,IAAI,EAAE,eAAe,EAAE,KAAK,CAAC,CAAC;QAetF,oEAAoE;QAC5D,mBAAc,GAAG,IAAI,uCAAuC,CAAC,IAAI,EAAE,gBAAgB,CAAC,CAAC;QAe7F,8EAA8E;QACtE,4BAAuB,GAAG,IAAI,gDAAgD,CAAC,IAAI,EAAE,0BAA0B,CAAC,CAAC;QAezH,4EAA4E;QACpE,0BAAqB,GAAG,IAAI,8CAA8C,CAAC,IAAI,EAAE,wBAAwB,CAAC,CAAC;QAenH,mEAAmE;QAC3D,kBAAa,GAAG,IAAI,sCAAsC,CAAC,IAAI,EAAE,eAAe,CAAC,CAAC;QArVxF,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,aAAa,CAAC;QAC3C,IAAI,CAAC,uBAAuB,GAAG,MAAM,CAAC,sBAAsB,CAAC;QAC7D,IAAI,CAAC,sBAAsB,GAAG,MAAM,CAAC,qBAAqB,CAAC;QAC3D,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,UAAU,CAAC;QACrC,IAAI,CAAC,2BAA2B,GAAG,MAAM,CAAC,0BAA0B,CAAC;QACrE,IAAI,CAAC,GAAG,GAAG,MAAM,CAAC,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,OAAO,CAAC;QAC/B,IAAI,CAAC,iBAAiB,GAAG,MAAM,CAAC,gBAAgB,CAAC;QACjD,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,UAAU,CAAC;QACrC,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,aAAa,CAAC;QAC3C,IAAI,CAAC,eAAe,GAAG,MAAM,CAAC,cAAc,CAAC;QAC7C,IAAI,CAAC,qBAAqB,GAAG,MAAM,CAAC,oBAAoB,CAAC;QACzD,IAAI,CAAC,2BAA2B,GAAG,MAAM,CAAC,0BAA0B,CAAC;QACrE,IAAI,CAAC,wBAAwB,GAAG,MAAM,CAAC,uBAAuB,CAAC;QAC/D,IAAI,CAAC,aAAa,CAAC,aAAa,GAAG,MAAM,CAAC,YAAY,CAAC;QACvD,IAAI,CAAC,cAAc,CAAC,aAAa,GAAG,MAAM,CAAC,aAAa,CAAC;QACzD,IAAI,CAAC,uBAAuB,CAAC,aAAa,GAAG,MAAM,CAAC,sBAAsB,CAAC;QAC3E,IAAI,CAAC,qBAAqB,CAAC,aAAa,GAAG,MAAM,CAAC,oBAAoB,CAAC;QACvE,IAAI,CAAC,aAAa,CAAC,aAAa,GAAG,MAAM,CAAC,YAAY,CAAC;IACzD,CAAC;IAQD,IAAW,aAAa;QACtB,OAAO,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,CAAC;IACpD,CAAC;IACD,IAAW,aAAa,CAAC,KAAa;QACpC,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;IAC9B,CAAC;IACD,oDAAoD;IACpD,IAAW,kBAAkB;QAC3B,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;IAED,wEAAwE;IACxE,IAAW,iBAAiB;QAC1B,OAAO,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,CAAC,CAAC;IACvD,CAAC;IAED,qEAAqE;IACrE,IAAW,cAAc;QACvB,OAAO,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,CAAC;IACpD,CAAC;IAID,IAAW,sBAAsB;QAC/B,OAAO,IAAI,CAAC,kBAAkB,CAAC,0BAA0B,CAAC,CAAC;IAC7D,CAAC;IACD,IAAW,sBAAsB,CAAC,KAAa;QAC7C,IAAI,CAAC,uBAAuB,GAAG,KAAK,CAAC;IACvC,CAAC;IACM,2BAA2B;QAChC,IAAI,CAAC,uBAAuB,GAAG,SAAS,CAAC;IAC3C,CAAC;IACD,oDAAoD;IACpD,IAAW,2BAA2B;QACpC,OAAO,IAAI,CAAC,uBAAuB,CAAC;IACtC,CAAC;IAED,qEAAqE;IACrE,IAAW,cAAc;QACvB,OAAO,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,CAAC;IACpD,CAAC;IAID,IAAW,qBAAqB;QAC9B,OAAO,IAAI,CAAC,kBAAkB,CAAC,yBAAyB,CAAC,CAAC;IAC5D,CAAC;IACD,IAAW,qBAAqB,CAAC,KAAa;QAC5C,IAAI,CAAC,sBAAsB,GAAG,KAAK,CAAC;IACtC,CAAC;IACM,0BAA0B;QAC/B,IAAI,CAAC,sBAAsB,GAAG,SAAS,CAAC;IAC1C,CAAC;IACD,oDAAoD;IACpD,IAAW,0BAA0B;QACnC,OAAO,IAAI,CAAC,sBAAsB,CAAC;IACrC,CAAC;IAED,qEAAqE;IACrE,IAAW,cAAc;QACvB,OAAO,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,CAAC;IACpD,CAAC;IAID,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,kBAAkB,CAAC,aAAa,CAAC,CAAC;IAChD,CAAC;IACD,IAAW,UAAU,CAAC,KAAa;QACjC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;IAC3B,CAAC;IACM,eAAe;QACpB,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC;IAC/B,CAAC;IACD,oDAAoD;IACpD,IAAW,eAAe;QACxB,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAID,IAAW,0BAA0B;QACnC,OAAO,IAAI,CAAC,mBAAmB,CAAC,8BAA8B,CAAC,CAAC;IAClE,CAAC;IACD,IAAW,0BAA0B,CAAC,KAAkC;QACtE,IAAI,CAAC,2BAA2B,GAAG,KAAK,CAAC;IAC3C,CAAC;IACM,+BAA+B;QACpC,IAAI,CAAC,2BAA2B,GAAG,SAAS,CAAC;IAC/C,CAAC;IACD,oDAAoD;IACpD,IAAW,+BAA+B;QACxC,OAAO,IAAI,CAAC,2BAA2B,CAAC;IAC1C,CAAC;IAID,IAAW,EAAE;QACX,OAAO,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;IACvC,CAAC;IACD,IAAW,EAAE,CAAC,KAAa;QACzB,IAAI,CAAC,GAAG,GAAG,KAAK,CAAC;IACnB,CAAC;IACM,OAAO;QACZ,IAAI,CAAC,GAAG,GAAG,SAAS,CAAC;IACvB,CAAC;IACD,oDAAoD;IACpD,IAAW,OAAO;QAChB,OAAO,IAAI,CAAC,GAAG,CAAC;IAClB,CAAC;IAED,gEAAgE;IAChE,IAAW,SAAS;QAClB,OAAO,IAAI,CAAC,kBAAkB,CAAC,YAAY,CAAC,CAAC;IAC/C,CAAC;IAID,IAAW,OAAO;QAChB,OAAO,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,CAAC;IAC7C,CAAC;IACD,IAAW,OAAO,CAAC,KAAa;QAC9B,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;IACxB,CAAC;IACM,YAAY;QACjB,IAAI,CAAC,QAAQ,GAAG,SAAS,CAAC;IAC5B,CAAC;IACD,oDAAoD;IACpD,IAAW,YAAY;QACrB,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAID,IAAW,gBAAgB;QACzB,OAAO,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,CAAC,CAAC;IACvD,CAAC;IACD,IAAW,gBAAgB,CAAC,KAAa;QACvC,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;IACjC,CAAC;IACM,qBAAqB;QAC1B,IAAI,CAAC,iBAAiB,GAAG,SAAS,CAAC;IACrC,CAAC;IACD,oDAAoD;IACpD,IAAW,qBAAqB;QAC9B,OAAO,IAAI,CAAC,iBAAiB,CAAC;IAChC,CAAC;IAID,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,mBAAmB,CAAC,aAAa,CAAC,CAAC;IACjD,CAAC;IACD,IAAW,UAAU,CAAC,KAAkC;QACtD,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;IAC3B,CAAC;IACM,eAAe;QACpB,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC;IAC/B,CAAC;IACD,oDAAoD;IACpD,IAAW,eAAe;QACxB,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAID,IAAW,aAAa;QACtB,OAAO,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,CAAC;IACpD,CAAC;IACD,IAAW,aAAa,CAAC,KAAa;QACpC,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;IAC9B,CAAC;IACM,kBAAkB;QACvB,IAAI,CAAC,cAAc,GAAG,SAAS,CAAC;IAClC,CAAC;IACD,oDAAoD;IACpD,IAAW,kBAAkB;QAC3B,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;IAID,IAAW,cAAc;QACvB,OAAO,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,CAAC;IACpD,CAAC;IACD,IAAW,cAAc,CAAC,KAAa;QACrC,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;IAC/B,CAAC;IACM,mBAAmB;QACxB,IAAI,CAAC,eAAe,GAAG,SAAS,CAAC;IACnC,CAAC;IACD,oDAAoD;IACpD,IAAW,mBAAmB;QAC5B,OAAO,IAAI,CAAC,eAAe,CAAC;IAC9B,CAAC;IAED,qEAAqE;IACrE,IAAW,aAAa;QACtB,OAAO,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,CAAC;IACpD,CAAC;IAID,IAAW,oBAAoB;QAC7B,OAAO,IAAI,CAAC,gBAAgB,CAAC,uBAAuB,CAAC,CAAC;IACxD,CAAC;IACD,IAAW,oBAAoB,CAAC,KAAe;QAC7C,IAAI,CAAC,qBAAqB,GAAG,KAAK,CAAC;IACrC,CAAC;IACM,yBAAyB;QAC9B,IAAI,CAAC,qBAAqB,GAAG,SAAS,CAAC;IACzC,CAAC;IACD,oDAAoD;IACpD,IAAW,yBAAyB;QAClC,OAAO,IAAI,CAAC,qBAAqB,CAAC;IACpC,CAAC;IAID,IAAW,0BAA0B;QACnC,OAAO,IAAI,CAAC,mBAAmB,CAAC,+BAA+B,CAAC,CAAC;IACnE,CAAC;IACD,IAAW,0BAA0B,CAAC,KAAkC;QACtE,IAAI,CAAC,2BAA2B,GAAG,KAAK,CAAC;IAC3C,CAAC;IACM,+BAA+B;QACpC,IAAI,CAAC,2BAA2B,GAAG,SAAS,CAAC;IAC/C,CAAC;IACD,oDAAoD;IACpD,IAAW,+BAA+B;QACxC,OAAO,IAAI,CAAC,2BAA2B,CAAC;IAC1C,CAAC;IAID,IAAW,uBAAuB;QAChC,OAAO,KAAK,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,2BAA2B,CAAC,CAAC,CAAC;IAC7E,CAAC;IACD,IAAW,uBAAuB,CAAC,KAAe;QAChD,IAAI,CAAC,wBAAwB,GAAG,KAAK,CAAC;IACxC,CAAC;IACM,4BAA4B;QACjC,IAAI,CAAC,wBAAwB,GAAG,SAAS,CAAC;IAC5C,CAAC;IACD,oDAAoD;IACpD,IAAW,4BAA4B;QACrC,OAAO,IAAI,CAAC,wBAAwB,CAAC;IACvC,CAAC;IAID,IAAW,YAAY;QACrB,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IACM,eAAe,CAAC,KAAoD;QACzE,IAAI,CAAC,aAAa,CAAC,aAAa,GAAG,KAAK,CAAC;IAC3C,CAAC;IACM,iBAAiB;QACtB,IAAI,CAAC,aAAa,CAAC,aAAa,GAAG,SAAS,CAAC;IAC/C,CAAC;IACD,oDAAoD;IACpD,IAAW,iBAAiB;QAC1B,OAAO,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC;IAC1C,CAAC;IAID,IAAW,aAAa;QACtB,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;IACM,gBAAgB,CAAC,KAA+B;QACrD,IAAI,CAAC,cAAc,CAAC,aAAa,GAAG,KAAK,CAAC;IAC5C,CAAC;IACM,kBAAkB;QACvB,IAAI,CAAC,cAAc,CAAC,aAAa,GAAG,SAAS,CAAC;IAChD,CAAC;IACD,oDAAoD;IACpD,IAAW,kBAAkB;QAC3B,OAAO,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC;IAC3C,CAAC;IAID,IAAW,sBAAsB;QAC/B,OAAO,IAAI,CAAC,uBAAuB,CAAC;IACtC,CAAC;IACM,yBAAyB,CAAC,KAAwC;QACvE,IAAI,CAAC,uBAAuB,CAAC,aAAa,GAAG,KAAK,CAAC;IACrD,CAAC;IACM,2BAA2B;QAChC,IAAI,CAAC,uBAAuB,CAAC,aAAa,GAAG,SAAS,CAAC;IACzD,CAAC;IACD,oDAAoD;IACpD,IAAW,2BAA2B;QACpC,OAAO,IAAI,CAAC,uBAAuB,CAAC,aAAa,CAAC;IACpD,CAAC;IAID,IAAW,oBAAoB;QAC7B,OAAO,IAAI,CAAC,qBAAqB,CAAC;IACpC,CAAC;IACM,uBAAuB,CAAC,KAAsC;QACnE,IAAI,CAAC,qBAAqB,CAAC,aAAa,GAAG,KAAK,CAAC;IACnD,CAAC;IACM,yBAAyB;QAC9B,IAAI,CAAC,qBAAqB,CAAC,aAAa,GAAG,SAAS,CAAC;IACvD,CAAC;IACD,oDAAoD;IACpD,IAAW,yBAAyB;QAClC,OAAO,IAAI,CAAC,qBAAqB,CAAC,aAAa,CAAC;IAClD,CAAC;IAID,IAAW,YAAY;QACrB,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IACM,eAAe,CAAC,KAA8B;QACnD,IAAI,CAAC,aAAa,CAAC,aAAa,GAAG,KAAK,CAAC;IAC3C,CAAC;IACM,iBAAiB;QACtB,IAAI,CAAC,aAAa,CAAC,aAAa,GAAG,SAAS,CAAC;IAC/C,CAAC;IACD,oDAAoD;IACpD,IAAW,iBAAiB;QAC1B,OAAO,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC;IAC1C,CAAC;IAED,YAAY;IACZ,YAAY;IACZ,YAAY;IAEF,oBAAoB;QAC5B,OAAO;YACL,eAAe,EAAE,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,cAAc,CAAC;YAC7D,wBAAwB,EAAE,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,uBAAuB,CAAC;YAC/E,uBAAuB,EAAE,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,sBAAsB,CAAC;YAC7E,WAAW,EAAE,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,WAAW,CAAC;YACtD,4BAA4B,EAAE,KAAK,CAAC,kBAAkB,CAAC,IAAI,CAAC,2BAA2B,CAAC;YACxF,EAAE,EAAE,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,GAAG,CAAC;YACrC,QAAQ,EAAE,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC;YAChD,kBAAkB,EAAE,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,iBAAiB,CAAC;YACnE,WAAW,EAAE,KAAK,CAAC,kBAAkB,CAAC,IAAI,CAAC,WAAW,CAAC;YACvD,eAAe,EAAE,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,cAAc,CAAC;YAC7D,eAAe,EAAE,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,eAAe,CAAC;YAC9D,qBAAqB,EAAE,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,iBAAiB,EAAE,KAAK,CAAC,CAAC,IAAI,CAAC,qBAAqB,CAAC;YACnG,6BAA6B,EAAE,KAAK,CAAC,kBAAkB,CAAC,IAAI,CAAC,2BAA2B,CAAC;YACzF,yBAAyB,EAAE,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,iBAAiB,EAAE,KAAK,CAAC,CAAC,IAAI,CAAC,wBAAwB,CAAC;YAC1G,aAAa,EAAE,KAAK,CAAC,UAAU,CAAC,kCAAkC,EAAE,IAAI,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC;YAC3G,cAAc,EAAE,mCAAmC,CAAC,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC;YACtF,wBAAwB,EAAE,4CAA4C,CAAC,IAAI,CAAC,uBAAuB,CAAC,aAAa,CAAC;YAClH,sBAAsB,EAAE,0CAA0C,CAAC,IAAI,CAAC,qBAAqB,CAAC,aAAa,CAAC;YAC5G,aAAa,EAAE,kCAAkC,CAAC,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC;SACpF,CAAC;IACJ,CAAC;;AAhaH,kCAiaC;;;AA/ZC,oBAAoB;AACpB,oBAAoB;AACpB,oBAAoB;AACG,0BAAc,GAAG,kBAAkB,CAAC","sourcesContent":["// https://www.terraform.io/docs/providers/acme/r/certificate\n// generated from terraform resource schema\n\nimport { Construct } from 'constructs';\nimport * as cdktf from 'cdktf';\n\n// Configuration\n\nexport interface CertificateConfig extends cdktf.TerraformMetaArguments {\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#account_key_pem Certificate#account_key_pem}\n  */\n  readonly accountKeyPem: string;\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#certificate_p12_password Certificate#certificate_p12_password}\n  */\n  readonly certificateP12Password?: string;\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#certificate_request_pem Certificate#certificate_request_pem}\n  */\n  readonly certificateRequestPem?: string;\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#common_name Certificate#common_name}\n  */\n  readonly commonName?: string;\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#disable_complete_propagation Certificate#disable_complete_propagation}\n  */\n  readonly disableCompletePropagation?: boolean | cdktf.IResolvable;\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#id Certificate#id}\n  *\n  * Please be aware that the id field is automatically added to all resources in Terraform providers using a Terraform provider SDK version below 2.\n  * If you experience problems setting this value it might not be settable. Please take a look at the provider documentation to ensure it should be settable.\n  */\n  readonly id?: string;\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#key_type Certificate#key_type}\n  */\n  readonly keyType?: string;\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#min_days_remaining Certificate#min_days_remaining}\n  */\n  readonly minDaysRemaining?: number;\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#must_staple Certificate#must_staple}\n  */\n  readonly mustStaple?: boolean | cdktf.IResolvable;\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#pre_check_delay Certificate#pre_check_delay}\n  */\n  readonly preCheckDelay?: number;\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#preferred_chain Certificate#preferred_chain}\n  */\n  readonly preferredChain?: string;\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#recursive_nameservers Certificate#recursive_nameservers}\n  */\n  readonly recursiveNameservers?: string[];\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#revoke_certificate_on_destroy Certificate#revoke_certificate_on_destroy}\n  */\n  readonly revokeCertificateOnDestroy?: boolean | cdktf.IResolvable;\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#subject_alternative_names Certificate#subject_alternative_names}\n  */\n  readonly subjectAlternativeNames?: string[];\n  /**\n  * dns_challenge block\n  * \n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#dns_challenge Certificate#dns_challenge}\n  */\n  readonly dnsChallenge?: CertificateDnsChallenge[] | cdktf.IResolvable;\n  /**\n  * http_challenge block\n  * \n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#http_challenge Certificate#http_challenge}\n  */\n  readonly httpChallenge?: CertificateHttpChallenge;\n  /**\n  * http_memcached_challenge block\n  * \n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#http_memcached_challenge Certificate#http_memcached_challenge}\n  */\n  readonly httpMemcachedChallenge?: CertificateHttpMemcachedChallenge;\n  /**\n  * http_webroot_challenge block\n  * \n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#http_webroot_challenge Certificate#http_webroot_challenge}\n  */\n  readonly httpWebrootChallenge?: CertificateHttpWebrootChallenge;\n  /**\n  * tls_challenge block\n  * \n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#tls_challenge Certificate#tls_challenge}\n  */\n  readonly tlsChallenge?: CertificateTlsChallenge;\n}\nexport interface CertificateDnsChallenge {\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#config Certificate#config}\n  */\n  readonly config?: { [key: string]: string };\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#provider Certificate#provider}\n  */\n  readonly provider: string;\n}\n\nexport function certificateDnsChallengeToTerraform(struct?: CertificateDnsChallenge | cdktf.IResolvable): any {\n  if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) { return struct; }\n  if (cdktf.isComplexElement(struct)) {\n    throw new Error(\"A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration\");\n  }\n  return {\n    config: cdktf.hashMapper(cdktf.stringToTerraform)(struct!.config),\n    provider: cdktf.stringToTerraform(struct!.provider),\n  }\n}\n\nexport class CertificateDnsChallengeOutputReference extends cdktf.ComplexObject {\n  private isEmptyObject = false;\n  private resolvableValue?: cdktf.IResolvable;\n\n  /**\n  * @param terraformResource The parent resource\n  * @param terraformAttribute The attribute on the parent resource this class is referencing\n  * @param complexObjectIndex the index of this item in the list\n  * @param complexObjectIsFromSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index)\n  */\n  public constructor(terraformResource: cdktf.IInterpolatingParent, terraformAttribute: string, complexObjectIndex: number, complexObjectIsFromSet: boolean) {\n    super(terraformResource, terraformAttribute, complexObjectIsFromSet, complexObjectIndex);\n  }\n\n  public get internalValue(): CertificateDnsChallenge | cdktf.IResolvable | undefined {\n    if (this.resolvableValue) {\n      return this.resolvableValue;\n    }\n    let hasAnyValues = this.isEmptyObject;\n    const internalValueResult: any = {};\n    if (this._config !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.config = this._config;\n    }\n    if (this._provider !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.provider = this._provider;\n    }\n    return hasAnyValues ? internalValueResult : undefined;\n  }\n\n  public set internalValue(value: CertificateDnsChallenge | cdktf.IResolvable | undefined) {\n    if (value === undefined) {\n      this.isEmptyObject = false;\n      this.resolvableValue = undefined;\n      this._config = undefined;\n      this._provider = undefined;\n    }\n    else if (cdktf.Tokenization.isResolvable(value)) {\n      this.isEmptyObject = false;\n      this.resolvableValue = value;\n    }\n    else {\n      this.isEmptyObject = Object.keys(value).length === 0;\n      this.resolvableValue = undefined;\n      this._config = value.config;\n      this._provider = value.provider;\n    }\n  }\n\n  // config - computed: false, optional: true, required: false\n  private _config?: { [key: string]: string }; \n  public get config() {\n    return this.getStringMapAttribute('config');\n  }\n  public set config(value: { [key: string]: string }) {\n    this._config = value;\n  }\n  public resetConfig() {\n    this._config = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get configInput() {\n    return this._config;\n  }\n\n  // provider - computed: false, optional: false, required: true\n  private _provider?: string; \n  public get provider() {\n    return this.getStringAttribute('provider');\n  }\n  public set provider(value: string) {\n    this._provider = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get providerInput() {\n    return this._provider;\n  }\n}\n\nexport class CertificateDnsChallengeList extends cdktf.ComplexList {\n  public internalValue? : CertificateDnsChallenge[] | cdktf.IResolvable\n\n  /**\n  * @param terraformResource The parent resource\n  * @param terraformAttribute The attribute on the parent resource this class is referencing\n  * @param wrapsSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index)\n  */\n  constructor(protected terraformResource: cdktf.IInterpolatingParent, protected terraformAttribute: string, protected wrapsSet: boolean) {\n    super(terraformResource, terraformAttribute, wrapsSet)\n  }\n\n  /**\n  * @param index the index of the item to return\n  */\n  public get(index: number): CertificateDnsChallengeOutputReference {\n    return new CertificateDnsChallengeOutputReference(this.terraformResource, this.terraformAttribute, index, this.wrapsSet);\n  }\n}\nexport interface CertificateHttpChallenge {\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#port Certificate#port}\n  */\n  readonly port?: number;\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#proxy_header Certificate#proxy_header}\n  */\n  readonly proxyHeader?: string;\n}\n\nexport function certificateHttpChallengeToTerraform(struct?: CertificateHttpChallengeOutputReference | CertificateHttpChallenge): any {\n  if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) { return struct; }\n  if (cdktf.isComplexElement(struct)) {\n    throw new Error(\"A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration\");\n  }\n  return {\n    port: cdktf.numberToTerraform(struct!.port),\n    proxy_header: cdktf.stringToTerraform(struct!.proxyHeader),\n  }\n}\n\nexport class CertificateHttpChallengeOutputReference extends cdktf.ComplexObject {\n  private isEmptyObject = false;\n\n  /**\n  * @param terraformResource The parent resource\n  * @param terraformAttribute The attribute on the parent resource this class is referencing\n  */\n  public constructor(terraformResource: cdktf.IInterpolatingParent, terraformAttribute: string) {\n    super(terraformResource, terraformAttribute, false, 0);\n  }\n\n  public get internalValue(): CertificateHttpChallenge | undefined {\n    let hasAnyValues = this.isEmptyObject;\n    const internalValueResult: any = {};\n    if (this._port !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.port = this._port;\n    }\n    if (this._proxyHeader !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.proxyHeader = this._proxyHeader;\n    }\n    return hasAnyValues ? internalValueResult : undefined;\n  }\n\n  public set internalValue(value: CertificateHttpChallenge | undefined) {\n    if (value === undefined) {\n      this.isEmptyObject = false;\n      this._port = undefined;\n      this._proxyHeader = undefined;\n    }\n    else {\n      this.isEmptyObject = Object.keys(value).length === 0;\n      this._port = value.port;\n      this._proxyHeader = value.proxyHeader;\n    }\n  }\n\n  // port - computed: false, optional: true, required: false\n  private _port?: number; \n  public get port() {\n    return this.getNumberAttribute('port');\n  }\n  public set port(value: number) {\n    this._port = value;\n  }\n  public resetPort() {\n    this._port = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get portInput() {\n    return this._port;\n  }\n\n  // proxy_header - computed: false, optional: true, required: false\n  private _proxyHeader?: string; \n  public get proxyHeader() {\n    return this.getStringAttribute('proxy_header');\n  }\n  public set proxyHeader(value: string) {\n    this._proxyHeader = value;\n  }\n  public resetProxyHeader() {\n    this._proxyHeader = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get proxyHeaderInput() {\n    return this._proxyHeader;\n  }\n}\nexport interface CertificateHttpMemcachedChallenge {\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#hosts Certificate#hosts}\n  */\n  readonly hosts: string[];\n}\n\nexport function certificateHttpMemcachedChallengeToTerraform(struct?: CertificateHttpMemcachedChallengeOutputReference | CertificateHttpMemcachedChallenge): any {\n  if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) { return struct; }\n  if (cdktf.isComplexElement(struct)) {\n    throw new Error(\"A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration\");\n  }\n  return {\n    hosts: cdktf.listMapper(cdktf.stringToTerraform, false)(struct!.hosts),\n  }\n}\n\nexport class CertificateHttpMemcachedChallengeOutputReference extends cdktf.ComplexObject {\n  private isEmptyObject = false;\n\n  /**\n  * @param terraformResource The parent resource\n  * @param terraformAttribute The attribute on the parent resource this class is referencing\n  */\n  public constructor(terraformResource: cdktf.IInterpolatingParent, terraformAttribute: string) {\n    super(terraformResource, terraformAttribute, false, 0);\n  }\n\n  public get internalValue(): CertificateHttpMemcachedChallenge | undefined {\n    let hasAnyValues = this.isEmptyObject;\n    const internalValueResult: any = {};\n    if (this._hosts !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.hosts = this._hosts;\n    }\n    return hasAnyValues ? internalValueResult : undefined;\n  }\n\n  public set internalValue(value: CertificateHttpMemcachedChallenge | undefined) {\n    if (value === undefined) {\n      this.isEmptyObject = false;\n      this._hosts = undefined;\n    }\n    else {\n      this.isEmptyObject = Object.keys(value).length === 0;\n      this._hosts = value.hosts;\n    }\n  }\n\n  // hosts - computed: false, optional: false, required: true\n  private _hosts?: string[]; \n  public get hosts() {\n    return cdktf.Fn.tolist(this.getListAttribute('hosts'));\n  }\n  public set hosts(value: string[]) {\n    this._hosts = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get hostsInput() {\n    return this._hosts;\n  }\n}\nexport interface CertificateHttpWebrootChallenge {\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#directory Certificate#directory}\n  */\n  readonly directory: string;\n}\n\nexport function certificateHttpWebrootChallengeToTerraform(struct?: CertificateHttpWebrootChallengeOutputReference | CertificateHttpWebrootChallenge): any {\n  if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) { return struct; }\n  if (cdktf.isComplexElement(struct)) {\n    throw new Error(\"A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration\");\n  }\n  return {\n    directory: cdktf.stringToTerraform(struct!.directory),\n  }\n}\n\nexport class CertificateHttpWebrootChallengeOutputReference extends cdktf.ComplexObject {\n  private isEmptyObject = false;\n\n  /**\n  * @param terraformResource The parent resource\n  * @param terraformAttribute The attribute on the parent resource this class is referencing\n  */\n  public constructor(terraformResource: cdktf.IInterpolatingParent, terraformAttribute: string) {\n    super(terraformResource, terraformAttribute, false, 0);\n  }\n\n  public get internalValue(): CertificateHttpWebrootChallenge | undefined {\n    let hasAnyValues = this.isEmptyObject;\n    const internalValueResult: any = {};\n    if (this._directory !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.directory = this._directory;\n    }\n    return hasAnyValues ? internalValueResult : undefined;\n  }\n\n  public set internalValue(value: CertificateHttpWebrootChallenge | undefined) {\n    if (value === undefined) {\n      this.isEmptyObject = false;\n      this._directory = undefined;\n    }\n    else {\n      this.isEmptyObject = Object.keys(value).length === 0;\n      this._directory = value.directory;\n    }\n  }\n\n  // directory - computed: false, optional: false, required: true\n  private _directory?: string; \n  public get directory() {\n    return this.getStringAttribute('directory');\n  }\n  public set directory(value: string) {\n    this._directory = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get directoryInput() {\n    return this._directory;\n  }\n}\nexport interface CertificateTlsChallenge {\n  /**\n  * Docs at Terraform Registry: {@link https://www.terraform.io/docs/providers/acme/r/certificate#port Certificate#port}\n  */\n  readonly port?: number;\n}\n\nexport function certificateTlsChallengeToTerraform(struct?: CertificateTlsChallengeOutputReference | CertificateTlsChallenge): any {\n  if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) { return struct; }\n  if (cdktf.isComplexElement(struct)) {\n    throw new Error(\"A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration\");\n  }\n  return {\n    port: cdktf.numberToTerraform(struct!.port),\n  }\n}\n\nexport class CertificateTlsChallengeOutputReference extends cdktf.ComplexObject {\n  private isEmptyObject = false;\n\n  /**\n  * @param terraformResource The parent resource\n  * @param terraformAttribute The attribute on the parent resource this class is referencing\n  */\n  public constructor(terraformResource: cdktf.IInterpolatingParent, terraformAttribute: string) {\n    super(terraformResource, terraformAttribute, false, 0);\n  }\n\n  public get internalValue(): CertificateTlsChallenge | undefined {\n    let hasAnyValues = this.isEmptyObject;\n    const internalValueResult: any = {};\n    if (this._port !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.port = this._port;\n    }\n    return hasAnyValues ? internalValueResult : undefined;\n  }\n\n  public set internalValue(value: CertificateTlsChallenge | undefined) {\n    if (value === undefined) {\n      this.isEmptyObject = false;\n      this._port = undefined;\n    }\n    else {\n      this.isEmptyObject = Object.keys(value).length === 0;\n      this._port = value.port;\n    }\n  }\n\n  // port - computed: false, optional: true, required: false\n  private _port?: number; \n  public get port() {\n    return this.getNumberAttribute('port');\n  }\n  public set port(value: number) {\n    this._port = value;\n  }\n  public resetPort() {\n    this._port = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get portInput() {\n    return this._port;\n  }\n}\n\n/**\n* Represents a {@link https://www.terraform.io/docs/providers/acme/r/certificate acme_certificate}\n*/\nexport class Certificate extends cdktf.TerraformResource {\n\n  // =================\n  // STATIC PROPERTIES\n  // =================\n  public static readonly tfResourceType = \"acme_certificate\";\n\n  // ===========\n  // INITIALIZER\n  // ===========\n\n  /**\n  * Create a new {@link https://www.terraform.io/docs/providers/acme/r/certificate acme_certificate} Resource\n  *\n  * @param scope The scope in which to define this construct\n  * @param id The scoped construct ID. Must be unique amongst siblings in the same scope\n  * @param options CertificateConfig\n  */\n  public constructor(scope: Construct, id: string, config: CertificateConfig) {\n    super(scope, id, {\n      terraformResourceType: 'acme_certificate',\n      terraformGeneratorMetadata: {\n        providerName: 'acme',\n        providerVersion: '2.10.0',\n        providerVersionConstraint: '~> 2.10'\n      },\n      provider: config.provider,\n      dependsOn: config.dependsOn,\n      count: config.count,\n      lifecycle: config.lifecycle,\n      provisioners: config.provisioners,\n      connection: config.connection,\n      forEach: config.forEach\n    });\n    this._accountKeyPem = config.accountKeyPem;\n    this._certificateP12Password = config.certificateP12Password;\n    this._certificateRequestPem = config.certificateRequestPem;\n    this._commonName = config.commonName;\n    this._disableCompletePropagation = config.disableCompletePropagation;\n    this._id = config.id;\n    this._keyType = config.keyType;\n    this._minDaysRemaining = config.minDaysRemaining;\n    this._mustStaple = config.mustStaple;\n    this._preCheckDelay = config.preCheckDelay;\n    this._preferredChain = config.preferredChain;\n    this._recursiveNameservers = config.recursiveNameservers;\n    this._revokeCertificateOnDestroy = config.revokeCertificateOnDestroy;\n    this._subjectAlternativeNames = config.subjectAlternativeNames;\n    this._dnsChallenge.internalValue = config.dnsChallenge;\n    this._httpChallenge.internalValue = config.httpChallenge;\n    this._httpMemcachedChallenge.internalValue = config.httpMemcachedChallenge;\n    this._httpWebrootChallenge.internalValue = config.httpWebrootChallenge;\n    this._tlsChallenge.internalValue = config.tlsChallenge;\n  }\n\n  // ==========\n  // ATTRIBUTES\n  // ==========\n\n  // account_key_pem - computed: false, optional: false, required: true\n  private _accountKeyPem?: string; \n  public get accountKeyPem() {\n    return this.getStringAttribute('account_key_pem');\n  }\n  public set accountKeyPem(value: string) {\n    this._accountKeyPem = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get accountKeyPemInput() {\n    return this._accountKeyPem;\n  }\n\n  // certificate_domain - computed: true, optional: false, required: false\n  public get certificateDomain() {\n    return this.getStringAttribute('certificate_domain');\n  }\n\n  // certificate_p12 - computed: true, optional: false, required: false\n  public get certificateP12() {\n    return this.getStringAttribute('certificate_p12');\n  }\n\n  // certificate_p12_password - computed: false, optional: true, required: false\n  private _certificateP12Password?: string; \n  public get certificateP12Password() {\n    return this.getStringAttribute('certificate_p12_password');\n  }\n  public set certificateP12Password(value: string) {\n    this._certificateP12Password = value;\n  }\n  public resetCertificateP12Password() {\n    this._certificateP12Password = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get certificateP12PasswordInput() {\n    return this._certificateP12Password;\n  }\n\n  // certificate_pem - computed: true, optional: false, required: false\n  public get certificatePem() {\n    return this.getStringAttribute('certificate_pem');\n  }\n\n  // certificate_request_pem - computed: false, optional: true, required: false\n  private _certificateRequestPem?: string; \n  public get certificateRequestPem() {\n    return this.getStringAttribute('certificate_request_pem');\n  }\n  public set certificateRequestPem(value: string) {\n    this._certificateRequestPem = value;\n  }\n  public resetCertificateRequestPem() {\n    this._certificateRequestPem = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get certificateRequestPemInput() {\n    return this._certificateRequestPem;\n  }\n\n  // certificate_url - computed: true, optional: false, required: false\n  public get certificateUrl() {\n    return this.getStringAttribute('certificate_url');\n  }\n\n  // common_name - computed: false, optional: true, required: false\n  private _commonName?: string; \n  public get commonName() {\n    return this.getStringAttribute('common_name');\n  }\n  public set commonName(value: string) {\n    this._commonName = value;\n  }\n  public resetCommonName() {\n    this._commonName = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get commonNameInput() {\n    return this._commonName;\n  }\n\n  // disable_complete_propagation - computed: false, optional: true, required: false\n  private _disableCompletePropagation?: boolean | cdktf.IResolvable; \n  public get disableCompletePropagation() {\n    return this.getBooleanAttribute('disable_complete_propagation');\n  }\n  public set disableCompletePropagation(value: boolean | cdktf.IResolvable) {\n    this._disableCompletePropagation = value;\n  }\n  public resetDisableCompletePropagation() {\n    this._disableCompletePropagation = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get disableCompletePropagationInput() {\n    return this._disableCompletePropagation;\n  }\n\n  // id - computed: true, optional: true, required: false\n  private _id?: string; \n  public get id() {\n    return this.getStringAttribute('id');\n  }\n  public set id(value: string) {\n    this._id = value;\n  }\n  public resetId() {\n    this._id = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get idInput() {\n    return this._id;\n  }\n\n  // issuer_pem - computed: true, optional: false, required: false\n  public get issuerPem() {\n    return this.getStringAttribute('issuer_pem');\n  }\n\n  // key_type - computed: false, optional: true, required: false\n  private _keyType?: string; \n  public get keyType() {\n    return this.getStringAttribute('key_type');\n  }\n  public set keyType(value: string) {\n    this._keyType = value;\n  }\n  public resetKeyType() {\n    this._keyType = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get keyTypeInput() {\n    return this._keyType;\n  }\n\n  // min_days_remaining - computed: false, optional: true, required: false\n  private _minDaysRemaining?: number; \n  public get minDaysRemaining() {\n    return this.getNumberAttribute('min_days_remaining');\n  }\n  public set minDaysRemaining(value: number) {\n    this._minDaysRemaining = value;\n  }\n  public resetMinDaysRemaining() {\n    this._minDaysRemaining = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get minDaysRemainingInput() {\n    return this._minDaysRemaining;\n  }\n\n  // must_staple - computed: false, optional: true, required: false\n  private _mustStaple?: boolean | cdktf.IResolvable; \n  public get mustStaple() {\n    return this.getBooleanAttribute('must_staple');\n  }\n  public set mustStaple(value: boolean | cdktf.IResolvable) {\n    this._mustStaple = value;\n  }\n  public resetMustStaple() {\n    this._mustStaple = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get mustStapleInput() {\n    return this._mustStaple;\n  }\n\n  // pre_check_delay - computed: false, optional: true, required: false\n  private _preCheckDelay?: number; \n  public get preCheckDelay() {\n    return this.getNumberAttribute('pre_check_delay');\n  }\n  public set preCheckDelay(value: number) {\n    this._preCheckDelay = value;\n  }\n  public resetPreCheckDelay() {\n    this._preCheckDelay = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get preCheckDelayInput() {\n    return this._preCheckDelay;\n  }\n\n  // preferred_chain - computed: false, optional: true, required: false\n  private _preferredChain?: string; \n  public get preferredChain() {\n    return this.getStringAttribute('preferred_chain');\n  }\n  public set preferredChain(value: string) {\n    this._preferredChain = value;\n  }\n  public resetPreferredChain() {\n    this._preferredChain = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get preferredChainInput() {\n    return this._preferredChain;\n  }\n\n  // private_key_pem - computed: true, optional: false, required: false\n  public get privateKeyPem() {\n    return this.getStringAttribute('private_key_pem');\n  }\n\n  // recursive_nameservers - computed: false, optional: true, required: false\n  private _recursiveNameservers?: string[]; \n  public get recursiveNameservers() {\n    return this.getListAttribute('recursive_nameservers');\n  }\n  public set recursiveNameservers(value: string[]) {\n    this._recursiveNameservers = value;\n  }\n  public resetRecursiveNameservers() {\n    this._recursiveNameservers = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get recursiveNameserversInput() {\n    return this._recursiveNameservers;\n  }\n\n  // revoke_certificate_on_destroy - computed: false, optional: true, required: false\n  private _revokeCertificateOnDestroy?: boolean | cdktf.IResolvable; \n  public get revokeCertificateOnDestroy() {\n    return this.getBooleanAttribute('revoke_certificate_on_destroy');\n  }\n  public set revokeCertificateOnDestroy(value: boolean | cdktf.IResolvable) {\n    this._revokeCertificateOnDestroy = value;\n  }\n  public resetRevokeCertificateOnDestroy() {\n    this._revokeCertificateOnDestroy = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get revokeCertificateOnDestroyInput() {\n    return this._revokeCertificateOnDestroy;\n  }\n\n  // subject_alternative_names - computed: false, optional: true, required: false\n  private _subjectAlternativeNames?: string[]; \n  public get subjectAlternativeNames() {\n    return cdktf.Fn.tolist(this.getListAttribute('subject_alternative_names'));\n  }\n  public set subjectAlternativeNames(value: string[]) {\n    this._subjectAlternativeNames = value;\n  }\n  public resetSubjectAlternativeNames() {\n    this._subjectAlternativeNames = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get subjectAlternativeNamesInput() {\n    return this._subjectAlternativeNames;\n  }\n\n  // dns_challenge - computed: false, optional: true, required: false\n  private _dnsChallenge = new CertificateDnsChallengeList(this, \"dns_challenge\", false);\n  public get dnsChallenge() {\n    return this._dnsChallenge;\n  }\n  public putDnsChallenge(value: CertificateDnsChallenge[] | cdktf.IResolvable) {\n    this._dnsChallenge.internalValue = value;\n  }\n  public resetDnsChallenge() {\n    this._dnsChallenge.internalValue = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get dnsChallengeInput() {\n    return this._dnsChallenge.internalValue;\n  }\n\n  // http_challenge - computed: false, optional: true, required: false\n  private _httpChallenge = new CertificateHttpChallengeOutputReference(this, \"http_challenge\");\n  public get httpChallenge() {\n    return this._httpChallenge;\n  }\n  public putHttpChallenge(value: CertificateHttpChallenge) {\n    this._httpChallenge.internalValue = value;\n  }\n  public resetHttpChallenge() {\n    this._httpChallenge.internalValue = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get httpChallengeInput() {\n    return this._httpChallenge.internalValue;\n  }\n\n  // http_memcached_challenge - computed: false, optional: true, required: false\n  private _httpMemcachedChallenge = new CertificateHttpMemcachedChallengeOutputReference(this, \"http_memcached_challenge\");\n  public get httpMemcachedChallenge() {\n    return this._httpMemcachedChallenge;\n  }\n  public putHttpMemcachedChallenge(value: CertificateHttpMemcachedChallenge) {\n    this._httpMemcachedChallenge.internalValue = value;\n  }\n  public resetHttpMemcachedChallenge() {\n    this._httpMemcachedChallenge.internalValue = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get httpMemcachedChallengeInput() {\n    return this._httpMemcachedChallenge.internalValue;\n  }\n\n  // http_webroot_challenge - computed: false, optional: true, required: false\n  private _httpWebrootChallenge = new CertificateHttpWebrootChallengeOutputReference(this, \"http_webroot_challenge\");\n  public get httpWebrootChallenge() {\n    return this._httpWebrootChallenge;\n  }\n  public putHttpWebrootChallenge(value: CertificateHttpWebrootChallenge) {\n    this._httpWebrootChallenge.internalValue = value;\n  }\n  public resetHttpWebrootChallenge() {\n    this._httpWebrootChallenge.internalValue = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get httpWebrootChallengeInput() {\n    return this._httpWebrootChallenge.internalValue;\n  }\n\n  // tls_challenge - computed: false, optional: true, required: false\n  private _tlsChallenge = new CertificateTlsChallengeOutputReference(this, \"tls_challenge\");\n  public get tlsChallenge() {\n    return this._tlsChallenge;\n  }\n  public putTlsChallenge(value: CertificateTlsChallenge) {\n    this._tlsChallenge.internalValue = value;\n  }\n  public resetTlsChallenge() {\n    this._tlsChallenge.internalValue = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get tlsChallengeInput() {\n    return this._tlsChallenge.internalValue;\n  }\n\n  // =========\n  // SYNTHESIS\n  // =========\n\n  protected synthesizeAttributes(): { [name: string]: any } {\n    return {\n      account_key_pem: cdktf.stringToTerraform(this._accountKeyPem),\n      certificate_p12_password: cdktf.stringToTerraform(this._certificateP12Password),\n      certificate_request_pem: cdktf.stringToTerraform(this._certificateRequestPem),\n      common_name: cdktf.stringToTerraform(this._commonName),\n      disable_complete_propagation: cdktf.booleanToTerraform(this._disableCompletePropagation),\n      id: cdktf.stringToTerraform(this._id),\n      key_type: cdktf.stringToTerraform(this._keyType),\n      min_days_remaining: cdktf.numberToTerraform(this._minDaysRemaining),\n      must_staple: cdktf.booleanToTerraform(this._mustStaple),\n      pre_check_delay: cdktf.numberToTerraform(this._preCheckDelay),\n      preferred_chain: cdktf.stringToTerraform(this._preferredChain),\n      recursive_nameservers: cdktf.listMapper(cdktf.stringToTerraform, false)(this._recursiveNameservers),\n      revoke_certificate_on_destroy: cdktf.booleanToTerraform(this._revokeCertificateOnDestroy),\n      subject_alternative_names: cdktf.listMapper(cdktf.stringToTerraform, false)(this._subjectAlternativeNames),\n      dns_challenge: cdktf.listMapper(certificateDnsChallengeToTerraform, true)(this._dnsChallenge.internalValue),\n      http_challenge: certificateHttpChallengeToTerraform(this._httpChallenge.internalValue),\n      http_memcached_challenge: certificateHttpMemcachedChallengeToTerraform(this._httpMemcachedChallenge.internalValue),\n      http_webroot_challenge: certificateHttpWebrootChallengeToTerraform(this._httpWebrootChallenge.internalValue),\n      tls_challenge: certificateTlsChallengeToTerraform(this._tlsChallenge.internalValue),\n    };\n  }\n}\n"]}