@cdktn/provider-tls 11.1.0 → 12.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.jsii +504 -375
- package/README.md +13 -13
- package/lib/cert-request/index.d.ts +37 -37
- package/lib/cert-request/index.js +49 -49
- package/lib/data-tls-certificate/index.d.ts +23 -22
- package/lib/data-tls-certificate/index.js +28 -24
- package/lib/data-tls-public-key/index.d.ts +11 -11
- package/lib/data-tls-public-key/index.js +14 -14
- package/lib/index.d.ts +1 -1
- package/lib/index.js +3 -3
- package/lib/lazy-index.d.ts +1 -1
- package/lib/lazy-index.js +3 -3
- package/lib/locally-signed-cert/index.d.ts +37 -26
- package/lib/locally-signed-cert/index.js +47 -26
- package/lib/private-key/index.d.ts +12 -12
- package/lib/private-key/index.js +16 -16
- package/lib/provider/index.d.ts +21 -21
- package/lib/provider/index.js +26 -26
- package/lib/self-signed-cert/index.d.ts +67 -56
- package/lib/self-signed-cert/index.js +82 -61
- package/package.json +14 -11
|
@@ -1,74 +1,80 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* Copyright
|
|
2
|
+
* Copyright IBM Corp. 2021, 2026
|
|
3
3
|
* SPDX-License-Identifier: MPL-2.0
|
|
4
4
|
*/
|
|
5
5
|
import { Construct } from 'constructs';
|
|
6
|
-
import * as
|
|
7
|
-
export interface LocallySignedCertConfig extends
|
|
6
|
+
import * as cdktn from 'cdktn';
|
|
7
|
+
export interface LocallySignedCertConfig extends cdktn.TerraformMetaArguments {
|
|
8
8
|
/**
|
|
9
9
|
* List of key usages allowed for the issued certificate. Values are defined in [RFC 5280](https://datatracker.ietf.org/doc/html/rfc5280) and combine flags defined by both [Key Usages](https://datatracker.ietf.org/doc/html/rfc5280#section-4.2.1.3) and [Extended Key Usages](https://datatracker.ietf.org/doc/html/rfc5280#section-4.2.1.12). Accepted values: `any_extended`, `cert_signing`, `client_auth`, `code_signing`, `content_commitment`, `crl_signing`, `data_encipherment`, `decipher_only`, `digital_signature`, `email_protection`, `encipher_only`, `ipsec_end_system`, `ipsec_tunnel`, `ipsec_user`, `key_agreement`, `key_encipherment`, `microsoft_commercial_code_signing`, `microsoft_kernel_code_signing`, `microsoft_server_gated_crypto`, `netscape_server_gated_crypto`, `ocsp_signing`, `server_auth`, `timestamping`.
|
|
10
10
|
*
|
|
11
|
-
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1
|
|
11
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/locally_signed_cert#allowed_uses LocallySignedCert#allowed_uses}
|
|
12
12
|
*/
|
|
13
13
|
readonly allowedUses: string[];
|
|
14
14
|
/**
|
|
15
15
|
* Certificate data of the Certificate Authority (CA) in [PEM (RFC 1421)](https://datatracker.ietf.org/doc/html/rfc1421) format.
|
|
16
16
|
*
|
|
17
|
-
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1
|
|
17
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/locally_signed_cert#ca_cert_pem LocallySignedCert#ca_cert_pem}
|
|
18
18
|
*/
|
|
19
19
|
readonly caCertPem: string;
|
|
20
20
|
/**
|
|
21
21
|
* Private key of the Certificate Authority (CA) used to sign the certificate, in [PEM (RFC 1421)](https://datatracker.ietf.org/doc/html/rfc1421) format.
|
|
22
22
|
*
|
|
23
|
-
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1
|
|
23
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/locally_signed_cert#ca_private_key_pem LocallySignedCert#ca_private_key_pem}
|
|
24
24
|
*/
|
|
25
25
|
readonly caPrivateKeyPem: string;
|
|
26
26
|
/**
|
|
27
27
|
* Certificate request data in [PEM (RFC 1421)](https://datatracker.ietf.org/doc/html/rfc1421) format.
|
|
28
28
|
*
|
|
29
|
-
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1
|
|
29
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/locally_signed_cert#cert_request_pem LocallySignedCert#cert_request_pem}
|
|
30
30
|
*/
|
|
31
31
|
readonly certRequestPem: string;
|
|
32
32
|
/**
|
|
33
33
|
* The resource will consider the certificate to have expired the given number of hours before its actual expiry time. This can be useful to deploy an updated certificate in advance of the expiration of the current certificate. However, the old certificate remains valid until its true expiration time, since this resource does not (and cannot) support certificate revocation. Also, this advance update can only be performed should the Terraform configuration be applied during the early renewal period. (default: `0`)
|
|
34
34
|
*
|
|
35
|
-
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1
|
|
35
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/locally_signed_cert#early_renewal_hours LocallySignedCert#early_renewal_hours}
|
|
36
36
|
*/
|
|
37
37
|
readonly earlyRenewalHours?: number;
|
|
38
38
|
/**
|
|
39
39
|
* Is the generated certificate representing a Certificate Authority (CA) (default: `false`).
|
|
40
40
|
*
|
|
41
|
-
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1
|
|
41
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/locally_signed_cert#is_ca_certificate LocallySignedCert#is_ca_certificate}
|
|
42
42
|
*/
|
|
43
|
-
readonly isCaCertificate?: boolean |
|
|
43
|
+
readonly isCaCertificate?: boolean | cdktn.IResolvable;
|
|
44
|
+
/**
|
|
45
|
+
* Maximum number of intermediate certificates that may follow this certificate in a valid certification path. If `is_ca_certificate` is `false`, this value is ignored.
|
|
46
|
+
*
|
|
47
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/locally_signed_cert#max_path_length LocallySignedCert#max_path_length}
|
|
48
|
+
*/
|
|
49
|
+
readonly maxPathLength?: number;
|
|
44
50
|
/**
|
|
45
51
|
* Should the generated certificate include a [subject key identifier](https://datatracker.ietf.org/doc/html/rfc5280#section-4.2.1.2) (default: `false`).
|
|
46
52
|
*
|
|
47
|
-
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1
|
|
53
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/locally_signed_cert#set_subject_key_id LocallySignedCert#set_subject_key_id}
|
|
48
54
|
*/
|
|
49
|
-
readonly setSubjectKeyId?: boolean |
|
|
55
|
+
readonly setSubjectKeyId?: boolean | cdktn.IResolvable;
|
|
50
56
|
/**
|
|
51
57
|
* Number of hours, after initial issuing, that the certificate will remain valid for.
|
|
52
58
|
*
|
|
53
|
-
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1
|
|
59
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/locally_signed_cert#validity_period_hours LocallySignedCert#validity_period_hours}
|
|
54
60
|
*/
|
|
55
61
|
readonly validityPeriodHours: number;
|
|
56
62
|
}
|
|
57
63
|
/**
|
|
58
|
-
* Represents a {@link https://registry.terraform.io/providers/hashicorp/tls/4.1
|
|
64
|
+
* Represents a {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/locally_signed_cert tls_locally_signed_cert}
|
|
59
65
|
*/
|
|
60
|
-
export declare class LocallySignedCert extends
|
|
66
|
+
export declare class LocallySignedCert extends cdktn.TerraformResource {
|
|
61
67
|
static readonly tfResourceType = "tls_locally_signed_cert";
|
|
62
68
|
/**
|
|
63
|
-
* Generates
|
|
69
|
+
* Generates CDKTN code for importing a LocallySignedCert resource upon running "cdktn plan <stack-name>"
|
|
64
70
|
* @param scope The scope in which to define this construct
|
|
65
71
|
* @param importToId The construct id used in the generated config for the LocallySignedCert to import
|
|
66
|
-
* @param importFromId The id of the existing LocallySignedCert that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/tls/4.1
|
|
72
|
+
* @param importFromId The id of the existing LocallySignedCert that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/locally_signed_cert#import import section} in the documentation of this resource for the id to use
|
|
67
73
|
* @param provider? Optional instance of the provider where the LocallySignedCert to import is found
|
|
68
74
|
*/
|
|
69
|
-
static generateConfigForImport(scope: Construct, importToId: string, importFromId: string, provider?:
|
|
75
|
+
static generateConfigForImport(scope: Construct, importToId: string, importFromId: string, provider?: cdktn.TerraformProvider): cdktn.ImportableResource;
|
|
70
76
|
/**
|
|
71
|
-
* Create a new {@link https://registry.terraform.io/providers/hashicorp/tls/4.1
|
|
77
|
+
* Create a new {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/locally_signed_cert tls_locally_signed_cert} Resource
|
|
72
78
|
*
|
|
73
79
|
* @param scope The scope in which to define this construct
|
|
74
80
|
* @param id The scoped construct ID. Must be unique amongst siblings in the same scope
|
|
@@ -100,16 +106,21 @@ export declare class LocallySignedCert extends cdktf.TerraformResource {
|
|
|
100
106
|
get earlyRenewalHoursInput(): number | undefined;
|
|
101
107
|
get id(): string;
|
|
102
108
|
private _isCaCertificate?;
|
|
103
|
-
get isCaCertificate(): boolean |
|
|
104
|
-
set isCaCertificate(value: boolean |
|
|
109
|
+
get isCaCertificate(): boolean | cdktn.IResolvable;
|
|
110
|
+
set isCaCertificate(value: boolean | cdktn.IResolvable);
|
|
105
111
|
resetIsCaCertificate(): void;
|
|
106
|
-
get isCaCertificateInput(): boolean |
|
|
107
|
-
|
|
112
|
+
get isCaCertificateInput(): boolean | cdktn.IResolvable | undefined;
|
|
113
|
+
private _maxPathLength?;
|
|
114
|
+
get maxPathLength(): number;
|
|
115
|
+
set maxPathLength(value: number);
|
|
116
|
+
resetMaxPathLength(): void;
|
|
117
|
+
get maxPathLengthInput(): number | undefined;
|
|
118
|
+
get readyForRenewal(): cdktn.IResolvable;
|
|
108
119
|
private _setSubjectKeyId?;
|
|
109
|
-
get setSubjectKeyId(): boolean |
|
|
110
|
-
set setSubjectKeyId(value: boolean |
|
|
120
|
+
get setSubjectKeyId(): boolean | cdktn.IResolvable;
|
|
121
|
+
set setSubjectKeyId(value: boolean | cdktn.IResolvable);
|
|
111
122
|
resetSetSubjectKeyId(): void;
|
|
112
|
-
get setSubjectKeyIdInput(): boolean |
|
|
123
|
+
get setSubjectKeyIdInput(): boolean | cdktn.IResolvable | undefined;
|
|
113
124
|
get validityEndTime(): string;
|
|
114
125
|
private _validityPeriodHours?;
|
|
115
126
|
get validityPeriodHours(): number;
|
|
@@ -3,29 +3,29 @@ var _a;
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
4
|
exports.LocallySignedCert = void 0;
|
|
5
5
|
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
|
-
const
|
|
6
|
+
const cdktn = require("cdktn");
|
|
7
7
|
/**
|
|
8
|
-
* Represents a {@link https://registry.terraform.io/providers/hashicorp/tls/4.1
|
|
8
|
+
* Represents a {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/locally_signed_cert tls_locally_signed_cert}
|
|
9
9
|
*/
|
|
10
|
-
class LocallySignedCert extends
|
|
10
|
+
class LocallySignedCert extends cdktn.TerraformResource {
|
|
11
11
|
// ==============
|
|
12
12
|
// STATIC Methods
|
|
13
13
|
// ==============
|
|
14
14
|
/**
|
|
15
|
-
* Generates
|
|
15
|
+
* Generates CDKTN code for importing a LocallySignedCert resource upon running "cdktn plan <stack-name>"
|
|
16
16
|
* @param scope The scope in which to define this construct
|
|
17
17
|
* @param importToId The construct id used in the generated config for the LocallySignedCert to import
|
|
18
|
-
* @param importFromId The id of the existing LocallySignedCert that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/tls/4.1
|
|
18
|
+
* @param importFromId The id of the existing LocallySignedCert that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/locally_signed_cert#import import section} in the documentation of this resource for the id to use
|
|
19
19
|
* @param provider? Optional instance of the provider where the LocallySignedCert to import is found
|
|
20
20
|
*/
|
|
21
21
|
static generateConfigForImport(scope, importToId, importFromId, provider) {
|
|
22
|
-
return new
|
|
22
|
+
return new cdktn.ImportableResource(scope, importToId, { terraformResourceType: "tls_locally_signed_cert", importId: importFromId, provider });
|
|
23
23
|
}
|
|
24
24
|
// ===========
|
|
25
25
|
// INITIALIZER
|
|
26
26
|
// ===========
|
|
27
27
|
/**
|
|
28
|
-
* Create a new {@link https://registry.terraform.io/providers/hashicorp/tls/4.1
|
|
28
|
+
* Create a new {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/locally_signed_cert tls_locally_signed_cert} Resource
|
|
29
29
|
*
|
|
30
30
|
* @param scope The scope in which to define this construct
|
|
31
31
|
* @param id The scoped construct ID. Must be unique amongst siblings in the same scope
|
|
@@ -36,7 +36,7 @@ class LocallySignedCert extends cdktf.TerraformResource {
|
|
|
36
36
|
terraformResourceType: 'tls_locally_signed_cert',
|
|
37
37
|
terraformGeneratorMetadata: {
|
|
38
38
|
providerName: 'tls',
|
|
39
|
-
providerVersion: '4.1
|
|
39
|
+
providerVersion: '4.2.1',
|
|
40
40
|
providerVersionConstraint: '~> 4.0'
|
|
41
41
|
},
|
|
42
42
|
provider: config.provider,
|
|
@@ -53,6 +53,7 @@ class LocallySignedCert extends cdktf.TerraformResource {
|
|
|
53
53
|
this._certRequestPem = config.certRequestPem;
|
|
54
54
|
this._earlyRenewalHours = config.earlyRenewalHours;
|
|
55
55
|
this._isCaCertificate = config.isCaCertificate;
|
|
56
|
+
this._maxPathLength = config.maxPathLength;
|
|
56
57
|
this._setSubjectKeyId = config.setSubjectKeyId;
|
|
57
58
|
this._validityPeriodHours = config.validityPeriodHours;
|
|
58
59
|
}
|
|
@@ -134,6 +135,19 @@ class LocallySignedCert extends cdktf.TerraformResource {
|
|
|
134
135
|
get isCaCertificateInput() {
|
|
135
136
|
return this._isCaCertificate;
|
|
136
137
|
}
|
|
138
|
+
get maxPathLength() {
|
|
139
|
+
return this.getNumberAttribute('max_path_length');
|
|
140
|
+
}
|
|
141
|
+
set maxPathLength(value) {
|
|
142
|
+
this._maxPathLength = value;
|
|
143
|
+
}
|
|
144
|
+
resetMaxPathLength() {
|
|
145
|
+
this._maxPathLength = undefined;
|
|
146
|
+
}
|
|
147
|
+
// Temporarily expose input value. Use with caution.
|
|
148
|
+
get maxPathLengthInput() {
|
|
149
|
+
return this._maxPathLength;
|
|
150
|
+
}
|
|
137
151
|
// ready_for_renewal - computed: true, optional: false, required: false
|
|
138
152
|
get readyForRenewal() {
|
|
139
153
|
return this.getBooleanAttribute('ready_for_renewal');
|
|
@@ -174,62 +188,69 @@ class LocallySignedCert extends cdktf.TerraformResource {
|
|
|
174
188
|
// =========
|
|
175
189
|
synthesizeAttributes() {
|
|
176
190
|
return {
|
|
177
|
-
allowed_uses:
|
|
178
|
-
ca_cert_pem:
|
|
179
|
-
ca_private_key_pem:
|
|
180
|
-
cert_request_pem:
|
|
181
|
-
early_renewal_hours:
|
|
182
|
-
is_ca_certificate:
|
|
183
|
-
|
|
184
|
-
|
|
191
|
+
allowed_uses: cdktn.listMapper(cdktn.stringToTerraform, false)(this._allowedUses),
|
|
192
|
+
ca_cert_pem: cdktn.stringToTerraform(this._caCertPem),
|
|
193
|
+
ca_private_key_pem: cdktn.stringToTerraform(this._caPrivateKeyPem),
|
|
194
|
+
cert_request_pem: cdktn.stringToTerraform(this._certRequestPem),
|
|
195
|
+
early_renewal_hours: cdktn.numberToTerraform(this._earlyRenewalHours),
|
|
196
|
+
is_ca_certificate: cdktn.booleanToTerraform(this._isCaCertificate),
|
|
197
|
+
max_path_length: cdktn.numberToTerraform(this._maxPathLength),
|
|
198
|
+
set_subject_key_id: cdktn.booleanToTerraform(this._setSubjectKeyId),
|
|
199
|
+
validity_period_hours: cdktn.numberToTerraform(this._validityPeriodHours),
|
|
185
200
|
};
|
|
186
201
|
}
|
|
187
202
|
synthesizeHclAttributes() {
|
|
188
203
|
const attrs = {
|
|
189
204
|
allowed_uses: {
|
|
190
|
-
value:
|
|
205
|
+
value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(this._allowedUses),
|
|
191
206
|
isBlock: false,
|
|
192
207
|
type: "list",
|
|
193
208
|
storageClassType: "stringList",
|
|
194
209
|
},
|
|
195
210
|
ca_cert_pem: {
|
|
196
|
-
value:
|
|
211
|
+
value: cdktn.stringToHclTerraform(this._caCertPem),
|
|
197
212
|
isBlock: false,
|
|
198
213
|
type: "simple",
|
|
199
214
|
storageClassType: "string",
|
|
200
215
|
},
|
|
201
216
|
ca_private_key_pem: {
|
|
202
|
-
value:
|
|
217
|
+
value: cdktn.stringToHclTerraform(this._caPrivateKeyPem),
|
|
203
218
|
isBlock: false,
|
|
204
219
|
type: "simple",
|
|
205
220
|
storageClassType: "string",
|
|
206
221
|
},
|
|
207
222
|
cert_request_pem: {
|
|
208
|
-
value:
|
|
223
|
+
value: cdktn.stringToHclTerraform(this._certRequestPem),
|
|
209
224
|
isBlock: false,
|
|
210
225
|
type: "simple",
|
|
211
226
|
storageClassType: "string",
|
|
212
227
|
},
|
|
213
228
|
early_renewal_hours: {
|
|
214
|
-
value:
|
|
229
|
+
value: cdktn.numberToHclTerraform(this._earlyRenewalHours),
|
|
215
230
|
isBlock: false,
|
|
216
231
|
type: "simple",
|
|
217
232
|
storageClassType: "number",
|
|
218
233
|
},
|
|
219
234
|
is_ca_certificate: {
|
|
220
|
-
value:
|
|
235
|
+
value: cdktn.booleanToHclTerraform(this._isCaCertificate),
|
|
221
236
|
isBlock: false,
|
|
222
237
|
type: "simple",
|
|
223
238
|
storageClassType: "boolean",
|
|
224
239
|
},
|
|
240
|
+
max_path_length: {
|
|
241
|
+
value: cdktn.numberToHclTerraform(this._maxPathLength),
|
|
242
|
+
isBlock: false,
|
|
243
|
+
type: "simple",
|
|
244
|
+
storageClassType: "number",
|
|
245
|
+
},
|
|
225
246
|
set_subject_key_id: {
|
|
226
|
-
value:
|
|
247
|
+
value: cdktn.booleanToHclTerraform(this._setSubjectKeyId),
|
|
227
248
|
isBlock: false,
|
|
228
249
|
type: "simple",
|
|
229
250
|
storageClassType: "boolean",
|
|
230
251
|
},
|
|
231
252
|
validity_period_hours: {
|
|
232
|
-
value:
|
|
253
|
+
value: cdktn.numberToHclTerraform(this._validityPeriodHours),
|
|
233
254
|
isBlock: false,
|
|
234
255
|
type: "simple",
|
|
235
256
|
storageClassType: "number",
|
|
@@ -241,9 +262,9 @@ class LocallySignedCert extends cdktf.TerraformResource {
|
|
|
241
262
|
}
|
|
242
263
|
exports.LocallySignedCert = LocallySignedCert;
|
|
243
264
|
_a = JSII_RTTI_SYMBOL_1;
|
|
244
|
-
LocallySignedCert[_a] = { fqn: "@cdktn/provider-tls.locallySignedCert.LocallySignedCert", version: "
|
|
265
|
+
LocallySignedCert[_a] = { fqn: "@cdktn/provider-tls.locallySignedCert.LocallySignedCert", version: "12.0.0" };
|
|
245
266
|
// =================
|
|
246
267
|
// STATIC PROPERTIES
|
|
247
268
|
// =================
|
|
248
269
|
LocallySignedCert.tfResourceType = "tls_locally_signed_cert";
|
|
249
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/locally-signed-cert/index.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Copyright (c) HashiCorp, Inc.\n * SPDX-License-Identifier: MPL-2.0\n */\n\n// https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs/resources/locally_signed_cert\n// generated from terraform resource schema\n\nimport { Construct } from 'constructs';\nimport * as cdktf from 'cdktf';\n\n// Configuration\n\nexport interface LocallySignedCertConfig extends cdktf.TerraformMetaArguments {\n  /**\n  * List of key usages allowed for the issued certificate. Values are defined in [RFC 5280](https://datatracker.ietf.org/doc/html/rfc5280) and combine flags defined by both [Key Usages](https://datatracker.ietf.org/doc/html/rfc5280#section-4.2.1.3) and [Extended Key Usages](https://datatracker.ietf.org/doc/html/rfc5280#section-4.2.1.12). Accepted values: `any_extended`, `cert_signing`, `client_auth`, `code_signing`, `content_commitment`, `crl_signing`, `data_encipherment`, `decipher_only`, `digital_signature`, `email_protection`, `encipher_only`, `ipsec_end_system`, `ipsec_tunnel`, `ipsec_user`, `key_agreement`, `key_encipherment`, `microsoft_commercial_code_signing`, `microsoft_kernel_code_signing`, `microsoft_server_gated_crypto`, `netscape_server_gated_crypto`, `ocsp_signing`, `server_auth`, `timestamping`.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs/resources/locally_signed_cert#allowed_uses LocallySignedCert#allowed_uses}\n  */\n  readonly allowedUses: string[];\n  /**\n  * Certificate data of the Certificate Authority (CA) in [PEM (RFC 1421)](https://datatracker.ietf.org/doc/html/rfc1421) format.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs/resources/locally_signed_cert#ca_cert_pem LocallySignedCert#ca_cert_pem}\n  */\n  readonly caCertPem: string;\n  /**\n  * Private key of the Certificate Authority (CA) used to sign the certificate, in [PEM (RFC 1421)](https://datatracker.ietf.org/doc/html/rfc1421) format.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs/resources/locally_signed_cert#ca_private_key_pem LocallySignedCert#ca_private_key_pem}\n  */\n  readonly caPrivateKeyPem: string;\n  /**\n  * Certificate request data in [PEM (RFC 1421)](https://datatracker.ietf.org/doc/html/rfc1421) format.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs/resources/locally_signed_cert#cert_request_pem LocallySignedCert#cert_request_pem}\n  */\n  readonly certRequestPem: string;\n  /**\n  * The resource will consider the certificate to have expired the given number of hours before its actual expiry time. This can be useful to deploy an updated certificate in advance of the expiration of the current certificate. However, the old certificate remains valid until its true expiration time, since this resource does not (and cannot) support certificate revocation. Also, this advance update can only be performed should the Terraform configuration be applied during the early renewal period. (default: `0`)\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs/resources/locally_signed_cert#early_renewal_hours LocallySignedCert#early_renewal_hours}\n  */\n  readonly earlyRenewalHours?: number;\n  /**\n  * Is the generated certificate representing a Certificate Authority (CA) (default: `false`).\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs/resources/locally_signed_cert#is_ca_certificate LocallySignedCert#is_ca_certificate}\n  */\n  readonly isCaCertificate?: boolean | cdktf.IResolvable;\n  /**\n  * Should the generated certificate include a [subject key identifier](https://datatracker.ietf.org/doc/html/rfc5280#section-4.2.1.2) (default: `false`).\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs/resources/locally_signed_cert#set_subject_key_id LocallySignedCert#set_subject_key_id}\n  */\n  readonly setSubjectKeyId?: boolean | cdktf.IResolvable;\n  /**\n  * Number of hours, after initial issuing, that the certificate will remain valid for.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs/resources/locally_signed_cert#validity_period_hours LocallySignedCert#validity_period_hours}\n  */\n  readonly validityPeriodHours: number;\n}\n\n/**\n* Represents a {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs/resources/locally_signed_cert tls_locally_signed_cert}\n*/\nexport class LocallySignedCert extends cdktf.TerraformResource {\n\n  // =================\n  // STATIC PROPERTIES\n  // =================\n  public static readonly tfResourceType = \"tls_locally_signed_cert\";\n\n  // ==============\n  // STATIC Methods\n  // ==============\n  /**\n  * Generates CDKTF code for importing a LocallySignedCert resource upon running \"cdktf plan <stack-name>\"\n  * @param scope The scope in which to define this construct\n  * @param importToId The construct id used in the generated config for the LocallySignedCert to import\n  * @param importFromId The id of the existing LocallySignedCert that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs/resources/locally_signed_cert#import import section} in the documentation of this resource for the id to use\n  * @param provider? Optional instance of the provider where the LocallySignedCert to import is found\n  */\n  public static generateConfigForImport(scope: Construct, importToId: string, importFromId: string, provider?: cdktf.TerraformProvider) {\n        return new cdktf.ImportableResource(scope, importToId, { terraformResourceType: \"tls_locally_signed_cert\", importId: importFromId, provider });\n      }\n\n  // ===========\n  // INITIALIZER\n  // ===========\n\n  /**\n  * Create a new {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs/resources/locally_signed_cert tls_locally_signed_cert} Resource\n  *\n  * @param scope The scope in which to define this construct\n  * @param id The scoped construct ID. Must be unique amongst siblings in the same scope\n  * @param options LocallySignedCertConfig\n  */\n  public constructor(scope: Construct, id: string, config: LocallySignedCertConfig) {\n    super(scope, id, {\n      terraformResourceType: 'tls_locally_signed_cert',\n      terraformGeneratorMetadata: {\n        providerName: 'tls',\n        providerVersion: '4.1.0',\n        providerVersionConstraint: '~> 4.0'\n      },\n      provider: config.provider,\n      dependsOn: config.dependsOn,\n      count: config.count,\n      lifecycle: config.lifecycle,\n      provisioners: config.provisioners,\n      connection: config.connection,\n      forEach: config.forEach\n    });\n    this._allowedUses = config.allowedUses;\n    this._caCertPem = config.caCertPem;\n    this._caPrivateKeyPem = config.caPrivateKeyPem;\n    this._certRequestPem = config.certRequestPem;\n    this._earlyRenewalHours = config.earlyRenewalHours;\n    this._isCaCertificate = config.isCaCertificate;\n    this._setSubjectKeyId = config.setSubjectKeyId;\n    this._validityPeriodHours = config.validityPeriodHours;\n  }\n\n  // ==========\n  // ATTRIBUTES\n  // ==========\n\n  // allowed_uses - computed: false, optional: false, required: true\n  private _allowedUses?: string[]; \n  public get allowedUses() {\n    return this.getListAttribute('allowed_uses');\n  }\n  public set allowedUses(value: string[]) {\n    this._allowedUses = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get allowedUsesInput() {\n    return this._allowedUses;\n  }\n\n  // ca_cert_pem - computed: false, optional: false, required: true\n  private _caCertPem?: string; \n  public get caCertPem() {\n    return this.getStringAttribute('ca_cert_pem');\n  }\n  public set caCertPem(value: string) {\n    this._caCertPem = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get caCertPemInput() {\n    return this._caCertPem;\n  }\n\n  // ca_key_algorithm - computed: true, optional: false, required: false\n  public get caKeyAlgorithm() {\n    return this.getStringAttribute('ca_key_algorithm');\n  }\n\n  // ca_private_key_pem - computed: false, optional: false, required: true\n  private _caPrivateKeyPem?: string; \n  public get caPrivateKeyPem() {\n    return this.getStringAttribute('ca_private_key_pem');\n  }\n  public set caPrivateKeyPem(value: string) {\n    this._caPrivateKeyPem = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get caPrivateKeyPemInput() {\n    return this._caPrivateKeyPem;\n  }\n\n  // cert_pem - computed: true, optional: false, required: false\n  public get certPem() {\n    return this.getStringAttribute('cert_pem');\n  }\n\n  // cert_request_pem - computed: false, optional: false, required: true\n  private _certRequestPem?: string; \n  public get certRequestPem() {\n    return this.getStringAttribute('cert_request_pem');\n  }\n  public set certRequestPem(value: string) {\n    this._certRequestPem = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get certRequestPemInput() {\n    return this._certRequestPem;\n  }\n\n  // early_renewal_hours - computed: true, optional: true, required: false\n  private _earlyRenewalHours?: number; \n  public get earlyRenewalHours() {\n    return this.getNumberAttribute('early_renewal_hours');\n  }\n  public set earlyRenewalHours(value: number) {\n    this._earlyRenewalHours = value;\n  }\n  public resetEarlyRenewalHours() {\n    this._earlyRenewalHours = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get earlyRenewalHoursInput() {\n    return this._earlyRenewalHours;\n  }\n\n  // id - computed: true, optional: false, required: false\n  public get id() {\n    return this.getStringAttribute('id');\n  }\n\n  // is_ca_certificate - computed: true, optional: true, required: false\n  private _isCaCertificate?: boolean | cdktf.IResolvable; \n  public get isCaCertificate() {\n    return this.getBooleanAttribute('is_ca_certificate');\n  }\n  public set isCaCertificate(value: boolean | cdktf.IResolvable) {\n    this._isCaCertificate = value;\n  }\n  public resetIsCaCertificate() {\n    this._isCaCertificate = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get isCaCertificateInput() {\n    return this._isCaCertificate;\n  }\n\n  // ready_for_renewal - computed: true, optional: false, required: false\n  public get readyForRenewal() {\n    return this.getBooleanAttribute('ready_for_renewal');\n  }\n\n  // set_subject_key_id - computed: true, optional: true, required: false\n  private _setSubjectKeyId?: boolean | cdktf.IResolvable; \n  public get setSubjectKeyId() {\n    return this.getBooleanAttribute('set_subject_key_id');\n  }\n  public set setSubjectKeyId(value: boolean | cdktf.IResolvable) {\n    this._setSubjectKeyId = value;\n  }\n  public resetSetSubjectKeyId() {\n    this._setSubjectKeyId = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get setSubjectKeyIdInput() {\n    return this._setSubjectKeyId;\n  }\n\n  // validity_end_time - computed: true, optional: false, required: false\n  public get validityEndTime() {\n    return this.getStringAttribute('validity_end_time');\n  }\n\n  // validity_period_hours - computed: false, optional: false, required: true\n  private _validityPeriodHours?: number; \n  public get validityPeriodHours() {\n    return this.getNumberAttribute('validity_period_hours');\n  }\n  public set validityPeriodHours(value: number) {\n    this._validityPeriodHours = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get validityPeriodHoursInput() {\n    return this._validityPeriodHours;\n  }\n\n  // validity_start_time - computed: true, optional: false, required: false\n  public get validityStartTime() {\n    return this.getStringAttribute('validity_start_time');\n  }\n\n  // =========\n  // SYNTHESIS\n  // =========\n\n  protected synthesizeAttributes(): { [name: string]: any } {\n    return {\n      allowed_uses: cdktf.listMapper(cdktf.stringToTerraform, false)(this._allowedUses),\n      ca_cert_pem: cdktf.stringToTerraform(this._caCertPem),\n      ca_private_key_pem: cdktf.stringToTerraform(this._caPrivateKeyPem),\n      cert_request_pem: cdktf.stringToTerraform(this._certRequestPem),\n      early_renewal_hours: cdktf.numberToTerraform(this._earlyRenewalHours),\n      is_ca_certificate: cdktf.booleanToTerraform(this._isCaCertificate),\n      set_subject_key_id: cdktf.booleanToTerraform(this._setSubjectKeyId),\n      validity_period_hours: cdktf.numberToTerraform(this._validityPeriodHours),\n    };\n  }\n\n  protected synthesizeHclAttributes(): { [name: string]: any } {\n    const attrs = {\n      allowed_uses: {\n        value: cdktf.listMapperHcl(cdktf.stringToHclTerraform, false)(this._allowedUses),\n        isBlock: false,\n        type: \"list\",\n        storageClassType: \"stringList\",\n      },\n      ca_cert_pem: {\n        value: cdktf.stringToHclTerraform(this._caCertPem),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"string\",\n      },\n      ca_private_key_pem: {\n        value: cdktf.stringToHclTerraform(this._caPrivateKeyPem),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"string\",\n      },\n      cert_request_pem: {\n        value: cdktf.stringToHclTerraform(this._certRequestPem),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"string\",\n      },\n      early_renewal_hours: {\n        value: cdktf.numberToHclTerraform(this._earlyRenewalHours),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"number\",\n      },\n      is_ca_certificate: {\n        value: cdktf.booleanToHclTerraform(this._isCaCertificate),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"boolean\",\n      },\n      set_subject_key_id: {\n        value: cdktf.booleanToHclTerraform(this._setSubjectKeyId),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"boolean\",\n      },\n      validity_period_hours: {\n        value: cdktf.numberToHclTerraform(this._validityPeriodHours),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"number\",\n      },\n    };\n\n    // remove undefined attributes\n    return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined ))\n  }\n}\n"]}
|
|
270
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/locally-signed-cert/index.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Copyright IBM Corp. 2021, 2026\n * SPDX-License-Identifier: MPL-2.0\n */\n\n// https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/locally_signed_cert\n// generated from terraform resource schema\n\nimport { Construct } from 'constructs';\nimport * as cdktn from 'cdktn';\n\n// Configuration\n\nexport interface LocallySignedCertConfig extends cdktn.TerraformMetaArguments {\n  /**\n  * List of key usages allowed for the issued certificate. Values are defined in [RFC 5280](https://datatracker.ietf.org/doc/html/rfc5280) and combine flags defined by both [Key Usages](https://datatracker.ietf.org/doc/html/rfc5280#section-4.2.1.3) and [Extended Key Usages](https://datatracker.ietf.org/doc/html/rfc5280#section-4.2.1.12). Accepted values: `any_extended`, `cert_signing`, `client_auth`, `code_signing`, `content_commitment`, `crl_signing`, `data_encipherment`, `decipher_only`, `digital_signature`, `email_protection`, `encipher_only`, `ipsec_end_system`, `ipsec_tunnel`, `ipsec_user`, `key_agreement`, `key_encipherment`, `microsoft_commercial_code_signing`, `microsoft_kernel_code_signing`, `microsoft_server_gated_crypto`, `netscape_server_gated_crypto`, `ocsp_signing`, `server_auth`, `timestamping`.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/locally_signed_cert#allowed_uses LocallySignedCert#allowed_uses}\n  */\n  readonly allowedUses: string[];\n  /**\n  * Certificate data of the Certificate Authority (CA) in [PEM (RFC 1421)](https://datatracker.ietf.org/doc/html/rfc1421) format.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/locally_signed_cert#ca_cert_pem LocallySignedCert#ca_cert_pem}\n  */\n  readonly caCertPem: string;\n  /**\n  * Private key of the Certificate Authority (CA) used to sign the certificate, in [PEM (RFC 1421)](https://datatracker.ietf.org/doc/html/rfc1421) format.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/locally_signed_cert#ca_private_key_pem LocallySignedCert#ca_private_key_pem}\n  */\n  readonly caPrivateKeyPem: string;\n  /**\n  * Certificate request data in [PEM (RFC 1421)](https://datatracker.ietf.org/doc/html/rfc1421) format.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/locally_signed_cert#cert_request_pem LocallySignedCert#cert_request_pem}\n  */\n  readonly certRequestPem: string;\n  /**\n  * The resource will consider the certificate to have expired the given number of hours before its actual expiry time. This can be useful to deploy an updated certificate in advance of the expiration of the current certificate. However, the old certificate remains valid until its true expiration time, since this resource does not (and cannot) support certificate revocation. Also, this advance update can only be performed should the Terraform configuration be applied during the early renewal period. (default: `0`)\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/locally_signed_cert#early_renewal_hours LocallySignedCert#early_renewal_hours}\n  */\n  readonly earlyRenewalHours?: number;\n  /**\n  * Is the generated certificate representing a Certificate Authority (CA) (default: `false`).\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/locally_signed_cert#is_ca_certificate LocallySignedCert#is_ca_certificate}\n  */\n  readonly isCaCertificate?: boolean | cdktn.IResolvable;\n  /**\n  * Maximum number of intermediate certificates that may follow this certificate in a valid certification path. If `is_ca_certificate` is `false`, this value is ignored.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/locally_signed_cert#max_path_length LocallySignedCert#max_path_length}\n  */\n  readonly maxPathLength?: number;\n  /**\n  * Should the generated certificate include a [subject key identifier](https://datatracker.ietf.org/doc/html/rfc5280#section-4.2.1.2) (default: `false`).\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/locally_signed_cert#set_subject_key_id LocallySignedCert#set_subject_key_id}\n  */\n  readonly setSubjectKeyId?: boolean | cdktn.IResolvable;\n  /**\n  * Number of hours, after initial issuing, that the certificate will remain valid for.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/locally_signed_cert#validity_period_hours LocallySignedCert#validity_period_hours}\n  */\n  readonly validityPeriodHours: number;\n}\n\n/**\n* Represents a {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/locally_signed_cert tls_locally_signed_cert}\n*/\nexport class LocallySignedCert extends cdktn.TerraformResource {\n\n  // =================\n  // STATIC PROPERTIES\n  // =================\n  public static readonly tfResourceType = \"tls_locally_signed_cert\";\n\n  // ==============\n  // STATIC Methods\n  // ==============\n  /**\n  * Generates CDKTN code for importing a LocallySignedCert resource upon running \"cdktn plan <stack-name>\"\n  * @param scope The scope in which to define this construct\n  * @param importToId The construct id used in the generated config for the LocallySignedCert to import\n  * @param importFromId The id of the existing LocallySignedCert that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/locally_signed_cert#import import section} in the documentation of this resource for the id to use\n  * @param provider? Optional instance of the provider where the LocallySignedCert to import is found\n  */\n  public static generateConfigForImport(scope: Construct, importToId: string, importFromId: string, provider?: cdktn.TerraformProvider) {\n        return new cdktn.ImportableResource(scope, importToId, { terraformResourceType: \"tls_locally_signed_cert\", importId: importFromId, provider });\n      }\n\n  // ===========\n  // INITIALIZER\n  // ===========\n\n  /**\n  * Create a new {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/locally_signed_cert tls_locally_signed_cert} Resource\n  *\n  * @param scope The scope in which to define this construct\n  * @param id The scoped construct ID. Must be unique amongst siblings in the same scope\n  * @param options LocallySignedCertConfig\n  */\n  public constructor(scope: Construct, id: string, config: LocallySignedCertConfig) {\n    super(scope, id, {\n      terraformResourceType: 'tls_locally_signed_cert',\n      terraformGeneratorMetadata: {\n        providerName: 'tls',\n        providerVersion: '4.2.1',\n        providerVersionConstraint: '~> 4.0'\n      },\n      provider: config.provider,\n      dependsOn: config.dependsOn,\n      count: config.count,\n      lifecycle: config.lifecycle,\n      provisioners: config.provisioners,\n      connection: config.connection,\n      forEach: config.forEach\n    });\n    this._allowedUses = config.allowedUses;\n    this._caCertPem = config.caCertPem;\n    this._caPrivateKeyPem = config.caPrivateKeyPem;\n    this._certRequestPem = config.certRequestPem;\n    this._earlyRenewalHours = config.earlyRenewalHours;\n    this._isCaCertificate = config.isCaCertificate;\n    this._maxPathLength = config.maxPathLength;\n    this._setSubjectKeyId = config.setSubjectKeyId;\n    this._validityPeriodHours = config.validityPeriodHours;\n  }\n\n  // ==========\n  // ATTRIBUTES\n  // ==========\n\n  // allowed_uses - computed: false, optional: false, required: true\n  private _allowedUses?: string[]; \n  public get allowedUses() {\n    return this.getListAttribute('allowed_uses');\n  }\n  public set allowedUses(value: string[]) {\n    this._allowedUses = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get allowedUsesInput() {\n    return this._allowedUses;\n  }\n\n  // ca_cert_pem - computed: false, optional: false, required: true\n  private _caCertPem?: string; \n  public get caCertPem() {\n    return this.getStringAttribute('ca_cert_pem');\n  }\n  public set caCertPem(value: string) {\n    this._caCertPem = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get caCertPemInput() {\n    return this._caCertPem;\n  }\n\n  // ca_key_algorithm - computed: true, optional: false, required: false\n  public get caKeyAlgorithm() {\n    return this.getStringAttribute('ca_key_algorithm');\n  }\n\n  // ca_private_key_pem - computed: false, optional: false, required: true\n  private _caPrivateKeyPem?: string; \n  public get caPrivateKeyPem() {\n    return this.getStringAttribute('ca_private_key_pem');\n  }\n  public set caPrivateKeyPem(value: string) {\n    this._caPrivateKeyPem = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get caPrivateKeyPemInput() {\n    return this._caPrivateKeyPem;\n  }\n\n  // cert_pem - computed: true, optional: false, required: false\n  public get certPem() {\n    return this.getStringAttribute('cert_pem');\n  }\n\n  // cert_request_pem - computed: false, optional: false, required: true\n  private _certRequestPem?: string; \n  public get certRequestPem() {\n    return this.getStringAttribute('cert_request_pem');\n  }\n  public set certRequestPem(value: string) {\n    this._certRequestPem = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get certRequestPemInput() {\n    return this._certRequestPem;\n  }\n\n  // early_renewal_hours - computed: true, optional: true, required: false\n  private _earlyRenewalHours?: number; \n  public get earlyRenewalHours() {\n    return this.getNumberAttribute('early_renewal_hours');\n  }\n  public set earlyRenewalHours(value: number) {\n    this._earlyRenewalHours = value;\n  }\n  public resetEarlyRenewalHours() {\n    this._earlyRenewalHours = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get earlyRenewalHoursInput() {\n    return this._earlyRenewalHours;\n  }\n\n  // id - computed: true, optional: false, required: false\n  public get id() {\n    return this.getStringAttribute('id');\n  }\n\n  // is_ca_certificate - computed: true, optional: true, required: false\n  private _isCaCertificate?: boolean | cdktn.IResolvable; \n  public get isCaCertificate() {\n    return this.getBooleanAttribute('is_ca_certificate');\n  }\n  public set isCaCertificate(value: boolean | cdktn.IResolvable) {\n    this._isCaCertificate = value;\n  }\n  public resetIsCaCertificate() {\n    this._isCaCertificate = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get isCaCertificateInput() {\n    return this._isCaCertificate;\n  }\n\n  // max_path_length - computed: true, optional: true, required: false\n  private _maxPathLength?: number; \n  public get maxPathLength() {\n    return this.getNumberAttribute('max_path_length');\n  }\n  public set maxPathLength(value: number) {\n    this._maxPathLength = value;\n  }\n  public resetMaxPathLength() {\n    this._maxPathLength = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get maxPathLengthInput() {\n    return this._maxPathLength;\n  }\n\n  // ready_for_renewal - computed: true, optional: false, required: false\n  public get readyForRenewal() {\n    return this.getBooleanAttribute('ready_for_renewal');\n  }\n\n  // set_subject_key_id - computed: true, optional: true, required: false\n  private _setSubjectKeyId?: boolean | cdktn.IResolvable; \n  public get setSubjectKeyId() {\n    return this.getBooleanAttribute('set_subject_key_id');\n  }\n  public set setSubjectKeyId(value: boolean | cdktn.IResolvable) {\n    this._setSubjectKeyId = value;\n  }\n  public resetSetSubjectKeyId() {\n    this._setSubjectKeyId = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get setSubjectKeyIdInput() {\n    return this._setSubjectKeyId;\n  }\n\n  // validity_end_time - computed: true, optional: false, required: false\n  public get validityEndTime() {\n    return this.getStringAttribute('validity_end_time');\n  }\n\n  // validity_period_hours - computed: false, optional: false, required: true\n  private _validityPeriodHours?: number; \n  public get validityPeriodHours() {\n    return this.getNumberAttribute('validity_period_hours');\n  }\n  public set validityPeriodHours(value: number) {\n    this._validityPeriodHours = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get validityPeriodHoursInput() {\n    return this._validityPeriodHours;\n  }\n\n  // validity_start_time - computed: true, optional: false, required: false\n  public get validityStartTime() {\n    return this.getStringAttribute('validity_start_time');\n  }\n\n  // =========\n  // SYNTHESIS\n  // =========\n\n  protected synthesizeAttributes(): { [name: string]: any } {\n    return {\n      allowed_uses: cdktn.listMapper(cdktn.stringToTerraform, false)(this._allowedUses),\n      ca_cert_pem: cdktn.stringToTerraform(this._caCertPem),\n      ca_private_key_pem: cdktn.stringToTerraform(this._caPrivateKeyPem),\n      cert_request_pem: cdktn.stringToTerraform(this._certRequestPem),\n      early_renewal_hours: cdktn.numberToTerraform(this._earlyRenewalHours),\n      is_ca_certificate: cdktn.booleanToTerraform(this._isCaCertificate),\n      max_path_length: cdktn.numberToTerraform(this._maxPathLength),\n      set_subject_key_id: cdktn.booleanToTerraform(this._setSubjectKeyId),\n      validity_period_hours: cdktn.numberToTerraform(this._validityPeriodHours),\n    };\n  }\n\n  protected synthesizeHclAttributes(): { [name: string]: any } {\n    const attrs = {\n      allowed_uses: {\n        value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(this._allowedUses),\n        isBlock: false,\n        type: \"list\",\n        storageClassType: \"stringList\",\n      },\n      ca_cert_pem: {\n        value: cdktn.stringToHclTerraform(this._caCertPem),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"string\",\n      },\n      ca_private_key_pem: {\n        value: cdktn.stringToHclTerraform(this._caPrivateKeyPem),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"string\",\n      },\n      cert_request_pem: {\n        value: cdktn.stringToHclTerraform(this._certRequestPem),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"string\",\n      },\n      early_renewal_hours: {\n        value: cdktn.numberToHclTerraform(this._earlyRenewalHours),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"number\",\n      },\n      is_ca_certificate: {\n        value: cdktn.booleanToHclTerraform(this._isCaCertificate),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"boolean\",\n      },\n      max_path_length: {\n        value: cdktn.numberToHclTerraform(this._maxPathLength),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"number\",\n      },\n      set_subject_key_id: {\n        value: cdktn.booleanToHclTerraform(this._setSubjectKeyId),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"boolean\",\n      },\n      validity_period_hours: {\n        value: cdktn.numberToHclTerraform(this._validityPeriodHours),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"number\",\n      },\n    };\n\n    // remove undefined attributes\n    return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined ))\n  }\n}\n"]}
|
|
@@ -1,44 +1,44 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* Copyright
|
|
2
|
+
* Copyright IBM Corp. 2021, 2026
|
|
3
3
|
* SPDX-License-Identifier: MPL-2.0
|
|
4
4
|
*/
|
|
5
5
|
import { Construct } from 'constructs';
|
|
6
|
-
import * as
|
|
7
|
-
export interface PrivateKeyConfig extends
|
|
6
|
+
import * as cdktn from 'cdktn';
|
|
7
|
+
export interface PrivateKeyConfig extends cdktn.TerraformMetaArguments {
|
|
8
8
|
/**
|
|
9
9
|
* Name of the algorithm to use when generating the private key. Currently-supported values are: `RSA`, `ECDSA`, `ED25519`.
|
|
10
10
|
*
|
|
11
|
-
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1
|
|
11
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/private_key#algorithm PrivateKey#algorithm}
|
|
12
12
|
*/
|
|
13
13
|
readonly algorithm: string;
|
|
14
14
|
/**
|
|
15
15
|
* When `algorithm` is `ECDSA`, the name of the elliptic curve to use. Currently-supported values are: `P224`, `P256`, `P384`, `P521`. (default: `P224`).
|
|
16
16
|
*
|
|
17
|
-
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1
|
|
17
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/private_key#ecdsa_curve PrivateKey#ecdsa_curve}
|
|
18
18
|
*/
|
|
19
19
|
readonly ecdsaCurve?: string;
|
|
20
20
|
/**
|
|
21
21
|
* When `algorithm` is `RSA`, the size of the generated RSA key, in bits (default: `2048`).
|
|
22
22
|
*
|
|
23
|
-
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1
|
|
23
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/private_key#rsa_bits PrivateKey#rsa_bits}
|
|
24
24
|
*/
|
|
25
25
|
readonly rsaBits?: number;
|
|
26
26
|
}
|
|
27
27
|
/**
|
|
28
|
-
* Represents a {@link https://registry.terraform.io/providers/hashicorp/tls/4.1
|
|
28
|
+
* Represents a {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/private_key tls_private_key}
|
|
29
29
|
*/
|
|
30
|
-
export declare class PrivateKey extends
|
|
30
|
+
export declare class PrivateKey extends cdktn.TerraformResource {
|
|
31
31
|
static readonly tfResourceType = "tls_private_key";
|
|
32
32
|
/**
|
|
33
|
-
* Generates
|
|
33
|
+
* Generates CDKTN code for importing a PrivateKey resource upon running "cdktn plan <stack-name>"
|
|
34
34
|
* @param scope The scope in which to define this construct
|
|
35
35
|
* @param importToId The construct id used in the generated config for the PrivateKey to import
|
|
36
|
-
* @param importFromId The id of the existing PrivateKey that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/tls/4.1
|
|
36
|
+
* @param importFromId The id of the existing PrivateKey that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/private_key#import import section} in the documentation of this resource for the id to use
|
|
37
37
|
* @param provider? Optional instance of the provider where the PrivateKey to import is found
|
|
38
38
|
*/
|
|
39
|
-
static generateConfigForImport(scope: Construct, importToId: string, importFromId: string, provider?:
|
|
39
|
+
static generateConfigForImport(scope: Construct, importToId: string, importFromId: string, provider?: cdktn.TerraformProvider): cdktn.ImportableResource;
|
|
40
40
|
/**
|
|
41
|
-
* Create a new {@link https://registry.terraform.io/providers/hashicorp/tls/4.1
|
|
41
|
+
* Create a new {@link https://registry.terraform.io/providers/hashicorp/tls/4.2.1/docs/resources/private_key tls_private_key} Resource
|
|
42
42
|
*
|
|
43
43
|
* @param scope The scope in which to define this construct
|
|
44
44
|
* @param id The scoped construct ID. Must be unique amongst siblings in the same scope
|