@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.
@@ -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"]}