netbox-plugin-dns 1.2.6__py3-none-any.whl → 1.2.7b2__py3-none-any.whl

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.

Potentially problematic release.


This version of netbox-plugin-dns might be problematic. Click here for more details.

Files changed (62) hide show
  1. netbox_dns/__init__.py +15 -1
  2. netbox_dns/api/serializers.py +3 -0
  3. netbox_dns/api/serializers_/dnssec_key_template.py +46 -0
  4. netbox_dns/api/serializers_/dnssec_policy.py +83 -0
  5. netbox_dns/api/serializers_/zone.py +10 -0
  6. netbox_dns/api/serializers_/zone_template.py +13 -4
  7. netbox_dns/api/urls.py +4 -0
  8. netbox_dns/api/views.py +18 -0
  9. netbox_dns/choices/__init__.py +2 -0
  10. netbox_dns/choices/dnssec_key_template.py +63 -0
  11. netbox_dns/choices/dnssec_policy.py +40 -0
  12. netbox_dns/choices/record.py +2 -25
  13. netbox_dns/choices/utilities.py +26 -0
  14. netbox_dns/fields/__init__.py +1 -0
  15. netbox_dns/fields/choice_array.py +20 -0
  16. netbox_dns/filtersets/__init__.py +3 -0
  17. netbox_dns/filtersets/dnssec_key_template.py +51 -0
  18. netbox_dns/filtersets/dnssec_policy.py +73 -0
  19. netbox_dns/filtersets/zone.py +23 -4
  20. netbox_dns/filtersets/zone_template.py +11 -0
  21. netbox_dns/forms/__init__.py +2 -0
  22. netbox_dns/forms/dnssec_key_template.py +188 -0
  23. netbox_dns/forms/dnssec_policy.py +563 -0
  24. netbox_dns/forms/zone.py +48 -0
  25. netbox_dns/forms/zone_template.py +29 -0
  26. netbox_dns/graphql/__init__.py +7 -3
  27. netbox_dns/graphql/filters.py +16 -0
  28. netbox_dns/graphql/schema.py +20 -0
  29. netbox_dns/graphql/types.py +67 -3
  30. netbox_dns/locale/de/LC_MESSAGES/django.mo +0 -0
  31. netbox_dns/locale/fr/LC_MESSAGES/django.mo +0 -0
  32. netbox_dns/migrations/0015_dnssec.py +168 -0
  33. netbox_dns/migrations/0016_dnssec_policy_status.py +18 -0
  34. netbox_dns/migrations/0017_dnssec_policy_zone_zone_template.py +41 -0
  35. netbox_dns/models/__init__.py +2 -0
  36. netbox_dns/models/dnssec_key_template.py +114 -0
  37. netbox_dns/models/dnssec_policy.py +201 -0
  38. netbox_dns/models/zone.py +29 -16
  39. netbox_dns/models/zone_template.py +16 -6
  40. netbox_dns/navigation.py +49 -0
  41. netbox_dns/signals/dnssec.py +32 -0
  42. netbox_dns/tables/__init__.py +2 -0
  43. netbox_dns/tables/dnssec_key_template.py +48 -0
  44. netbox_dns/tables/dnssec_policy.py +131 -0
  45. netbox_dns/tables/zone.py +17 -1
  46. netbox_dns/tables/zone_template.py +4 -0
  47. netbox_dns/templates/netbox_dns/dnsseckeytemplate.html +70 -0
  48. netbox_dns/templates/netbox_dns/dnssecpolicy.html +155 -0
  49. netbox_dns/templates/netbox_dns/zone.html +16 -0
  50. netbox_dns/templates/netbox_dns/zonetemplate/child.html +46 -0
  51. netbox_dns/templates/netbox_dns/zonetemplate.html +12 -0
  52. netbox_dns/urls.py +16 -0
  53. netbox_dns/validators/__init__.py +1 -0
  54. netbox_dns/validators/dnssec.py +146 -0
  55. netbox_dns/views/__init__.py +2 -0
  56. netbox_dns/views/dnssec_key_template.py +87 -0
  57. netbox_dns/views/dnssec_policy.py +153 -0
  58. {netbox_plugin_dns-1.2.6.dist-info → netbox_plugin_dns-1.2.7b2.dist-info}/METADATA +2 -2
  59. {netbox_plugin_dns-1.2.6.dist-info → netbox_plugin_dns-1.2.7b2.dist-info}/RECORD +62 -38
  60. {netbox_plugin_dns-1.2.6.dist-info → netbox_plugin_dns-1.2.7b2.dist-info}/LICENSE +0 -0
  61. {netbox_plugin_dns-1.2.6.dist-info → netbox_plugin_dns-1.2.7b2.dist-info}/WHEEL +0 -0
  62. {netbox_plugin_dns-1.2.6.dist-info → netbox_plugin_dns-1.2.7b2.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,201 @@
1
+ from django.db import models
2
+ from django.urls import reverse
3
+ from django.utils.translation import gettext_lazy as _
4
+
5
+ from netbox.models import NetBoxModel
6
+ from netbox.search import SearchIndex, register_search
7
+ from netbox.models.features import ContactsMixin
8
+ from netbox.plugins.utils import get_plugin_config
9
+
10
+ from netbox_dns.choices import DNSSECPolicyDigestChoices, DNSSECPolicyStatusChoices
11
+ from netbox_dns.fields import ChoiceArrayField
12
+
13
+
14
+ __all__ = (
15
+ "DNSSECPolicy",
16
+ "DNSSECPolicyIndex",
17
+ )
18
+
19
+
20
+ class DNSSECPolicy(ContactsMixin, NetBoxModel):
21
+ name = models.CharField(
22
+ verbose_name=_("Name"),
23
+ max_length=255,
24
+ unique=True,
25
+ )
26
+ description = models.CharField(
27
+ verbose_name=_("Description"),
28
+ max_length=200,
29
+ blank=True,
30
+ )
31
+ status = models.CharField(
32
+ verbose_name=_("Status"),
33
+ choices=DNSSECPolicyStatusChoices,
34
+ default=DNSSECPolicyStatusChoices.STATUS_ACTIVE,
35
+ blank=False,
36
+ null=False,
37
+ )
38
+
39
+ key_templates = models.ManyToManyField(
40
+ verbose_name=_("Key Templates"),
41
+ to="DNSSECKeyTemplate",
42
+ related_name="policies",
43
+ blank=True,
44
+ )
45
+ dnskey_ttl = models.PositiveIntegerField(
46
+ verbose_name=_("DNSKEY TTL"),
47
+ blank=True,
48
+ null=True,
49
+ )
50
+ purge_keys = models.PositiveIntegerField(
51
+ verbose_name=_("Purge Keys"),
52
+ blank=True,
53
+ null=True,
54
+ )
55
+ publish_safety = models.PositiveIntegerField(
56
+ verbose_name=_("Publish Safety"),
57
+ blank=True,
58
+ null=True,
59
+ )
60
+ retire_safety = models.PositiveIntegerField(
61
+ verbose_name=_("Retire Safety"),
62
+ blank=True,
63
+ null=True,
64
+ )
65
+ signatures_jitter = models.PositiveIntegerField(
66
+ verbose_name=_("Signatures Jitter"),
67
+ blank=True,
68
+ null=True,
69
+ )
70
+ signatures_refresh = models.PositiveIntegerField(
71
+ verbose_name=_("Signatures Refresh"),
72
+ blank=True,
73
+ null=True,
74
+ )
75
+ signatures_validity = models.PositiveIntegerField(
76
+ verbose_name=_("Signatures Validity"),
77
+ blank=True,
78
+ null=True,
79
+ )
80
+ signatures_validity_dnskey = models.PositiveIntegerField(
81
+ verbose_name=_("Signatures Validity for DNSKEY"),
82
+ blank=True,
83
+ null=True,
84
+ )
85
+ max_zone_ttl = models.PositiveIntegerField(
86
+ verbose_name=_("Max Zone TTL"),
87
+ blank=True,
88
+ null=True,
89
+ )
90
+ zone_propagation_delay = models.PositiveIntegerField(
91
+ verbose_name=_("Zone Propagation Delay"),
92
+ blank=True,
93
+ null=True,
94
+ )
95
+
96
+ create_cdnskey = models.BooleanField(
97
+ verbose_name=_("Create CDNSKEY"),
98
+ null=False,
99
+ default=True,
100
+ )
101
+ cds_digest_types = ChoiceArrayField(
102
+ base_field=models.CharField(
103
+ choices=DNSSECPolicyDigestChoices,
104
+ ),
105
+ verbose_name=_("CDS Digest Types"),
106
+ blank=True,
107
+ null=True,
108
+ default=list,
109
+ )
110
+ parent_ds_ttl = models.PositiveIntegerField(
111
+ verbose_name=_("Parent DS TTL"),
112
+ blank=True,
113
+ null=True,
114
+ )
115
+ parent_propagation_delay = models.PositiveIntegerField(
116
+ verbose_name=_("Parent Propagation Delay"),
117
+ blank=True,
118
+ null=True,
119
+ )
120
+
121
+ use_nsec3 = models.BooleanField(
122
+ verbose_name=_("Use NSEC3"),
123
+ null=False,
124
+ default=True,
125
+ )
126
+ nsec3_iterations = models.PositiveIntegerField(
127
+ verbose_name=_("NSEC3 Iterations"),
128
+ blank=True,
129
+ null=True,
130
+ )
131
+ nsec3_opt_out = models.BooleanField(
132
+ verbose_name=_("NSEC3 Opt-Out"),
133
+ blank=False,
134
+ null=False,
135
+ default=False,
136
+ )
137
+ nsec3_salt_size = models.PositiveIntegerField(
138
+ verbose_name=_("NSEC3 Salt Size"),
139
+ blank=True,
140
+ null=True,
141
+ )
142
+
143
+ tenant = models.ForeignKey(
144
+ verbose_name=_("Tenant"),
145
+ to="tenancy.Tenant",
146
+ on_delete=models.PROTECT,
147
+ related_name="netbox_dns_dnssec_policy",
148
+ blank=True,
149
+ null=True,
150
+ )
151
+
152
+ clone_fields = (
153
+ "name",
154
+ "key_templates",
155
+ "description",
156
+ "tenant",
157
+ )
158
+
159
+ class Meta:
160
+ verbose_name = _("DNSSEC Policy")
161
+ verbose_name_plural = _("DNSSEC Policies")
162
+
163
+ ordering = ("name",)
164
+
165
+ def __str__(self):
166
+ return str(self.name)
167
+
168
+ def get_status_color(self):
169
+ return DNSSECPolicyStatusChoices.colors.get(self.status)
170
+
171
+ # TODO: Remove in version 1.3.0 (NetBox #18555)
172
+ def get_absolute_url(self):
173
+ return reverse("plugins:netbox_dns:dnssecpolicy", kwargs={"pk": self.pk})
174
+
175
+ @property
176
+ def purge_keys_value(self):
177
+ return self.purge_keys if self.purge_keys is not None else 776000
178
+
179
+ @property
180
+ def publish_safety_value(self):
181
+ return self.publish_safety if self.publish_safety is not None else 3600
182
+
183
+ def get_effective_value(self, attribute):
184
+ default_value = get_plugin_config("netbox_dns", f"dnssec_{attribute}", None)
185
+
186
+ if not hasattr(self, attribute):
187
+ raise AttributeError(f"DNSSECPolicy does not have attribute {attribute}")
188
+
189
+ if (value := getattr(self, attribute)) is None:
190
+ return default_value
191
+
192
+ return value
193
+
194
+
195
+ @register_search
196
+ class DNSSECPolicyIndex(SearchIndex):
197
+ model = DNSSECPolicy
198
+ fields = (
199
+ ("name", 100),
200
+ ("description", 500),
201
+ )
netbox_dns/models/zone.py CHANGED
@@ -97,6 +97,11 @@ class Zone(ObjectModificationMixin, ContactsMixin, NetBoxModel):
97
97
  max_length=255,
98
98
  db_collation="natural_sort",
99
99
  )
100
+ description = models.CharField(
101
+ verbose_name=_("Description"),
102
+ max_length=200,
103
+ blank=True,
104
+ )
100
105
  status = models.CharField(
101
106
  verbose_name=_("Status"),
102
107
  max_length=50,
@@ -170,25 +175,19 @@ class Zone(ObjectModificationMixin, ContactsMixin, NetBoxModel):
170
175
  help_text=_("Automatically generate the SOA serial number"),
171
176
  default=True,
172
177
  )
173
- description = models.CharField(
174
- verbose_name=_("Description"),
175
- max_length=200,
176
- blank=True,
177
- )
178
- arpa_network = NetworkField(
179
- verbose_name=_("ARPA Network"),
180
- help_text=_("Network related to a reverse lookup zone (.arpa)"),
181
- blank=True,
182
- null=True,
183
- )
184
- tenant = models.ForeignKey(
185
- verbose_name=_("Tenant"),
186
- to="tenancy.Tenant",
178
+ dnssec_policy = models.ForeignKey(
179
+ verbose_name=_("DNSSEC Policy"),
180
+ to="DNSSECPolicy",
187
181
  on_delete=models.PROTECT,
188
- related_name="netbox_dns_zones",
182
+ related_name="zones",
189
183
  blank=True,
190
184
  null=True,
191
185
  )
186
+ inline_signing = models.BooleanField(
187
+ verbose_name=_("Inline Signing"),
188
+ help_text=_("Use inline signing for DNSSEC"),
189
+ default=True,
190
+ )
192
191
  registrar = models.ForeignKey(
193
192
  verbose_name=_("Registrar"),
194
193
  to="Registrar",
@@ -255,12 +254,27 @@ class Zone(ObjectModificationMixin, ContactsMixin, NetBoxModel):
255
254
  blank=True,
256
255
  null=True,
257
256
  )
257
+ arpa_network = NetworkField(
258
+ verbose_name=_("ARPA Network"),
259
+ help_text=_("Network related to a reverse lookup zone (.arpa)"),
260
+ blank=True,
261
+ null=True,
262
+ )
263
+ tenant = models.ForeignKey(
264
+ verbose_name=_("Tenant"),
265
+ to="tenancy.Tenant",
266
+ on_delete=models.PROTECT,
267
+ related_name="netbox_dns_zones",
268
+ blank=True,
269
+ null=True,
270
+ )
258
271
 
259
272
  objects = ZoneManager()
260
273
 
261
274
  clone_fields = (
262
275
  "view",
263
276
  "name",
277
+ "description",
264
278
  "status",
265
279
  "nameservers",
266
280
  "default_ttl",
@@ -271,7 +285,6 @@ class Zone(ObjectModificationMixin, ContactsMixin, NetBoxModel):
271
285
  "soa_retry",
272
286
  "soa_expire",
273
287
  "soa_minimum",
274
- "description",
275
288
  "tenant",
276
289
  )
277
290
 
@@ -55,11 +55,11 @@ class ZoneTemplate(NetBoxModel):
55
55
  related_name="zone_templates",
56
56
  blank=True,
57
57
  )
58
- tenant = models.ForeignKey(
59
- verbose_name=_("Tenant"),
60
- to="tenancy.Tenant",
58
+ dnssec_policy = models.ForeignKey(
59
+ verbose_name=_("DNSSEC Policy"),
60
+ to="DNSSECPolicy",
61
61
  on_delete=models.SET_NULL,
62
- related_name="+",
62
+ related_name="zone_templates",
63
63
  blank=True,
64
64
  null=True,
65
65
  )
@@ -103,28 +103,38 @@ class ZoneTemplate(NetBoxModel):
103
103
  blank=True,
104
104
  null=True,
105
105
  )
106
+ tenant = models.ForeignKey(
107
+ verbose_name=_("Tenant"),
108
+ to="tenancy.Tenant",
109
+ on_delete=models.SET_NULL,
110
+ related_name="+",
111
+ blank=True,
112
+ null=True,
113
+ )
106
114
 
107
115
  clone_fields = (
108
116
  "description",
109
117
  "nameservers",
110
118
  "record_templates",
111
- "tenant",
119
+ "dnssec_policy",
112
120
  "registrar",
113
121
  "registrant",
114
122
  "admin_c",
115
123
  "tech_c",
116
124
  "billing_c",
125
+ "tenant",
117
126
  )
118
127
 
119
128
  template_fields = (
120
129
  "soa_mname",
121
130
  "soa_rname",
122
- "tenant",
131
+ "dnssec_policy",
123
132
  "registrar",
124
133
  "registrant",
125
134
  "admin_c",
126
135
  "tech_c",
127
136
  "billing_c",
137
+ "tenant",
128
138
  )
129
139
 
130
140
  class Meta:
netbox_dns/navigation.py CHANGED
@@ -92,6 +92,46 @@ managed_record_menu_item = PluginMenuItem(
92
92
  permissions=["netbox_dns.view_record"],
93
93
  )
94
94
 
95
+ dnsseckeytemplate_menu_item = PluginMenuItem(
96
+ link="plugins:netbox_dns:dnsseckeytemplate_list",
97
+ link_text=_("DNSSEC Key Templates"),
98
+ permissions=["netbox_dns.view_dnsseckeytemplate"],
99
+ buttons=(
100
+ PluginMenuButton(
101
+ "plugins:netbox_dns:dnsseckeytemplate_add",
102
+ _("Add"),
103
+ "mdi mdi-plus-thick",
104
+ permissions=["netbox_dns.add_dnsseckeytemplate"],
105
+ ),
106
+ PluginMenuButton(
107
+ "plugins:netbox_dns:dnsseckeytemplate_bulk_import",
108
+ _("Import"),
109
+ "mdi mdi-upload",
110
+ permissions=["netbox_dns.add_dnsseckeytemplate"],
111
+ ),
112
+ ),
113
+ )
114
+
115
+ dnssecpolicy_menu_item = PluginMenuItem(
116
+ link="plugins:netbox_dns:dnssecpolicy_list",
117
+ link_text=_("DNSSEC Policies"),
118
+ permissions=["netbox_dns.view_dnssecpolicy"],
119
+ buttons=(
120
+ PluginMenuButton(
121
+ "plugins:netbox_dns:dnssecpolicy_add",
122
+ _("Add"),
123
+ "mdi mdi-plus-thick",
124
+ permissions=["netbox_dns.add_dnssecpolicy"],
125
+ ),
126
+ PluginMenuButton(
127
+ "plugins:netbox_dns:dnssecpolicy_bulk_import",
128
+ _("Import"),
129
+ "mdi mdi-upload",
130
+ permissions=["netbox_dns.add_dnssecpolicy"],
131
+ ),
132
+ ),
133
+ )
134
+
95
135
  zonetemplate_menu_item = PluginMenuItem(
96
136
  link="plugins:netbox_dns:zonetemplate_list",
97
137
  link_text=_("Zone Templates"),
@@ -187,6 +227,13 @@ if top_level_menu:
187
227
  managed_record_menu_item,
188
228
  ),
189
229
  ),
230
+ (
231
+ _("DNSSEC"),
232
+ (
233
+ dnsseckeytemplate_menu_item,
234
+ dnssecpolicy_menu_item,
235
+ ),
236
+ ),
190
237
  (
191
238
  _("Templates"),
192
239
  (
@@ -211,6 +258,8 @@ else:
211
258
  nameserver_menu_item,
212
259
  record_menu_item,
213
260
  managed_record_menu_item,
261
+ dnsseckeytemplate_menu_item,
262
+ dnssecpolicy_menu_item,
214
263
  registrar_menu_item,
215
264
  contact_menu_item,
216
265
  )
@@ -0,0 +1,32 @@
1
+ from django.dispatch import receiver
2
+ from django.db.models.signals import m2m_changed
3
+ from django.core.exceptions import ValidationError
4
+
5
+ from netbox.context import current_request
6
+ from utilities.exceptions import AbortRequest
7
+
8
+ from netbox_dns.validators import validate_key_template_assignment
9
+
10
+ from netbox_dns.models import DNSSECPolicy, DNSSECKeyTemplate
11
+
12
+
13
+ @receiver(m2m_changed, sender=DNSSECPolicy.key_templates.through)
14
+ def dnssec_policy_key_templates_changed(action, instance, pk_set, **kwargs):
15
+ request = current_request.get()
16
+
17
+ key_templates = instance.key_templates.all()
18
+ match action:
19
+ case "pre_remove":
20
+ key_templates = key_templates.exclude(pk__in=pk_set)
21
+ case "pre_add":
22
+ key_templates |= DNSSECKeyTemplate.objects.filter(pk__in=pk_set)
23
+ case _:
24
+ return
25
+
26
+ try:
27
+ validate_key_template_assignment(key_templates)
28
+ except ValidationError as exc:
29
+ if request is not None:
30
+ raise AbortRequest(exc)
31
+ else:
32
+ raise exc
@@ -6,3 +6,5 @@ from .registration_contact import *
6
6
  from .registrar import *
7
7
  from .zone_template import *
8
8
  from .record_template import *
9
+ from .dnssec_key_template import *
10
+ from .dnssec_policy import *
@@ -0,0 +1,48 @@
1
+ import django_tables2 as tables
2
+ from django.utils.translation import gettext_lazy as _
3
+
4
+
5
+ from netbox.tables import (
6
+ NetBoxTable,
7
+ ChoiceFieldColumn,
8
+ TagColumn,
9
+ )
10
+ from tenancy.tables import TenancyColumnsMixin
11
+
12
+ from netbox_dns.models import DNSSECKeyTemplate
13
+
14
+
15
+ __all__ = ("DNSSECKeyTemplateTable",)
16
+
17
+
18
+ class DNSSECKeyTemplateTable(TenancyColumnsMixin, NetBoxTable):
19
+ name = tables.Column(
20
+ verbose_name=_("Name"),
21
+ linkify=True,
22
+ )
23
+ type = ChoiceFieldColumn(
24
+ verbose_name=_("Key Type"),
25
+ )
26
+ lifetime = tables.Column(
27
+ verbose_name=_("Lifetime"),
28
+ )
29
+ algorithm = ChoiceFieldColumn(
30
+ verbose_name=_("Algorithm"),
31
+ )
32
+ key_size = ChoiceFieldColumn(
33
+ verbose_name=_("Key Size"),
34
+ )
35
+ tags = TagColumn(
36
+ url_name="plugins:netbox_dns:dnsseckeytemplate_list",
37
+ )
38
+
39
+ class Meta(NetBoxTable.Meta):
40
+ model = DNSSECKeyTemplate
41
+ fields = ("description",)
42
+ default_columns = (
43
+ "name",
44
+ "type",
45
+ "algorithm",
46
+ "key_size",
47
+ "tags",
48
+ )
@@ -0,0 +1,131 @@
1
+ import django_tables2 as tables
2
+ from django.utils.translation import gettext_lazy as _
3
+
4
+
5
+ from netbox.tables import (
6
+ NetBoxTable,
7
+ TagColumn,
8
+ ChoiceFieldColumn,
9
+ ActionsColumn,
10
+ )
11
+ from tenancy.tables import TenancyColumnsMixin
12
+
13
+ from netbox_dns.models import DNSSECPolicy
14
+
15
+
16
+ __all__ = (
17
+ "DNSSECPolicyTable",
18
+ "DNSSECPolicyDisplayTable",
19
+ )
20
+
21
+
22
+ class DNSSECPolicyTable(TenancyColumnsMixin, NetBoxTable):
23
+ name = tables.Column(
24
+ verbose_name=_("Name"),
25
+ linkify=True,
26
+ )
27
+ status = ChoiceFieldColumn(
28
+ verbose_name=_("Status"),
29
+ )
30
+ dnskey_ttl = tables.Column(
31
+ verbose_name=_("DNSKEY TTL"),
32
+ )
33
+ purge_keys = tables.Column(
34
+ verbose_name=_("Purge Keys"),
35
+ )
36
+ publish_safety = tables.Column(
37
+ verbose_name=_("Publish Safety"),
38
+ )
39
+ retire_safety = tables.Column(
40
+ verbose_name=_("Retire Safety"),
41
+ )
42
+ signatures_jitter = tables.Column(
43
+ verbose_name=_("Signatures Jitter"),
44
+ )
45
+ signatures_refresh = tables.Column(
46
+ verbose_name=_("Signatures Refresh"),
47
+ )
48
+ signatures_validity = tables.Column(
49
+ verbose_name=_("Signatures Validity"),
50
+ )
51
+ signatures_validity_dnskey = tables.Column(
52
+ verbose_name=_("Signatures Validity (DNSKEY)"),
53
+ )
54
+ max_zone_ttl = tables.Column(
55
+ verbose_name=_("Max Zone TTL"),
56
+ )
57
+ dnskey_ttl = tables.Column(
58
+ verbose_name=_("DNSKEY TTL"),
59
+ )
60
+ zone_propagation_delay = tables.Column(
61
+ verbose_name=_("Zone Propagation Delay"),
62
+ )
63
+ create_cdnskey = tables.BooleanColumn(
64
+ verbose_name=_("Create CDNSKEY"),
65
+ )
66
+ cds_digest_types = tables.Column(
67
+ verbose_name=_("CDS Digest Types"),
68
+ )
69
+ parent_ds_ttl = tables.Column(
70
+ verbose_name=_("Parent DS TTL"),
71
+ )
72
+ parent_propagation_delay = tables.Column(
73
+ verbose_name=_("Parent Propagation Delay"),
74
+ )
75
+ use_nsec3 = tables.BooleanColumn(
76
+ verbose_name=_("Use NSEC3"),
77
+ )
78
+ nsec3_iterations = tables.Column(
79
+ verbose_name=_("NSEC3 Iterations"),
80
+ )
81
+ nsec3_opt_out = tables.BooleanColumn(
82
+ verbose_name=_("NSEC3 Opt Out"),
83
+ )
84
+ nsec3_salt_size = tables.Column(
85
+ verbose_name=_("NSEC3 Salt Size"),
86
+ )
87
+ tags = TagColumn(
88
+ url_name="plugins:netbox_dns:dnssecpolicy_list",
89
+ )
90
+
91
+ class Meta(NetBoxTable.Meta):
92
+ model = DNSSECPolicy
93
+ fields = ("description",)
94
+ default_columns = (
95
+ "name",
96
+ "description",
97
+ "status",
98
+ "use_nsec3",
99
+ "tags",
100
+ )
101
+
102
+
103
+ class DNSSECPolicyDisplayTable(TenancyColumnsMixin, NetBoxTable):
104
+ actions = ActionsColumn(actions="")
105
+
106
+ name = tables.Column(
107
+ verbose_name=_("Name"),
108
+ linkify=True,
109
+ )
110
+ status = ChoiceFieldColumn(
111
+ verbose_name=_("Status"),
112
+ )
113
+ create_cdnskey = tables.BooleanColumn(
114
+ verbose_name=_("Create CDNSKEY"),
115
+ )
116
+ use_nsec3 = tables.BooleanColumn(
117
+ verbose_name=_("Use NSEC3"),
118
+ )
119
+ tags = TagColumn(
120
+ url_name="plugins:netbox_dns:dnssecpolicy_list",
121
+ )
122
+
123
+ class Meta(NetBoxTable.Meta):
124
+ model = DNSSECPolicy
125
+ fields = ("description",)
126
+ default_columns = (
127
+ "name",
128
+ "description",
129
+ "status",
130
+ "tags",
131
+ )
netbox_dns/tables/zone.py CHANGED
@@ -5,13 +5,17 @@ from netbox.tables import (
5
5
  ChoiceFieldColumn,
6
6
  NetBoxTable,
7
7
  TagColumn,
8
+ ActionsColumn,
8
9
  )
9
10
  from tenancy.tables import TenancyColumnsMixin
10
11
 
11
12
  from netbox_dns.models import Zone
12
13
 
13
14
 
14
- __all__ = ("ZoneTable",)
15
+ __all__ = (
16
+ "ZoneTable",
17
+ "ZoneDisplayTable",
18
+ )
15
19
 
16
20
 
17
21
  class ZoneTable(TenancyColumnsMixin, NetBoxTable):
@@ -36,6 +40,10 @@ class ZoneTable(TenancyColumnsMixin, NetBoxTable):
36
40
  default_ttl = tables.Column(
37
41
  verbose_name="Default TTL",
38
42
  )
43
+ dnssec_policy = tables.Column(
44
+ verbose_name=_("DNSSEC Policy"),
45
+ linkify=True,
46
+ )
39
47
  rfc2317_prefix = tables.Column(
40
48
  verbose_name=_("RFC2317 Prefix"),
41
49
  )
@@ -73,6 +81,7 @@ class ZoneTable(TenancyColumnsMixin, NetBoxTable):
73
81
  "description",
74
82
  "soa_rname",
75
83
  "soa_serial",
84
+ "inline_signing",
76
85
  "rfc2317_parent_managed",
77
86
  "registry_domain_id",
78
87
  )
@@ -82,3 +91,10 @@ class ZoneTable(TenancyColumnsMixin, NetBoxTable):
82
91
  "status",
83
92
  "tags",
84
93
  )
94
+
95
+
96
+ class ZoneDisplayTable(ZoneTable):
97
+ actions = ActionsColumn(actions=("changelog",))
98
+
99
+ class Meta(ZoneTable.Meta):
100
+ pass
@@ -25,6 +25,10 @@ class ZoneTemplateTable(TenancyColumnsMixin, NetBoxTable):
25
25
  tags = TagColumn(
26
26
  url_name="plugins:netbox_dns:zonetemplate_list",
27
27
  )
28
+ dnssec_policy = tables.Column(
29
+ verbose_name=_("DNSSEC Policy"),
30
+ linkify=True,
31
+ )
28
32
  registrar = tables.Column(
29
33
  verbose_name=_("Registrar"),
30
34
  linkify=True,