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.

Files changed (69) hide show
  1. netbox_dns/__init__.py +23 -4
  2. netbox_dns/api/serializers.py +2 -1
  3. netbox_dns/api/serializers_/prefix.py +18 -0
  4. netbox_dns/api/serializers_/{contact.py → registration_contact.py} +5 -5
  5. netbox_dns/api/serializers_/view.py +34 -2
  6. netbox_dns/api/serializers_/zone.py +5 -5
  7. netbox_dns/api/serializers_/zone_template.py +5 -5
  8. netbox_dns/api/urls.py +5 -2
  9. netbox_dns/api/views.py +17 -7
  10. netbox_dns/fields/__init__.py +1 -0
  11. netbox_dns/fields/ipam.py +15 -0
  12. netbox_dns/filtersets/__init__.py +1 -1
  13. netbox_dns/filtersets/{contact.py → registration_contact.py} +4 -4
  14. netbox_dns/filtersets/view.py +16 -0
  15. netbox_dns/filtersets/zone.py +15 -15
  16. netbox_dns/filtersets/zone_template.py +15 -15
  17. netbox_dns/forms/__init__.py +1 -1
  18. netbox_dns/forms/{contact.py → registration_contact.py} +16 -16
  19. netbox_dns/forms/view.py +204 -4
  20. netbox_dns/forms/zone.py +15 -18
  21. netbox_dns/forms/zone_template.py +13 -13
  22. netbox_dns/graphql/__init__.py +2 -2
  23. netbox_dns/graphql/filters.py +5 -5
  24. netbox_dns/graphql/schema.py +9 -5
  25. netbox_dns/graphql/types.py +41 -12
  26. netbox_dns/management/commands/rebuild_dnssync.py +18 -0
  27. netbox_dns/management/commands/setup_dnssync.py +140 -0
  28. netbox_dns/migrations/0008_view_prefixes.py +18 -0
  29. netbox_dns/migrations/0009_rename_contact_registrationcontact.py +27 -0
  30. netbox_dns/models/__init__.py +1 -3
  31. netbox_dns/models/record.py +139 -20
  32. netbox_dns/models/{contact.py → registration_contact.py} +8 -8
  33. netbox_dns/models/view.py +5 -0
  34. netbox_dns/models/zone.py +66 -30
  35. netbox_dns/models/zone_template.py +4 -4
  36. netbox_dns/navigation.py +7 -7
  37. netbox_dns/signals/ipam_dnssync.py +224 -0
  38. netbox_dns/tables/__init__.py +1 -1
  39. netbox_dns/tables/ipam_dnssync.py +11 -0
  40. netbox_dns/tables/record.py +33 -0
  41. netbox_dns/tables/{contact.py → registration_contact.py} +5 -5
  42. netbox_dns/tables/view.py +24 -2
  43. netbox_dns/template_content.py +41 -40
  44. netbox_dns/templates/netbox_dns/record.html +6 -6
  45. netbox_dns/templates/netbox_dns/{contact.html → registrationcontact.html} +1 -1
  46. netbox_dns/templates/netbox_dns/view/button.html +9 -0
  47. netbox_dns/templates/netbox_dns/view/prefix.html +41 -0
  48. netbox_dns/templates/netbox_dns/view/related.html +17 -0
  49. netbox_dns/templates/netbox_dns/view.html +25 -0
  50. netbox_dns/urls/__init__.py +2 -2
  51. netbox_dns/urls/registration_contact.py +60 -0
  52. netbox_dns/urls/view.py +6 -0
  53. netbox_dns/utilities/__init__.py +2 -74
  54. netbox_dns/utilities/conversions.py +83 -0
  55. netbox_dns/utilities/ipam_dnssync.py +295 -0
  56. netbox_dns/views/__init__.py +1 -1
  57. netbox_dns/views/record.py +3 -5
  58. netbox_dns/views/registration_contact.py +94 -0
  59. netbox_dns/views/view.py +26 -1
  60. {netbox_plugin_dns-1.0.7.dist-info → netbox_plugin_dns-1.1.0.dist-info}/METADATA +2 -1
  61. {netbox_plugin_dns-1.0.7.dist-info → netbox_plugin_dns-1.1.0.dist-info}/RECORD +63 -54
  62. netbox_dns/management/commands/setup_coupling.py +0 -109
  63. netbox_dns/signals/ipam_coupling.py +0 -168
  64. netbox_dns/templates/netbox_dns/related_dns_objects.html +0 -21
  65. netbox_dns/urls/contact.py +0 -29
  66. netbox_dns/utilities/ipam_coupling.py +0 -112
  67. netbox_dns/views/contact.py +0 -94
  68. {netbox_plugin_dns-1.0.7.dist-info → netbox_plugin_dns-1.1.0.dist-info}/LICENSE +0 -0
  69. {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.7"
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
- "feature_ipam_coupling": False,
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
- "TXT",
29
- "SRV",
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
@@ -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 Contact
5
+ from netbox_dns.models import RegistrationContact
6
6
 
7
7
 
8
- __all__ = ("ContactSerializer",)
8
+ __all__ = ("RegistrationContactSerializer",)
9
9
 
10
10
 
11
- class ContactSerializer(NetBoxModelSerializer):
11
+ class RegistrationContactSerializer(NetBoxModelSerializer):
12
12
  url = serializers.HyperlinkedIdentityField(
13
- view_name="plugins-api:netbox_dns-api:contact-detail"
13
+ view_name="plugins-api:netbox_dns-api:registrationcontact-detail"
14
14
  )
15
15
 
16
16
  class Meta:
17
- model = Contact
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.serializers_.tenants import TenantSerializer
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
- tenant = TenantSerializer(nested=True, required=False, allow_null=True)
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 .contact import ContactSerializer
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 = ContactSerializer(
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 = ContactSerializer(
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 = ContactSerializer(
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 = ContactSerializer(
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 .contact import ContactSerializer
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 = ContactSerializer(
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 = ContactSerializer(
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 = ContactSerializer(
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 = ContactSerializer(
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
- ContactViewSet,
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", ContactViewSet)
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
- ContactSerializer,
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
- ContactFilterSet,
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
- Contact,
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 ContactViewSet(NetBoxModelViewSet):
112
- queryset = Contact.objects.all()
113
- serializer_class = ContactSerializer
114
- filterset_class = ContactFilterSet
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
@@ -1,3 +1,4 @@
1
1
  from .network import *
2
2
  from .address import *
3
3
  from .rfc2317 import *
4
+ from .ipam import *
@@ -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,7 +2,7 @@ from .view import *
2
2
  from .zone import *
3
3
  from .nameserver import *
4
4
  from .record import *
5
- from .contact import *
5
+ from .registration_contact import *
6
6
  from .registrar import *
7
7
 
8
8
  from .zone_template import *
@@ -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 Contact
5
+ from netbox_dns.models import RegistrationContact
6
6
 
7
7
 
8
- __all__ = ("ContactFilterSet",)
8
+ __all__ = ("RegistrationContactFilterSet",)
9
9
 
10
10
 
11
- class ContactFilterSet(NetBoxModelFilterSet):
11
+ class RegistrationContactFilterSet(NetBoxModelFilterSet):
12
12
  class Meta:
13
- model = Contact
13
+ model = RegistrationContact
14
14
  fields = (
15
15
  "id",
16
16
  "name",
@@ -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")
@@ -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, Contact, NameServer
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=Contact.objects.all(),
98
+ queryset=RegistrationContact.objects.all(),
99
99
  label="Registrant ID",
100
100
  )
101
101
  registrant = django_filters.ModelMultipleChoiceFilter(
102
- queryset=Contact.objects.all(),
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=Contact.objects.all(),
109
- label="Administrative Contact ID",
108
+ queryset=RegistrationContact.objects.all(),
109
+ label="Administrative RegistrationContact ID",
110
110
  )
111
111
  admin_c = django_filters.ModelMultipleChoiceFilter(
112
- queryset=Contact.objects.all(),
112
+ queryset=RegistrationContact.objects.all(),
113
113
  field_name="admin_c__contact_id",
114
114
  to_field_name="contact_id",
115
- label="Administrative Contact",
115
+ label="Administrative RegistrationContact",
116
116
  )
117
117
  tech_c_id = django_filters.ModelMultipleChoiceFilter(
118
- queryset=Contact.objects.all(),
119
- label="Technical Contact ID",
118
+ queryset=RegistrationContact.objects.all(),
119
+ label="Technical RegistrationContact ID",
120
120
  )
121
121
  tech_c = django_filters.ModelMultipleChoiceFilter(
122
- queryset=Contact.objects.all(),
122
+ queryset=RegistrationContact.objects.all(),
123
123
  field_name="tech_c__contact_id",
124
124
  to_field_name="contact_id",
125
- label="Technical Contact",
125
+ label="Technical RegistrationContact",
126
126
  )
127
127
  billing_c_id = django_filters.ModelMultipleChoiceFilter(
128
- queryset=Contact.objects.all(),
129
- label="Billing Contact ID",
128
+ queryset=RegistrationContact.objects.all(),
129
+ label="Billing RegistrationContact ID",
130
130
  )
131
131
  billing_c = django_filters.ModelMultipleChoiceFilter(
132
- queryset=Contact.objects.all(),
132
+ queryset=RegistrationContact.objects.all(),
133
133
  field_name="billing_c__contact_id",
134
134
  to_field_name="contact_id",
135
- label="Billing Contact",
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
- Contact,
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=Contact.objects.all(),
56
+ queryset=RegistrationContact.objects.all(),
57
57
  label="Registrant ID",
58
58
  )
59
59
  registrant = django_filters.ModelMultipleChoiceFilter(
60
- queryset=Contact.objects.all(),
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=Contact.objects.all(),
67
- label="Administrative Contact ID",
66
+ queryset=RegistrationContact.objects.all(),
67
+ label="Administrative RegistrationContact ID",
68
68
  )
69
69
  admin_c = django_filters.ModelMultipleChoiceFilter(
70
- queryset=Contact.objects.all(),
70
+ queryset=RegistrationContact.objects.all(),
71
71
  field_name="admin_c__contact_id",
72
72
  to_field_name="contact_id",
73
- label="Administrative Contact",
73
+ label="Administrative RegistrationContact",
74
74
  )
75
75
  tech_c_id = django_filters.ModelMultipleChoiceFilter(
76
- queryset=Contact.objects.all(),
77
- label="Technical Contact ID",
76
+ queryset=RegistrationContact.objects.all(),
77
+ label="Technical RegistrationContact ID",
78
78
  )
79
79
  tech_c = django_filters.ModelMultipleChoiceFilter(
80
- queryset=Contact.objects.all(),
80
+ queryset=RegistrationContact.objects.all(),
81
81
  field_name="tech_c__contact_id",
82
82
  to_field_name="contact_id",
83
- label="Technical Contact",
83
+ label="Technical RegistrationContact",
84
84
  )
85
85
  billing_c_id = django_filters.ModelMultipleChoiceFilter(
86
- queryset=Contact.objects.all(),
87
- label="Billing Contact ID",
86
+ queryset=RegistrationContact.objects.all(),
87
+ label="Billing RegistrationContact ID",
88
88
  )
89
89
  billing_c = django_filters.ModelMultipleChoiceFilter(
90
- queryset=Contact.objects.all(),
90
+ queryset=RegistrationContact.objects.all(),
91
91
  field_name="billing_c__contact_id",
92
92
  to_field_name="contact_id",
93
- label="Billing Contact",
93
+ label="Billing RegistrationContact",
94
94
  )
95
95
 
96
96
  class Meta:
@@ -2,7 +2,7 @@ from .view import *
2
2
  from .zone import *
3
3
  from .nameserver import *
4
4
  from .record import *
5
- from .contact import *
5
+ from .registration_contact import *
6
6
  from .registrar import *
7
7
  from .zone_template import *
8
8
  from .record_template import *
@@ -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 Contact
12
+ from netbox_dns.models import RegistrationContact
13
13
 
14
14
 
15
15
  __all__ = (
16
- "ContactForm",
17
- "ContactFilterForm",
18
- "ContactImportForm",
19
- "ContactBulkEditForm",
16
+ "RegistrationContactForm",
17
+ "RegistrationContactFilterForm",
18
+ "RegistrationContactImportForm",
19
+ "RegistrationContactBulkEditForm",
20
20
  )
21
21
 
22
22
 
23
- class ContactForm(NetBoxModelForm):
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="Contact",
40
+ name="RegistrationContact",
41
41
  ),
42
42
  FieldSet("tags", name="Tags"),
43
43
  )
44
44
 
45
45
  class Meta:
46
- model = Contact
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 ContactFilterForm(NetBoxModelFilterSetForm):
67
- model = Contact
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="Contact ID",
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(Contact)
131
+ tag = TagFilterField(RegistrationContact)
132
132
 
133
133
 
134
- class ContactImportForm(NetBoxModelImportForm):
134
+ class RegistrationContactImportForm(NetBoxModelImportForm):
135
135
  class Meta:
136
- model = Contact
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 ContactBulkEditForm(NetBoxModelBulkEditForm):
157
- model = Contact
156
+ class RegistrationContactBulkEditForm(NetBoxModelBulkEditForm):
157
+ model = RegistrationContact
158
158
 
159
159
  name = forms.CharField(
160
160
  required=False,