netbox-plugin-dns 0.22.9__py3-none-any.whl → 1.0b1__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.
- netbox_dns/__init__.py +3 -14
- netbox_dns/api/nested_serializers.py +4 -60
- netbox_dns/api/serializers.py +8 -314
- netbox_dns/api/serializers_/__init__.py +0 -0
- netbox_dns/api/serializers_/contact.py +37 -0
- netbox_dns/api/serializers_/nameserver.py +39 -0
- netbox_dns/api/serializers_/record.py +90 -0
- netbox_dns/api/serializers_/registrar.py +31 -0
- netbox_dns/api/serializers_/view.py +29 -0
- netbox_dns/api/serializers_/zone.py +170 -0
- netbox_dns/api/views.py +13 -13
- netbox_dns/fields/network.py +1 -1
- netbox_dns/fields/rfc2317.py +1 -1
- netbox_dns/{filters → filtersets}/contact.py +2 -1
- netbox_dns/filtersets/nameserver.py +37 -0
- netbox_dns/{filters → filtersets}/record.py +51 -6
- netbox_dns/{filters → filtersets}/registrar.py +2 -1
- netbox_dns/{filters → filtersets}/view.py +2 -2
- netbox_dns/filtersets/zone.py +205 -0
- netbox_dns/forms/contact.py +61 -33
- netbox_dns/forms/nameserver.py +21 -8
- netbox_dns/forms/record.py +35 -36
- netbox_dns/forms/registrar.py +45 -15
- netbox_dns/forms/view.py +19 -8
- netbox_dns/forms/zone.py +112 -87
- netbox_dns/graphql/__init__.py +17 -27
- netbox_dns/graphql/filters.py +49 -0
- netbox_dns/graphql/schema.py +66 -7
- netbox_dns/graphql/types.py +146 -0
- netbox_dns/management/commands/cleanup_database.py +0 -4
- netbox_dns/management/commands/cleanup_rrset_ttl.py +3 -5
- netbox_dns/management/commands/setup_coupling.py +15 -15
- netbox_dns/management/commands/update_soa.py +1 -1
- netbox_dns/migrations/0001_squashed_netbox_dns_0_15.py +0 -27
- netbox_dns/migrations/0001_squashed_netbox_dns_0_22.py +556 -0
- netbox_dns/migrations/{0013_add_nameserver_zone_record_description.py → 0002_contact_description_registrar_description.py} +4 -9
- netbox_dns/migrations/0020_netbox_3_4.py +1 -1
- netbox_dns/models/contact.py +6 -1
- netbox_dns/models/nameserver.py +3 -3
- netbox_dns/models/record.py +8 -15
- netbox_dns/models/registrar.py +5 -1
- netbox_dns/models/view.py +1 -1
- netbox_dns/models/zone.py +6 -9
- netbox_dns/navigation.py +1 -15
- netbox_dns/signals/ipam_coupling.py +3 -8
- netbox_dns/tables/contact.py +1 -0
- netbox_dns/tables/nameserver.py +0 -2
- netbox_dns/tables/registrar.py +1 -0
- netbox_dns/template_content.py +3 -7
- netbox_dns/templates/netbox_dns/contact.html +60 -56
- netbox_dns/templates/netbox_dns/nameserver.html +27 -27
- netbox_dns/templates/netbox_dns/record.html +92 -94
- netbox_dns/templates/netbox_dns/registrar.html +38 -36
- netbox_dns/templates/netbox_dns/view.html +21 -21
- netbox_dns/templates/netbox_dns/zone/base.html +5 -3
- netbox_dns/templates/netbox_dns/zone/child.html +3 -3
- netbox_dns/templates/netbox_dns/zone/managed_record.html +1 -1
- netbox_dns/templates/netbox_dns/zone/record.html +3 -3
- netbox_dns/templates/netbox_dns/zone/registration.html +26 -27
- netbox_dns/templates/netbox_dns/zone/rfc2317_child_zone.html +1 -1
- netbox_dns/templates/netbox_dns/zone.html +150 -149
- netbox_dns/utilities/__init__.py +1 -6
- netbox_dns/utilities/ipam_coupling.py +2 -7
- netbox_dns/validators/dns_name.py +4 -9
- netbox_dns/validators/rfc2317.py +2 -2
- netbox_dns/views/contact.py +4 -4
- netbox_dns/views/nameserver.py +5 -5
- netbox_dns/views/record.py +19 -12
- netbox_dns/views/registrar.py +4 -4
- netbox_dns/views/view.py +4 -4
- netbox_dns/views/zone.py +7 -8
- {netbox_plugin_dns-0.22.9.dist-info → netbox_plugin_dns-1.0b1.dist-info}/METADATA +5 -7
- netbox_plugin_dns-1.0b1.dist-info/RECORD +103 -0
- netbox_dns/filters/nameserver.py +0 -18
- netbox_dns/filters/zone.py +0 -112
- netbox_dns/graphql/contact.py +0 -19
- netbox_dns/graphql/nameserver.py +0 -19
- netbox_dns/graphql/record.py +0 -19
- netbox_dns/graphql/registrar.py +0 -19
- netbox_dns/graphql/view.py +0 -19
- netbox_dns/graphql/zone.py +0 -19
- netbox_dns/migrations/0001_initial.py +0 -115
- netbox_dns/migrations/0002_zone_default_ttl.py +0 -18
- netbox_dns/migrations/0003_soa_managed_records.py +0 -112
- netbox_dns/migrations/0004_create_ptr_for_a_aaaa_records.py +0 -80
- netbox_dns/migrations/0005_update_ns_records.py +0 -41
- netbox_dns/migrations/0006_zone_soa_serial_auto.py +0 -29
- netbox_dns/migrations/0007_alter_zone_soa_serial_auto.py +0 -17
- netbox_dns/migrations/0008_zone_status_names.py +0 -21
- netbox_dns/migrations/0009_netbox32.py +0 -71
- netbox_dns/migrations/0010_update_soa_records.py +0 -58
- netbox_dns/migrations/0011_add_view_model.py +0 -70
- netbox_dns/migrations/0012_adjust_zone_and_record.py +0 -17
- netbox_dns/migrations/0014_add_view_description.py +0 -16
- netbox_dns/migrations/0015_add_record_status.py +0 -17
- netbox_dns/migrations/0016_cleanup_ptr_records.py +0 -38
- netbox_dns/migrations/0017_alter_record_ttl.py +0 -17
- netbox_dns/migrations/0018_zone_arpa_network.py +0 -51
- netbox_dns/migrations/0019_update_ns_ttl.py +0 -19
- netbox_plugin_dns-0.22.9.dist-info/RECORD +0 -117
- /netbox_dns/{filters → filtersets}/__init__.py +0 -0
- {netbox_plugin_dns-0.22.9.dist-info → netbox_plugin_dns-1.0b1.dist-info}/LICENSE +0 -0
- {netbox_plugin_dns-0.22.9.dist-info → netbox_plugin_dns-1.0b1.dist-info}/WHEEL +0 -0
|
@@ -0,0 +1,170 @@
|
|
|
1
|
+
from rest_framework import serializers
|
|
2
|
+
|
|
3
|
+
from netbox.api.serializers import NetBoxModelSerializer
|
|
4
|
+
from tenancy.api.serializers_.tenants import TenantSerializer
|
|
5
|
+
|
|
6
|
+
from netbox_dns.api.serializers_.view import ViewSerializer
|
|
7
|
+
from netbox_dns.api.serializers_.nameserver import NameServerSerializer
|
|
8
|
+
from netbox_dns.api.serializers_.registrar import RegistrarSerializer
|
|
9
|
+
from netbox_dns.api.serializers_.contact import ContactSerializer
|
|
10
|
+
from netbox_dns.api.nested_serializers import NestedZoneSerializer
|
|
11
|
+
|
|
12
|
+
from netbox_dns.models import Zone
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
class ZoneSerializer(NetBoxModelSerializer):
|
|
16
|
+
# +
|
|
17
|
+
# This is a hack to avoid the exception raised by the UniqueTogetherValidator
|
|
18
|
+
# after NetBox commit https://github.com/netbox-community/netbox/commit/78e284c
|
|
19
|
+
#
|
|
20
|
+
# See https://github.com/netbox-community/netbox/issues/15351 for details.
|
|
21
|
+
# -
|
|
22
|
+
def __init__(self, *args, **kwargs):
|
|
23
|
+
super().__init__(*args, **kwargs)
|
|
24
|
+
if self.nested:
|
|
25
|
+
self.validators = []
|
|
26
|
+
|
|
27
|
+
url = serializers.HyperlinkedIdentityField(
|
|
28
|
+
view_name="plugins-api:netbox_dns-api:zone-detail"
|
|
29
|
+
)
|
|
30
|
+
view = ViewSerializer(
|
|
31
|
+
nested=True,
|
|
32
|
+
many=False,
|
|
33
|
+
read_only=False,
|
|
34
|
+
required=False,
|
|
35
|
+
default=None,
|
|
36
|
+
help_text="View the zone belongs to",
|
|
37
|
+
)
|
|
38
|
+
nameservers = NameServerSerializer(
|
|
39
|
+
nested=True,
|
|
40
|
+
many=True,
|
|
41
|
+
read_only=False,
|
|
42
|
+
required=False,
|
|
43
|
+
help_text="Nameservers for the zone",
|
|
44
|
+
)
|
|
45
|
+
soa_mname = NameServerSerializer(
|
|
46
|
+
nested=True,
|
|
47
|
+
many=False,
|
|
48
|
+
read_only=False,
|
|
49
|
+
required=False,
|
|
50
|
+
help_text="Primary nameserver for the zone",
|
|
51
|
+
)
|
|
52
|
+
rfc2317_parent_zone = NestedZoneSerializer(
|
|
53
|
+
many=False,
|
|
54
|
+
read_only=True,
|
|
55
|
+
required=False,
|
|
56
|
+
help_text="RFC2317 arent zone for the zone",
|
|
57
|
+
)
|
|
58
|
+
rfc2317_child_zones = NestedZoneSerializer(
|
|
59
|
+
many=True,
|
|
60
|
+
read_only=True,
|
|
61
|
+
required=False,
|
|
62
|
+
help_text="RFC2317 child zones of the zone",
|
|
63
|
+
)
|
|
64
|
+
registrar = RegistrarSerializer(
|
|
65
|
+
nested=True,
|
|
66
|
+
many=False,
|
|
67
|
+
read_only=False,
|
|
68
|
+
required=False,
|
|
69
|
+
help_text="The registrar the domain is registered with",
|
|
70
|
+
)
|
|
71
|
+
registrant = ContactSerializer(
|
|
72
|
+
many=False,
|
|
73
|
+
read_only=False,
|
|
74
|
+
required=False,
|
|
75
|
+
help_text="The owner of the domain",
|
|
76
|
+
)
|
|
77
|
+
admin_c = ContactSerializer(
|
|
78
|
+
many=False,
|
|
79
|
+
read_only=False,
|
|
80
|
+
required=False,
|
|
81
|
+
help_text="The administrative contact for the domain",
|
|
82
|
+
)
|
|
83
|
+
tech_c = ContactSerializer(
|
|
84
|
+
many=False,
|
|
85
|
+
read_only=False,
|
|
86
|
+
required=False,
|
|
87
|
+
help_text="The technical contact for the domain",
|
|
88
|
+
)
|
|
89
|
+
billing_c = ContactSerializer(
|
|
90
|
+
many=False,
|
|
91
|
+
read_only=False,
|
|
92
|
+
required=False,
|
|
93
|
+
help_text="The billing contact for the domain",
|
|
94
|
+
)
|
|
95
|
+
active = serializers.BooleanField(
|
|
96
|
+
required=False,
|
|
97
|
+
read_only=True,
|
|
98
|
+
allow_null=True,
|
|
99
|
+
)
|
|
100
|
+
tenant = TenantSerializer(nested=True, required=False, allow_null=True)
|
|
101
|
+
|
|
102
|
+
def create(self, validated_data):
|
|
103
|
+
nameservers = validated_data.pop("nameservers", None)
|
|
104
|
+
|
|
105
|
+
zone = super().create(validated_data)
|
|
106
|
+
|
|
107
|
+
if nameservers is not None:
|
|
108
|
+
zone.nameservers.set(nameservers)
|
|
109
|
+
|
|
110
|
+
return zone
|
|
111
|
+
|
|
112
|
+
def update(self, instance, validated_data):
|
|
113
|
+
nameservers = validated_data.pop("nameservers", None)
|
|
114
|
+
|
|
115
|
+
zone = super().update(instance, validated_data)
|
|
116
|
+
|
|
117
|
+
if nameservers is not None:
|
|
118
|
+
zone.nameservers.set(nameservers)
|
|
119
|
+
|
|
120
|
+
return zone
|
|
121
|
+
|
|
122
|
+
class Meta:
|
|
123
|
+
model = Zone
|
|
124
|
+
fields = (
|
|
125
|
+
"id",
|
|
126
|
+
"url",
|
|
127
|
+
"name",
|
|
128
|
+
"view",
|
|
129
|
+
"display",
|
|
130
|
+
"nameservers",
|
|
131
|
+
"status",
|
|
132
|
+
"description",
|
|
133
|
+
"tags",
|
|
134
|
+
"created",
|
|
135
|
+
"last_updated",
|
|
136
|
+
"default_ttl",
|
|
137
|
+
"soa_ttl",
|
|
138
|
+
"soa_mname",
|
|
139
|
+
"soa_rname",
|
|
140
|
+
"soa_serial",
|
|
141
|
+
"soa_serial_auto",
|
|
142
|
+
"soa_refresh",
|
|
143
|
+
"soa_retry",
|
|
144
|
+
"soa_expire",
|
|
145
|
+
"soa_minimum",
|
|
146
|
+
"rfc2317_prefix",
|
|
147
|
+
"rfc2317_parent_managed",
|
|
148
|
+
"rfc2317_parent_zone",
|
|
149
|
+
"rfc2317_child_zones",
|
|
150
|
+
"registrar",
|
|
151
|
+
"registry_domain_id",
|
|
152
|
+
"registrant",
|
|
153
|
+
"tech_c",
|
|
154
|
+
"admin_c",
|
|
155
|
+
"billing_c",
|
|
156
|
+
"active",
|
|
157
|
+
"custom_fields",
|
|
158
|
+
"tenant",
|
|
159
|
+
)
|
|
160
|
+
brief_fields = (
|
|
161
|
+
"id",
|
|
162
|
+
"url",
|
|
163
|
+
"name",
|
|
164
|
+
"view",
|
|
165
|
+
"display",
|
|
166
|
+
"status",
|
|
167
|
+
"description",
|
|
168
|
+
"rfc2317_prefix",
|
|
169
|
+
"active",
|
|
170
|
+
)
|
netbox_dns/api/views.py
CHANGED
|
@@ -13,13 +13,13 @@ from netbox_dns.api.serializers import (
|
|
|
13
13
|
RegistrarSerializer,
|
|
14
14
|
ContactSerializer,
|
|
15
15
|
)
|
|
16
|
-
from netbox_dns.
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
16
|
+
from netbox_dns.filtersets import (
|
|
17
|
+
ViewFilterSet,
|
|
18
|
+
ZoneFilterSet,
|
|
19
|
+
NameServerFilterSet,
|
|
20
|
+
RecordFilterSet,
|
|
21
|
+
RegistrarFilterSet,
|
|
22
|
+
ContactFilterSet,
|
|
23
23
|
)
|
|
24
24
|
from netbox_dns.models import View, Zone, NameServer, Record, Registrar, Contact
|
|
25
25
|
|
|
@@ -32,7 +32,7 @@ class NetBoxDNSRootView(APIRootView):
|
|
|
32
32
|
class ViewViewSet(NetBoxModelViewSet):
|
|
33
33
|
queryset = View.objects.all()
|
|
34
34
|
serializer_class = ViewSerializer
|
|
35
|
-
filterset_class =
|
|
35
|
+
filterset_class = ViewFilterSet
|
|
36
36
|
|
|
37
37
|
@action(detail=True, methods=["get"])
|
|
38
38
|
def views(self, request, pk=None):
|
|
@@ -51,7 +51,7 @@ class ZoneViewSet(NetBoxModelViewSet):
|
|
|
51
51
|
"tenant",
|
|
52
52
|
)
|
|
53
53
|
serializer_class = ZoneSerializer
|
|
54
|
-
filterset_class =
|
|
54
|
+
filterset_class = ZoneFilterSet
|
|
55
55
|
|
|
56
56
|
@action(detail=True, methods=["get"])
|
|
57
57
|
def records(self, request, pk=None):
|
|
@@ -71,7 +71,7 @@ class ZoneViewSet(NetBoxModelViewSet):
|
|
|
71
71
|
class NameServerViewSet(NetBoxModelViewSet):
|
|
72
72
|
queryset = NameServer.objects.prefetch_related("zones", "tenant")
|
|
73
73
|
serializer_class = NameServerSerializer
|
|
74
|
-
filterset_class =
|
|
74
|
+
filterset_class = NameServerFilterSet
|
|
75
75
|
|
|
76
76
|
@action(detail=True, methods=["get"])
|
|
77
77
|
def zones(self, request, pk=None):
|
|
@@ -83,7 +83,7 @@ class NameServerViewSet(NetBoxModelViewSet):
|
|
|
83
83
|
class RecordViewSet(NetBoxModelViewSet):
|
|
84
84
|
queryset = Record.objects.all().prefetch_related("zone", "zone__view", "tenant")
|
|
85
85
|
serializer_class = RecordSerializer
|
|
86
|
-
filterset_class =
|
|
86
|
+
filterset_class = RecordFilterSet
|
|
87
87
|
|
|
88
88
|
def destroy(self, request, *args, **kwargs):
|
|
89
89
|
v_object = self.get_object()
|
|
@@ -105,10 +105,10 @@ class RecordViewSet(NetBoxModelViewSet):
|
|
|
105
105
|
class RegistrarViewSet(NetBoxModelViewSet):
|
|
106
106
|
queryset = Registrar.objects.all()
|
|
107
107
|
serializer_class = RegistrarSerializer
|
|
108
|
-
filterset_class =
|
|
108
|
+
filterset_class = RegistrarFilterSet
|
|
109
109
|
|
|
110
110
|
|
|
111
111
|
class ContactViewSet(NetBoxModelViewSet):
|
|
112
112
|
queryset = Contact.objects.all()
|
|
113
113
|
serializer_class = ContactSerializer
|
|
114
|
-
filterset_class =
|
|
114
|
+
filterset_class = ContactFilterSet
|
netbox_dns/fields/network.py
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
from django import forms
|
|
2
2
|
from django.db import models
|
|
3
|
-
from django.db.models import Lookup, Transform
|
|
3
|
+
from django.db.models import Lookup, Transform, IntegerField
|
|
4
4
|
from django.core.exceptions import ValidationError
|
|
5
5
|
|
|
6
6
|
from netaddr import AddrFormatError, IPNetwork
|
netbox_dns/fields/rfc2317.py
CHANGED
|
@@ -51,7 +51,7 @@ class RFC2317NetworkField(models.Field):
|
|
|
51
51
|
|
|
52
52
|
try:
|
|
53
53
|
ip_network = IPNetwork(value)
|
|
54
|
-
except (
|
|
54
|
+
except (AddrFormatError, TypeError, ValueError) as exc:
|
|
55
55
|
raise ValidationError(exc)
|
|
56
56
|
|
|
57
57
|
if ip_network.version != 4:
|
|
@@ -5,12 +5,13 @@ from netbox.filtersets import NetBoxModelFilterSet
|
|
|
5
5
|
from netbox_dns.models import Contact
|
|
6
6
|
|
|
7
7
|
|
|
8
|
-
class
|
|
8
|
+
class ContactFilterSet(NetBoxModelFilterSet):
|
|
9
9
|
class Meta:
|
|
10
10
|
model = Contact
|
|
11
11
|
fields = (
|
|
12
12
|
"id",
|
|
13
13
|
"name",
|
|
14
|
+
"description",
|
|
14
15
|
"contact_id",
|
|
15
16
|
"organization",
|
|
16
17
|
"street",
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import django_filters
|
|
2
|
+
from django.db.models import Q
|
|
3
|
+
|
|
4
|
+
from netbox.filtersets import NetBoxModelFilterSet
|
|
5
|
+
from tenancy.filtersets import TenancyFilterSet
|
|
6
|
+
|
|
7
|
+
from netbox_dns.models import NameServer, Zone
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
class NameServerFilterSet(TenancyFilterSet, NetBoxModelFilterSet):
|
|
11
|
+
zone_id = django_filters.ModelMultipleChoiceFilter(
|
|
12
|
+
field_name="zones",
|
|
13
|
+
queryset=Zone.objects.all(),
|
|
14
|
+
to_field_name="id",
|
|
15
|
+
label="Zones",
|
|
16
|
+
)
|
|
17
|
+
soa_zone_id = django_filters.ModelMultipleChoiceFilter(
|
|
18
|
+
method="filter_soa_zones",
|
|
19
|
+
queryset=Zone.objects.all(),
|
|
20
|
+
label="SOA Zones",
|
|
21
|
+
)
|
|
22
|
+
|
|
23
|
+
class Meta:
|
|
24
|
+
model = NameServer
|
|
25
|
+
fields = ("id", "name", "description")
|
|
26
|
+
|
|
27
|
+
def search(self, queryset, name, value):
|
|
28
|
+
if not value.strip():
|
|
29
|
+
return queryset
|
|
30
|
+
qs_filter = Q(name__icontains=value)
|
|
31
|
+
return queryset.filter(qs_filter)
|
|
32
|
+
|
|
33
|
+
def filter_soa_zones(self, queryset, name, value):
|
|
34
|
+
if not value:
|
|
35
|
+
return queryset
|
|
36
|
+
soa_mnames = {zone.soa_mname.pk for zone in value}
|
|
37
|
+
return queryset.filter(pk__in=soa_mnames)
|
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
import netaddr
|
|
2
|
+
|
|
1
3
|
import django_filters
|
|
2
4
|
from django.db.models import Q
|
|
3
5
|
|
|
@@ -5,16 +7,17 @@ from netbox.filtersets import NetBoxModelFilterSet
|
|
|
5
7
|
from tenancy.filtersets import TenancyFilterSet
|
|
6
8
|
from utilities.filters import MultiValueCharFilter
|
|
7
9
|
|
|
10
|
+
from ipam.models import IPAddress
|
|
11
|
+
|
|
8
12
|
from netbox_dns.models import View, Zone, Record, RecordTypeChoices, RecordStatusChoices
|
|
9
13
|
|
|
10
14
|
|
|
11
|
-
class
|
|
15
|
+
class RecordFilterSet(TenancyFilterSet, NetBoxModelFilterSet):
|
|
12
16
|
fqdn = MultiValueCharFilter(
|
|
13
17
|
method="filter_fqdn",
|
|
14
18
|
)
|
|
15
19
|
type = django_filters.MultipleChoiceFilter(
|
|
16
20
|
choices=RecordTypeChoices,
|
|
17
|
-
null_value=None,
|
|
18
21
|
)
|
|
19
22
|
status = django_filters.MultipleChoiceFilter(
|
|
20
23
|
choices=RecordStatusChoices,
|
|
@@ -40,20 +43,48 @@ class RecordFilter(TenancyFilterSet, NetBoxModelFilterSet):
|
|
|
40
43
|
to_field_name="name",
|
|
41
44
|
label="View the Parent Zone belongs to",
|
|
42
45
|
)
|
|
46
|
+
address_record_id = django_filters.ModelMultipleChoiceFilter(
|
|
47
|
+
field_name="address_record",
|
|
48
|
+
queryset=Record.objects.all(),
|
|
49
|
+
to_field_name="id",
|
|
50
|
+
label="Address Record",
|
|
51
|
+
)
|
|
52
|
+
ptr_record_id = django_filters.ModelMultipleChoiceFilter(
|
|
53
|
+
field_name="ptr_record",
|
|
54
|
+
queryset=Record.objects.all(),
|
|
55
|
+
to_field_name="id",
|
|
56
|
+
label="Pointer Record",
|
|
57
|
+
)
|
|
58
|
+
rfc2317_cname_record_id = django_filters.ModelMultipleChoiceFilter(
|
|
59
|
+
field_name="rfc2317_cname_record",
|
|
60
|
+
queryset=Record.objects.all(),
|
|
61
|
+
to_field_name="id",
|
|
62
|
+
label="Pointer Record",
|
|
63
|
+
)
|
|
64
|
+
ipam_ip_address_id = django_filters.ModelMultipleChoiceFilter(
|
|
65
|
+
field_name="ipam_ip_address",
|
|
66
|
+
queryset=IPAddress.objects.all(),
|
|
67
|
+
to_field_name="id",
|
|
68
|
+
label="IPAM IP Address",
|
|
69
|
+
)
|
|
70
|
+
ip_address = MultiValueCharFilter(
|
|
71
|
+
method="filter_ip_address",
|
|
72
|
+
label="IP Address",
|
|
73
|
+
)
|
|
74
|
+
|
|
43
75
|
managed = django_filters.BooleanFilter()
|
|
44
76
|
|
|
45
77
|
class Meta:
|
|
46
78
|
model = Record
|
|
47
79
|
fields = (
|
|
48
80
|
"id",
|
|
49
|
-
"type",
|
|
50
81
|
"name",
|
|
51
82
|
"fqdn",
|
|
83
|
+
"description",
|
|
84
|
+
"ttl",
|
|
52
85
|
"value",
|
|
53
|
-
"
|
|
54
|
-
"zone",
|
|
86
|
+
"disable_ptr",
|
|
55
87
|
"managed",
|
|
56
|
-
"tenant",
|
|
57
88
|
)
|
|
58
89
|
|
|
59
90
|
def filter_fqdn(self, queryset, name, value):
|
|
@@ -68,6 +99,20 @@ class RecordFilter(TenancyFilterSet, NetBoxModelFilterSet):
|
|
|
68
99
|
|
|
69
100
|
return queryset.filter(fqdn__in=fqdns)
|
|
70
101
|
|
|
102
|
+
def filter_ip_address(self, queryset, name, value):
|
|
103
|
+
if not value:
|
|
104
|
+
return queryset
|
|
105
|
+
try:
|
|
106
|
+
ip_addresses = [
|
|
107
|
+
str(netaddr.IPAddress(item)) for item in value if item.strip()
|
|
108
|
+
]
|
|
109
|
+
if not ip_addresses:
|
|
110
|
+
return queryset
|
|
111
|
+
|
|
112
|
+
return queryset.filter(ip_address__in=ip_addresses)
|
|
113
|
+
except (netaddr.AddrFormatError, ValueError):
|
|
114
|
+
return queryset.none()
|
|
115
|
+
|
|
71
116
|
def search(self, queryset, name, value):
|
|
72
117
|
if not value.strip():
|
|
73
118
|
return queryset
|
|
@@ -5,12 +5,13 @@ from netbox.filtersets import NetBoxModelFilterSet
|
|
|
5
5
|
from netbox_dns.models import Registrar
|
|
6
6
|
|
|
7
7
|
|
|
8
|
-
class
|
|
8
|
+
class RegistrarFilterSet(NetBoxModelFilterSet):
|
|
9
9
|
class Meta:
|
|
10
10
|
model = Registrar
|
|
11
11
|
fields = (
|
|
12
12
|
"id",
|
|
13
13
|
"name",
|
|
14
|
+
"description",
|
|
14
15
|
"iana_id",
|
|
15
16
|
"address",
|
|
16
17
|
"referral_url",
|
|
@@ -6,10 +6,10 @@ from tenancy.filtersets import TenancyFilterSet
|
|
|
6
6
|
from netbox_dns.models import View
|
|
7
7
|
|
|
8
8
|
|
|
9
|
-
class
|
|
9
|
+
class ViewFilterSet(NetBoxModelFilterSet, TenancyFilterSet):
|
|
10
10
|
class Meta:
|
|
11
11
|
model = View
|
|
12
|
-
fields = ("id", "name", "
|
|
12
|
+
fields = ("id", "name", "description")
|
|
13
13
|
|
|
14
14
|
def search(self, queryset, name, value):
|
|
15
15
|
if not value.strip():
|
|
@@ -0,0 +1,205 @@
|
|
|
1
|
+
import netaddr
|
|
2
|
+
|
|
3
|
+
import django_filters
|
|
4
|
+
from django.db.models import Q
|
|
5
|
+
|
|
6
|
+
from netbox.filtersets import NetBoxModelFilterSet
|
|
7
|
+
from tenancy.filtersets import TenancyFilterSet
|
|
8
|
+
from utilities.filters import MultiValueCharFilter
|
|
9
|
+
|
|
10
|
+
from netbox_dns.models import (
|
|
11
|
+
View,
|
|
12
|
+
Zone,
|
|
13
|
+
ZoneStatusChoices,
|
|
14
|
+
Registrar,
|
|
15
|
+
Contact,
|
|
16
|
+
NameServer,
|
|
17
|
+
)
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
class ZoneFilterSet(TenancyFilterSet, NetBoxModelFilterSet):
|
|
21
|
+
status = django_filters.MultipleChoiceFilter(
|
|
22
|
+
choices=ZoneStatusChoices,
|
|
23
|
+
)
|
|
24
|
+
view_id = django_filters.ModelMultipleChoiceFilter(
|
|
25
|
+
queryset=View.objects.all(),
|
|
26
|
+
label="View ID",
|
|
27
|
+
)
|
|
28
|
+
view = django_filters.ModelMultipleChoiceFilter(
|
|
29
|
+
queryset=View.objects.all(),
|
|
30
|
+
field_name="view__name",
|
|
31
|
+
to_field_name="name",
|
|
32
|
+
label="View",
|
|
33
|
+
)
|
|
34
|
+
# DEPRECATED: Remove in 1.0
|
|
35
|
+
name_server_id = django_filters.ModelMultipleChoiceFilter(
|
|
36
|
+
queryset=NameServer.objects.all(),
|
|
37
|
+
field_name="nameservers",
|
|
38
|
+
to_field_name="id",
|
|
39
|
+
label="Nameserver IDs",
|
|
40
|
+
)
|
|
41
|
+
# DEPRECATED: Remove in 1.0
|
|
42
|
+
name_server = django_filters.ModelMultipleChoiceFilter(
|
|
43
|
+
queryset=NameServer.objects.all(),
|
|
44
|
+
field_name="nameservers__name",
|
|
45
|
+
to_field_name="name",
|
|
46
|
+
label="Nameservers",
|
|
47
|
+
)
|
|
48
|
+
nameserver_id = django_filters.ModelMultipleChoiceFilter(
|
|
49
|
+
queryset=NameServer.objects.all(),
|
|
50
|
+
field_name="nameservers",
|
|
51
|
+
to_field_name="id",
|
|
52
|
+
label="Nameservers ID",
|
|
53
|
+
)
|
|
54
|
+
nameserver = django_filters.ModelMultipleChoiceFilter(
|
|
55
|
+
queryset=NameServer.objects.all(),
|
|
56
|
+
field_name="nameservers__name",
|
|
57
|
+
to_field_name="name",
|
|
58
|
+
label="Nameserver",
|
|
59
|
+
)
|
|
60
|
+
soa_mname_id = django_filters.ModelMultipleChoiceFilter(
|
|
61
|
+
queryset=NameServer.objects.all(),
|
|
62
|
+
label="SOA MNname ID",
|
|
63
|
+
)
|
|
64
|
+
soa_mname = django_filters.ModelMultipleChoiceFilter(
|
|
65
|
+
queryset=NameServer.objects.all(),
|
|
66
|
+
field_name="soa_mname__name",
|
|
67
|
+
to_field_name="name",
|
|
68
|
+
label="SOA MNname",
|
|
69
|
+
)
|
|
70
|
+
arpa_network = MultiValueCharFilter(
|
|
71
|
+
method="filter_arpa_network",
|
|
72
|
+
label="ARPA Network",
|
|
73
|
+
)
|
|
74
|
+
rfc2317_prefix = MultiValueCharFilter(
|
|
75
|
+
method="filter_rfc2317_prefix",
|
|
76
|
+
label="RFC2317 Prefix",
|
|
77
|
+
)
|
|
78
|
+
rfc2317_parent_zone_id = django_filters.ModelMultipleChoiceFilter(
|
|
79
|
+
queryset=Zone.objects.all(),
|
|
80
|
+
field_name="rfc2317_parent_zone",
|
|
81
|
+
to_field_name="id",
|
|
82
|
+
label="RFC2317 Parent Zone",
|
|
83
|
+
)
|
|
84
|
+
rfc2317_parent_zone = django_filters.ModelMultipleChoiceFilter(
|
|
85
|
+
queryset=Zone.objects.all(),
|
|
86
|
+
field_name="rfc2317_parent_zone__name",
|
|
87
|
+
to_field_name="name",
|
|
88
|
+
label="RFC2317 Parent Zone",
|
|
89
|
+
)
|
|
90
|
+
registrar_id = django_filters.ModelMultipleChoiceFilter(
|
|
91
|
+
queryset=Registrar.objects.all(),
|
|
92
|
+
label="Registrar ID",
|
|
93
|
+
)
|
|
94
|
+
registrar = django_filters.ModelMultipleChoiceFilter(
|
|
95
|
+
queryset=Registrar.objects.all(),
|
|
96
|
+
field_name="registrar__name",
|
|
97
|
+
to_field_name="name",
|
|
98
|
+
label="Registrar",
|
|
99
|
+
)
|
|
100
|
+
registrant_id = django_filters.ModelMultipleChoiceFilter(
|
|
101
|
+
queryset=Contact.objects.all(),
|
|
102
|
+
label="Registrant ID",
|
|
103
|
+
)
|
|
104
|
+
registrant = django_filters.ModelMultipleChoiceFilter(
|
|
105
|
+
queryset=Contact.objects.all(),
|
|
106
|
+
field_name="registrant__contact_id",
|
|
107
|
+
to_field_name="contact_id",
|
|
108
|
+
label="Registrant",
|
|
109
|
+
)
|
|
110
|
+
admin_c_id = django_filters.ModelMultipleChoiceFilter(
|
|
111
|
+
queryset=Contact.objects.all(),
|
|
112
|
+
label="Administrative Contact ID",
|
|
113
|
+
)
|
|
114
|
+
admin_c = django_filters.ModelMultipleChoiceFilter(
|
|
115
|
+
queryset=Contact.objects.all(),
|
|
116
|
+
field_name="admin_c__contact_id",
|
|
117
|
+
to_field_name="contact_id",
|
|
118
|
+
label="Administrative Contact",
|
|
119
|
+
)
|
|
120
|
+
tech_c_id = django_filters.ModelMultipleChoiceFilter(
|
|
121
|
+
queryset=Contact.objects.all(),
|
|
122
|
+
label="Technical Contact ID",
|
|
123
|
+
)
|
|
124
|
+
tech_c = django_filters.ModelMultipleChoiceFilter(
|
|
125
|
+
queryset=Contact.objects.all(),
|
|
126
|
+
field_name="tech_c__contact_id",
|
|
127
|
+
to_field_name="contact_id",
|
|
128
|
+
label="Technical Contact",
|
|
129
|
+
)
|
|
130
|
+
billing_c_id = django_filters.ModelMultipleChoiceFilter(
|
|
131
|
+
queryset=Contact.objects.all(),
|
|
132
|
+
label="Billing Contact ID",
|
|
133
|
+
)
|
|
134
|
+
billing_c = django_filters.ModelMultipleChoiceFilter(
|
|
135
|
+
queryset=Contact.objects.all(),
|
|
136
|
+
field_name="billing_c__contact_id",
|
|
137
|
+
to_field_name="contact_id",
|
|
138
|
+
label="Billing Contact",
|
|
139
|
+
)
|
|
140
|
+
active = django_filters.BooleanFilter(
|
|
141
|
+
label="Zone is active",
|
|
142
|
+
)
|
|
143
|
+
|
|
144
|
+
class Meta:
|
|
145
|
+
model = Zone
|
|
146
|
+
fields = (
|
|
147
|
+
"id",
|
|
148
|
+
"name",
|
|
149
|
+
"description",
|
|
150
|
+
"default_ttl",
|
|
151
|
+
"soa_ttl",
|
|
152
|
+
"soa_rname",
|
|
153
|
+
"soa_serial",
|
|
154
|
+
"soa_refresh",
|
|
155
|
+
"soa_retry",
|
|
156
|
+
"soa_expire",
|
|
157
|
+
"soa_minimum",
|
|
158
|
+
"soa_serial_auto",
|
|
159
|
+
"rfc2317_parent_managed",
|
|
160
|
+
"registry_domain_id",
|
|
161
|
+
)
|
|
162
|
+
|
|
163
|
+
def filter_arpa_network(self, queryset, name, value):
|
|
164
|
+
if not value:
|
|
165
|
+
return queryset
|
|
166
|
+
try:
|
|
167
|
+
arpa_networks = [
|
|
168
|
+
str(netaddr.IPNetwork(item)) for item in value if item.strip()
|
|
169
|
+
]
|
|
170
|
+
if not arpa_networks:
|
|
171
|
+
return queryset
|
|
172
|
+
return queryset.filter(arpa_network__in=arpa_networks)
|
|
173
|
+
|
|
174
|
+
except (netaddr.AddrFormatError, ValueError):
|
|
175
|
+
return queryset.none()
|
|
176
|
+
|
|
177
|
+
def filter_rfc2317_prefix(self, queryset, name, value):
|
|
178
|
+
if not value:
|
|
179
|
+
return queryset
|
|
180
|
+
try:
|
|
181
|
+
rfc2317_prefixes = [
|
|
182
|
+
str(netaddr.IPNetwork(item)) for item in value if item.strip()
|
|
183
|
+
]
|
|
184
|
+
if not rfc2317_prefixes:
|
|
185
|
+
return queryset
|
|
186
|
+
return queryset.filter(rfc2317_prefix__in=rfc2317_prefixes)
|
|
187
|
+
|
|
188
|
+
except (netaddr.AddrFormatError, ValueError):
|
|
189
|
+
return queryset.none()
|
|
190
|
+
|
|
191
|
+
def search(self, queryset, name, value):
|
|
192
|
+
if not value.strip():
|
|
193
|
+
return queryset
|
|
194
|
+
qs_filter = (
|
|
195
|
+
Q(name__icontains=value)
|
|
196
|
+
| Q(status__icontains=value)
|
|
197
|
+
| Q(view__name__icontains=value)
|
|
198
|
+
| Q(registrar__name__icontains=value)
|
|
199
|
+
| Q(registry_domain_id__icontains=value)
|
|
200
|
+
| Q(registrant__name__icontains=value)
|
|
201
|
+
| Q(admin_c__name__icontains=value)
|
|
202
|
+
| Q(tech_c__name__icontains=value)
|
|
203
|
+
| Q(billing_c__name__icontains=value)
|
|
204
|
+
)
|
|
205
|
+
return queryset.filter(qs_filter)
|