@cdktf/provider-acme 0.0.0

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,947 @@
1
+ "use strict";
2
+ var _a, _b, _c, _d, _e;
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.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)) {
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.anyToTerraform)(struct.config),
16
+ provider: cdktf.stringToTerraform(struct.provider),
17
+ };
18
+ }
19
+ exports.certificateDnsChallengeToTerraform = certificateDnsChallengeToTerraform;
20
+ function certificateHttpChallengeToTerraform(struct) {
21
+ if (!cdktf.canInspect(struct)) {
22
+ return struct;
23
+ }
24
+ if (cdktf.isComplexElement(struct)) {
25
+ throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
26
+ }
27
+ return {
28
+ port: cdktf.numberToTerraform(struct.port),
29
+ proxy_header: cdktf.stringToTerraform(struct.proxyHeader),
30
+ };
31
+ }
32
+ exports.certificateHttpChallengeToTerraform = certificateHttpChallengeToTerraform;
33
+ /**
34
+ * @stability stable
35
+ */
36
+ class CertificateHttpChallengeOutputReference extends cdktf.ComplexObject {
37
+ /**
38
+ * @param terraformResource The parent resource.
39
+ * @param terraformAttribute The attribute on the parent resource this class is referencing.
40
+ * @param isSingleItem True if this is a block, false if it's a list.
41
+ * @stability stable
42
+ */
43
+ constructor(terraformResource, terraformAttribute, isSingleItem) {
44
+ super(terraformResource, terraformAttribute, isSingleItem);
45
+ this.isEmptyObject = false;
46
+ }
47
+ /**
48
+ * @stability stable
49
+ */
50
+ get internalValue() {
51
+ let hasAnyValues = this.isEmptyObject;
52
+ const internalValueResult = {};
53
+ if (this._port !== undefined) {
54
+ hasAnyValues = true;
55
+ internalValueResult.port = this._port;
56
+ }
57
+ if (this._proxyHeader !== undefined) {
58
+ hasAnyValues = true;
59
+ internalValueResult.proxyHeader = this._proxyHeader;
60
+ }
61
+ return hasAnyValues ? internalValueResult : undefined;
62
+ }
63
+ /**
64
+ * @stability stable
65
+ */
66
+ set internalValue(value) {
67
+ if (value === undefined) {
68
+ this.isEmptyObject = false;
69
+ this._port = undefined;
70
+ this._proxyHeader = undefined;
71
+ }
72
+ else {
73
+ this.isEmptyObject = Object.keys(value).length === 0;
74
+ this._port = value.port;
75
+ this._proxyHeader = value.proxyHeader;
76
+ }
77
+ }
78
+ /**
79
+ * @stability stable
80
+ */
81
+ get port() {
82
+ return this.getNumberAttribute('port');
83
+ }
84
+ /**
85
+ * @stability stable
86
+ */
87
+ set port(value) {
88
+ this._port = value;
89
+ }
90
+ /**
91
+ * @stability stable
92
+ */
93
+ resetPort() {
94
+ this._port = undefined;
95
+ }
96
+ // Temporarily expose input value. Use with caution.
97
+ /**
98
+ * @stability stable
99
+ */
100
+ get portInput() {
101
+ return this._port;
102
+ }
103
+ /**
104
+ * @stability stable
105
+ */
106
+ get proxyHeader() {
107
+ return this.getStringAttribute('proxy_header');
108
+ }
109
+ /**
110
+ * @stability stable
111
+ */
112
+ set proxyHeader(value) {
113
+ this._proxyHeader = value;
114
+ }
115
+ /**
116
+ * @stability stable
117
+ */
118
+ resetProxyHeader() {
119
+ this._proxyHeader = undefined;
120
+ }
121
+ // Temporarily expose input value. Use with caution.
122
+ /**
123
+ * @stability stable
124
+ */
125
+ get proxyHeaderInput() {
126
+ return this._proxyHeader;
127
+ }
128
+ }
129
+ exports.CertificateHttpChallengeOutputReference = CertificateHttpChallengeOutputReference;
130
+ _a = JSII_RTTI_SYMBOL_1;
131
+ CertificateHttpChallengeOutputReference[_a] = { fqn: "@cdktf/provider-acme.CertificateHttpChallengeOutputReference", version: "0.0.0" };
132
+ function certificateHttpMemcachedChallengeToTerraform(struct) {
133
+ if (!cdktf.canInspect(struct)) {
134
+ return struct;
135
+ }
136
+ if (cdktf.isComplexElement(struct)) {
137
+ throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
138
+ }
139
+ return {
140
+ hosts: cdktf.listMapper(cdktf.stringToTerraform)(struct.hosts),
141
+ };
142
+ }
143
+ exports.certificateHttpMemcachedChallengeToTerraform = certificateHttpMemcachedChallengeToTerraform;
144
+ /**
145
+ * @stability stable
146
+ */
147
+ class CertificateHttpMemcachedChallengeOutputReference extends cdktf.ComplexObject {
148
+ /**
149
+ * @param terraformResource The parent resource.
150
+ * @param terraformAttribute The attribute on the parent resource this class is referencing.
151
+ * @param isSingleItem True if this is a block, false if it's a list.
152
+ * @stability stable
153
+ */
154
+ constructor(terraformResource, terraformAttribute, isSingleItem) {
155
+ super(terraformResource, terraformAttribute, isSingleItem);
156
+ this.isEmptyObject = false;
157
+ }
158
+ /**
159
+ * @stability stable
160
+ */
161
+ get internalValue() {
162
+ let hasAnyValues = this.isEmptyObject;
163
+ const internalValueResult = {};
164
+ if (this._hosts !== undefined) {
165
+ hasAnyValues = true;
166
+ internalValueResult.hosts = this._hosts;
167
+ }
168
+ return hasAnyValues ? internalValueResult : undefined;
169
+ }
170
+ /**
171
+ * @stability stable
172
+ */
173
+ set internalValue(value) {
174
+ if (value === undefined) {
175
+ this.isEmptyObject = false;
176
+ this._hosts = undefined;
177
+ }
178
+ else {
179
+ this.isEmptyObject = Object.keys(value).length === 0;
180
+ this._hosts = value.hosts;
181
+ }
182
+ }
183
+ /**
184
+ * @stability stable
185
+ */
186
+ get hosts() {
187
+ return this.getListAttribute('hosts');
188
+ }
189
+ /**
190
+ * @stability stable
191
+ */
192
+ set hosts(value) {
193
+ this._hosts = value;
194
+ }
195
+ // Temporarily expose input value. Use with caution.
196
+ /**
197
+ * @stability stable
198
+ */
199
+ get hostsInput() {
200
+ return this._hosts;
201
+ }
202
+ }
203
+ exports.CertificateHttpMemcachedChallengeOutputReference = CertificateHttpMemcachedChallengeOutputReference;
204
+ _b = JSII_RTTI_SYMBOL_1;
205
+ CertificateHttpMemcachedChallengeOutputReference[_b] = { fqn: "@cdktf/provider-acme.CertificateHttpMemcachedChallengeOutputReference", version: "0.0.0" };
206
+ function certificateHttpWebrootChallengeToTerraform(struct) {
207
+ if (!cdktf.canInspect(struct)) {
208
+ return struct;
209
+ }
210
+ if (cdktf.isComplexElement(struct)) {
211
+ throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
212
+ }
213
+ return {
214
+ directory: cdktf.stringToTerraform(struct.directory),
215
+ };
216
+ }
217
+ exports.certificateHttpWebrootChallengeToTerraform = certificateHttpWebrootChallengeToTerraform;
218
+ /**
219
+ * @stability stable
220
+ */
221
+ class CertificateHttpWebrootChallengeOutputReference extends cdktf.ComplexObject {
222
+ /**
223
+ * @param terraformResource The parent resource.
224
+ * @param terraformAttribute The attribute on the parent resource this class is referencing.
225
+ * @param isSingleItem True if this is a block, false if it's a list.
226
+ * @stability stable
227
+ */
228
+ constructor(terraformResource, terraformAttribute, isSingleItem) {
229
+ super(terraformResource, terraformAttribute, isSingleItem);
230
+ this.isEmptyObject = false;
231
+ }
232
+ /**
233
+ * @stability stable
234
+ */
235
+ get internalValue() {
236
+ let hasAnyValues = this.isEmptyObject;
237
+ const internalValueResult = {};
238
+ if (this._directory !== undefined) {
239
+ hasAnyValues = true;
240
+ internalValueResult.directory = this._directory;
241
+ }
242
+ return hasAnyValues ? internalValueResult : undefined;
243
+ }
244
+ /**
245
+ * @stability stable
246
+ */
247
+ set internalValue(value) {
248
+ if (value === undefined) {
249
+ this.isEmptyObject = false;
250
+ this._directory = undefined;
251
+ }
252
+ else {
253
+ this.isEmptyObject = Object.keys(value).length === 0;
254
+ this._directory = value.directory;
255
+ }
256
+ }
257
+ /**
258
+ * @stability stable
259
+ */
260
+ get directory() {
261
+ return this.getStringAttribute('directory');
262
+ }
263
+ /**
264
+ * @stability stable
265
+ */
266
+ set directory(value) {
267
+ this._directory = value;
268
+ }
269
+ // Temporarily expose input value. Use with caution.
270
+ /**
271
+ * @stability stable
272
+ */
273
+ get directoryInput() {
274
+ return this._directory;
275
+ }
276
+ }
277
+ exports.CertificateHttpWebrootChallengeOutputReference = CertificateHttpWebrootChallengeOutputReference;
278
+ _c = JSII_RTTI_SYMBOL_1;
279
+ CertificateHttpWebrootChallengeOutputReference[_c] = { fqn: "@cdktf/provider-acme.CertificateHttpWebrootChallengeOutputReference", version: "0.0.0" };
280
+ function certificateTlsChallengeToTerraform(struct) {
281
+ if (!cdktf.canInspect(struct)) {
282
+ return struct;
283
+ }
284
+ if (cdktf.isComplexElement(struct)) {
285
+ throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
286
+ }
287
+ return {
288
+ port: cdktf.numberToTerraform(struct.port),
289
+ };
290
+ }
291
+ exports.certificateTlsChallengeToTerraform = certificateTlsChallengeToTerraform;
292
+ /**
293
+ * @stability stable
294
+ */
295
+ class CertificateTlsChallengeOutputReference extends cdktf.ComplexObject {
296
+ /**
297
+ * @param terraformResource The parent resource.
298
+ * @param terraformAttribute The attribute on the parent resource this class is referencing.
299
+ * @param isSingleItem True if this is a block, false if it's a list.
300
+ * @stability stable
301
+ */
302
+ constructor(terraformResource, terraformAttribute, isSingleItem) {
303
+ super(terraformResource, terraformAttribute, isSingleItem);
304
+ this.isEmptyObject = false;
305
+ }
306
+ /**
307
+ * @stability stable
308
+ */
309
+ get internalValue() {
310
+ let hasAnyValues = this.isEmptyObject;
311
+ const internalValueResult = {};
312
+ if (this._port !== undefined) {
313
+ hasAnyValues = true;
314
+ internalValueResult.port = this._port;
315
+ }
316
+ return hasAnyValues ? internalValueResult : undefined;
317
+ }
318
+ /**
319
+ * @stability stable
320
+ */
321
+ set internalValue(value) {
322
+ if (value === undefined) {
323
+ this.isEmptyObject = false;
324
+ this._port = undefined;
325
+ }
326
+ else {
327
+ this.isEmptyObject = Object.keys(value).length === 0;
328
+ this._port = value.port;
329
+ }
330
+ }
331
+ /**
332
+ * @stability stable
333
+ */
334
+ get port() {
335
+ return this.getNumberAttribute('port');
336
+ }
337
+ /**
338
+ * @stability stable
339
+ */
340
+ set port(value) {
341
+ this._port = value;
342
+ }
343
+ /**
344
+ * @stability stable
345
+ */
346
+ resetPort() {
347
+ this._port = undefined;
348
+ }
349
+ // Temporarily expose input value. Use with caution.
350
+ /**
351
+ * @stability stable
352
+ */
353
+ get portInput() {
354
+ return this._port;
355
+ }
356
+ }
357
+ exports.CertificateTlsChallengeOutputReference = CertificateTlsChallengeOutputReference;
358
+ _d = JSII_RTTI_SYMBOL_1;
359
+ CertificateTlsChallengeOutputReference[_d] = { fqn: "@cdktf/provider-acme.CertificateTlsChallengeOutputReference", version: "0.0.0" };
360
+ /**
361
+ * Represents a {@link https://www.terraform.io/docs/providers/acme/r/certificate.html acme_certificate}.
362
+ *
363
+ * @stability stable
364
+ */
365
+ class Certificate extends cdktf.TerraformResource {
366
+ // ===========
367
+ // INITIALIZER
368
+ // ===========
369
+ /**
370
+ * Create a new {@link https://www.terraform.io/docs/providers/acme/r/certificate.html acme_certificate} Resource.
371
+ *
372
+ * @param scope The scope in which to define this construct.
373
+ * @param id The scoped construct ID.
374
+ * @stability stable
375
+ */
376
+ constructor(scope, id, config) {
377
+ super(scope, id, {
378
+ terraformResourceType: 'acme_certificate',
379
+ terraformGeneratorMetadata: {
380
+ providerName: 'acme'
381
+ },
382
+ provider: config.provider,
383
+ dependsOn: config.dependsOn,
384
+ count: config.count,
385
+ lifecycle: config.lifecycle
386
+ });
387
+ // http_challenge - computed: false, optional: true, required: false
388
+ this._httpChallenge = new CertificateHttpChallengeOutputReference(this, "http_challenge", true);
389
+ // http_memcached_challenge - computed: false, optional: true, required: false
390
+ this._httpMemcachedChallenge = new CertificateHttpMemcachedChallengeOutputReference(this, "http_memcached_challenge", true);
391
+ // http_webroot_challenge - computed: false, optional: true, required: false
392
+ this._httpWebrootChallenge = new CertificateHttpWebrootChallengeOutputReference(this, "http_webroot_challenge", true);
393
+ // tls_challenge - computed: false, optional: true, required: false
394
+ this._tlsChallenge = new CertificateTlsChallengeOutputReference(this, "tls_challenge", true);
395
+ this._accountKeyPem = config.accountKeyPem;
396
+ this._certificateP12Password = config.certificateP12Password;
397
+ this._certificateRequestPem = config.certificateRequestPem;
398
+ this._commonName = config.commonName;
399
+ this._disableCompletePropagation = config.disableCompletePropagation;
400
+ this._keyType = config.keyType;
401
+ this._minDaysRemaining = config.minDaysRemaining;
402
+ this._mustStaple = config.mustStaple;
403
+ this._preCheckDelay = config.preCheckDelay;
404
+ this._preferredChain = config.preferredChain;
405
+ this._recursiveNameservers = config.recursiveNameservers;
406
+ this._revokeCertificateOnDestroy = config.revokeCertificateOnDestroy;
407
+ this._subjectAlternativeNames = config.subjectAlternativeNames;
408
+ this._dnsChallenge = config.dnsChallenge;
409
+ this._httpChallenge.internalValue = config.httpChallenge;
410
+ this._httpMemcachedChallenge.internalValue = config.httpMemcachedChallenge;
411
+ this._httpWebrootChallenge.internalValue = config.httpWebrootChallenge;
412
+ this._tlsChallenge.internalValue = config.tlsChallenge;
413
+ }
414
+ /**
415
+ * @stability stable
416
+ */
417
+ get accountKeyPem() {
418
+ return this.getStringAttribute('account_key_pem');
419
+ }
420
+ /**
421
+ * @stability stable
422
+ */
423
+ set accountKeyPem(value) {
424
+ this._accountKeyPem = value;
425
+ }
426
+ // Temporarily expose input value. Use with caution.
427
+ /**
428
+ * @stability stable
429
+ */
430
+ get accountKeyPemInput() {
431
+ return this._accountKeyPem;
432
+ }
433
+ // certificate_domain - computed: true, optional: false, required: false
434
+ /**
435
+ * @stability stable
436
+ */
437
+ get certificateDomain() {
438
+ return this.getStringAttribute('certificate_domain');
439
+ }
440
+ // certificate_p12 - computed: true, optional: false, required: false
441
+ /**
442
+ * @stability stable
443
+ */
444
+ get certificateP12() {
445
+ return this.getStringAttribute('certificate_p12');
446
+ }
447
+ /**
448
+ * @stability stable
449
+ */
450
+ get certificateP12Password() {
451
+ return this.getStringAttribute('certificate_p12_password');
452
+ }
453
+ /**
454
+ * @stability stable
455
+ */
456
+ set certificateP12Password(value) {
457
+ this._certificateP12Password = value;
458
+ }
459
+ /**
460
+ * @stability stable
461
+ */
462
+ resetCertificateP12Password() {
463
+ this._certificateP12Password = undefined;
464
+ }
465
+ // Temporarily expose input value. Use with caution.
466
+ /**
467
+ * @stability stable
468
+ */
469
+ get certificateP12PasswordInput() {
470
+ return this._certificateP12Password;
471
+ }
472
+ // certificate_pem - computed: true, optional: false, required: false
473
+ /**
474
+ * @stability stable
475
+ */
476
+ get certificatePem() {
477
+ return this.getStringAttribute('certificate_pem');
478
+ }
479
+ /**
480
+ * @stability stable
481
+ */
482
+ get certificateRequestPem() {
483
+ return this.getStringAttribute('certificate_request_pem');
484
+ }
485
+ /**
486
+ * @stability stable
487
+ */
488
+ set certificateRequestPem(value) {
489
+ this._certificateRequestPem = value;
490
+ }
491
+ /**
492
+ * @stability stable
493
+ */
494
+ resetCertificateRequestPem() {
495
+ this._certificateRequestPem = undefined;
496
+ }
497
+ // Temporarily expose input value. Use with caution.
498
+ /**
499
+ * @stability stable
500
+ */
501
+ get certificateRequestPemInput() {
502
+ return this._certificateRequestPem;
503
+ }
504
+ // certificate_url - computed: true, optional: false, required: false
505
+ /**
506
+ * @stability stable
507
+ */
508
+ get certificateUrl() {
509
+ return this.getStringAttribute('certificate_url');
510
+ }
511
+ /**
512
+ * @stability stable
513
+ */
514
+ get commonName() {
515
+ return this.getStringAttribute('common_name');
516
+ }
517
+ /**
518
+ * @stability stable
519
+ */
520
+ set commonName(value) {
521
+ this._commonName = value;
522
+ }
523
+ /**
524
+ * @stability stable
525
+ */
526
+ resetCommonName() {
527
+ this._commonName = undefined;
528
+ }
529
+ // Temporarily expose input value. Use with caution.
530
+ /**
531
+ * @stability stable
532
+ */
533
+ get commonNameInput() {
534
+ return this._commonName;
535
+ }
536
+ /**
537
+ * @stability stable
538
+ */
539
+ get disableCompletePropagation() {
540
+ return this.getBooleanAttribute('disable_complete_propagation');
541
+ }
542
+ /**
543
+ * @stability stable
544
+ */
545
+ set disableCompletePropagation(value) {
546
+ this._disableCompletePropagation = value;
547
+ }
548
+ /**
549
+ * @stability stable
550
+ */
551
+ resetDisableCompletePropagation() {
552
+ this._disableCompletePropagation = undefined;
553
+ }
554
+ // Temporarily expose input value. Use with caution.
555
+ /**
556
+ * @stability stable
557
+ */
558
+ get disableCompletePropagationInput() {
559
+ return this._disableCompletePropagation;
560
+ }
561
+ // id - computed: true, optional: true, required: false
562
+ /**
563
+ * @stability stable
564
+ */
565
+ get id() {
566
+ return this.getStringAttribute('id');
567
+ }
568
+ // issuer_pem - computed: true, optional: false, required: false
569
+ /**
570
+ * @stability stable
571
+ */
572
+ get issuerPem() {
573
+ return this.getStringAttribute('issuer_pem');
574
+ }
575
+ /**
576
+ * @stability stable
577
+ */
578
+ get keyType() {
579
+ return this.getStringAttribute('key_type');
580
+ }
581
+ /**
582
+ * @stability stable
583
+ */
584
+ set keyType(value) {
585
+ this._keyType = value;
586
+ }
587
+ /**
588
+ * @stability stable
589
+ */
590
+ resetKeyType() {
591
+ this._keyType = undefined;
592
+ }
593
+ // Temporarily expose input value. Use with caution.
594
+ /**
595
+ * @stability stable
596
+ */
597
+ get keyTypeInput() {
598
+ return this._keyType;
599
+ }
600
+ /**
601
+ * @stability stable
602
+ */
603
+ get minDaysRemaining() {
604
+ return this.getNumberAttribute('min_days_remaining');
605
+ }
606
+ /**
607
+ * @stability stable
608
+ */
609
+ set minDaysRemaining(value) {
610
+ this._minDaysRemaining = value;
611
+ }
612
+ /**
613
+ * @stability stable
614
+ */
615
+ resetMinDaysRemaining() {
616
+ this._minDaysRemaining = undefined;
617
+ }
618
+ // Temporarily expose input value. Use with caution.
619
+ /**
620
+ * @stability stable
621
+ */
622
+ get minDaysRemainingInput() {
623
+ return this._minDaysRemaining;
624
+ }
625
+ /**
626
+ * @stability stable
627
+ */
628
+ get mustStaple() {
629
+ return this.getBooleanAttribute('must_staple');
630
+ }
631
+ /**
632
+ * @stability stable
633
+ */
634
+ set mustStaple(value) {
635
+ this._mustStaple = value;
636
+ }
637
+ /**
638
+ * @stability stable
639
+ */
640
+ resetMustStaple() {
641
+ this._mustStaple = undefined;
642
+ }
643
+ // Temporarily expose input value. Use with caution.
644
+ /**
645
+ * @stability stable
646
+ */
647
+ get mustStapleInput() {
648
+ return this._mustStaple;
649
+ }
650
+ /**
651
+ * @stability stable
652
+ */
653
+ get preCheckDelay() {
654
+ return this.getNumberAttribute('pre_check_delay');
655
+ }
656
+ /**
657
+ * @stability stable
658
+ */
659
+ set preCheckDelay(value) {
660
+ this._preCheckDelay = value;
661
+ }
662
+ /**
663
+ * @stability stable
664
+ */
665
+ resetPreCheckDelay() {
666
+ this._preCheckDelay = undefined;
667
+ }
668
+ // Temporarily expose input value. Use with caution.
669
+ /**
670
+ * @stability stable
671
+ */
672
+ get preCheckDelayInput() {
673
+ return this._preCheckDelay;
674
+ }
675
+ /**
676
+ * @stability stable
677
+ */
678
+ get preferredChain() {
679
+ return this.getStringAttribute('preferred_chain');
680
+ }
681
+ /**
682
+ * @stability stable
683
+ */
684
+ set preferredChain(value) {
685
+ this._preferredChain = value;
686
+ }
687
+ /**
688
+ * @stability stable
689
+ */
690
+ resetPreferredChain() {
691
+ this._preferredChain = undefined;
692
+ }
693
+ // Temporarily expose input value. Use with caution.
694
+ /**
695
+ * @stability stable
696
+ */
697
+ get preferredChainInput() {
698
+ return this._preferredChain;
699
+ }
700
+ // private_key_pem - computed: true, optional: false, required: false
701
+ /**
702
+ * @stability stable
703
+ */
704
+ get privateKeyPem() {
705
+ return this.getStringAttribute('private_key_pem');
706
+ }
707
+ /**
708
+ * @stability stable
709
+ */
710
+ get recursiveNameservers() {
711
+ return this.getListAttribute('recursive_nameservers');
712
+ }
713
+ /**
714
+ * @stability stable
715
+ */
716
+ set recursiveNameservers(value) {
717
+ this._recursiveNameservers = value;
718
+ }
719
+ /**
720
+ * @stability stable
721
+ */
722
+ resetRecursiveNameservers() {
723
+ this._recursiveNameservers = undefined;
724
+ }
725
+ // Temporarily expose input value. Use with caution.
726
+ /**
727
+ * @stability stable
728
+ */
729
+ get recursiveNameserversInput() {
730
+ return this._recursiveNameservers;
731
+ }
732
+ /**
733
+ * @stability stable
734
+ */
735
+ get revokeCertificateOnDestroy() {
736
+ return this.getBooleanAttribute('revoke_certificate_on_destroy');
737
+ }
738
+ /**
739
+ * @stability stable
740
+ */
741
+ set revokeCertificateOnDestroy(value) {
742
+ this._revokeCertificateOnDestroy = value;
743
+ }
744
+ /**
745
+ * @stability stable
746
+ */
747
+ resetRevokeCertificateOnDestroy() {
748
+ this._revokeCertificateOnDestroy = undefined;
749
+ }
750
+ // Temporarily expose input value. Use with caution.
751
+ /**
752
+ * @stability stable
753
+ */
754
+ get revokeCertificateOnDestroyInput() {
755
+ return this._revokeCertificateOnDestroy;
756
+ }
757
+ /**
758
+ * @stability stable
759
+ */
760
+ get subjectAlternativeNames() {
761
+ return this.getListAttribute('subject_alternative_names');
762
+ }
763
+ /**
764
+ * @stability stable
765
+ */
766
+ set subjectAlternativeNames(value) {
767
+ this._subjectAlternativeNames = value;
768
+ }
769
+ /**
770
+ * @stability stable
771
+ */
772
+ resetSubjectAlternativeNames() {
773
+ this._subjectAlternativeNames = undefined;
774
+ }
775
+ // Temporarily expose input value. Use with caution.
776
+ /**
777
+ * @stability stable
778
+ */
779
+ get subjectAlternativeNamesInput() {
780
+ return this._subjectAlternativeNames;
781
+ }
782
+ /**
783
+ * @stability stable
784
+ */
785
+ get dnsChallenge() {
786
+ // Getting the computed value is not yet implemented
787
+ return this.interpolationForAttribute('dns_challenge');
788
+ }
789
+ /**
790
+ * @stability stable
791
+ */
792
+ set dnsChallenge(value) {
793
+ this._dnsChallenge = value;
794
+ }
795
+ /**
796
+ * @stability stable
797
+ */
798
+ resetDnsChallenge() {
799
+ this._dnsChallenge = undefined;
800
+ }
801
+ // Temporarily expose input value. Use with caution.
802
+ /**
803
+ * @stability stable
804
+ */
805
+ get dnsChallengeInput() {
806
+ return this._dnsChallenge;
807
+ }
808
+ /**
809
+ * @stability stable
810
+ */
811
+ get httpChallenge() {
812
+ return this._httpChallenge;
813
+ }
814
+ /**
815
+ * @stability stable
816
+ */
817
+ putHttpChallenge(value) {
818
+ this._httpChallenge.internalValue = value;
819
+ }
820
+ /**
821
+ * @stability stable
822
+ */
823
+ resetHttpChallenge() {
824
+ this._httpChallenge.internalValue = undefined;
825
+ }
826
+ // Temporarily expose input value. Use with caution.
827
+ /**
828
+ * @stability stable
829
+ */
830
+ get httpChallengeInput() {
831
+ return this._httpChallenge.internalValue;
832
+ }
833
+ /**
834
+ * @stability stable
835
+ */
836
+ get httpMemcachedChallenge() {
837
+ return this._httpMemcachedChallenge;
838
+ }
839
+ /**
840
+ * @stability stable
841
+ */
842
+ putHttpMemcachedChallenge(value) {
843
+ this._httpMemcachedChallenge.internalValue = value;
844
+ }
845
+ /**
846
+ * @stability stable
847
+ */
848
+ resetHttpMemcachedChallenge() {
849
+ this._httpMemcachedChallenge.internalValue = undefined;
850
+ }
851
+ // Temporarily expose input value. Use with caution.
852
+ /**
853
+ * @stability stable
854
+ */
855
+ get httpMemcachedChallengeInput() {
856
+ return this._httpMemcachedChallenge.internalValue;
857
+ }
858
+ /**
859
+ * @stability stable
860
+ */
861
+ get httpWebrootChallenge() {
862
+ return this._httpWebrootChallenge;
863
+ }
864
+ /**
865
+ * @stability stable
866
+ */
867
+ putHttpWebrootChallenge(value) {
868
+ this._httpWebrootChallenge.internalValue = value;
869
+ }
870
+ /**
871
+ * @stability stable
872
+ */
873
+ resetHttpWebrootChallenge() {
874
+ this._httpWebrootChallenge.internalValue = undefined;
875
+ }
876
+ // Temporarily expose input value. Use with caution.
877
+ /**
878
+ * @stability stable
879
+ */
880
+ get httpWebrootChallengeInput() {
881
+ return this._httpWebrootChallenge.internalValue;
882
+ }
883
+ /**
884
+ * @stability stable
885
+ */
886
+ get tlsChallenge() {
887
+ return this._tlsChallenge;
888
+ }
889
+ /**
890
+ * @stability stable
891
+ */
892
+ putTlsChallenge(value) {
893
+ this._tlsChallenge.internalValue = value;
894
+ }
895
+ /**
896
+ * @stability stable
897
+ */
898
+ resetTlsChallenge() {
899
+ this._tlsChallenge.internalValue = undefined;
900
+ }
901
+ // Temporarily expose input value. Use with caution.
902
+ /**
903
+ * @stability stable
904
+ */
905
+ get tlsChallengeInput() {
906
+ return this._tlsChallenge.internalValue;
907
+ }
908
+ // =========
909
+ // SYNTHESIS
910
+ // =========
911
+ /**
912
+ * @stability stable
913
+ */
914
+ synthesizeAttributes() {
915
+ return {
916
+ account_key_pem: cdktf.stringToTerraform(this._accountKeyPem),
917
+ certificate_p12_password: cdktf.stringToTerraform(this._certificateP12Password),
918
+ certificate_request_pem: cdktf.stringToTerraform(this._certificateRequestPem),
919
+ common_name: cdktf.stringToTerraform(this._commonName),
920
+ disable_complete_propagation: cdktf.booleanToTerraform(this._disableCompletePropagation),
921
+ key_type: cdktf.stringToTerraform(this._keyType),
922
+ min_days_remaining: cdktf.numberToTerraform(this._minDaysRemaining),
923
+ must_staple: cdktf.booleanToTerraform(this._mustStaple),
924
+ pre_check_delay: cdktf.numberToTerraform(this._preCheckDelay),
925
+ preferred_chain: cdktf.stringToTerraform(this._preferredChain),
926
+ recursive_nameservers: cdktf.listMapper(cdktf.stringToTerraform)(this._recursiveNameservers),
927
+ revoke_certificate_on_destroy: cdktf.booleanToTerraform(this._revokeCertificateOnDestroy),
928
+ subject_alternative_names: cdktf.listMapper(cdktf.stringToTerraform)(this._subjectAlternativeNames),
929
+ dns_challenge: cdktf.listMapper(certificateDnsChallengeToTerraform)(this._dnsChallenge),
930
+ http_challenge: certificateHttpChallengeToTerraform(this._httpChallenge.internalValue),
931
+ http_memcached_challenge: certificateHttpMemcachedChallengeToTerraform(this._httpMemcachedChallenge.internalValue),
932
+ http_webroot_challenge: certificateHttpWebrootChallengeToTerraform(this._httpWebrootChallenge.internalValue),
933
+ tls_challenge: certificateTlsChallengeToTerraform(this._tlsChallenge.internalValue),
934
+ };
935
+ }
936
+ }
937
+ exports.Certificate = Certificate;
938
+ _e = JSII_RTTI_SYMBOL_1;
939
+ Certificate[_e] = { fqn: "@cdktf/provider-acme.Certificate", version: "0.0.0" };
940
+ // =================
941
+ // STATIC PROPERTIES
942
+ // =================
943
+ /**
944
+ * @stability stable
945
+ */
946
+ Certificate.tfResourceType = "acme_certificate";
947
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"certificate.js","sourceRoot":"","sources":["../src/certificate.ts"],"names":[],"mappings":"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","sourcesContent":["// https://www.terraform.io/docs/providers/acme/r/certificate.html\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  readonly accountKeyPem: string;\n                                                                                                                                                                                \n  readonly certificateP12Password?: string;\n                                                                                                                                                                              \n  readonly certificateRequestPem?: string;\n                                                                                                                                                      \n  readonly commonName?: string;\n                                                                                                                                                                                        \n  readonly disableCompletePropagation?: boolean | cdktf.IResolvable;\n                                                                                                                                                \n  readonly keyType?: string;\n                                                                                                                                                                    \n  readonly minDaysRemaining?: number;\n                                                                                                                                                      \n  readonly mustStaple?: boolean | cdktf.IResolvable;\n                                                                                                                                                              \n  readonly preCheckDelay?: number;\n                                                                                                                                                              \n  readonly preferredChain?: string;\n                                                                                                                                                                          \n  readonly recursiveNameservers?: string[];\n                                                                                                                                                                                          \n  readonly revokeCertificateOnDestroy?: boolean | cdktf.IResolvable;\n                                                                                                                                                                                  \n  readonly subjectAlternativeNames?: string[];\n                                                                                                                                                                                       \n  readonly dnsChallenge?: CertificateDnsChallenge[];\n                                                                                                                                                                                          \n  readonly httpChallenge?: CertificateHttpChallenge;\n                                                                                                                                                                                                                        \n  readonly httpMemcachedChallenge?: CertificateHttpMemcachedChallenge;\n                                                                                                                                                                                                                  \n  readonly httpWebrootChallenge?: CertificateHttpWebrootChallenge;\n                                                                                                                                                                                       \n  readonly tlsChallenge?: CertificateTlsChallenge;\n}\nexport interface CertificateDnsChallenge {\n                                                                                                                                            \n  readonly config?: { [key: string]: string } | cdktf.IResolvable;\n                                                                                                                                                \n  readonly provider: string;\n}\n\nexport function certificateDnsChallengeToTerraform(struct?: CertificateDnsChallenge): any {\n  if (!cdktf.canInspect(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.anyToTerraform)(struct!.config),\n    provider: cdktf.stringToTerraform(struct!.provider),\n  }\n}\n\nexport interface CertificateHttpChallenge {\n                                                                                                                                        \n  readonly port?: number;\n                                                                                                                                                        \n  readonly proxyHeader?: string;\n}\n\nexport function certificateHttpChallengeToTerraform(struct?: CertificateHttpChallengeOutputReference | CertificateHttpChallenge): any {\n  if (!cdktf.canInspect(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  public constructor(terraformResource: cdktf.ITerraformResource, terraformAttribute: string, isSingleItem: boolean) {\n    super(terraformResource, terraformAttribute, isSingleItem);\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  readonly hosts: string[];\n}\n\nexport function certificateHttpMemcachedChallengeToTerraform(struct?: CertificateHttpMemcachedChallengeOutputReference | CertificateHttpMemcachedChallenge): any {\n  if (!cdktf.canInspect(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)(struct!.hosts),\n  }\n}\n\nexport class CertificateHttpMemcachedChallengeOutputReference extends cdktf.ComplexObject {\n  private isEmptyObject = false;\n\n                                                                                                                                                                                                                              \n  public constructor(terraformResource: cdktf.ITerraformResource, terraformAttribute: string, isSingleItem: boolean) {\n    super(terraformResource, terraformAttribute, isSingleItem);\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 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  readonly directory: string;\n}\n\nexport function certificateHttpWebrootChallengeToTerraform(struct?: CertificateHttpWebrootChallengeOutputReference | CertificateHttpWebrootChallenge): any {\n  if (!cdktf.canInspect(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  public constructor(terraformResource: cdktf.ITerraformResource, terraformAttribute: string, isSingleItem: boolean) {\n    super(terraformResource, terraformAttribute, isSingleItem);\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  readonly port?: number;\n}\n\nexport function certificateTlsChallengeToTerraform(struct?: CertificateTlsChallengeOutputReference | CertificateTlsChallenge): any {\n  if (!cdktf.canInspect(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  public constructor(terraformResource: cdktf.ITerraformResource, terraformAttribute: string, isSingleItem: boolean) {\n    super(terraformResource, terraformAttribute, isSingleItem);\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                                                                                                              \nexport class Certificate extends cdktf.TerraformResource {\n\n  // =================\n  // STATIC PROPERTIES\n  // =================\n  public static readonly tfResourceType: string = \"acme_certificate\";\n\n  // ===========\n  // INITIALIZER\n  // ===========\n\n                                                                                                                                                                                                                                                                                                                            \n  public constructor(scope: Construct, id: string, config: CertificateConfig) {\n    super(scope, id, {\n      terraformResourceType: 'acme_certificate',\n      terraformGeneratorMetadata: {\n        providerName: 'acme'\n      },\n      provider: config.provider,\n      dependsOn: config.dependsOn,\n      count: config.count,\n      lifecycle: config.lifecycle\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._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 = 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') as any;\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  public get id() {\n    return this.getStringAttribute('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') as any;\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') as any;\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 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?: CertificateDnsChallenge[]; \n  public get dnsChallenge() {\n    // Getting the computed value is not yet implemented\n    return this.interpolationForAttribute('dns_challenge') as any;\n  }\n  public set dnsChallenge(value: CertificateDnsChallenge[]) {\n    this._dnsChallenge = value;\n  }\n  public resetDnsChallenge() {\n    this._dnsChallenge = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get dnsChallengeInput() {\n    return this._dnsChallenge;\n  }\n\n  // http_challenge - computed: false, optional: true, required: false\n  private _httpChallenge = new CertificateHttpChallengeOutputReference(this as any, \"http_challenge\", true);\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 as any, \"http_memcached_challenge\", true);\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 as any, \"http_webroot_challenge\", true);\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 as any, \"tls_challenge\", true);\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      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)(this._recursiveNameservers),\n      revoke_certificate_on_destroy: cdktf.booleanToTerraform(this._revokeCertificateOnDestroy),\n      subject_alternative_names: cdktf.listMapper(cdktf.stringToTerraform)(this._subjectAlternativeNames),\n      dns_challenge: cdktf.listMapper(certificateDnsChallengeToTerraform)(this._dnsChallenge),\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"]}