@cdktf/provider-acme 0.0.0
Sign up to get free protection for your applications and to get access to all the features.
- package/.gitattributes +23 -0
- package/.jsii +2899 -0
- package/API.md +2204 -0
- package/LICENSE +353 -0
- package/README.md +77 -0
- package/lib/acme-provider.d.ts +76 -0
- package/lib/acme-provider.js +102 -0
- package/lib/certificate.d.ts +715 -0
- package/lib/certificate.js +947 -0
- package/lib/index.d.ts +3 -0
- package/lib/index.js +17 -0
- package/lib/registration.d.ts +168 -0
- package/lib/registration.js +241 -0
- package/package.json +101 -0
@@ -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"]}
|