@cdktn/provider-dns 9.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.
Files changed (42) hide show
  1. package/.jsii +8002 -0
  2. package/LICENSE +355 -0
  3. package/README.md +94 -0
  4. package/lib/a-record-set/index.d.ts +90 -0
  5. package/lib/a-record-set/index.js +171 -0
  6. package/lib/aaaa-record-set/index.d.ts +90 -0
  7. package/lib/aaaa-record-set/index.js +171 -0
  8. package/lib/cname-record/index.d.ts +78 -0
  9. package/lib/cname-record/index.js +151 -0
  10. package/lib/data-dns-a-record-set/index.d.ts +48 -0
  11. package/lib/data-dns-a-record-set/index.js +101 -0
  12. package/lib/data-dns-aaaa-record-set/index.d.ts +48 -0
  13. package/lib/data-dns-aaaa-record-set/index.js +101 -0
  14. package/lib/data-dns-cname-record-set/index.d.ts +48 -0
  15. package/lib/data-dns-cname-record-set/index.js +101 -0
  16. package/lib/data-dns-mx-record-set/index.d.ts +82 -0
  17. package/lib/data-dns-mx-record-set/index.js +178 -0
  18. package/lib/data-dns-ns-record-set/index.d.ts +48 -0
  19. package/lib/data-dns-ns-record-set/index.js +98 -0
  20. package/lib/data-dns-ptr-record-set/index.d.ts +48 -0
  21. package/lib/data-dns-ptr-record-set/index.js +101 -0
  22. package/lib/data-dns-srv-record-set/index.d.ts +84 -0
  23. package/lib/data-dns-srv-record-set/index.js +189 -0
  24. package/lib/data-dns-txt-record-set/index.d.ts +49 -0
  25. package/lib/data-dns-txt-record-set/index.js +102 -0
  26. package/lib/index.d.ts +21 -0
  27. package/lib/index.js +26 -0
  28. package/lib/lazy-index.d.ts +4 -0
  29. package/lib/lazy-index.js +24 -0
  30. package/lib/mx-record-set/index.d.ts +133 -0
  31. package/lib/mx-record-set/index.js +291 -0
  32. package/lib/ns-record-set/index.d.ts +78 -0
  33. package/lib/ns-record-set/index.js +154 -0
  34. package/lib/provider/index.d.ts +145 -0
  35. package/lib/provider/index.js +247 -0
  36. package/lib/ptr-record/index.d.ts +79 -0
  37. package/lib/ptr-record/index.js +157 -0
  38. package/lib/srv-record-set/index.d.ts +152 -0
  39. package/lib/srv-record-set/index.js +334 -0
  40. package/lib/txt-record-set/index.d.ts +79 -0
  41. package/lib/txt-record-set/index.js +157 -0
  42. package/package.json +152 -0
@@ -0,0 +1,154 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.NsRecordSet = 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/dns/3.4.3/docs/resources/ns_record_set dns_ns_record_set}
9
+ */
10
+ class NsRecordSet extends cdktf.TerraformResource {
11
+ // ==============
12
+ // STATIC Methods
13
+ // ==============
14
+ /**
15
+ * Generates CDKTF code for importing a NsRecordSet 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 NsRecordSet to import
18
+ * @param importFromId The id of the existing NsRecordSet that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/ns_record_set#import import section} in the documentation of this resource for the id to use
19
+ * @param provider? Optional instance of the provider where the NsRecordSet to import is found
20
+ */
21
+ static generateConfigForImport(scope, importToId, importFromId, provider) {
22
+ return new cdktf.ImportableResource(scope, importToId, { terraformResourceType: "dns_ns_record_set", importId: importFromId, provider });
23
+ }
24
+ // ===========
25
+ // INITIALIZER
26
+ // ===========
27
+ /**
28
+ * Create a new {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/ns_record_set dns_ns_record_set} 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 NsRecordSetConfig
33
+ */
34
+ constructor(scope, id, config) {
35
+ super(scope, id, {
36
+ terraformResourceType: 'dns_ns_record_set',
37
+ terraformGeneratorMetadata: {
38
+ providerName: 'dns',
39
+ providerVersion: '3.4.3',
40
+ providerVersionConstraint: '~> 3.2'
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._name = config.name;
51
+ this._nameservers = config.nameservers;
52
+ this._ttl = config.ttl;
53
+ this._zone = config.zone;
54
+ }
55
+ // ==========
56
+ // ATTRIBUTES
57
+ // ==========
58
+ // id - computed: true, optional: false, required: false
59
+ get id() {
60
+ return this.getStringAttribute('id');
61
+ }
62
+ get name() {
63
+ return this.getStringAttribute('name');
64
+ }
65
+ set name(value) {
66
+ this._name = value;
67
+ }
68
+ // Temporarily expose input value. Use with caution.
69
+ get nameInput() {
70
+ return this._name;
71
+ }
72
+ get nameservers() {
73
+ return cdktf.Fn.tolist(this.getListAttribute('nameservers'));
74
+ }
75
+ set nameservers(value) {
76
+ this._nameservers = value;
77
+ }
78
+ // Temporarily expose input value. Use with caution.
79
+ get nameserversInput() {
80
+ return this._nameservers;
81
+ }
82
+ get ttl() {
83
+ return this.getNumberAttribute('ttl');
84
+ }
85
+ set ttl(value) {
86
+ this._ttl = value;
87
+ }
88
+ resetTtl() {
89
+ this._ttl = undefined;
90
+ }
91
+ // Temporarily expose input value. Use with caution.
92
+ get ttlInput() {
93
+ return this._ttl;
94
+ }
95
+ get zone() {
96
+ return this.getStringAttribute('zone');
97
+ }
98
+ set zone(value) {
99
+ this._zone = value;
100
+ }
101
+ // Temporarily expose input value. Use with caution.
102
+ get zoneInput() {
103
+ return this._zone;
104
+ }
105
+ // =========
106
+ // SYNTHESIS
107
+ // =========
108
+ synthesizeAttributes() {
109
+ return {
110
+ name: cdktf.stringToTerraform(this._name),
111
+ nameservers: cdktf.listMapper(cdktf.stringToTerraform, false)(this._nameservers),
112
+ ttl: cdktf.numberToTerraform(this._ttl),
113
+ zone: cdktf.stringToTerraform(this._zone),
114
+ };
115
+ }
116
+ synthesizeHclAttributes() {
117
+ const attrs = {
118
+ name: {
119
+ value: cdktf.stringToHclTerraform(this._name),
120
+ isBlock: false,
121
+ type: "simple",
122
+ storageClassType: "string",
123
+ },
124
+ nameservers: {
125
+ value: cdktf.listMapperHcl(cdktf.stringToHclTerraform, false)(this._nameservers),
126
+ isBlock: false,
127
+ type: "set",
128
+ storageClassType: "stringList",
129
+ },
130
+ ttl: {
131
+ value: cdktf.numberToHclTerraform(this._ttl),
132
+ isBlock: false,
133
+ type: "simple",
134
+ storageClassType: "number",
135
+ },
136
+ zone: {
137
+ value: cdktf.stringToHclTerraform(this._zone),
138
+ isBlock: false,
139
+ type: "simple",
140
+ storageClassType: "string",
141
+ },
142
+ };
143
+ // remove undefined attributes
144
+ return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
145
+ }
146
+ }
147
+ exports.NsRecordSet = NsRecordSet;
148
+ _a = JSII_RTTI_SYMBOL_1;
149
+ NsRecordSet[_a] = { fqn: "@cdktn/provider-dns.nsRecordSet.NsRecordSet", version: "9.1.0" };
150
+ // =================
151
+ // STATIC PROPERTIES
152
+ // =================
153
+ NsRecordSet.tfResourceType = "dns_ns_record_set";
154
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/ns-record-set/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/dns/3.4.3/docs/resources/ns_record_set\n// generated from terraform resource schema\n\nimport { Construct } from 'constructs';\nimport * as cdktf from 'cdktf';\n\n// Configuration\n\nexport interface NsRecordSetConfig extends cdktf.TerraformMetaArguments {\n  /**\n  * The name of the record set. The `zone` argument will be appended to this value to create the full record path.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/ns_record_set#name NsRecordSet#name}\n  */\n  readonly name: string;\n  /**\n  * The nameservers this record set will point to.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/ns_record_set#nameservers NsRecordSet#nameservers}\n  */\n  readonly nameservers: string[];\n  /**\n  * The TTL of the record set. Defaults to `3600`.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/ns_record_set#ttl NsRecordSet#ttl}\n  */\n  readonly ttl?: number;\n  /**\n  * DNS zone the record set belongs to. It must be an FQDN, that is, include the trailing dot.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/ns_record_set#zone NsRecordSet#zone}\n  */\n  readonly zone: string;\n}\n\n/**\n* Represents a {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/ns_record_set dns_ns_record_set}\n*/\nexport class NsRecordSet extends cdktf.TerraformResource {\n\n  // =================\n  // STATIC PROPERTIES\n  // =================\n  public static readonly tfResourceType = \"dns_ns_record_set\";\n\n  // ==============\n  // STATIC Methods\n  // ==============\n  /**\n  * Generates CDKTF code for importing a NsRecordSet 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 NsRecordSet to import\n  * @param importFromId The id of the existing NsRecordSet that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/ns_record_set#import import section} in the documentation of this resource for the id to use\n  * @param provider? Optional instance of the provider where the NsRecordSet 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: \"dns_ns_record_set\", importId: importFromId, provider });\n      }\n\n  // ===========\n  // INITIALIZER\n  // ===========\n\n  /**\n  * Create a new {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/ns_record_set dns_ns_record_set} 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 NsRecordSetConfig\n  */\n  public constructor(scope: Construct, id: string, config: NsRecordSetConfig) {\n    super(scope, id, {\n      terraformResourceType: 'dns_ns_record_set',\n      terraformGeneratorMetadata: {\n        providerName: 'dns',\n        providerVersion: '3.4.3',\n        providerVersionConstraint: '~> 3.2'\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._name = config.name;\n    this._nameservers = config.nameservers;\n    this._ttl = config.ttl;\n    this._zone = config.zone;\n  }\n\n  // ==========\n  // ATTRIBUTES\n  // ==========\n\n  // id - computed: true, optional: false, required: false\n  public get id() {\n    return this.getStringAttribute('id');\n  }\n\n  // name - computed: false, optional: false, required: true\n  private _name?: string; \n  public get name() {\n    return this.getStringAttribute('name');\n  }\n  public set name(value: string) {\n    this._name = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get nameInput() {\n    return this._name;\n  }\n\n  // nameservers - computed: false, optional: false, required: true\n  private _nameservers?: string[]; \n  public get nameservers() {\n    return cdktf.Fn.tolist(this.getListAttribute('nameservers'));\n  }\n  public set nameservers(value: string[]) {\n    this._nameservers = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get nameserversInput() {\n    return this._nameservers;\n  }\n\n  // ttl - computed: true, optional: true, required: false\n  private _ttl?: number; \n  public get ttl() {\n    return this.getNumberAttribute('ttl');\n  }\n  public set ttl(value: number) {\n    this._ttl = value;\n  }\n  public resetTtl() {\n    this._ttl = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get ttlInput() {\n    return this._ttl;\n  }\n\n  // zone - computed: false, optional: false, required: true\n  private _zone?: string; \n  public get zone() {\n    return this.getStringAttribute('zone');\n  }\n  public set zone(value: string) {\n    this._zone = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get zoneInput() {\n    return this._zone;\n  }\n\n  // =========\n  // SYNTHESIS\n  // =========\n\n  protected synthesizeAttributes(): { [name: string]: any } {\n    return {\n      name: cdktf.stringToTerraform(this._name),\n      nameservers: cdktf.listMapper(cdktf.stringToTerraform, false)(this._nameservers),\n      ttl: cdktf.numberToTerraform(this._ttl),\n      zone: cdktf.stringToTerraform(this._zone),\n    };\n  }\n\n  protected synthesizeHclAttributes(): { [name: string]: any } {\n    const attrs = {\n      name: {\n        value: cdktf.stringToHclTerraform(this._name),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"string\",\n      },\n      nameservers: {\n        value: cdktf.listMapperHcl(cdktf.stringToHclTerraform, false)(this._nameservers),\n        isBlock: false,\n        type: \"set\",\n        storageClassType: \"stringList\",\n      },\n      ttl: {\n        value: cdktf.numberToHclTerraform(this._ttl),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"number\",\n      },\n      zone: {\n        value: cdktf.stringToHclTerraform(this._zone),\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"]}
@@ -0,0 +1,145 @@
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 DnsProviderConfig {
8
+ /**
9
+ * Alias name
10
+ *
11
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#alias DnsProvider#alias}
12
+ */
13
+ readonly alias?: string;
14
+ /**
15
+ * update block
16
+ *
17
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#update DnsProvider#update}
18
+ */
19
+ readonly update?: DnsProviderUpdate[] | cdktf.IResolvable;
20
+ }
21
+ export interface DnsProviderUpdateGssapi {
22
+ /**
23
+ * This or `password` is required if `username` is set, not supported on Windows. The path to a keytab file containing a key for `username`. Value can also be sourced from the DNS_UPDATE_KEYTAB environment variable.
24
+ *
25
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#keytab DnsProvider#keytab}
26
+ */
27
+ readonly keytab?: string;
28
+ /**
29
+ * This or `keytab` is required if `username` is set. The matching password for `username`. Value can also be sourced from the DNS_UPDATE_PASSWORD environment variable.
30
+ *
31
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#password DnsProvider#password}
32
+ */
33
+ readonly password?: string;
34
+ /**
35
+ * The Kerberos realm or Active Directory domain. Value can also be sourced from the DNS_UPDATE_REALM environment variable.
36
+ *
37
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#realm DnsProvider#realm}
38
+ */
39
+ readonly realm?: string;
40
+ /**
41
+ * The name of the user to authenticate as. If not set the current user session will be used. Value can also be sourced from the DNS_UPDATE_USERNAME environment variable.
42
+ *
43
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#username DnsProvider#username}
44
+ */
45
+ readonly username?: string;
46
+ }
47
+ export declare function dnsProviderUpdateGssapiToTerraform(struct?: DnsProviderUpdateGssapi | cdktf.IResolvable): any;
48
+ export declare function dnsProviderUpdateGssapiToHclTerraform(struct?: DnsProviderUpdateGssapi | cdktf.IResolvable): any;
49
+ export interface DnsProviderUpdate {
50
+ /**
51
+ * Required if `key_name` is set. When using TSIG authentication, the algorithm to use for HMAC. Valid values are `hmac-md5`, `hmac-sha1`, `hmac-sha256` or `hmac-sha512`. Value can also be sourced from the DNS_UPDATE_KEYALGORITHM environment variable.
52
+ *
53
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#key_algorithm DnsProvider#key_algorithm}
54
+ */
55
+ readonly keyAlgorithm?: string;
56
+ /**
57
+ * The name of the TSIG key used to sign the DNS update messages. Value can also be sourced from the DNS_UPDATE_KEYNAME environment variable.
58
+ *
59
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#key_name DnsProvider#key_name}
60
+ */
61
+ readonly keyName?: string;
62
+ /**
63
+ * Required if `key_name` is set
64
+ * A Base64-encoded string containing the shared secret to be used for TSIG. Value can also be sourced from the DNS_UPDATE_KEYSECRET environment variable.
65
+ *
66
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#key_secret DnsProvider#key_secret}
67
+ */
68
+ readonly keySecret?: string;
69
+ /**
70
+ * The target UDP port on the server where updates are sent to. Defaults to `53`. Value can also be sourced from the DNS_UPDATE_PORT environment variable.
71
+ *
72
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#port DnsProvider#port}
73
+ */
74
+ readonly port?: number;
75
+ /**
76
+ * How many times to retry on connection timeout. Defaults to `3`. Value can also be sourced from the DNS_UPDATE_RETRIES environment variable.
77
+ *
78
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#retries DnsProvider#retries}
79
+ */
80
+ readonly retries?: number;
81
+ /**
82
+ * The hostname or IP address of the DNS server to send updates to. Value can also be sourced from the DNS_UPDATE_SERVER environment variable.
83
+ *
84
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#server DnsProvider#server}
85
+ */
86
+ readonly server?: string;
87
+ /**
88
+ * Timeout for DNS queries. Valid values are durations expressed as `500ms`, etc. or a plain number which is treated as whole seconds. Value can also be sourced from the DNS_UPDATE_TIMEOUT environment variable.
89
+ *
90
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#timeout DnsProvider#timeout}
91
+ */
92
+ readonly timeout?: string;
93
+ /**
94
+ * Transport to use for DNS queries. Valid values are `udp`, `udp4`, `udp6`, `tcp`, `tcp4`, or `tcp6`. Any UDP transport will retry automatically with the equivalent TCP transport in the event of a truncated response. Defaults to `udp`. Value can also be sourced from the DNS_UPDATE_TRANSPORT environment variable.
95
+ *
96
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#transport DnsProvider#transport}
97
+ */
98
+ readonly transport?: string;
99
+ /**
100
+ * gssapi block
101
+ *
102
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#gssapi DnsProvider#gssapi}
103
+ */
104
+ readonly gssapi?: DnsProviderUpdateGssapi[] | cdktf.IResolvable;
105
+ }
106
+ export declare function dnsProviderUpdateToTerraform(struct?: DnsProviderUpdate | cdktf.IResolvable): any;
107
+ export declare function dnsProviderUpdateToHclTerraform(struct?: DnsProviderUpdate | cdktf.IResolvable): any;
108
+ /**
109
+ * Represents a {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs dns}
110
+ */
111
+ export declare class DnsProvider extends cdktf.TerraformProvider {
112
+ static readonly tfResourceType = "dns";
113
+ /**
114
+ * Generates CDKTF code for importing a DnsProvider resource upon running "cdktf plan <stack-name>"
115
+ * @param scope The scope in which to define this construct
116
+ * @param importToId The construct id used in the generated config for the DnsProvider to import
117
+ * @param importFromId The id of the existing DnsProvider that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#import import section} in the documentation of this resource for the id to use
118
+ * @param provider? Optional instance of the provider where the DnsProvider to import is found
119
+ */
120
+ static generateConfigForImport(scope: Construct, importToId: string, importFromId: string, provider?: cdktf.TerraformProvider): cdktf.ImportableResource;
121
+ /**
122
+ * Create a new {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs dns} Resource
123
+ *
124
+ * @param scope The scope in which to define this construct
125
+ * @param id The scoped construct ID. Must be unique amongst siblings in the same scope
126
+ * @param options DnsProviderConfig = {}
127
+ */
128
+ constructor(scope: Construct, id: string, config?: DnsProviderConfig);
129
+ private _alias?;
130
+ get alias(): string | undefined;
131
+ set alias(value: string | undefined);
132
+ resetAlias(): void;
133
+ get aliasInput(): string | undefined;
134
+ private _update?;
135
+ get update(): DnsProviderUpdate[] | cdktf.IResolvable | undefined;
136
+ set update(value: DnsProviderUpdate[] | cdktf.IResolvable | undefined);
137
+ resetUpdate(): void;
138
+ get updateInput(): cdktf.IResolvable | DnsProviderUpdate[] | undefined;
139
+ protected synthesizeAttributes(): {
140
+ [name: string]: any;
141
+ };
142
+ protected synthesizeHclAttributes(): {
143
+ [name: string]: any;
144
+ };
145
+ }
@@ -0,0 +1,247 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.DnsProvider = void 0;
5
+ exports.dnsProviderUpdateGssapiToTerraform = dnsProviderUpdateGssapiToTerraform;
6
+ exports.dnsProviderUpdateGssapiToHclTerraform = dnsProviderUpdateGssapiToHclTerraform;
7
+ exports.dnsProviderUpdateToTerraform = dnsProviderUpdateToTerraform;
8
+ exports.dnsProviderUpdateToHclTerraform = dnsProviderUpdateToHclTerraform;
9
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
10
+ const cdktf = require("cdktf");
11
+ function dnsProviderUpdateGssapiToTerraform(struct) {
12
+ if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) {
13
+ return struct;
14
+ }
15
+ if (cdktf.isComplexElement(struct)) {
16
+ throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
17
+ }
18
+ return {
19
+ keytab: cdktf.stringToTerraform(struct.keytab),
20
+ password: cdktf.stringToTerraform(struct.password),
21
+ realm: cdktf.stringToTerraform(struct.realm),
22
+ username: cdktf.stringToTerraform(struct.username),
23
+ };
24
+ }
25
+ function dnsProviderUpdateGssapiToHclTerraform(struct) {
26
+ if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) {
27
+ return struct;
28
+ }
29
+ if (cdktf.isComplexElement(struct)) {
30
+ throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
31
+ }
32
+ const attrs = {
33
+ keytab: {
34
+ value: cdktf.stringToHclTerraform(struct.keytab),
35
+ isBlock: false,
36
+ type: "simple",
37
+ storageClassType: "string",
38
+ },
39
+ password: {
40
+ value: cdktf.stringToHclTerraform(struct.password),
41
+ isBlock: false,
42
+ type: "simple",
43
+ storageClassType: "string",
44
+ },
45
+ realm: {
46
+ value: cdktf.stringToHclTerraform(struct.realm),
47
+ isBlock: false,
48
+ type: "simple",
49
+ storageClassType: "string",
50
+ },
51
+ username: {
52
+ value: cdktf.stringToHclTerraform(struct.username),
53
+ isBlock: false,
54
+ type: "simple",
55
+ storageClassType: "string",
56
+ },
57
+ };
58
+ // remove undefined attributes
59
+ return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
60
+ }
61
+ function dnsProviderUpdateToTerraform(struct) {
62
+ if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) {
63
+ return struct;
64
+ }
65
+ if (cdktf.isComplexElement(struct)) {
66
+ throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
67
+ }
68
+ return {
69
+ key_algorithm: cdktf.stringToTerraform(struct.keyAlgorithm),
70
+ key_name: cdktf.stringToTerraform(struct.keyName),
71
+ key_secret: cdktf.stringToTerraform(struct.keySecret),
72
+ port: cdktf.numberToTerraform(struct.port),
73
+ retries: cdktf.numberToTerraform(struct.retries),
74
+ server: cdktf.stringToTerraform(struct.server),
75
+ timeout: cdktf.stringToTerraform(struct.timeout),
76
+ transport: cdktf.stringToTerraform(struct.transport),
77
+ gssapi: cdktf.listMapper(dnsProviderUpdateGssapiToTerraform, true)(struct.gssapi),
78
+ };
79
+ }
80
+ function dnsProviderUpdateToHclTerraform(struct) {
81
+ if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) {
82
+ return struct;
83
+ }
84
+ if (cdktf.isComplexElement(struct)) {
85
+ throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
86
+ }
87
+ const attrs = {
88
+ key_algorithm: {
89
+ value: cdktf.stringToHclTerraform(struct.keyAlgorithm),
90
+ isBlock: false,
91
+ type: "simple",
92
+ storageClassType: "string",
93
+ },
94
+ key_name: {
95
+ value: cdktf.stringToHclTerraform(struct.keyName),
96
+ isBlock: false,
97
+ type: "simple",
98
+ storageClassType: "string",
99
+ },
100
+ key_secret: {
101
+ value: cdktf.stringToHclTerraform(struct.keySecret),
102
+ isBlock: false,
103
+ type: "simple",
104
+ storageClassType: "string",
105
+ },
106
+ port: {
107
+ value: cdktf.numberToHclTerraform(struct.port),
108
+ isBlock: false,
109
+ type: "simple",
110
+ storageClassType: "number",
111
+ },
112
+ retries: {
113
+ value: cdktf.numberToHclTerraform(struct.retries),
114
+ isBlock: false,
115
+ type: "simple",
116
+ storageClassType: "number",
117
+ },
118
+ server: {
119
+ value: cdktf.stringToHclTerraform(struct.server),
120
+ isBlock: false,
121
+ type: "simple",
122
+ storageClassType: "string",
123
+ },
124
+ timeout: {
125
+ value: cdktf.stringToHclTerraform(struct.timeout),
126
+ isBlock: false,
127
+ type: "simple",
128
+ storageClassType: "string",
129
+ },
130
+ transport: {
131
+ value: cdktf.stringToHclTerraform(struct.transport),
132
+ isBlock: false,
133
+ type: "simple",
134
+ storageClassType: "string",
135
+ },
136
+ gssapi: {
137
+ value: cdktf.listMapperHcl(dnsProviderUpdateGssapiToHclTerraform, true)(struct.gssapi),
138
+ isBlock: true,
139
+ type: "list",
140
+ storageClassType: "DnsProviderUpdateGssapiList",
141
+ },
142
+ };
143
+ // remove undefined attributes
144
+ return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
145
+ }
146
+ /**
147
+ * Represents a {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs dns}
148
+ */
149
+ class DnsProvider extends cdktf.TerraformProvider {
150
+ // ==============
151
+ // STATIC Methods
152
+ // ==============
153
+ /**
154
+ * Generates CDKTF code for importing a DnsProvider resource upon running "cdktf plan <stack-name>"
155
+ * @param scope The scope in which to define this construct
156
+ * @param importToId The construct id used in the generated config for the DnsProvider to import
157
+ * @param importFromId The id of the existing DnsProvider that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#import import section} in the documentation of this resource for the id to use
158
+ * @param provider? Optional instance of the provider where the DnsProvider to import is found
159
+ */
160
+ static generateConfigForImport(scope, importToId, importFromId, provider) {
161
+ return new cdktf.ImportableResource(scope, importToId, { terraformResourceType: "dns", importId: importFromId, provider });
162
+ }
163
+ // ===========
164
+ // INITIALIZER
165
+ // ===========
166
+ /**
167
+ * Create a new {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs dns} Resource
168
+ *
169
+ * @param scope The scope in which to define this construct
170
+ * @param id The scoped construct ID. Must be unique amongst siblings in the same scope
171
+ * @param options DnsProviderConfig = {}
172
+ */
173
+ constructor(scope, id, config = {}) {
174
+ super(scope, id, {
175
+ terraformResourceType: 'dns',
176
+ terraformGeneratorMetadata: {
177
+ providerName: 'dns',
178
+ providerVersion: '3.4.3',
179
+ providerVersionConstraint: '~> 3.2'
180
+ },
181
+ terraformProviderSource: 'dns'
182
+ });
183
+ this._alias = config.alias;
184
+ this._update = config.update;
185
+ }
186
+ get alias() {
187
+ return this._alias;
188
+ }
189
+ set alias(value) {
190
+ this._alias = value;
191
+ }
192
+ resetAlias() {
193
+ this._alias = undefined;
194
+ }
195
+ // Temporarily expose input value. Use with caution.
196
+ get aliasInput() {
197
+ return this._alias;
198
+ }
199
+ get update() {
200
+ return this._update;
201
+ }
202
+ set update(value) {
203
+ this._update = value;
204
+ }
205
+ resetUpdate() {
206
+ this._update = undefined;
207
+ }
208
+ // Temporarily expose input value. Use with caution.
209
+ get updateInput() {
210
+ return this._update;
211
+ }
212
+ // =========
213
+ // SYNTHESIS
214
+ // =========
215
+ synthesizeAttributes() {
216
+ return {
217
+ alias: cdktf.stringToTerraform(this._alias),
218
+ update: cdktf.listMapper(dnsProviderUpdateToTerraform, true)(this._update),
219
+ };
220
+ }
221
+ synthesizeHclAttributes() {
222
+ const attrs = {
223
+ alias: {
224
+ value: cdktf.stringToHclTerraform(this._alias),
225
+ isBlock: false,
226
+ type: "simple",
227
+ storageClassType: "string",
228
+ },
229
+ update: {
230
+ value: cdktf.listMapperHcl(dnsProviderUpdateToHclTerraform, true)(this._update),
231
+ isBlock: true,
232
+ type: "list",
233
+ storageClassType: "DnsProviderUpdateList",
234
+ },
235
+ };
236
+ // remove undefined attributes
237
+ return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
238
+ }
239
+ }
240
+ exports.DnsProvider = DnsProvider;
241
+ _a = JSII_RTTI_SYMBOL_1;
242
+ DnsProvider[_a] = { fqn: "@cdktn/provider-dns.provider.DnsProvider", version: "9.1.0" };
243
+ // =================
244
+ // STATIC PROPERTIES
245
+ // =================
246
+ DnsProvider.tfResourceType = "dns";
247
+ //# 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/dns/3.4.3/docs\n// generated from terraform resource schema\n\nimport { Construct } from 'constructs';\nimport * as cdktf from 'cdktf';\n\n// Configuration\n\nexport interface DnsProviderConfig {\n  /**\n  * Alias name\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#alias DnsProvider#alias}\n  */\n  readonly alias?: string;\n  /**\n  * update block\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#update DnsProvider#update}\n  */\n  readonly update?: DnsProviderUpdate[] | cdktf.IResolvable;\n}\nexport interface DnsProviderUpdateGssapi {\n  /**\n  * This or `password` is required if `username` is set, not supported on Windows. The path to a keytab file containing a key for `username`. Value can also be sourced from the DNS_UPDATE_KEYTAB environment variable.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#keytab DnsProvider#keytab}\n  */\n  readonly keytab?: string;\n  /**\n  * This or `keytab` is required if `username` is set. The matching password for `username`. Value can also be sourced from the DNS_UPDATE_PASSWORD environment variable.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#password DnsProvider#password}\n  */\n  readonly password?: string;\n  /**\n  * The Kerberos realm or Active Directory domain. Value can also be sourced from the DNS_UPDATE_REALM environment variable.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#realm DnsProvider#realm}\n  */\n  readonly realm?: string;\n  /**\n  * The name of the user to authenticate as. If not set the current user session will be used. Value can also be sourced from the DNS_UPDATE_USERNAME environment variable.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#username DnsProvider#username}\n  */\n  readonly username?: string;\n}\n\nexport function dnsProviderUpdateGssapiToTerraform(struct?: DnsProviderUpdateGssapi | 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    keytab: cdktf.stringToTerraform(struct!.keytab),\n    password: cdktf.stringToTerraform(struct!.password),\n    realm: cdktf.stringToTerraform(struct!.realm),\n    username: cdktf.stringToTerraform(struct!.username),\n  }\n}\n\n\nexport function dnsProviderUpdateGssapiToHclTerraform(struct?: DnsProviderUpdateGssapi | 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    keytab: {\n      value: cdktf.stringToHclTerraform(struct!.keytab),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"string\",\n    },\n    password: {\n      value: cdktf.stringToHclTerraform(struct!.password),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"string\",\n    },\n    realm: {\n      value: cdktf.stringToHclTerraform(struct!.realm),\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\nexport interface DnsProviderUpdate {\n  /**\n  * Required if `key_name` is set. When using TSIG authentication, the algorithm to use for HMAC. Valid values are `hmac-md5`, `hmac-sha1`, `hmac-sha256` or `hmac-sha512`. Value can also be sourced from the DNS_UPDATE_KEYALGORITHM environment variable.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#key_algorithm DnsProvider#key_algorithm}\n  */\n  readonly keyAlgorithm?: string;\n  /**\n  * The name of the TSIG key used to sign the DNS update messages. Value can also be sourced from the DNS_UPDATE_KEYNAME environment variable.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#key_name DnsProvider#key_name}\n  */\n  readonly keyName?: string;\n  /**\n  * Required if `key_name` is set\n  * A Base64-encoded string containing the shared secret to be used for TSIG. Value can also be sourced from the DNS_UPDATE_KEYSECRET environment variable.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#key_secret DnsProvider#key_secret}\n  */\n  readonly keySecret?: string;\n  /**\n  * The target UDP port on the server where updates are sent to. Defaults to `53`. Value can also be sourced from the DNS_UPDATE_PORT environment variable.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#port DnsProvider#port}\n  */\n  readonly port?: number;\n  /**\n  * How many times to retry on connection timeout. Defaults to `3`. Value can also be sourced from the DNS_UPDATE_RETRIES environment variable.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#retries DnsProvider#retries}\n  */\n  readonly retries?: number;\n  /**\n  * The hostname or IP address of the DNS server to send updates to. Value can also be sourced from the DNS_UPDATE_SERVER environment variable.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#server DnsProvider#server}\n  */\n  readonly server?: string;\n  /**\n  * Timeout for DNS queries. Valid values are durations expressed as `500ms`, etc. or a plain number which is treated as whole seconds. Value can also be sourced from the DNS_UPDATE_TIMEOUT environment variable.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#timeout DnsProvider#timeout}\n  */\n  readonly timeout?: string;\n  /**\n  * Transport to use for DNS queries. Valid values are `udp`, `udp4`, `udp6`, `tcp`, `tcp4`, or `tcp6`. Any UDP transport will retry automatically with the equivalent TCP transport in the event of a truncated response. Defaults to `udp`. Value can also be sourced from the DNS_UPDATE_TRANSPORT environment variable.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#transport DnsProvider#transport}\n  */\n  readonly transport?: string;\n  /**\n  * gssapi block\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs#gssapi DnsProvider#gssapi}\n  */\n  readonly gssapi?: DnsProviderUpdateGssapi[] | cdktf.IResolvable;\n}\n\nexport function dnsProviderUpdateToTerraform(struct?: DnsProviderUpdate | 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    key_algorithm: cdktf.stringToTerraform(struct!.keyAlgorithm),\n    key_name: cdktf.stringToTerraform(struct!.keyName),\n    key_secret: cdktf.stringToTerraform(struct!.keySecret),\n    port: cdktf.numberToTerraform(struct!.port),\n    retries: cdktf.numberToTerraform(struct!.retries),\n    server: cdktf.stringToTerraform(struct!.server),\n    timeout: cdktf.stringToTerraform(struct!.timeout),\n    transport: cdktf.stringToTerraform(struct!.transport),\n    gssapi: cdktf.listMapper(dnsProviderUpdateGssapiToTerraform, true)(struct!.gssapi),\n  }\n}\n\n\nexport function dnsProviderUpdateToHclTerraform(struct?: DnsProviderUpdate | 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    key_algorithm: {\n      value: cdktf.stringToHclTerraform(struct!.keyAlgorithm),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"string\",\n    },\n    key_name: {\n      value: cdktf.stringToHclTerraform(struct!.keyName),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"string\",\n    },\n    key_secret: {\n      value: cdktf.stringToHclTerraform(struct!.keySecret),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"string\",\n    },\n    port: {\n      value: cdktf.numberToHclTerraform(struct!.port),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"number\",\n    },\n    retries: {\n      value: cdktf.numberToHclTerraform(struct!.retries),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"number\",\n    },\n    server: {\n      value: cdktf.stringToHclTerraform(struct!.server),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"string\",\n    },\n    timeout: {\n      value: cdktf.stringToHclTerraform(struct!.timeout),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"string\",\n    },\n    transport: {\n      value: cdktf.stringToHclTerraform(struct!.transport),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"string\",\n    },\n    gssapi: {\n      value: cdktf.listMapperHcl(dnsProviderUpdateGssapiToHclTerraform, true)(struct!.gssapi),\n      isBlock: true,\n      type: \"list\",\n      storageClassType: \"DnsProviderUpdateGssapiList\",\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/dns/3.4.3/docs dns}\n*/\nexport class DnsProvider extends cdktf.TerraformProvider {\n\n  // =================\n  // STATIC PROPERTIES\n  // =================\n  public static readonly tfResourceType = \"dns\";\n\n  // ==============\n  // STATIC Methods\n  // ==============\n  /**\n  * Generates CDKTF code for importing a DnsProvider 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 DnsProvider to import\n  * @param importFromId The id of the existing DnsProvider that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/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 DnsProvider 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: \"dns\", importId: importFromId, provider });\n      }\n\n  // ===========\n  // INITIALIZER\n  // ===========\n\n  /**\n  * Create a new {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs dns} 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 DnsProviderConfig = {}\n  */\n  public constructor(scope: Construct, id: string, config: DnsProviderConfig = {}) {\n    super(scope, id, {\n      terraformResourceType: 'dns',\n      terraformGeneratorMetadata: {\n        providerName: 'dns',\n        providerVersion: '3.4.3',\n        providerVersionConstraint: '~> 3.2'\n      },\n      terraformProviderSource: 'dns'\n    });\n    this._alias = config.alias;\n    this._update = config.update;\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  // update - computed: false, optional: true, required: false\n  private _update?: DnsProviderUpdate[] | cdktf.IResolvable; \n  public get update() {\n    return this._update;\n  }\n  public set update(value: DnsProviderUpdate[] | cdktf.IResolvable | undefined) {\n    this._update = value;\n  }\n  public resetUpdate() {\n    this._update = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get updateInput() {\n    return this._update;\n  }\n\n  // =========\n  // SYNTHESIS\n  // =========\n\n  protected synthesizeAttributes(): { [name: string]: any } {\n    return {\n      alias: cdktf.stringToTerraform(this._alias),\n      update: cdktf.listMapper(dnsProviderUpdateToTerraform, true)(this._update),\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      update: {\n        value: cdktf.listMapperHcl(dnsProviderUpdateToHclTerraform, true)(this._update),\n        isBlock: true,\n        type: \"list\",\n        storageClassType: \"DnsProviderUpdateList\",\n      },\n    };\n\n    // remove undefined attributes\n    return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined ))\n  }\n}\n"]}