@cdktn/provider-tls 11.1.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/lib/index.d.ts ADDED
@@ -0,0 +1,11 @@
1
+ /**
2
+ * Copyright (c) HashiCorp, Inc.
3
+ * SPDX-License-Identifier: MPL-2.0
4
+ */
5
+ export * as certRequest from './cert-request';
6
+ export * as locallySignedCert from './locally-signed-cert';
7
+ export * as privateKey from './private-key';
8
+ export * as selfSignedCert from './self-signed-cert';
9
+ export * as dataTlsCertificate from './data-tls-certificate';
10
+ export * as dataTlsPublicKey from './data-tls-public-key';
11
+ export * as provider from './provider';
package/lib/index.js ADDED
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+ /**
3
+ * Copyright (c) HashiCorp, Inc.
4
+ * SPDX-License-Identifier: MPL-2.0
5
+ */
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.provider = exports.dataTlsPublicKey = exports.dataTlsCertificate = exports.selfSignedCert = exports.privateKey = exports.locallySignedCert = exports.certRequest = void 0;
8
+ // generated by cdktf get
9
+ exports.certRequest = require("./cert-request");
10
+ exports.locallySignedCert = require("./locally-signed-cert");
11
+ exports.privateKey = require("./private-key");
12
+ exports.selfSignedCert = require("./self-signed-cert");
13
+ exports.dataTlsCertificate = require("./data-tls-certificate");
14
+ exports.dataTlsPublicKey = require("./data-tls-public-key");
15
+ exports.provider = require("./provider");
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7R0FHRzs7O0FBRUgseUJBQXlCO0FBQ3pCLGdEQUE4QztBQUM5Qyw2REFBMkQ7QUFDM0QsOENBQTRDO0FBQzVDLHVEQUFxRDtBQUNyRCwrREFBNkQ7QUFDN0QsNERBQTBEO0FBQzFELHlDQUF1QyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSBIYXNoaUNvcnAsIEluYy5cbiAqIFNQRFgtTGljZW5zZS1JZGVudGlmaWVyOiBNUEwtMi4wXG4gKi9cblxuLy8gZ2VuZXJhdGVkIGJ5IGNka3RmIGdldFxuZXhwb3J0ICogYXMgY2VydFJlcXVlc3QgZnJvbSAnLi9jZXJ0LXJlcXVlc3QnO1xuZXhwb3J0ICogYXMgbG9jYWxseVNpZ25lZENlcnQgZnJvbSAnLi9sb2NhbGx5LXNpZ25lZC1jZXJ0JztcbmV4cG9ydCAqIGFzIHByaXZhdGVLZXkgZnJvbSAnLi9wcml2YXRlLWtleSc7XG5leHBvcnQgKiBhcyBzZWxmU2lnbmVkQ2VydCBmcm9tICcuL3NlbGYtc2lnbmVkLWNlcnQnO1xuZXhwb3J0ICogYXMgZGF0YVRsc0NlcnRpZmljYXRlIGZyb20gJy4vZGF0YS10bHMtY2VydGlmaWNhdGUnO1xuZXhwb3J0ICogYXMgZGF0YVRsc1B1YmxpY0tleSBmcm9tICcuL2RhdGEtdGxzLXB1YmxpYy1rZXknO1xuZXhwb3J0ICogYXMgcHJvdmlkZXIgZnJvbSAnLi9wcm92aWRlcic7XG5cbiJdfQ==
@@ -0,0 +1,4 @@
1
+ /**
2
+ * Copyright (c) HashiCorp, Inc.
3
+ * SPDX-License-Identifier: MPL-2.0
4
+ */
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ /**
3
+ * Copyright (c) HashiCorp, Inc.
4
+ * SPDX-License-Identifier: MPL-2.0
5
+ */
6
+ // generated by cdktf get
7
+ Object.defineProperty(exports, 'certRequest', { get: function () { return require('./cert-request'); } });
8
+ Object.defineProperty(exports, 'locallySignedCert', { get: function () { return require('./locally-signed-cert'); } });
9
+ Object.defineProperty(exports, 'privateKey', { get: function () { return require('./private-key'); } });
10
+ Object.defineProperty(exports, 'selfSignedCert', { get: function () { return require('./self-signed-cert'); } });
11
+ Object.defineProperty(exports, 'dataTlsCertificate', { get: function () { return require('./data-tls-certificate'); } });
12
+ Object.defineProperty(exports, 'dataTlsPublicKey', { get: function () { return require('./data-tls-public-key'); } });
13
+ Object.defineProperty(exports, 'provider', { get: function () { return require('./provider'); } });
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF6eS1pbmRleC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9sYXp5LWluZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7O0dBR0c7QUFFSCx5QkFBeUI7QUFDekIsTUFBTSxDQUFDLGNBQWMsQ0FBQyxPQUFPLEVBQUUsYUFBYSxFQUFFLEVBQUUsR0FBRyxFQUFFLGNBQWMsT0FBTyxPQUFPLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUM7QUFDMUcsTUFBTSxDQUFDLGNBQWMsQ0FBQyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsRUFBRSxHQUFHLEVBQUUsY0FBYyxPQUFPLE9BQU8sQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQztBQUN2SCxNQUFNLENBQUMsY0FBYyxDQUFDLE9BQU8sRUFBRSxZQUFZLEVBQUUsRUFBRSxHQUFHLEVBQUUsY0FBYyxPQUFPLE9BQU8sQ0FBQyxlQUFlLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUM7QUFDeEcsTUFBTSxDQUFDLGNBQWMsQ0FBQyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsRUFBRSxHQUFHLEVBQUUsY0FBYyxPQUFPLE9BQU8sQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQztBQUNqSCxNQUFNLENBQUMsY0FBYyxDQUFDLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxFQUFFLEdBQUcsRUFBRSxjQUFjLE9BQU8sT0FBTyxDQUFDLHdCQUF3QixDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDO0FBQ3pILE1BQU0sQ0FBQyxjQUFjLENBQUMsT0FBTyxFQUFFLGtCQUFrQixFQUFFLEVBQUUsR0FBRyxFQUFFLGNBQWMsT0FBTyxPQUFPLENBQUMsdUJBQXVCLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUM7QUFDdEgsTUFBTSxDQUFDLGNBQWMsQ0FBQyxPQUFPLEVBQUUsVUFBVSxFQUFFLEVBQUUsR0FBRyxFQUFFLGNBQWMsT0FBTyxPQUFPLENBQUMsWUFBWSxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIEhhc2hpQ29ycCwgSW5jLlxuICogU1BEWC1MaWNlbnNlLUlkZW50aWZpZXI6IE1QTC0yLjBcbiAqL1xuXG4vLyBnZW5lcmF0ZWQgYnkgY2RrdGYgZ2V0XG5PYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgJ2NlcnRSZXF1ZXN0JywgeyBnZXQ6IGZ1bmN0aW9uICgpIHsgcmV0dXJuIHJlcXVpcmUoJy4vY2VydC1yZXF1ZXN0Jyk7IH0gfSk7XG5PYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgJ2xvY2FsbHlTaWduZWRDZXJ0JywgeyBnZXQ6IGZ1bmN0aW9uICgpIHsgcmV0dXJuIHJlcXVpcmUoJy4vbG9jYWxseS1zaWduZWQtY2VydCcpOyB9IH0pO1xuT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsICdwcml2YXRlS2V5JywgeyBnZXQ6IGZ1bmN0aW9uICgpIHsgcmV0dXJuIHJlcXVpcmUoJy4vcHJpdmF0ZS1rZXknKTsgfSB9KTtcbk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCAnc2VsZlNpZ25lZENlcnQnLCB7IGdldDogZnVuY3Rpb24gKCkgeyByZXR1cm4gcmVxdWlyZSgnLi9zZWxmLXNpZ25lZC1jZXJ0Jyk7IH0gfSk7XG5PYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgJ2RhdGFUbHNDZXJ0aWZpY2F0ZScsIHsgZ2V0OiBmdW5jdGlvbiAoKSB7IHJldHVybiByZXF1aXJlKCcuL2RhdGEtdGxzLWNlcnRpZmljYXRlJyk7IH0gfSk7XG5PYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgJ2RhdGFUbHNQdWJsaWNLZXknLCB7IGdldDogZnVuY3Rpb24gKCkgeyByZXR1cm4gcmVxdWlyZSgnLi9kYXRhLXRscy1wdWJsaWMta2V5Jyk7IH0gfSk7XG5PYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgJ3Byb3ZpZGVyJywgeyBnZXQ6IGZ1bmN0aW9uICgpIHsgcmV0dXJuIHJlcXVpcmUoJy4vcHJvdmlkZXInKTsgfSB9KTtcblxuIl19
@@ -0,0 +1,125 @@
1
+ /**
2
+ * Copyright (c) HashiCorp, Inc.
3
+ * SPDX-License-Identifier: MPL-2.0
4
+ */
5
+ import { Construct } from 'constructs';
6
+ import * as cdktf from 'cdktf';
7
+ export interface LocallySignedCertConfig extends cdktf.TerraformMetaArguments {
8
+ /**
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
+ *
11
+ * 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}
12
+ */
13
+ readonly allowedUses: string[];
14
+ /**
15
+ * Certificate data of the Certificate Authority (CA) in [PEM (RFC 1421)](https://datatracker.ietf.org/doc/html/rfc1421) format.
16
+ *
17
+ * 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}
18
+ */
19
+ readonly caCertPem: string;
20
+ /**
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
+ *
23
+ * 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}
24
+ */
25
+ readonly caPrivateKeyPem: string;
26
+ /**
27
+ * Certificate request data in [PEM (RFC 1421)](https://datatracker.ietf.org/doc/html/rfc1421) format.
28
+ *
29
+ * 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}
30
+ */
31
+ readonly certRequestPem: string;
32
+ /**
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
+ *
35
+ * 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}
36
+ */
37
+ readonly earlyRenewalHours?: number;
38
+ /**
39
+ * Is the generated certificate representing a Certificate Authority (CA) (default: `false`).
40
+ *
41
+ * 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}
42
+ */
43
+ readonly isCaCertificate?: boolean | cdktf.IResolvable;
44
+ /**
45
+ * Should the generated certificate include a [subject key identifier](https://datatracker.ietf.org/doc/html/rfc5280#section-4.2.1.2) (default: `false`).
46
+ *
47
+ * 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}
48
+ */
49
+ readonly setSubjectKeyId?: boolean | cdktf.IResolvable;
50
+ /**
51
+ * Number of hours, after initial issuing, that the certificate will remain valid for.
52
+ *
53
+ * 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}
54
+ */
55
+ readonly validityPeriodHours: number;
56
+ }
57
+ /**
58
+ * Represents a {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs/resources/locally_signed_cert tls_locally_signed_cert}
59
+ */
60
+ export declare class LocallySignedCert extends cdktf.TerraformResource {
61
+ static readonly tfResourceType = "tls_locally_signed_cert";
62
+ /**
63
+ * Generates CDKTF code for importing a LocallySignedCert resource upon running "cdktf plan <stack-name>"
64
+ * @param scope The scope in which to define this construct
65
+ * @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.0/docs/resources/locally_signed_cert#import import section} in the documentation of this resource for the id to use
67
+ * @param provider? Optional instance of the provider where the LocallySignedCert to import is found
68
+ */
69
+ static generateConfigForImport(scope: Construct, importToId: string, importFromId: string, provider?: cdktf.TerraformProvider): cdktf.ImportableResource;
70
+ /**
71
+ * Create a new {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs/resources/locally_signed_cert tls_locally_signed_cert} Resource
72
+ *
73
+ * @param scope The scope in which to define this construct
74
+ * @param id The scoped construct ID. Must be unique amongst siblings in the same scope
75
+ * @param options LocallySignedCertConfig
76
+ */
77
+ constructor(scope: Construct, id: string, config: LocallySignedCertConfig);
78
+ private _allowedUses?;
79
+ get allowedUses(): string[];
80
+ set allowedUses(value: string[]);
81
+ get allowedUsesInput(): string[] | undefined;
82
+ private _caCertPem?;
83
+ get caCertPem(): string;
84
+ set caCertPem(value: string);
85
+ get caCertPemInput(): string | undefined;
86
+ get caKeyAlgorithm(): string;
87
+ private _caPrivateKeyPem?;
88
+ get caPrivateKeyPem(): string;
89
+ set caPrivateKeyPem(value: string);
90
+ get caPrivateKeyPemInput(): string | undefined;
91
+ get certPem(): string;
92
+ private _certRequestPem?;
93
+ get certRequestPem(): string;
94
+ set certRequestPem(value: string);
95
+ get certRequestPemInput(): string | undefined;
96
+ private _earlyRenewalHours?;
97
+ get earlyRenewalHours(): number;
98
+ set earlyRenewalHours(value: number);
99
+ resetEarlyRenewalHours(): void;
100
+ get earlyRenewalHoursInput(): number | undefined;
101
+ get id(): string;
102
+ private _isCaCertificate?;
103
+ get isCaCertificate(): boolean | cdktf.IResolvable;
104
+ set isCaCertificate(value: boolean | cdktf.IResolvable);
105
+ resetIsCaCertificate(): void;
106
+ get isCaCertificateInput(): boolean | cdktf.IResolvable | undefined;
107
+ get readyForRenewal(): cdktf.IResolvable;
108
+ private _setSubjectKeyId?;
109
+ get setSubjectKeyId(): boolean | cdktf.IResolvable;
110
+ set setSubjectKeyId(value: boolean | cdktf.IResolvable);
111
+ resetSetSubjectKeyId(): void;
112
+ get setSubjectKeyIdInput(): boolean | cdktf.IResolvable | undefined;
113
+ get validityEndTime(): string;
114
+ private _validityPeriodHours?;
115
+ get validityPeriodHours(): number;
116
+ set validityPeriodHours(value: number);
117
+ get validityPeriodHoursInput(): number | undefined;
118
+ get validityStartTime(): string;
119
+ protected synthesizeAttributes(): {
120
+ [name: string]: any;
121
+ };
122
+ protected synthesizeHclAttributes(): {
123
+ [name: string]: any;
124
+ };
125
+ }
@@ -0,0 +1,249 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.LocallySignedCert = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ const cdktf = require("cdktf");
7
+ /**
8
+ * Represents a {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs/resources/locally_signed_cert tls_locally_signed_cert}
9
+ */
10
+ class LocallySignedCert extends cdktf.TerraformResource {
11
+ // ==============
12
+ // STATIC Methods
13
+ // ==============
14
+ /**
15
+ * Generates CDKTF code for importing a LocallySignedCert resource upon running "cdktf plan <stack-name>"
16
+ * @param scope The scope in which to define this construct
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.0/docs/resources/locally_signed_cert#import import section} in the documentation of this resource for the id to use
19
+ * @param provider? Optional instance of the provider where the LocallySignedCert to import is found
20
+ */
21
+ static generateConfigForImport(scope, importToId, importFromId, provider) {
22
+ return new cdktf.ImportableResource(scope, importToId, { terraformResourceType: "tls_locally_signed_cert", importId: importFromId, provider });
23
+ }
24
+ // ===========
25
+ // INITIALIZER
26
+ // ===========
27
+ /**
28
+ * Create a new {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs/resources/locally_signed_cert tls_locally_signed_cert} Resource
29
+ *
30
+ * @param scope The scope in which to define this construct
31
+ * @param id The scoped construct ID. Must be unique amongst siblings in the same scope
32
+ * @param options LocallySignedCertConfig
33
+ */
34
+ constructor(scope, id, config) {
35
+ super(scope, id, {
36
+ terraformResourceType: 'tls_locally_signed_cert',
37
+ terraformGeneratorMetadata: {
38
+ providerName: 'tls',
39
+ providerVersion: '4.1.0',
40
+ providerVersionConstraint: '~> 4.0'
41
+ },
42
+ provider: config.provider,
43
+ dependsOn: config.dependsOn,
44
+ count: config.count,
45
+ lifecycle: config.lifecycle,
46
+ provisioners: config.provisioners,
47
+ connection: config.connection,
48
+ forEach: config.forEach
49
+ });
50
+ this._allowedUses = config.allowedUses;
51
+ this._caCertPem = config.caCertPem;
52
+ this._caPrivateKeyPem = config.caPrivateKeyPem;
53
+ this._certRequestPem = config.certRequestPem;
54
+ this._earlyRenewalHours = config.earlyRenewalHours;
55
+ this._isCaCertificate = config.isCaCertificate;
56
+ this._setSubjectKeyId = config.setSubjectKeyId;
57
+ this._validityPeriodHours = config.validityPeriodHours;
58
+ }
59
+ get allowedUses() {
60
+ return this.getListAttribute('allowed_uses');
61
+ }
62
+ set allowedUses(value) {
63
+ this._allowedUses = value;
64
+ }
65
+ // Temporarily expose input value. Use with caution.
66
+ get allowedUsesInput() {
67
+ return this._allowedUses;
68
+ }
69
+ get caCertPem() {
70
+ return this.getStringAttribute('ca_cert_pem');
71
+ }
72
+ set caCertPem(value) {
73
+ this._caCertPem = value;
74
+ }
75
+ // Temporarily expose input value. Use with caution.
76
+ get caCertPemInput() {
77
+ return this._caCertPem;
78
+ }
79
+ // ca_key_algorithm - computed: true, optional: false, required: false
80
+ get caKeyAlgorithm() {
81
+ return this.getStringAttribute('ca_key_algorithm');
82
+ }
83
+ get caPrivateKeyPem() {
84
+ return this.getStringAttribute('ca_private_key_pem');
85
+ }
86
+ set caPrivateKeyPem(value) {
87
+ this._caPrivateKeyPem = value;
88
+ }
89
+ // Temporarily expose input value. Use with caution.
90
+ get caPrivateKeyPemInput() {
91
+ return this._caPrivateKeyPem;
92
+ }
93
+ // cert_pem - computed: true, optional: false, required: false
94
+ get certPem() {
95
+ return this.getStringAttribute('cert_pem');
96
+ }
97
+ get certRequestPem() {
98
+ return this.getStringAttribute('cert_request_pem');
99
+ }
100
+ set certRequestPem(value) {
101
+ this._certRequestPem = value;
102
+ }
103
+ // Temporarily expose input value. Use with caution.
104
+ get certRequestPemInput() {
105
+ return this._certRequestPem;
106
+ }
107
+ get earlyRenewalHours() {
108
+ return this.getNumberAttribute('early_renewal_hours');
109
+ }
110
+ set earlyRenewalHours(value) {
111
+ this._earlyRenewalHours = value;
112
+ }
113
+ resetEarlyRenewalHours() {
114
+ this._earlyRenewalHours = undefined;
115
+ }
116
+ // Temporarily expose input value. Use with caution.
117
+ get earlyRenewalHoursInput() {
118
+ return this._earlyRenewalHours;
119
+ }
120
+ // id - computed: true, optional: false, required: false
121
+ get id() {
122
+ return this.getStringAttribute('id');
123
+ }
124
+ get isCaCertificate() {
125
+ return this.getBooleanAttribute('is_ca_certificate');
126
+ }
127
+ set isCaCertificate(value) {
128
+ this._isCaCertificate = value;
129
+ }
130
+ resetIsCaCertificate() {
131
+ this._isCaCertificate = undefined;
132
+ }
133
+ // Temporarily expose input value. Use with caution.
134
+ get isCaCertificateInput() {
135
+ return this._isCaCertificate;
136
+ }
137
+ // ready_for_renewal - computed: true, optional: false, required: false
138
+ get readyForRenewal() {
139
+ return this.getBooleanAttribute('ready_for_renewal');
140
+ }
141
+ get setSubjectKeyId() {
142
+ return this.getBooleanAttribute('set_subject_key_id');
143
+ }
144
+ set setSubjectKeyId(value) {
145
+ this._setSubjectKeyId = value;
146
+ }
147
+ resetSetSubjectKeyId() {
148
+ this._setSubjectKeyId = undefined;
149
+ }
150
+ // Temporarily expose input value. Use with caution.
151
+ get setSubjectKeyIdInput() {
152
+ return this._setSubjectKeyId;
153
+ }
154
+ // validity_end_time - computed: true, optional: false, required: false
155
+ get validityEndTime() {
156
+ return this.getStringAttribute('validity_end_time');
157
+ }
158
+ get validityPeriodHours() {
159
+ return this.getNumberAttribute('validity_period_hours');
160
+ }
161
+ set validityPeriodHours(value) {
162
+ this._validityPeriodHours = value;
163
+ }
164
+ // Temporarily expose input value. Use with caution.
165
+ get validityPeriodHoursInput() {
166
+ return this._validityPeriodHours;
167
+ }
168
+ // validity_start_time - computed: true, optional: false, required: false
169
+ get validityStartTime() {
170
+ return this.getStringAttribute('validity_start_time');
171
+ }
172
+ // =========
173
+ // SYNTHESIS
174
+ // =========
175
+ synthesizeAttributes() {
176
+ return {
177
+ allowed_uses: cdktf.listMapper(cdktf.stringToTerraform, false)(this._allowedUses),
178
+ ca_cert_pem: cdktf.stringToTerraform(this._caCertPem),
179
+ ca_private_key_pem: cdktf.stringToTerraform(this._caPrivateKeyPem),
180
+ cert_request_pem: cdktf.stringToTerraform(this._certRequestPem),
181
+ early_renewal_hours: cdktf.numberToTerraform(this._earlyRenewalHours),
182
+ is_ca_certificate: cdktf.booleanToTerraform(this._isCaCertificate),
183
+ set_subject_key_id: cdktf.booleanToTerraform(this._setSubjectKeyId),
184
+ validity_period_hours: cdktf.numberToTerraform(this._validityPeriodHours),
185
+ };
186
+ }
187
+ synthesizeHclAttributes() {
188
+ const attrs = {
189
+ allowed_uses: {
190
+ value: cdktf.listMapperHcl(cdktf.stringToHclTerraform, false)(this._allowedUses),
191
+ isBlock: false,
192
+ type: "list",
193
+ storageClassType: "stringList",
194
+ },
195
+ ca_cert_pem: {
196
+ value: cdktf.stringToHclTerraform(this._caCertPem),
197
+ isBlock: false,
198
+ type: "simple",
199
+ storageClassType: "string",
200
+ },
201
+ ca_private_key_pem: {
202
+ value: cdktf.stringToHclTerraform(this._caPrivateKeyPem),
203
+ isBlock: false,
204
+ type: "simple",
205
+ storageClassType: "string",
206
+ },
207
+ cert_request_pem: {
208
+ value: cdktf.stringToHclTerraform(this._certRequestPem),
209
+ isBlock: false,
210
+ type: "simple",
211
+ storageClassType: "string",
212
+ },
213
+ early_renewal_hours: {
214
+ value: cdktf.numberToHclTerraform(this._earlyRenewalHours),
215
+ isBlock: false,
216
+ type: "simple",
217
+ storageClassType: "number",
218
+ },
219
+ is_ca_certificate: {
220
+ value: cdktf.booleanToHclTerraform(this._isCaCertificate),
221
+ isBlock: false,
222
+ type: "simple",
223
+ storageClassType: "boolean",
224
+ },
225
+ set_subject_key_id: {
226
+ value: cdktf.booleanToHclTerraform(this._setSubjectKeyId),
227
+ isBlock: false,
228
+ type: "simple",
229
+ storageClassType: "boolean",
230
+ },
231
+ validity_period_hours: {
232
+ value: cdktf.numberToHclTerraform(this._validityPeriodHours),
233
+ isBlock: false,
234
+ type: "simple",
235
+ storageClassType: "number",
236
+ },
237
+ };
238
+ // remove undefined attributes
239
+ return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
240
+ }
241
+ }
242
+ exports.LocallySignedCert = LocallySignedCert;
243
+ _a = JSII_RTTI_SYMBOL_1;
244
+ LocallySignedCert[_a] = { fqn: "@cdktn/provider-tls.locallySignedCert.LocallySignedCert", version: "11.1.0" };
245
+ // =================
246
+ // STATIC PROPERTIES
247
+ // =================
248
+ 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"]}
@@ -0,0 +1,76 @@
1
+ /**
2
+ * Copyright (c) HashiCorp, Inc.
3
+ * SPDX-License-Identifier: MPL-2.0
4
+ */
5
+ import { Construct } from 'constructs';
6
+ import * as cdktf from 'cdktf';
7
+ export interface PrivateKeyConfig extends cdktf.TerraformMetaArguments {
8
+ /**
9
+ * Name of the algorithm to use when generating the private key. Currently-supported values are: `RSA`, `ECDSA`, `ED25519`.
10
+ *
11
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs/resources/private_key#algorithm PrivateKey#algorithm}
12
+ */
13
+ readonly algorithm: string;
14
+ /**
15
+ * When `algorithm` is `ECDSA`, the name of the elliptic curve to use. Currently-supported values are: `P224`, `P256`, `P384`, `P521`. (default: `P224`).
16
+ *
17
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs/resources/private_key#ecdsa_curve PrivateKey#ecdsa_curve}
18
+ */
19
+ readonly ecdsaCurve?: string;
20
+ /**
21
+ * When `algorithm` is `RSA`, the size of the generated RSA key, in bits (default: `2048`).
22
+ *
23
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs/resources/private_key#rsa_bits PrivateKey#rsa_bits}
24
+ */
25
+ readonly rsaBits?: number;
26
+ }
27
+ /**
28
+ * Represents a {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs/resources/private_key tls_private_key}
29
+ */
30
+ export declare class PrivateKey extends cdktf.TerraformResource {
31
+ static readonly tfResourceType = "tls_private_key";
32
+ /**
33
+ * Generates CDKTF code for importing a PrivateKey resource upon running "cdktf plan <stack-name>"
34
+ * @param scope The scope in which to define this construct
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.0/docs/resources/private_key#import import section} in the documentation of this resource for the id to use
37
+ * @param provider? Optional instance of the provider where the PrivateKey to import is found
38
+ */
39
+ static generateConfigForImport(scope: Construct, importToId: string, importFromId: string, provider?: cdktf.TerraformProvider): cdktf.ImportableResource;
40
+ /**
41
+ * Create a new {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs/resources/private_key tls_private_key} Resource
42
+ *
43
+ * @param scope The scope in which to define this construct
44
+ * @param id The scoped construct ID. Must be unique amongst siblings in the same scope
45
+ * @param options PrivateKeyConfig
46
+ */
47
+ constructor(scope: Construct, id: string, config: PrivateKeyConfig);
48
+ private _algorithm?;
49
+ get algorithm(): string;
50
+ set algorithm(value: string);
51
+ get algorithmInput(): string | undefined;
52
+ private _ecdsaCurve?;
53
+ get ecdsaCurve(): string;
54
+ set ecdsaCurve(value: string);
55
+ resetEcdsaCurve(): void;
56
+ get ecdsaCurveInput(): string | undefined;
57
+ get id(): string;
58
+ get privateKeyOpenssh(): string;
59
+ get privateKeyPem(): string;
60
+ get privateKeyPemPkcs8(): string;
61
+ get publicKeyFingerprintMd5(): string;
62
+ get publicKeyFingerprintSha256(): string;
63
+ get publicKeyOpenssh(): string;
64
+ get publicKeyPem(): string;
65
+ private _rsaBits?;
66
+ get rsaBits(): number;
67
+ set rsaBits(value: number);
68
+ resetRsaBits(): void;
69
+ get rsaBitsInput(): number | undefined;
70
+ protected synthesizeAttributes(): {
71
+ [name: string]: any;
72
+ };
73
+ protected synthesizeHclAttributes(): {
74
+ [name: string]: any;
75
+ };
76
+ }