netbox-plugin-dns 1.0.7__py3-none-any.whl → 1.1.0__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 +23 -4
- netbox_dns/api/serializers.py +2 -1
- netbox_dns/api/serializers_/prefix.py +18 -0
- netbox_dns/api/serializers_/{contact.py → registration_contact.py} +5 -5
- netbox_dns/api/serializers_/view.py +34 -2
- netbox_dns/api/serializers_/zone.py +5 -5
- netbox_dns/api/serializers_/zone_template.py +5 -5
- netbox_dns/api/urls.py +5 -2
- netbox_dns/api/views.py +17 -7
- netbox_dns/fields/__init__.py +1 -0
- netbox_dns/fields/ipam.py +15 -0
- netbox_dns/filtersets/__init__.py +1 -1
- netbox_dns/filtersets/{contact.py → registration_contact.py} +4 -4
- netbox_dns/filtersets/view.py +16 -0
- netbox_dns/filtersets/zone.py +15 -15
- netbox_dns/filtersets/zone_template.py +15 -15
- netbox_dns/forms/__init__.py +1 -1
- netbox_dns/forms/{contact.py → registration_contact.py} +16 -16
- netbox_dns/forms/view.py +204 -4
- netbox_dns/forms/zone.py +15 -18
- netbox_dns/forms/zone_template.py +13 -13
- netbox_dns/graphql/__init__.py +2 -2
- netbox_dns/graphql/filters.py +5 -5
- netbox_dns/graphql/schema.py +9 -5
- netbox_dns/graphql/types.py +41 -12
- netbox_dns/management/commands/rebuild_dnssync.py +18 -0
- netbox_dns/management/commands/setup_dnssync.py +140 -0
- netbox_dns/migrations/0008_view_prefixes.py +18 -0
- netbox_dns/migrations/0009_rename_contact_registrationcontact.py +27 -0
- netbox_dns/models/__init__.py +1 -3
- netbox_dns/models/record.py +139 -20
- netbox_dns/models/{contact.py → registration_contact.py} +8 -8
- netbox_dns/models/view.py +5 -0
- netbox_dns/models/zone.py +66 -30
- netbox_dns/models/zone_template.py +4 -4
- netbox_dns/navigation.py +7 -7
- netbox_dns/signals/ipam_dnssync.py +224 -0
- netbox_dns/tables/__init__.py +1 -1
- netbox_dns/tables/ipam_dnssync.py +11 -0
- netbox_dns/tables/record.py +33 -0
- netbox_dns/tables/{contact.py → registration_contact.py} +5 -5
- netbox_dns/tables/view.py +24 -2
- netbox_dns/template_content.py +41 -40
- netbox_dns/templates/netbox_dns/record.html +6 -6
- netbox_dns/templates/netbox_dns/{contact.html → registrationcontact.html} +1 -1
- netbox_dns/templates/netbox_dns/view/button.html +9 -0
- netbox_dns/templates/netbox_dns/view/prefix.html +41 -0
- netbox_dns/templates/netbox_dns/view/related.html +17 -0
- netbox_dns/templates/netbox_dns/view.html +25 -0
- netbox_dns/urls/__init__.py +2 -2
- netbox_dns/urls/registration_contact.py +60 -0
- netbox_dns/urls/view.py +6 -0
- netbox_dns/utilities/__init__.py +2 -74
- netbox_dns/utilities/conversions.py +83 -0
- netbox_dns/utilities/ipam_dnssync.py +295 -0
- netbox_dns/views/__init__.py +1 -1
- netbox_dns/views/record.py +3 -5
- netbox_dns/views/registration_contact.py +94 -0
- netbox_dns/views/view.py +26 -1
- {netbox_plugin_dns-1.0.7.dist-info → netbox_plugin_dns-1.1.0.dist-info}/METADATA +2 -1
- {netbox_plugin_dns-1.0.7.dist-info → netbox_plugin_dns-1.1.0.dist-info}/RECORD +63 -54
- netbox_dns/management/commands/setup_coupling.py +0 -109
- netbox_dns/signals/ipam_coupling.py +0 -168
- netbox_dns/templates/netbox_dns/related_dns_objects.html +0 -21
- netbox_dns/urls/contact.py +0 -29
- netbox_dns/utilities/ipam_coupling.py +0 -112
- netbox_dns/views/contact.py +0 -94
- {netbox_plugin_dns-1.0.7.dist-info → netbox_plugin_dns-1.1.0.dist-info}/LICENSE +0 -0
- {netbox_plugin_dns-1.0.7.dist-info → netbox_plugin_dns-1.1.0.dist-info}/WHEEL +0 -0
netbox_dns/__init__.py
CHANGED
|
@@ -1,6 +1,11 @@
|
|
|
1
|
+
from django.conf import settings
|
|
2
|
+
|
|
1
3
|
from netbox.plugins import PluginConfig
|
|
4
|
+
from ipam.choices import IPAddressStatusChoices
|
|
5
|
+
|
|
6
|
+
from netbox_dns.choices import RecordTypeChoices
|
|
2
7
|
|
|
3
|
-
__version__ = "1.0
|
|
8
|
+
__version__ = "1.1.0"
|
|
4
9
|
|
|
5
10
|
|
|
6
11
|
class DNSConfig(PluginConfig):
|
|
@@ -20,13 +25,20 @@ class DNSConfig(PluginConfig):
|
|
|
20
25
|
"zone_soa_retry": 7200,
|
|
21
26
|
"zone_soa_expire": 2419200,
|
|
22
27
|
"zone_soa_minimum": 3600,
|
|
23
|
-
"
|
|
28
|
+
"dnssync_disabled": False,
|
|
29
|
+
"dnssync_ipaddress_active_status": [
|
|
30
|
+
IPAddressStatusChoices.STATUS_ACTIVE,
|
|
31
|
+
IPAddressStatusChoices.STATUS_DHCP,
|
|
32
|
+
IPAddressStatusChoices.STATUS_SLAAC,
|
|
33
|
+
],
|
|
34
|
+
"dnssync_conflict_deactivate": False,
|
|
35
|
+
"dnssync_minimum_zone_labels": 2,
|
|
24
36
|
"tolerate_characters_in_zone_labels": "",
|
|
25
37
|
"tolerate_underscores_in_labels": False,
|
|
26
38
|
"tolerate_underscores_in_hostnames": False, # Deprecated, will be removed in 1.2.0
|
|
27
39
|
"tolerate_leading_underscore_types": [
|
|
28
|
-
|
|
29
|
-
|
|
40
|
+
RecordTypeChoices.TXT,
|
|
41
|
+
RecordTypeChoices.SRV,
|
|
30
42
|
],
|
|
31
43
|
"tolerate_non_rfc1035_types": [],
|
|
32
44
|
"enable_root_zones": False,
|
|
@@ -37,6 +49,13 @@ class DNSConfig(PluginConfig):
|
|
|
37
49
|
}
|
|
38
50
|
base_url = "netbox-dns"
|
|
39
51
|
|
|
52
|
+
def ready(self):
|
|
53
|
+
super().ready()
|
|
54
|
+
|
|
55
|
+
if not settings.PLUGINS_CONFIG["netbox_dns"].get("dnssync_disabled"):
|
|
56
|
+
import netbox_dns.signals.ipam_dnssync
|
|
57
|
+
import netbox_dns.tables.ipam_dnssync
|
|
58
|
+
|
|
40
59
|
|
|
41
60
|
#
|
|
42
61
|
# Initialize plugin config
|
netbox_dns/api/serializers.py
CHANGED
|
@@ -1,10 +1,11 @@
|
|
|
1
|
-
from .serializers_.contact import *
|
|
2
1
|
from .serializers_.nameserver import *
|
|
3
2
|
from .serializers_.record import *
|
|
4
3
|
from .serializers_.registrar import *
|
|
4
|
+
from .serializers_.registration_contact import *
|
|
5
5
|
from .serializers_.view import *
|
|
6
6
|
from .serializers_.zone import *
|
|
7
7
|
from .serializers_.zone_template import *
|
|
8
8
|
from .serializers_.record_template import *
|
|
9
|
+
from .serializers_.prefix import *
|
|
9
10
|
|
|
10
11
|
from .nested_serializers import *
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
from rest_framework.serializers import HyperlinkedIdentityField
|
|
2
|
+
|
|
3
|
+
from ipam.api.serializers import PrefixSerializer as IPAMPrefixSerializer
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
__all__ = ("PrefixSerializer",)
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
class PrefixSerializer(IPAMPrefixSerializer):
|
|
10
|
+
url = HyperlinkedIdentityField(view_name="plugins-api:netbox_dns-api:prefix-detail")
|
|
11
|
+
|
|
12
|
+
def to_representation(self, instance):
|
|
13
|
+
representation = super().to_representation(instance)
|
|
14
|
+
|
|
15
|
+
if instance.vrf is not None:
|
|
16
|
+
representation["display"] += f" [{instance.vrf.name}]"
|
|
17
|
+
|
|
18
|
+
return representation
|
|
@@ -2,19 +2,19 @@ from rest_framework import serializers
|
|
|
2
2
|
|
|
3
3
|
from netbox.api.serializers import NetBoxModelSerializer
|
|
4
4
|
|
|
5
|
-
from netbox_dns.models import
|
|
5
|
+
from netbox_dns.models import RegistrationContact
|
|
6
6
|
|
|
7
7
|
|
|
8
|
-
__all__ = ("
|
|
8
|
+
__all__ = ("RegistrationContactSerializer",)
|
|
9
9
|
|
|
10
10
|
|
|
11
|
-
class
|
|
11
|
+
class RegistrationContactSerializer(NetBoxModelSerializer):
|
|
12
12
|
url = serializers.HyperlinkedIdentityField(
|
|
13
|
-
view_name="plugins-api:netbox_dns-api:
|
|
13
|
+
view_name="plugins-api:netbox_dns-api:registrationcontact-detail"
|
|
14
14
|
)
|
|
15
15
|
|
|
16
16
|
class Meta:
|
|
17
|
-
model =
|
|
17
|
+
model = RegistrationContact
|
|
18
18
|
fields = (
|
|
19
19
|
"id",
|
|
20
20
|
"url",
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
from rest_framework import serializers
|
|
2
2
|
|
|
3
3
|
from netbox.api.serializers import NetBoxModelSerializer
|
|
4
|
-
from tenancy.api.
|
|
4
|
+
from tenancy.api.serializers import TenantSerializer
|
|
5
|
+
from ipam.api.serializers import PrefixSerializer
|
|
5
6
|
|
|
6
7
|
from netbox_dns.models import View
|
|
7
8
|
|
|
@@ -16,8 +17,38 @@ class ViewSerializer(NetBoxModelSerializer):
|
|
|
16
17
|
default_view = serializers.BooleanField(
|
|
17
18
|
read_only=True,
|
|
18
19
|
)
|
|
20
|
+
prefixes = PrefixSerializer(
|
|
21
|
+
many=True,
|
|
22
|
+
nested=True,
|
|
23
|
+
read_only=False,
|
|
24
|
+
required=False,
|
|
25
|
+
help_text="IPAM Prefixes assigned to the View",
|
|
26
|
+
)
|
|
27
|
+
tenant = TenantSerializer(
|
|
28
|
+
nested=True,
|
|
29
|
+
required=False,
|
|
30
|
+
allow_null=True,
|
|
31
|
+
)
|
|
32
|
+
|
|
33
|
+
def create(self, validated_data):
|
|
34
|
+
prefixes = validated_data.pop("prefixes", None)
|
|
35
|
+
|
|
36
|
+
view = super().create(validated_data)
|
|
37
|
+
|
|
38
|
+
if prefixes is not None:
|
|
39
|
+
view.prefixes.set(prefixes)
|
|
40
|
+
|
|
41
|
+
return view
|
|
42
|
+
|
|
43
|
+
def update(self, instance, validated_data):
|
|
44
|
+
prefixes = validated_data.pop("prefixes", None)
|
|
45
|
+
|
|
46
|
+
view = super().update(instance, validated_data)
|
|
47
|
+
|
|
48
|
+
if prefixes is not None:
|
|
49
|
+
view.prefixes.set(prefixes)
|
|
19
50
|
|
|
20
|
-
|
|
51
|
+
return view
|
|
21
52
|
|
|
22
53
|
class Meta:
|
|
23
54
|
model = View
|
|
@@ -33,5 +64,6 @@ class ViewSerializer(NetBoxModelSerializer):
|
|
|
33
64
|
"last_updated",
|
|
34
65
|
"custom_fields",
|
|
35
66
|
"tenant",
|
|
67
|
+
"prefixes",
|
|
36
68
|
)
|
|
37
69
|
brief_fields = ("id", "url", "display", "name", "default_view", "description")
|
|
@@ -6,7 +6,7 @@ from tenancy.api.serializers import TenantSerializer
|
|
|
6
6
|
from .view import ViewSerializer
|
|
7
7
|
from .nameserver import NameServerSerializer
|
|
8
8
|
from .registrar import RegistrarSerializer
|
|
9
|
-
from .
|
|
9
|
+
from .registration_contact import RegistrationContactSerializer
|
|
10
10
|
from .zone_template import ZoneTemplateSerializer
|
|
11
11
|
|
|
12
12
|
from ..nested_serializers import NestedZoneSerializer
|
|
@@ -62,28 +62,28 @@ class ZoneSerializer(NetBoxModelSerializer):
|
|
|
62
62
|
required=False,
|
|
63
63
|
help_text="The registrar the domain is registered with",
|
|
64
64
|
)
|
|
65
|
-
registrant =
|
|
65
|
+
registrant = RegistrationContactSerializer(
|
|
66
66
|
nested=True,
|
|
67
67
|
many=False,
|
|
68
68
|
read_only=False,
|
|
69
69
|
required=False,
|
|
70
70
|
help_text="The owner of the domain",
|
|
71
71
|
)
|
|
72
|
-
admin_c =
|
|
72
|
+
admin_c = RegistrationContactSerializer(
|
|
73
73
|
nested=True,
|
|
74
74
|
many=False,
|
|
75
75
|
read_only=False,
|
|
76
76
|
required=False,
|
|
77
77
|
help_text="The administrative contact for the domain",
|
|
78
78
|
)
|
|
79
|
-
tech_c =
|
|
79
|
+
tech_c = RegistrationContactSerializer(
|
|
80
80
|
nested=True,
|
|
81
81
|
many=False,
|
|
82
82
|
read_only=False,
|
|
83
83
|
required=False,
|
|
84
84
|
help_text="The technical contact for the domain",
|
|
85
85
|
)
|
|
86
|
-
billing_c =
|
|
86
|
+
billing_c = RegistrationContactSerializer(
|
|
87
87
|
nested=True,
|
|
88
88
|
many=False,
|
|
89
89
|
read_only=False,
|
|
@@ -8,7 +8,7 @@ from netbox_dns.api.nested_serializers import NestedRecordTemplateSerializer
|
|
|
8
8
|
|
|
9
9
|
from .nameserver import NameServerSerializer
|
|
10
10
|
from .registrar import RegistrarSerializer
|
|
11
|
-
from .
|
|
11
|
+
from .registration_contact import RegistrationContactSerializer
|
|
12
12
|
|
|
13
13
|
|
|
14
14
|
__all__ = ("ZoneTemplateSerializer",)
|
|
@@ -38,28 +38,28 @@ class ZoneTemplateSerializer(NetBoxModelSerializer):
|
|
|
38
38
|
required=False,
|
|
39
39
|
help_text="The registrar the domain is registered with",
|
|
40
40
|
)
|
|
41
|
-
registrant =
|
|
41
|
+
registrant = RegistrationContactSerializer(
|
|
42
42
|
nested=True,
|
|
43
43
|
many=False,
|
|
44
44
|
read_only=False,
|
|
45
45
|
required=False,
|
|
46
46
|
help_text="The owner of the domain",
|
|
47
47
|
)
|
|
48
|
-
admin_c =
|
|
48
|
+
admin_c = RegistrationContactSerializer(
|
|
49
49
|
nested=True,
|
|
50
50
|
many=False,
|
|
51
51
|
read_only=False,
|
|
52
52
|
required=False,
|
|
53
53
|
help_text="The administrative contact for the domain",
|
|
54
54
|
)
|
|
55
|
-
tech_c =
|
|
55
|
+
tech_c = RegistrationContactSerializer(
|
|
56
56
|
nested=True,
|
|
57
57
|
many=False,
|
|
58
58
|
read_only=False,
|
|
59
59
|
required=False,
|
|
60
60
|
help_text="The technical contact for the domain",
|
|
61
61
|
)
|
|
62
|
-
billing_c =
|
|
62
|
+
billing_c = RegistrationContactSerializer(
|
|
63
63
|
nested=True,
|
|
64
64
|
many=False,
|
|
65
65
|
read_only=False,
|
netbox_dns/api/urls.py
CHANGED
|
@@ -7,9 +7,10 @@ from netbox_dns.api.views import (
|
|
|
7
7
|
NameServerViewSet,
|
|
8
8
|
RecordViewSet,
|
|
9
9
|
RegistrarViewSet,
|
|
10
|
-
|
|
10
|
+
RegistrationContactViewSet,
|
|
11
11
|
ZoneTemplateViewSet,
|
|
12
12
|
RecordTemplateViewSet,
|
|
13
|
+
PrefixViewSet,
|
|
13
14
|
)
|
|
14
15
|
|
|
15
16
|
router = NetBoxRouter()
|
|
@@ -20,8 +21,10 @@ router.register("zones", ZoneViewSet)
|
|
|
20
21
|
router.register("nameservers", NameServerViewSet)
|
|
21
22
|
router.register("records", RecordViewSet)
|
|
22
23
|
router.register("registrars", RegistrarViewSet)
|
|
23
|
-
router.register("contacts",
|
|
24
|
+
router.register("contacts", RegistrationContactViewSet)
|
|
24
25
|
router.register("zonetemplates", ZoneTemplateViewSet)
|
|
25
26
|
router.register("recordtemplates", RecordTemplateViewSet)
|
|
26
27
|
|
|
28
|
+
router.register("prefixes", PrefixViewSet)
|
|
29
|
+
|
|
27
30
|
urlpatterns = router.urls
|
netbox_dns/api/views.py
CHANGED
|
@@ -1,6 +1,9 @@
|
|
|
1
1
|
from rest_framework import serializers
|
|
2
2
|
from rest_framework.routers import APIRootView
|
|
3
3
|
|
|
4
|
+
from ipam.models import Prefix
|
|
5
|
+
from ipam.filtersets import PrefixFilterSet
|
|
6
|
+
|
|
4
7
|
from netbox.api.viewsets import NetBoxModelViewSet
|
|
5
8
|
|
|
6
9
|
from netbox_dns.api.serializers import (
|
|
@@ -9,9 +12,10 @@ from netbox_dns.api.serializers import (
|
|
|
9
12
|
NameServerSerializer,
|
|
10
13
|
RecordSerializer,
|
|
11
14
|
RegistrarSerializer,
|
|
12
|
-
|
|
15
|
+
RegistrationContactSerializer,
|
|
13
16
|
ZoneTemplateSerializer,
|
|
14
17
|
RecordTemplateSerializer,
|
|
18
|
+
PrefixSerializer,
|
|
15
19
|
)
|
|
16
20
|
from netbox_dns.filtersets import (
|
|
17
21
|
ViewFilterSet,
|
|
@@ -19,7 +23,7 @@ from netbox_dns.filtersets import (
|
|
|
19
23
|
NameServerFilterSet,
|
|
20
24
|
RecordFilterSet,
|
|
21
25
|
RegistrarFilterSet,
|
|
22
|
-
|
|
26
|
+
RegistrationContactFilterSet,
|
|
23
27
|
ZoneTemplateFilterSet,
|
|
24
28
|
RecordTemplateFilterSet,
|
|
25
29
|
)
|
|
@@ -29,7 +33,7 @@ from netbox_dns.models import (
|
|
|
29
33
|
NameServer,
|
|
30
34
|
Record,
|
|
31
35
|
Registrar,
|
|
32
|
-
|
|
36
|
+
RegistrationContact,
|
|
33
37
|
ZoneTemplate,
|
|
34
38
|
RecordTemplate,
|
|
35
39
|
)
|
|
@@ -108,10 +112,10 @@ class RegistrarViewSet(NetBoxModelViewSet):
|
|
|
108
112
|
filterset_class = RegistrarFilterSet
|
|
109
113
|
|
|
110
114
|
|
|
111
|
-
class
|
|
112
|
-
queryset =
|
|
113
|
-
serializer_class =
|
|
114
|
-
filterset_class =
|
|
115
|
+
class RegistrationContactViewSet(NetBoxModelViewSet):
|
|
116
|
+
queryset = RegistrationContact.objects.all()
|
|
117
|
+
serializer_class = RegistrationContactSerializer
|
|
118
|
+
filterset_class = RegistrationContactFilterSet
|
|
115
119
|
|
|
116
120
|
|
|
117
121
|
class ZoneTemplateViewSet(NetBoxModelViewSet):
|
|
@@ -124,3 +128,9 @@ class RecordTemplateViewSet(NetBoxModelViewSet):
|
|
|
124
128
|
queryset = RecordTemplate.objects.all()
|
|
125
129
|
serializer_class = RecordTemplateSerializer
|
|
126
130
|
filterset_class = RecordTemplateFilterSet
|
|
131
|
+
|
|
132
|
+
|
|
133
|
+
class PrefixViewSet(NetBoxModelViewSet):
|
|
134
|
+
queryset = Prefix.objects.all()
|
|
135
|
+
serializer_class = PrefixSerializer
|
|
136
|
+
filterset_class = PrefixFilterSet
|
netbox_dns/fields/__init__.py
CHANGED
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
from utilities.forms.fields import DynamicModelMultipleChoiceField
|
|
2
|
+
from utilities.forms.widgets import APISelectMultiple
|
|
3
|
+
|
|
4
|
+
|
|
5
|
+
__all__ = ("PrefixDynamicModelMultipleChoiceField",)
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
class PrefixDynamicModelMultipleChoiceField(DynamicModelMultipleChoiceField):
|
|
9
|
+
widget = APISelectMultiple(api_url="/api/plugins/netbox-dns/prefixes")
|
|
10
|
+
|
|
11
|
+
def label_from_instance(self, obj):
|
|
12
|
+
if obj.vrf:
|
|
13
|
+
return f"{str(obj.prefix)} [{obj.vrf.name}]"
|
|
14
|
+
|
|
15
|
+
return str(obj.prefix)
|
|
@@ -2,15 +2,15 @@ from django.db.models import Q
|
|
|
2
2
|
|
|
3
3
|
from netbox.filtersets import NetBoxModelFilterSet
|
|
4
4
|
|
|
5
|
-
from netbox_dns.models import
|
|
5
|
+
from netbox_dns.models import RegistrationContact
|
|
6
6
|
|
|
7
7
|
|
|
8
|
-
__all__ = ("
|
|
8
|
+
__all__ = ("RegistrationContactFilterSet",)
|
|
9
9
|
|
|
10
10
|
|
|
11
|
-
class
|
|
11
|
+
class RegistrationContactFilterSet(NetBoxModelFilterSet):
|
|
12
12
|
class Meta:
|
|
13
|
-
model =
|
|
13
|
+
model = RegistrationContact
|
|
14
14
|
fields = (
|
|
15
15
|
"id",
|
|
16
16
|
"name",
|
netbox_dns/filtersets/view.py
CHANGED
|
@@ -1,7 +1,10 @@
|
|
|
1
|
+
import django_filters
|
|
2
|
+
|
|
1
3
|
from django.db.models import Q
|
|
2
4
|
|
|
3
5
|
from netbox.filtersets import NetBoxModelFilterSet
|
|
4
6
|
from tenancy.filtersets import TenancyFilterSet
|
|
7
|
+
from ipam.models import Prefix
|
|
5
8
|
|
|
6
9
|
from netbox_dns.models import View
|
|
7
10
|
|
|
@@ -10,6 +13,19 @@ __all__ = ("ViewFilterSet",)
|
|
|
10
13
|
|
|
11
14
|
|
|
12
15
|
class ViewFilterSet(NetBoxModelFilterSet, TenancyFilterSet):
|
|
16
|
+
prefix_id = django_filters.ModelMultipleChoiceFilter(
|
|
17
|
+
queryset=Prefix.objects.all(),
|
|
18
|
+
field_name="prefixes",
|
|
19
|
+
to_field_name="id",
|
|
20
|
+
label="Prefixes ID",
|
|
21
|
+
)
|
|
22
|
+
prefix = django_filters.ModelMultipleChoiceFilter(
|
|
23
|
+
queryset=Prefix.objects.all(),
|
|
24
|
+
field_name="prefixes__prefix",
|
|
25
|
+
to_field_name="prefix",
|
|
26
|
+
label="Prefix",
|
|
27
|
+
)
|
|
28
|
+
|
|
13
29
|
class Meta:
|
|
14
30
|
model = View
|
|
15
31
|
fields = ("id", "name", "default_view", "description")
|
netbox_dns/filtersets/zone.py
CHANGED
|
@@ -7,7 +7,7 @@ from netbox.filtersets import NetBoxModelFilterSet
|
|
|
7
7
|
from tenancy.filtersets import TenancyFilterSet
|
|
8
8
|
from utilities.filters import MultiValueCharFilter
|
|
9
9
|
|
|
10
|
-
from netbox_dns.models import View, Zone, Registrar,
|
|
10
|
+
from netbox_dns.models import View, Zone, Registrar, RegistrationContact, NameServer
|
|
11
11
|
from netbox_dns.choices import ZoneStatusChoices
|
|
12
12
|
|
|
13
13
|
|
|
@@ -95,44 +95,44 @@ class ZoneFilterSet(TenancyFilterSet, NetBoxModelFilterSet):
|
|
|
95
95
|
label="Registrar",
|
|
96
96
|
)
|
|
97
97
|
registrant_id = django_filters.ModelMultipleChoiceFilter(
|
|
98
|
-
queryset=
|
|
98
|
+
queryset=RegistrationContact.objects.all(),
|
|
99
99
|
label="Registrant ID",
|
|
100
100
|
)
|
|
101
101
|
registrant = django_filters.ModelMultipleChoiceFilter(
|
|
102
|
-
queryset=
|
|
102
|
+
queryset=RegistrationContact.objects.all(),
|
|
103
103
|
field_name="registrant__contact_id",
|
|
104
104
|
to_field_name="contact_id",
|
|
105
105
|
label="Registrant",
|
|
106
106
|
)
|
|
107
107
|
admin_c_id = django_filters.ModelMultipleChoiceFilter(
|
|
108
|
-
queryset=
|
|
109
|
-
label="Administrative
|
|
108
|
+
queryset=RegistrationContact.objects.all(),
|
|
109
|
+
label="Administrative RegistrationContact ID",
|
|
110
110
|
)
|
|
111
111
|
admin_c = django_filters.ModelMultipleChoiceFilter(
|
|
112
|
-
queryset=
|
|
112
|
+
queryset=RegistrationContact.objects.all(),
|
|
113
113
|
field_name="admin_c__contact_id",
|
|
114
114
|
to_field_name="contact_id",
|
|
115
|
-
label="Administrative
|
|
115
|
+
label="Administrative RegistrationContact",
|
|
116
116
|
)
|
|
117
117
|
tech_c_id = django_filters.ModelMultipleChoiceFilter(
|
|
118
|
-
queryset=
|
|
119
|
-
label="Technical
|
|
118
|
+
queryset=RegistrationContact.objects.all(),
|
|
119
|
+
label="Technical RegistrationContact ID",
|
|
120
120
|
)
|
|
121
121
|
tech_c = django_filters.ModelMultipleChoiceFilter(
|
|
122
|
-
queryset=
|
|
122
|
+
queryset=RegistrationContact.objects.all(),
|
|
123
123
|
field_name="tech_c__contact_id",
|
|
124
124
|
to_field_name="contact_id",
|
|
125
|
-
label="Technical
|
|
125
|
+
label="Technical RegistrationContact",
|
|
126
126
|
)
|
|
127
127
|
billing_c_id = django_filters.ModelMultipleChoiceFilter(
|
|
128
|
-
queryset=
|
|
129
|
-
label="Billing
|
|
128
|
+
queryset=RegistrationContact.objects.all(),
|
|
129
|
+
label="Billing RegistrationContact ID",
|
|
130
130
|
)
|
|
131
131
|
billing_c = django_filters.ModelMultipleChoiceFilter(
|
|
132
|
-
queryset=
|
|
132
|
+
queryset=RegistrationContact.objects.all(),
|
|
133
133
|
field_name="billing_c__contact_id",
|
|
134
134
|
to_field_name="contact_id",
|
|
135
|
-
label="Billing
|
|
135
|
+
label="Billing RegistrationContact",
|
|
136
136
|
)
|
|
137
137
|
active = django_filters.BooleanFilter(
|
|
138
138
|
label="Zone is active",
|
|
@@ -9,7 +9,7 @@ from netbox_dns.models import (
|
|
|
9
9
|
ZoneTemplate,
|
|
10
10
|
RecordTemplate,
|
|
11
11
|
Registrar,
|
|
12
|
-
|
|
12
|
+
RegistrationContact,
|
|
13
13
|
NameServer,
|
|
14
14
|
)
|
|
15
15
|
|
|
@@ -53,44 +53,44 @@ class ZoneTemplateFilterSet(TenancyFilterSet, NetBoxModelFilterSet):
|
|
|
53
53
|
label="Registrar",
|
|
54
54
|
)
|
|
55
55
|
registrant_id = django_filters.ModelMultipleChoiceFilter(
|
|
56
|
-
queryset=
|
|
56
|
+
queryset=RegistrationContact.objects.all(),
|
|
57
57
|
label="Registrant ID",
|
|
58
58
|
)
|
|
59
59
|
registrant = django_filters.ModelMultipleChoiceFilter(
|
|
60
|
-
queryset=
|
|
60
|
+
queryset=RegistrationContact.objects.all(),
|
|
61
61
|
field_name="registrant__contact_id",
|
|
62
62
|
to_field_name="contact_id",
|
|
63
63
|
label="Registrant",
|
|
64
64
|
)
|
|
65
65
|
admin_c_id = django_filters.ModelMultipleChoiceFilter(
|
|
66
|
-
queryset=
|
|
67
|
-
label="Administrative
|
|
66
|
+
queryset=RegistrationContact.objects.all(),
|
|
67
|
+
label="Administrative RegistrationContact ID",
|
|
68
68
|
)
|
|
69
69
|
admin_c = django_filters.ModelMultipleChoiceFilter(
|
|
70
|
-
queryset=
|
|
70
|
+
queryset=RegistrationContact.objects.all(),
|
|
71
71
|
field_name="admin_c__contact_id",
|
|
72
72
|
to_field_name="contact_id",
|
|
73
|
-
label="Administrative
|
|
73
|
+
label="Administrative RegistrationContact",
|
|
74
74
|
)
|
|
75
75
|
tech_c_id = django_filters.ModelMultipleChoiceFilter(
|
|
76
|
-
queryset=
|
|
77
|
-
label="Technical
|
|
76
|
+
queryset=RegistrationContact.objects.all(),
|
|
77
|
+
label="Technical RegistrationContact ID",
|
|
78
78
|
)
|
|
79
79
|
tech_c = django_filters.ModelMultipleChoiceFilter(
|
|
80
|
-
queryset=
|
|
80
|
+
queryset=RegistrationContact.objects.all(),
|
|
81
81
|
field_name="tech_c__contact_id",
|
|
82
82
|
to_field_name="contact_id",
|
|
83
|
-
label="Technical
|
|
83
|
+
label="Technical RegistrationContact",
|
|
84
84
|
)
|
|
85
85
|
billing_c_id = django_filters.ModelMultipleChoiceFilter(
|
|
86
|
-
queryset=
|
|
87
|
-
label="Billing
|
|
86
|
+
queryset=RegistrationContact.objects.all(),
|
|
87
|
+
label="Billing RegistrationContact ID",
|
|
88
88
|
)
|
|
89
89
|
billing_c = django_filters.ModelMultipleChoiceFilter(
|
|
90
|
-
queryset=
|
|
90
|
+
queryset=RegistrationContact.objects.all(),
|
|
91
91
|
field_name="billing_c__contact_id",
|
|
92
92
|
to_field_name="contact_id",
|
|
93
|
-
label="Billing
|
|
93
|
+
label="Billing RegistrationContact",
|
|
94
94
|
)
|
|
95
95
|
|
|
96
96
|
class Meta:
|
netbox_dns/forms/__init__.py
CHANGED
|
@@ -9,18 +9,18 @@ from netbox.forms import (
|
|
|
9
9
|
from utilities.forms.fields import TagFilterField
|
|
10
10
|
from utilities.forms.rendering import FieldSet
|
|
11
11
|
|
|
12
|
-
from netbox_dns.models import
|
|
12
|
+
from netbox_dns.models import RegistrationContact
|
|
13
13
|
|
|
14
14
|
|
|
15
15
|
__all__ = (
|
|
16
|
-
"
|
|
17
|
-
"
|
|
18
|
-
"
|
|
19
|
-
"
|
|
16
|
+
"RegistrationContactForm",
|
|
17
|
+
"RegistrationContactFilterForm",
|
|
18
|
+
"RegistrationContactImportForm",
|
|
19
|
+
"RegistrationContactBulkEditForm",
|
|
20
20
|
)
|
|
21
21
|
|
|
22
22
|
|
|
23
|
-
class
|
|
23
|
+
class RegistrationContactForm(NetBoxModelForm):
|
|
24
24
|
fieldsets = (
|
|
25
25
|
FieldSet(
|
|
26
26
|
"name",
|
|
@@ -37,13 +37,13 @@ class ContactForm(NetBoxModelForm):
|
|
|
37
37
|
"fax",
|
|
38
38
|
"fax_ext",
|
|
39
39
|
"email",
|
|
40
|
-
name="
|
|
40
|
+
name="RegistrationContact",
|
|
41
41
|
),
|
|
42
42
|
FieldSet("tags", name="Tags"),
|
|
43
43
|
)
|
|
44
44
|
|
|
45
45
|
class Meta:
|
|
46
|
-
model =
|
|
46
|
+
model = RegistrationContact
|
|
47
47
|
fields = (
|
|
48
48
|
"name",
|
|
49
49
|
"description",
|
|
@@ -63,8 +63,8 @@ class ContactForm(NetBoxModelForm):
|
|
|
63
63
|
)
|
|
64
64
|
|
|
65
65
|
|
|
66
|
-
class
|
|
67
|
-
model =
|
|
66
|
+
class RegistrationContactFilterForm(NetBoxModelFilterSetForm):
|
|
67
|
+
model = RegistrationContact
|
|
68
68
|
|
|
69
69
|
fieldsets = (
|
|
70
70
|
FieldSet("q", "filter_id", "tag"),
|
|
@@ -89,7 +89,7 @@ class ContactFilterForm(NetBoxModelFilterSetForm):
|
|
|
89
89
|
)
|
|
90
90
|
contact_id = forms.CharField(
|
|
91
91
|
required=False,
|
|
92
|
-
label="
|
|
92
|
+
label="RegistrationContact ID",
|
|
93
93
|
)
|
|
94
94
|
organization = forms.CharField(
|
|
95
95
|
required=False,
|
|
@@ -128,12 +128,12 @@ class ContactFilterForm(NetBoxModelFilterSetForm):
|
|
|
128
128
|
email = forms.CharField(
|
|
129
129
|
required=False,
|
|
130
130
|
)
|
|
131
|
-
tag = TagFilterField(
|
|
131
|
+
tag = TagFilterField(RegistrationContact)
|
|
132
132
|
|
|
133
133
|
|
|
134
|
-
class
|
|
134
|
+
class RegistrationContactImportForm(NetBoxModelImportForm):
|
|
135
135
|
class Meta:
|
|
136
|
-
model =
|
|
136
|
+
model = RegistrationContact
|
|
137
137
|
fields = (
|
|
138
138
|
"name",
|
|
139
139
|
"description",
|
|
@@ -153,8 +153,8 @@ class ContactImportForm(NetBoxModelImportForm):
|
|
|
153
153
|
)
|
|
154
154
|
|
|
155
155
|
|
|
156
|
-
class
|
|
157
|
-
model =
|
|
156
|
+
class RegistrationContactBulkEditForm(NetBoxModelBulkEditForm):
|
|
157
|
+
model = RegistrationContact
|
|
158
158
|
|
|
159
159
|
name = forms.CharField(
|
|
160
160
|
required=False,
|