@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/.jsii +6405 -0
- package/LICENSE +355 -0
- package/README.md +94 -0
- package/lib/cert-request/index.d.ts +236 -0
- package/lib/cert-request/index.js +534 -0
- package/lib/data-tls-certificate/index.d.ts +114 -0
- package/lib/data-tls-certificate/index.js +262 -0
- package/lib/data-tls-public-key/index.d.ts +64 -0
- package/lib/data-tls-public-key/index.js +141 -0
- package/lib/index.d.ts +11 -0
- package/lib/index.js +16 -0
- package/lib/lazy-index.d.ts +4 -0
- package/lib/lazy-index.js +14 -0
- package/lib/locally-signed-cert/index.d.ts +125 -0
- package/lib/locally-signed-cert/index.js +249 -0
- package/lib/private-key/index.d.ts +76 -0
- package/lib/private-key/index.js +164 -0
- package/lib/provider/index.d.ts +86 -0
- package/lib/provider/index.js +160 -0
- package/lib/self-signed-cert/index.d.ts +303 -0
- package/lib/self-signed-cert/index.js +663 -0
- package/package.json +152 -0
|
@@ -0,0 +1,164 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.PrivateKey = 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/private_key tls_private_key}
|
|
9
|
+
*/
|
|
10
|
+
class PrivateKey extends cdktf.TerraformResource {
|
|
11
|
+
// ==============
|
|
12
|
+
// STATIC Methods
|
|
13
|
+
// ==============
|
|
14
|
+
/**
|
|
15
|
+
* Generates CDKTF code for importing a PrivateKey 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 PrivateKey to import
|
|
18
|
+
* @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
|
|
19
|
+
* @param provider? Optional instance of the provider where the PrivateKey to import is found
|
|
20
|
+
*/
|
|
21
|
+
static generateConfigForImport(scope, importToId, importFromId, provider) {
|
|
22
|
+
return new cdktf.ImportableResource(scope, importToId, { terraformResourceType: "tls_private_key", 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/private_key tls_private_key} 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 PrivateKeyConfig
|
|
33
|
+
*/
|
|
34
|
+
constructor(scope, id, config) {
|
|
35
|
+
super(scope, id, {
|
|
36
|
+
terraformResourceType: 'tls_private_key',
|
|
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._algorithm = config.algorithm;
|
|
51
|
+
this._ecdsaCurve = config.ecdsaCurve;
|
|
52
|
+
this._rsaBits = config.rsaBits;
|
|
53
|
+
}
|
|
54
|
+
get algorithm() {
|
|
55
|
+
return this.getStringAttribute('algorithm');
|
|
56
|
+
}
|
|
57
|
+
set algorithm(value) {
|
|
58
|
+
this._algorithm = value;
|
|
59
|
+
}
|
|
60
|
+
// Temporarily expose input value. Use with caution.
|
|
61
|
+
get algorithmInput() {
|
|
62
|
+
return this._algorithm;
|
|
63
|
+
}
|
|
64
|
+
get ecdsaCurve() {
|
|
65
|
+
return this.getStringAttribute('ecdsa_curve');
|
|
66
|
+
}
|
|
67
|
+
set ecdsaCurve(value) {
|
|
68
|
+
this._ecdsaCurve = value;
|
|
69
|
+
}
|
|
70
|
+
resetEcdsaCurve() {
|
|
71
|
+
this._ecdsaCurve = undefined;
|
|
72
|
+
}
|
|
73
|
+
// Temporarily expose input value. Use with caution.
|
|
74
|
+
get ecdsaCurveInput() {
|
|
75
|
+
return this._ecdsaCurve;
|
|
76
|
+
}
|
|
77
|
+
// id - computed: true, optional: false, required: false
|
|
78
|
+
get id() {
|
|
79
|
+
return this.getStringAttribute('id');
|
|
80
|
+
}
|
|
81
|
+
// private_key_openssh - computed: true, optional: false, required: false
|
|
82
|
+
get privateKeyOpenssh() {
|
|
83
|
+
return this.getStringAttribute('private_key_openssh');
|
|
84
|
+
}
|
|
85
|
+
// private_key_pem - computed: true, optional: false, required: false
|
|
86
|
+
get privateKeyPem() {
|
|
87
|
+
return this.getStringAttribute('private_key_pem');
|
|
88
|
+
}
|
|
89
|
+
// private_key_pem_pkcs8 - computed: true, optional: false, required: false
|
|
90
|
+
get privateKeyPemPkcs8() {
|
|
91
|
+
return this.getStringAttribute('private_key_pem_pkcs8');
|
|
92
|
+
}
|
|
93
|
+
// public_key_fingerprint_md5 - computed: true, optional: false, required: false
|
|
94
|
+
get publicKeyFingerprintMd5() {
|
|
95
|
+
return this.getStringAttribute('public_key_fingerprint_md5');
|
|
96
|
+
}
|
|
97
|
+
// public_key_fingerprint_sha256 - computed: true, optional: false, required: false
|
|
98
|
+
get publicKeyFingerprintSha256() {
|
|
99
|
+
return this.getStringAttribute('public_key_fingerprint_sha256');
|
|
100
|
+
}
|
|
101
|
+
// public_key_openssh - computed: true, optional: false, required: false
|
|
102
|
+
get publicKeyOpenssh() {
|
|
103
|
+
return this.getStringAttribute('public_key_openssh');
|
|
104
|
+
}
|
|
105
|
+
// public_key_pem - computed: true, optional: false, required: false
|
|
106
|
+
get publicKeyPem() {
|
|
107
|
+
return this.getStringAttribute('public_key_pem');
|
|
108
|
+
}
|
|
109
|
+
get rsaBits() {
|
|
110
|
+
return this.getNumberAttribute('rsa_bits');
|
|
111
|
+
}
|
|
112
|
+
set rsaBits(value) {
|
|
113
|
+
this._rsaBits = value;
|
|
114
|
+
}
|
|
115
|
+
resetRsaBits() {
|
|
116
|
+
this._rsaBits = undefined;
|
|
117
|
+
}
|
|
118
|
+
// Temporarily expose input value. Use with caution.
|
|
119
|
+
get rsaBitsInput() {
|
|
120
|
+
return this._rsaBits;
|
|
121
|
+
}
|
|
122
|
+
// =========
|
|
123
|
+
// SYNTHESIS
|
|
124
|
+
// =========
|
|
125
|
+
synthesizeAttributes() {
|
|
126
|
+
return {
|
|
127
|
+
algorithm: cdktf.stringToTerraform(this._algorithm),
|
|
128
|
+
ecdsa_curve: cdktf.stringToTerraform(this._ecdsaCurve),
|
|
129
|
+
rsa_bits: cdktf.numberToTerraform(this._rsaBits),
|
|
130
|
+
};
|
|
131
|
+
}
|
|
132
|
+
synthesizeHclAttributes() {
|
|
133
|
+
const attrs = {
|
|
134
|
+
algorithm: {
|
|
135
|
+
value: cdktf.stringToHclTerraform(this._algorithm),
|
|
136
|
+
isBlock: false,
|
|
137
|
+
type: "simple",
|
|
138
|
+
storageClassType: "string",
|
|
139
|
+
},
|
|
140
|
+
ecdsa_curve: {
|
|
141
|
+
value: cdktf.stringToHclTerraform(this._ecdsaCurve),
|
|
142
|
+
isBlock: false,
|
|
143
|
+
type: "simple",
|
|
144
|
+
storageClassType: "string",
|
|
145
|
+
},
|
|
146
|
+
rsa_bits: {
|
|
147
|
+
value: cdktf.numberToHclTerraform(this._rsaBits),
|
|
148
|
+
isBlock: false,
|
|
149
|
+
type: "simple",
|
|
150
|
+
storageClassType: "number",
|
|
151
|
+
},
|
|
152
|
+
};
|
|
153
|
+
// remove undefined attributes
|
|
154
|
+
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
exports.PrivateKey = PrivateKey;
|
|
158
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
159
|
+
PrivateKey[_a] = { fqn: "@cdktn/provider-tls.privateKey.PrivateKey", version: "11.1.0" };
|
|
160
|
+
// =================
|
|
161
|
+
// STATIC PROPERTIES
|
|
162
|
+
// =================
|
|
163
|
+
PrivateKey.tfResourceType = "tls_private_key";
|
|
164
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/private-key/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/private_key\n// generated from terraform resource schema\n\nimport { Construct } from 'constructs';\nimport * as cdktf from 'cdktf';\n\n// Configuration\n\nexport interface PrivateKeyConfig extends cdktf.TerraformMetaArguments {\n  /**\n  * Name of the algorithm to use when generating the private key. Currently-supported values are: `RSA`, `ECDSA`, `ED25519`. \n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs/resources/private_key#algorithm PrivateKey#algorithm}\n  */\n  readonly algorithm: string;\n  /**\n  * When `algorithm` is `ECDSA`, the name of the elliptic curve to use. Currently-supported values are: `P224`, `P256`, `P384`, `P521`. (default: `P224`).\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs/resources/private_key#ecdsa_curve PrivateKey#ecdsa_curve}\n  */\n  readonly ecdsaCurve?: string;\n  /**\n  * When `algorithm` is `RSA`, the size of the generated RSA key, in bits (default: `2048`).\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs/resources/private_key#rsa_bits PrivateKey#rsa_bits}\n  */\n  readonly rsaBits?: number;\n}\n\n/**\n* Represents a {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs/resources/private_key tls_private_key}\n*/\nexport class PrivateKey extends cdktf.TerraformResource {\n\n  // =================\n  // STATIC PROPERTIES\n  // =================\n  public static readonly tfResourceType = \"tls_private_key\";\n\n  // ==============\n  // STATIC Methods\n  // ==============\n  /**\n  * Generates CDKTF code for importing a PrivateKey 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 PrivateKey to import\n  * @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\n  * @param provider? Optional instance of the provider where the PrivateKey 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_private_key\", 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/private_key tls_private_key} 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 PrivateKeyConfig\n  */\n  public constructor(scope: Construct, id: string, config: PrivateKeyConfig) {\n    super(scope, id, {\n      terraformResourceType: 'tls_private_key',\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._algorithm = config.algorithm;\n    this._ecdsaCurve = config.ecdsaCurve;\n    this._rsaBits = config.rsaBits;\n  }\n\n  // ==========\n  // ATTRIBUTES\n  // ==========\n\n  // algorithm - computed: false, optional: false, required: true\n  private _algorithm?: string; \n  public get algorithm() {\n    return this.getStringAttribute('algorithm');\n  }\n  public set algorithm(value: string) {\n    this._algorithm = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get algorithmInput() {\n    return this._algorithm;\n  }\n\n  // ecdsa_curve - computed: true, optional: true, required: false\n  private _ecdsaCurve?: string; \n  public get ecdsaCurve() {\n    return this.getStringAttribute('ecdsa_curve');\n  }\n  public set ecdsaCurve(value: string) {\n    this._ecdsaCurve = value;\n  }\n  public resetEcdsaCurve() {\n    this._ecdsaCurve = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get ecdsaCurveInput() {\n    return this._ecdsaCurve;\n  }\n\n  // id - computed: true, optional: false, required: false\n  public get id() {\n    return this.getStringAttribute('id');\n  }\n\n  // private_key_openssh - computed: true, optional: false, required: false\n  public get privateKeyOpenssh() {\n    return this.getStringAttribute('private_key_openssh');\n  }\n\n  // private_key_pem - computed: true, optional: false, required: false\n  public get privateKeyPem() {\n    return this.getStringAttribute('private_key_pem');\n  }\n\n  // private_key_pem_pkcs8 - computed: true, optional: false, required: false\n  public get privateKeyPemPkcs8() {\n    return this.getStringAttribute('private_key_pem_pkcs8');\n  }\n\n  // public_key_fingerprint_md5 - computed: true, optional: false, required: false\n  public get publicKeyFingerprintMd5() {\n    return this.getStringAttribute('public_key_fingerprint_md5');\n  }\n\n  // public_key_fingerprint_sha256 - computed: true, optional: false, required: false\n  public get publicKeyFingerprintSha256() {\n    return this.getStringAttribute('public_key_fingerprint_sha256');\n  }\n\n  // public_key_openssh - computed: true, optional: false, required: false\n  public get publicKeyOpenssh() {\n    return this.getStringAttribute('public_key_openssh');\n  }\n\n  // public_key_pem - computed: true, optional: false, required: false\n  public get publicKeyPem() {\n    return this.getStringAttribute('public_key_pem');\n  }\n\n  // rsa_bits - computed: true, optional: true, required: false\n  private _rsaBits?: number; \n  public get rsaBits() {\n    return this.getNumberAttribute('rsa_bits');\n  }\n  public set rsaBits(value: number) {\n    this._rsaBits = value;\n  }\n  public resetRsaBits() {\n    this._rsaBits = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get rsaBitsInput() {\n    return this._rsaBits;\n  }\n\n  // =========\n  // SYNTHESIS\n  // =========\n\n  protected synthesizeAttributes(): { [name: string]: any } {\n    return {\n      algorithm: cdktf.stringToTerraform(this._algorithm),\n      ecdsa_curve: cdktf.stringToTerraform(this._ecdsaCurve),\n      rsa_bits: cdktf.numberToTerraform(this._rsaBits),\n    };\n  }\n\n  protected synthesizeHclAttributes(): { [name: string]: any } {\n    const attrs = {\n      algorithm: {\n        value: cdktf.stringToHclTerraform(this._algorithm),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"string\",\n      },\n      ecdsa_curve: {\n        value: cdktf.stringToHclTerraform(this._ecdsaCurve),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"string\",\n      },\n      rsa_bits: {\n        value: cdktf.numberToHclTerraform(this._rsaBits),\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,86 @@
|
|
|
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 TlsProviderConfig {
|
|
8
|
+
/**
|
|
9
|
+
* Alias name
|
|
10
|
+
*
|
|
11
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs#alias TlsProvider#alias}
|
|
12
|
+
*/
|
|
13
|
+
readonly alias?: string;
|
|
14
|
+
/**
|
|
15
|
+
* proxy block
|
|
16
|
+
*
|
|
17
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs#proxy TlsProvider#proxy}
|
|
18
|
+
*/
|
|
19
|
+
readonly proxy?: TlsProviderProxy[] | cdktf.IResolvable;
|
|
20
|
+
}
|
|
21
|
+
export interface TlsProviderProxy {
|
|
22
|
+
/**
|
|
23
|
+
* When `true` the provider will discover the proxy configuration from environment variables. This is based upon [`http.ProxyFromEnvironment`](https://pkg.go.dev/net/http#ProxyFromEnvironment) and it supports the same environment variables (default: `true`).
|
|
24
|
+
*
|
|
25
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs#from_env TlsProvider#from_env}
|
|
26
|
+
*/
|
|
27
|
+
readonly fromEnv?: boolean | cdktf.IResolvable;
|
|
28
|
+
/**
|
|
29
|
+
* Password used for Basic authentication against the Proxy.
|
|
30
|
+
*
|
|
31
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs#password TlsProvider#password}
|
|
32
|
+
*/
|
|
33
|
+
readonly password?: string;
|
|
34
|
+
/**
|
|
35
|
+
* URL used to connect to the Proxy. Accepted schemes are: `http`, `https`, `socks5`.
|
|
36
|
+
*
|
|
37
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs#url TlsProvider#url}
|
|
38
|
+
*/
|
|
39
|
+
readonly url?: string;
|
|
40
|
+
/**
|
|
41
|
+
* Username (or Token) used for Basic authentication against the Proxy.
|
|
42
|
+
*
|
|
43
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs#username TlsProvider#username}
|
|
44
|
+
*/
|
|
45
|
+
readonly username?: string;
|
|
46
|
+
}
|
|
47
|
+
export declare function tlsProviderProxyToTerraform(struct?: TlsProviderProxy | cdktf.IResolvable): any;
|
|
48
|
+
export declare function tlsProviderProxyToHclTerraform(struct?: TlsProviderProxy | cdktf.IResolvable): any;
|
|
49
|
+
/**
|
|
50
|
+
* Represents a {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs tls}
|
|
51
|
+
*/
|
|
52
|
+
export declare class TlsProvider extends cdktf.TerraformProvider {
|
|
53
|
+
static readonly tfResourceType = "tls";
|
|
54
|
+
/**
|
|
55
|
+
* Generates CDKTF code for importing a TlsProvider resource upon running "cdktf plan <stack-name>"
|
|
56
|
+
* @param scope The scope in which to define this construct
|
|
57
|
+
* @param importToId The construct id used in the generated config for the TlsProvider to import
|
|
58
|
+
* @param importFromId The id of the existing TlsProvider that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs#import import section} in the documentation of this resource for the id to use
|
|
59
|
+
* @param provider? Optional instance of the provider where the TlsProvider to import is found
|
|
60
|
+
*/
|
|
61
|
+
static generateConfigForImport(scope: Construct, importToId: string, importFromId: string, provider?: cdktf.TerraformProvider): cdktf.ImportableResource;
|
|
62
|
+
/**
|
|
63
|
+
* Create a new {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs tls} Resource
|
|
64
|
+
*
|
|
65
|
+
* @param scope The scope in which to define this construct
|
|
66
|
+
* @param id The scoped construct ID. Must be unique amongst siblings in the same scope
|
|
67
|
+
* @param options TlsProviderConfig = {}
|
|
68
|
+
*/
|
|
69
|
+
constructor(scope: Construct, id: string, config?: TlsProviderConfig);
|
|
70
|
+
private _alias?;
|
|
71
|
+
get alias(): string | undefined;
|
|
72
|
+
set alias(value: string | undefined);
|
|
73
|
+
resetAlias(): void;
|
|
74
|
+
get aliasInput(): string | undefined;
|
|
75
|
+
private _proxy?;
|
|
76
|
+
get proxy(): TlsProviderProxy[] | cdktf.IResolvable | undefined;
|
|
77
|
+
set proxy(value: TlsProviderProxy[] | cdktf.IResolvable | undefined);
|
|
78
|
+
resetProxy(): void;
|
|
79
|
+
get proxyInput(): cdktf.IResolvable | TlsProviderProxy[] | undefined;
|
|
80
|
+
protected synthesizeAttributes(): {
|
|
81
|
+
[name: string]: any;
|
|
82
|
+
};
|
|
83
|
+
protected synthesizeHclAttributes(): {
|
|
84
|
+
[name: string]: any;
|
|
85
|
+
};
|
|
86
|
+
}
|
|
@@ -0,0 +1,160 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.TlsProvider = void 0;
|
|
5
|
+
exports.tlsProviderProxyToTerraform = tlsProviderProxyToTerraform;
|
|
6
|
+
exports.tlsProviderProxyToHclTerraform = tlsProviderProxyToHclTerraform;
|
|
7
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
8
|
+
const cdktf = require("cdktf");
|
|
9
|
+
function tlsProviderProxyToTerraform(struct) {
|
|
10
|
+
if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) {
|
|
11
|
+
return struct;
|
|
12
|
+
}
|
|
13
|
+
if (cdktf.isComplexElement(struct)) {
|
|
14
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
15
|
+
}
|
|
16
|
+
return {
|
|
17
|
+
from_env: cdktf.booleanToTerraform(struct.fromEnv),
|
|
18
|
+
password: cdktf.stringToTerraform(struct.password),
|
|
19
|
+
url: cdktf.stringToTerraform(struct.url),
|
|
20
|
+
username: cdktf.stringToTerraform(struct.username),
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
function tlsProviderProxyToHclTerraform(struct) {
|
|
24
|
+
if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) {
|
|
25
|
+
return struct;
|
|
26
|
+
}
|
|
27
|
+
if (cdktf.isComplexElement(struct)) {
|
|
28
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
29
|
+
}
|
|
30
|
+
const attrs = {
|
|
31
|
+
from_env: {
|
|
32
|
+
value: cdktf.booleanToHclTerraform(struct.fromEnv),
|
|
33
|
+
isBlock: false,
|
|
34
|
+
type: "simple",
|
|
35
|
+
storageClassType: "boolean",
|
|
36
|
+
},
|
|
37
|
+
password: {
|
|
38
|
+
value: cdktf.stringToHclTerraform(struct.password),
|
|
39
|
+
isBlock: false,
|
|
40
|
+
type: "simple",
|
|
41
|
+
storageClassType: "string",
|
|
42
|
+
},
|
|
43
|
+
url: {
|
|
44
|
+
value: cdktf.stringToHclTerraform(struct.url),
|
|
45
|
+
isBlock: false,
|
|
46
|
+
type: "simple",
|
|
47
|
+
storageClassType: "string",
|
|
48
|
+
},
|
|
49
|
+
username: {
|
|
50
|
+
value: cdktf.stringToHclTerraform(struct.username),
|
|
51
|
+
isBlock: false,
|
|
52
|
+
type: "simple",
|
|
53
|
+
storageClassType: "string",
|
|
54
|
+
},
|
|
55
|
+
};
|
|
56
|
+
// remove undefined attributes
|
|
57
|
+
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* Represents a {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs tls}
|
|
61
|
+
*/
|
|
62
|
+
class TlsProvider extends cdktf.TerraformProvider {
|
|
63
|
+
// ==============
|
|
64
|
+
// STATIC Methods
|
|
65
|
+
// ==============
|
|
66
|
+
/**
|
|
67
|
+
* Generates CDKTF code for importing a TlsProvider resource upon running "cdktf plan <stack-name>"
|
|
68
|
+
* @param scope The scope in which to define this construct
|
|
69
|
+
* @param importToId The construct id used in the generated config for the TlsProvider to import
|
|
70
|
+
* @param importFromId The id of the existing TlsProvider that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs#import import section} in the documentation of this resource for the id to use
|
|
71
|
+
* @param provider? Optional instance of the provider where the TlsProvider to import is found
|
|
72
|
+
*/
|
|
73
|
+
static generateConfigForImport(scope, importToId, importFromId, provider) {
|
|
74
|
+
return new cdktf.ImportableResource(scope, importToId, { terraformResourceType: "tls", importId: importFromId, provider });
|
|
75
|
+
}
|
|
76
|
+
// ===========
|
|
77
|
+
// INITIALIZER
|
|
78
|
+
// ===========
|
|
79
|
+
/**
|
|
80
|
+
* Create a new {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs tls} Resource
|
|
81
|
+
*
|
|
82
|
+
* @param scope The scope in which to define this construct
|
|
83
|
+
* @param id The scoped construct ID. Must be unique amongst siblings in the same scope
|
|
84
|
+
* @param options TlsProviderConfig = {}
|
|
85
|
+
*/
|
|
86
|
+
constructor(scope, id, config = {}) {
|
|
87
|
+
super(scope, id, {
|
|
88
|
+
terraformResourceType: 'tls',
|
|
89
|
+
terraformGeneratorMetadata: {
|
|
90
|
+
providerName: 'tls',
|
|
91
|
+
providerVersion: '4.1.0',
|
|
92
|
+
providerVersionConstraint: '~> 4.0'
|
|
93
|
+
},
|
|
94
|
+
terraformProviderSource: 'hashicorp/tls'
|
|
95
|
+
});
|
|
96
|
+
this._alias = config.alias;
|
|
97
|
+
this._proxy = config.proxy;
|
|
98
|
+
}
|
|
99
|
+
get alias() {
|
|
100
|
+
return this._alias;
|
|
101
|
+
}
|
|
102
|
+
set alias(value) {
|
|
103
|
+
this._alias = value;
|
|
104
|
+
}
|
|
105
|
+
resetAlias() {
|
|
106
|
+
this._alias = undefined;
|
|
107
|
+
}
|
|
108
|
+
// Temporarily expose input value. Use with caution.
|
|
109
|
+
get aliasInput() {
|
|
110
|
+
return this._alias;
|
|
111
|
+
}
|
|
112
|
+
get proxy() {
|
|
113
|
+
return this._proxy;
|
|
114
|
+
}
|
|
115
|
+
set proxy(value) {
|
|
116
|
+
this._proxy = value;
|
|
117
|
+
}
|
|
118
|
+
resetProxy() {
|
|
119
|
+
this._proxy = undefined;
|
|
120
|
+
}
|
|
121
|
+
// Temporarily expose input value. Use with caution.
|
|
122
|
+
get proxyInput() {
|
|
123
|
+
return this._proxy;
|
|
124
|
+
}
|
|
125
|
+
// =========
|
|
126
|
+
// SYNTHESIS
|
|
127
|
+
// =========
|
|
128
|
+
synthesizeAttributes() {
|
|
129
|
+
return {
|
|
130
|
+
alias: cdktf.stringToTerraform(this._alias),
|
|
131
|
+
proxy: cdktf.listMapper(tlsProviderProxyToTerraform, true)(this._proxy),
|
|
132
|
+
};
|
|
133
|
+
}
|
|
134
|
+
synthesizeHclAttributes() {
|
|
135
|
+
const attrs = {
|
|
136
|
+
alias: {
|
|
137
|
+
value: cdktf.stringToHclTerraform(this._alias),
|
|
138
|
+
isBlock: false,
|
|
139
|
+
type: "simple",
|
|
140
|
+
storageClassType: "string",
|
|
141
|
+
},
|
|
142
|
+
proxy: {
|
|
143
|
+
value: cdktf.listMapperHcl(tlsProviderProxyToHclTerraform, true)(this._proxy),
|
|
144
|
+
isBlock: true,
|
|
145
|
+
type: "list",
|
|
146
|
+
storageClassType: "TlsProviderProxyList",
|
|
147
|
+
},
|
|
148
|
+
};
|
|
149
|
+
// remove undefined attributes
|
|
150
|
+
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
exports.TlsProvider = TlsProvider;
|
|
154
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
155
|
+
TlsProvider[_a] = { fqn: "@cdktn/provider-tls.provider.TlsProvider", version: "11.1.0" };
|
|
156
|
+
// =================
|
|
157
|
+
// STATIC PROPERTIES
|
|
158
|
+
// =================
|
|
159
|
+
TlsProvider.tfResourceType = "tls";
|
|
160
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/provider/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\n// generated from terraform resource schema\n\nimport { Construct } from 'constructs';\nimport * as cdktf from 'cdktf';\n\n// Configuration\n\nexport interface TlsProviderConfig {\n  /**\n  * Alias name\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs#alias TlsProvider#alias}\n  */\n  readonly alias?: string;\n  /**\n  * proxy block\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs#proxy TlsProvider#proxy}\n  */\n  readonly proxy?: TlsProviderProxy[] | cdktf.IResolvable;\n}\nexport interface TlsProviderProxy {\n  /**\n  * When `true` the provider will discover the proxy configuration from environment variables. This is based upon [`http.ProxyFromEnvironment`](https://pkg.go.dev/net/http#ProxyFromEnvironment) and it supports the same environment variables (default: `true`).\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs#from_env TlsProvider#from_env}\n  */\n  readonly fromEnv?: boolean | cdktf.IResolvable;\n  /**\n  * Password used for Basic authentication against the Proxy.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs#password TlsProvider#password}\n  */\n  readonly password?: string;\n  /**\n  * URL used to connect to the Proxy. Accepted schemes are: `http`, `https`, `socks5`. \n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs#url TlsProvider#url}\n  */\n  readonly url?: string;\n  /**\n  * Username (or Token) used for Basic authentication against the Proxy.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs#username TlsProvider#username}\n  */\n  readonly username?: string;\n}\n\nexport function tlsProviderProxyToTerraform(struct?: TlsProviderProxy | cdktf.IResolvable): any {\n  if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) { return struct; }\n  if (cdktf.isComplexElement(struct)) {\n    throw new Error(\"A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration\");\n  }\n  return {\n    from_env: cdktf.booleanToTerraform(struct!.fromEnv),\n    password: cdktf.stringToTerraform(struct!.password),\n    url: cdktf.stringToTerraform(struct!.url),\n    username: cdktf.stringToTerraform(struct!.username),\n  }\n}\n\n\nexport function tlsProviderProxyToHclTerraform(struct?: TlsProviderProxy | cdktf.IResolvable): any {\n  if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) { return struct; }\n  if (cdktf.isComplexElement(struct)) {\n    throw new Error(\"A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration\");\n  }\n  const attrs = {\n    from_env: {\n      value: cdktf.booleanToHclTerraform(struct!.fromEnv),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"boolean\",\n    },\n    password: {\n      value: cdktf.stringToHclTerraform(struct!.password),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"string\",\n    },\n    url: {\n      value: cdktf.stringToHclTerraform(struct!.url),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"string\",\n    },\n    username: {\n      value: cdktf.stringToHclTerraform(struct!.username),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"string\",\n    },\n  };\n\n  // remove undefined attributes\n  return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));\n}\n\n\n/**\n* Represents a {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs tls}\n*/\nexport class TlsProvider extends cdktf.TerraformProvider {\n\n  // =================\n  // STATIC PROPERTIES\n  // =================\n  public static readonly tfResourceType = \"tls\";\n\n  // ==============\n  // STATIC Methods\n  // ==============\n  /**\n  * Generates CDKTF code for importing a TlsProvider 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 TlsProvider to import\n  * @param importFromId The id of the existing TlsProvider that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/tls/4.1.0/docs#import import section} in the documentation of this resource for the id to use\n  * @param provider? Optional instance of the provider where the TlsProvider 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\", 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 tls} 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 TlsProviderConfig = {}\n  */\n  public constructor(scope: Construct, id: string, config: TlsProviderConfig = {}) {\n    super(scope, id, {\n      terraformResourceType: 'tls',\n      terraformGeneratorMetadata: {\n        providerName: 'tls',\n        providerVersion: '4.1.0',\n        providerVersionConstraint: '~> 4.0'\n      },\n      terraformProviderSource: 'hashicorp/tls'\n    });\n    this._alias = config.alias;\n    this._proxy = config.proxy;\n  }\n\n  // ==========\n  // ATTRIBUTES\n  // ==========\n\n  // alias - computed: false, optional: true, required: false\n  private _alias?: string; \n  public get alias() {\n    return this._alias;\n  }\n  public set alias(value: string | undefined) {\n    this._alias = value;\n  }\n  public resetAlias() {\n    this._alias = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get aliasInput() {\n    return this._alias;\n  }\n\n  // proxy - computed: false, optional: true, required: false\n  private _proxy?: TlsProviderProxy[] | cdktf.IResolvable; \n  public get proxy() {\n    return this._proxy;\n  }\n  public set proxy(value: TlsProviderProxy[] | cdktf.IResolvable | undefined) {\n    this._proxy = value;\n  }\n  public resetProxy() {\n    this._proxy = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get proxyInput() {\n    return this._proxy;\n  }\n\n  // =========\n  // SYNTHESIS\n  // =========\n\n  protected synthesizeAttributes(): { [name: string]: any } {\n    return {\n      alias: cdktf.stringToTerraform(this._alias),\n      proxy: cdktf.listMapper(tlsProviderProxyToTerraform, true)(this._proxy),\n    };\n  }\n\n  protected synthesizeHclAttributes(): { [name: string]: any } {\n    const attrs = {\n      alias: {\n        value: cdktf.stringToHclTerraform(this._alias),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"string\",\n      },\n      proxy: {\n        value: cdktf.listMapperHcl(tlsProviderProxyToHclTerraform, true)(this._proxy),\n        isBlock: true,\n        type: \"list\",\n        storageClassType: \"TlsProviderProxyList\",\n      },\n    };\n\n    // remove undefined attributes\n    return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined ))\n  }\n}\n"]}
|