@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,79 @@
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 PtrRecordConfig extends cdktf.TerraformMetaArguments {
8
+ /**
9
+ * The name of the record. The `zone` argument will be appended to this value to create the full record path.
10
+ *
11
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/ptr_record#name PtrRecord#name}
12
+ */
13
+ readonly name?: string;
14
+ /**
15
+ * The canonical name this record will point to.
16
+ *
17
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/ptr_record#ptr PtrRecord#ptr}
18
+ */
19
+ readonly ptr: string;
20
+ /**
21
+ * The TTL of the record. Defaults to `3600`.
22
+ *
23
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/ptr_record#ttl PtrRecord#ttl}
24
+ */
25
+ readonly ttl?: number;
26
+ /**
27
+ * DNS zone the record set belongs to. It must be an FQDN, that is, include the trailing dot.
28
+ *
29
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/ptr_record#zone PtrRecord#zone}
30
+ */
31
+ readonly zone: string;
32
+ }
33
+ /**
34
+ * Represents a {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/ptr_record dns_ptr_record}
35
+ */
36
+ export declare class PtrRecord extends cdktf.TerraformResource {
37
+ static readonly tfResourceType = "dns_ptr_record";
38
+ /**
39
+ * Generates CDKTF code for importing a PtrRecord resource upon running "cdktf plan <stack-name>"
40
+ * @param scope The scope in which to define this construct
41
+ * @param importToId The construct id used in the generated config for the PtrRecord to import
42
+ * @param importFromId The id of the existing PtrRecord that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/ptr_record#import import section} in the documentation of this resource for the id to use
43
+ * @param provider? Optional instance of the provider where the PtrRecord to import is found
44
+ */
45
+ static generateConfigForImport(scope: Construct, importToId: string, importFromId: string, provider?: cdktf.TerraformProvider): cdktf.ImportableResource;
46
+ /**
47
+ * Create a new {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/ptr_record dns_ptr_record} Resource
48
+ *
49
+ * @param scope The scope in which to define this construct
50
+ * @param id The scoped construct ID. Must be unique amongst siblings in the same scope
51
+ * @param options PtrRecordConfig
52
+ */
53
+ constructor(scope: Construct, id: string, config: PtrRecordConfig);
54
+ get id(): string;
55
+ private _name?;
56
+ get name(): string;
57
+ set name(value: string);
58
+ resetName(): void;
59
+ get nameInput(): string | undefined;
60
+ private _ptr?;
61
+ get ptr(): string;
62
+ set ptr(value: string);
63
+ get ptrInput(): string | undefined;
64
+ private _ttl?;
65
+ get ttl(): number;
66
+ set ttl(value: number);
67
+ resetTtl(): void;
68
+ get ttlInput(): number | undefined;
69
+ private _zone?;
70
+ get zone(): string;
71
+ set zone(value: string);
72
+ get zoneInput(): string | undefined;
73
+ protected synthesizeAttributes(): {
74
+ [name: string]: any;
75
+ };
76
+ protected synthesizeHclAttributes(): {
77
+ [name: string]: any;
78
+ };
79
+ }
@@ -0,0 +1,157 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.PtrRecord = 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/ptr_record dns_ptr_record}
9
+ */
10
+ class PtrRecord extends cdktf.TerraformResource {
11
+ // ==============
12
+ // STATIC Methods
13
+ // ==============
14
+ /**
15
+ * Generates CDKTF code for importing a PtrRecord 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 PtrRecord to import
18
+ * @param importFromId The id of the existing PtrRecord that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/ptr_record#import import section} in the documentation of this resource for the id to use
19
+ * @param provider? Optional instance of the provider where the PtrRecord to import is found
20
+ */
21
+ static generateConfigForImport(scope, importToId, importFromId, provider) {
22
+ return new cdktf.ImportableResource(scope, importToId, { terraformResourceType: "dns_ptr_record", 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/ptr_record dns_ptr_record} 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 PtrRecordConfig
33
+ */
34
+ constructor(scope, id, config) {
35
+ super(scope, id, {
36
+ terraformResourceType: 'dns_ptr_record',
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._ptr = config.ptr;
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
+ resetName() {
69
+ this._name = undefined;
70
+ }
71
+ // Temporarily expose input value. Use with caution.
72
+ get nameInput() {
73
+ return this._name;
74
+ }
75
+ get ptr() {
76
+ return this.getStringAttribute('ptr');
77
+ }
78
+ set ptr(value) {
79
+ this._ptr = value;
80
+ }
81
+ // Temporarily expose input value. Use with caution.
82
+ get ptrInput() {
83
+ return this._ptr;
84
+ }
85
+ get ttl() {
86
+ return this.getNumberAttribute('ttl');
87
+ }
88
+ set ttl(value) {
89
+ this._ttl = value;
90
+ }
91
+ resetTtl() {
92
+ this._ttl = undefined;
93
+ }
94
+ // Temporarily expose input value. Use with caution.
95
+ get ttlInput() {
96
+ return this._ttl;
97
+ }
98
+ get zone() {
99
+ return this.getStringAttribute('zone');
100
+ }
101
+ set zone(value) {
102
+ this._zone = value;
103
+ }
104
+ // Temporarily expose input value. Use with caution.
105
+ get zoneInput() {
106
+ return this._zone;
107
+ }
108
+ // =========
109
+ // SYNTHESIS
110
+ // =========
111
+ synthesizeAttributes() {
112
+ return {
113
+ name: cdktf.stringToTerraform(this._name),
114
+ ptr: cdktf.stringToTerraform(this._ptr),
115
+ ttl: cdktf.numberToTerraform(this._ttl),
116
+ zone: cdktf.stringToTerraform(this._zone),
117
+ };
118
+ }
119
+ synthesizeHclAttributes() {
120
+ const attrs = {
121
+ name: {
122
+ value: cdktf.stringToHclTerraform(this._name),
123
+ isBlock: false,
124
+ type: "simple",
125
+ storageClassType: "string",
126
+ },
127
+ ptr: {
128
+ value: cdktf.stringToHclTerraform(this._ptr),
129
+ isBlock: false,
130
+ type: "simple",
131
+ storageClassType: "string",
132
+ },
133
+ ttl: {
134
+ value: cdktf.numberToHclTerraform(this._ttl),
135
+ isBlock: false,
136
+ type: "simple",
137
+ storageClassType: "number",
138
+ },
139
+ zone: {
140
+ value: cdktf.stringToHclTerraform(this._zone),
141
+ isBlock: false,
142
+ type: "simple",
143
+ storageClassType: "string",
144
+ },
145
+ };
146
+ // remove undefined attributes
147
+ return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
148
+ }
149
+ }
150
+ exports.PtrRecord = PtrRecord;
151
+ _a = JSII_RTTI_SYMBOL_1;
152
+ PtrRecord[_a] = { fqn: "@cdktn/provider-dns.ptrRecord.PtrRecord", version: "9.1.0" };
153
+ // =================
154
+ // STATIC PROPERTIES
155
+ // =================
156
+ PtrRecord.tfResourceType = "dns_ptr_record";
157
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/ptr-record/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/ptr_record\n// generated from terraform resource schema\n\nimport { Construct } from 'constructs';\nimport * as cdktf from 'cdktf';\n\n// Configuration\n\nexport interface PtrRecordConfig extends cdktf.TerraformMetaArguments {\n  /**\n  * The name of the record. 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/ptr_record#name PtrRecord#name}\n  */\n  readonly name?: string;\n  /**\n  * The canonical name this record will point to.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/ptr_record#ptr PtrRecord#ptr}\n  */\n  readonly ptr: string;\n  /**\n  * The TTL of the record. Defaults to `3600`.\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/ptr_record#ttl PtrRecord#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/ptr_record#zone PtrRecord#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/ptr_record dns_ptr_record}\n*/\nexport class PtrRecord extends cdktf.TerraformResource {\n\n  // =================\n  // STATIC PROPERTIES\n  // =================\n  public static readonly tfResourceType = \"dns_ptr_record\";\n\n  // ==============\n  // STATIC Methods\n  // ==============\n  /**\n  * Generates CDKTF code for importing a PtrRecord 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 PtrRecord to import\n  * @param importFromId The id of the existing PtrRecord that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/ptr_record#import import section} in the documentation of this resource for the id to use\n  * @param provider? Optional instance of the provider where the PtrRecord 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_ptr_record\", 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/ptr_record dns_ptr_record} 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 PtrRecordConfig\n  */\n  public constructor(scope: Construct, id: string, config: PtrRecordConfig) {\n    super(scope, id, {\n      terraformResourceType: 'dns_ptr_record',\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._ptr = config.ptr;\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: true, required: false\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  public resetName() {\n    this._name = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get nameInput() {\n    return this._name;\n  }\n\n  // ptr - computed: false, optional: false, required: true\n  private _ptr?: string; \n  public get ptr() {\n    return this.getStringAttribute('ptr');\n  }\n  public set ptr(value: string) {\n    this._ptr = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get ptrInput() {\n    return this._ptr;\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      ptr: cdktf.stringToTerraform(this._ptr),\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      ptr: {\n        value: cdktf.stringToHclTerraform(this._ptr),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"string\",\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,152 @@
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 SrvRecordSetConfig extends cdktf.TerraformMetaArguments {
8
+ /**
9
+ * The name of the record set. The `zone` argument will be appended to this value to create the full record path.
10
+ *
11
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/srv_record_set#name SrvRecordSet#name}
12
+ */
13
+ readonly name: string;
14
+ /**
15
+ * The TTL of the record set. Defaults to `3600`.
16
+ *
17
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/srv_record_set#ttl SrvRecordSet#ttl}
18
+ */
19
+ readonly ttl?: number;
20
+ /**
21
+ * DNS zone the record set belongs to. It must be an FQDN, that is, include the trailing dot.
22
+ *
23
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/srv_record_set#zone SrvRecordSet#zone}
24
+ */
25
+ readonly zone: string;
26
+ /**
27
+ * srv block
28
+ *
29
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/srv_record_set#srv SrvRecordSet#srv}
30
+ */
31
+ readonly srv?: SrvRecordSetSrv[] | cdktf.IResolvable;
32
+ }
33
+ export interface SrvRecordSetSrv {
34
+ /**
35
+ * The port for the service on the target.
36
+ *
37
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/srv_record_set#port SrvRecordSet#port}
38
+ */
39
+ readonly port: number;
40
+ /**
41
+ * The priority for the record.
42
+ *
43
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/srv_record_set#priority SrvRecordSet#priority}
44
+ */
45
+ readonly priority: number;
46
+ /**
47
+ * The FQDN of the target, include the trailing dot.
48
+ *
49
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/srv_record_set#target SrvRecordSet#target}
50
+ */
51
+ readonly target: string;
52
+ /**
53
+ * The weight for the record.
54
+ *
55
+ * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/srv_record_set#weight SrvRecordSet#weight}
56
+ */
57
+ readonly weight: number;
58
+ }
59
+ export declare function srvRecordSetSrvToTerraform(struct?: SrvRecordSetSrv | cdktf.IResolvable): any;
60
+ export declare function srvRecordSetSrvToHclTerraform(struct?: SrvRecordSetSrv | cdktf.IResolvable): any;
61
+ export declare class SrvRecordSetSrvOutputReference extends cdktf.ComplexObject {
62
+ private isEmptyObject;
63
+ private resolvableValue?;
64
+ /**
65
+ * @param terraformResource The parent resource
66
+ * @param terraformAttribute The attribute on the parent resource this class is referencing
67
+ * @param complexObjectIndex the index of this item in the list
68
+ * @param complexObjectIsFromSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index)
69
+ */
70
+ constructor(terraformResource: cdktf.IInterpolatingParent, terraformAttribute: string, complexObjectIndex: number, complexObjectIsFromSet: boolean);
71
+ get internalValue(): SrvRecordSetSrv | cdktf.IResolvable | undefined;
72
+ set internalValue(value: SrvRecordSetSrv | cdktf.IResolvable | undefined);
73
+ private _port?;
74
+ get port(): number;
75
+ set port(value: number);
76
+ get portInput(): number | undefined;
77
+ private _priority?;
78
+ get priority(): number;
79
+ set priority(value: number);
80
+ get priorityInput(): number | undefined;
81
+ private _target?;
82
+ get target(): string;
83
+ set target(value: string);
84
+ get targetInput(): string | undefined;
85
+ private _weight?;
86
+ get weight(): number;
87
+ set weight(value: number);
88
+ get weightInput(): number | undefined;
89
+ }
90
+ export declare class SrvRecordSetSrvList extends cdktf.ComplexList {
91
+ protected terraformResource: cdktf.IInterpolatingParent;
92
+ protected terraformAttribute: string;
93
+ protected wrapsSet: boolean;
94
+ internalValue?: SrvRecordSetSrv[] | cdktf.IResolvable;
95
+ /**
96
+ * @param terraformResource The parent resource
97
+ * @param terraformAttribute The attribute on the parent resource this class is referencing
98
+ * @param wrapsSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index)
99
+ */
100
+ constructor(terraformResource: cdktf.IInterpolatingParent, terraformAttribute: string, wrapsSet: boolean);
101
+ /**
102
+ * @param index the index of the item to return
103
+ */
104
+ get(index: number): SrvRecordSetSrvOutputReference;
105
+ }
106
+ /**
107
+ * Represents a {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/srv_record_set dns_srv_record_set}
108
+ */
109
+ export declare class SrvRecordSet extends cdktf.TerraformResource {
110
+ static readonly tfResourceType = "dns_srv_record_set";
111
+ /**
112
+ * Generates CDKTF code for importing a SrvRecordSet resource upon running "cdktf plan <stack-name>"
113
+ * @param scope The scope in which to define this construct
114
+ * @param importToId The construct id used in the generated config for the SrvRecordSet to import
115
+ * @param importFromId The id of the existing SrvRecordSet that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/srv_record_set#import import section} in the documentation of this resource for the id to use
116
+ * @param provider? Optional instance of the provider where the SrvRecordSet to import is found
117
+ */
118
+ static generateConfigForImport(scope: Construct, importToId: string, importFromId: string, provider?: cdktf.TerraformProvider): cdktf.ImportableResource;
119
+ /**
120
+ * Create a new {@link https://registry.terraform.io/providers/hashicorp/dns/3.4.3/docs/resources/srv_record_set dns_srv_record_set} Resource
121
+ *
122
+ * @param scope The scope in which to define this construct
123
+ * @param id The scoped construct ID. Must be unique amongst siblings in the same scope
124
+ * @param options SrvRecordSetConfig
125
+ */
126
+ constructor(scope: Construct, id: string, config: SrvRecordSetConfig);
127
+ get id(): string;
128
+ private _name?;
129
+ get name(): string;
130
+ set name(value: string);
131
+ get nameInput(): string | undefined;
132
+ private _ttl?;
133
+ get ttl(): number;
134
+ set ttl(value: number);
135
+ resetTtl(): void;
136
+ get ttlInput(): number | undefined;
137
+ private _zone?;
138
+ get zone(): string;
139
+ set zone(value: string);
140
+ get zoneInput(): string | undefined;
141
+ private _srv;
142
+ get srv(): SrvRecordSetSrvList;
143
+ putSrv(value: SrvRecordSetSrv[] | cdktf.IResolvable): void;
144
+ resetSrv(): void;
145
+ get srvInput(): cdktf.IResolvable | SrvRecordSetSrv[] | undefined;
146
+ protected synthesizeAttributes(): {
147
+ [name: string]: any;
148
+ };
149
+ protected synthesizeHclAttributes(): {
150
+ [name: string]: any;
151
+ };
152
+ }