mirror of
https://github.com/netbox-community/netbox.git
synced 2026-03-21 20:18:38 -06:00
Simplify find_parent_prefix method
This commit is contained in:
@@ -350,7 +350,7 @@ class Prefix(ContactsMixin, GetAvailablePrefixesMixin, CachedScopeMixin, Primary
|
|||||||
def save(self, *args, **kwargs):
|
def save(self, *args, **kwargs):
|
||||||
|
|
||||||
if not self.pk or not self.parent or (self.prefix != self._prefix) or (self.vrf_id != self._vrf_id):
|
if not self.pk or not self.parent or (self.prefix != self._prefix) or (self.vrf_id != self._vrf_id):
|
||||||
parent = self.find_parent_prefix(network=self.prefix, vrf=self.vrf, exclude=self.pk)
|
parent = self.find_parent_prefix(networks=self.prefix, vrf=self.vrf, exclude=self.pk)
|
||||||
self.parent = parent
|
self.parent = parent
|
||||||
|
|
||||||
if isinstance(self.prefix, netaddr.IPNetwork):
|
if isinstance(self.prefix, netaddr.IPNetwork):
|
||||||
@@ -522,27 +522,15 @@ class Prefix(ContactsMixin, GetAvailablePrefixesMixin, CachedScopeMixin, Primary
|
|||||||
return min(utilization, 100)
|
return min(utilization, 100)
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def find_parent_prefix(cls, network, vrf=None, exclude=None):
|
def find_parent_prefix(cls, networks, vrf=None, exclude=None):
|
||||||
prefixes = Prefix.objects.filter(
|
# TODO: Document
|
||||||
models.Q(
|
if type(networks) in [netaddr.IPAddress, netaddr.IPNetwork, str]:
|
||||||
vrf=vrf,
|
networks = [networks, ]
|
||||||
prefix__net_contains=str(network)
|
|
||||||
) | models.Q(
|
|
||||||
vrf=None,
|
|
||||||
status=PrefixStatusChoices.STATUS_CONTAINER,
|
|
||||||
prefix__net_contains=str(network),
|
|
||||||
)
|
|
||||||
)
|
|
||||||
if exclude:
|
|
||||||
prefixes = prefixes.exclude(pk=exclude)
|
|
||||||
return prefixes.last()
|
|
||||||
|
|
||||||
@classmethod
|
|
||||||
def find_parent_prefix_range(cls, networks, vrf=None, exclude=None):
|
|
||||||
network_filter = models.Q()
|
network_filter = models.Q()
|
||||||
for network in networks:
|
for network in networks:
|
||||||
network_filter &= models.Q(
|
network_filter &= models.Q(
|
||||||
prefix__net_contains=network
|
prefix__net_contains_or_equals=network
|
||||||
)
|
)
|
||||||
prefixes = Prefix.objects.filter(
|
prefixes = Prefix.objects.filter(
|
||||||
models.Q(
|
models.Q(
|
||||||
@@ -743,8 +731,8 @@ class IPRange(ContactsMixin, PrimaryModel):
|
|||||||
self.size = int(self.end_address.ip - self.start_address.ip) + 1
|
self.size = int(self.end_address.ip - self.start_address.ip) + 1
|
||||||
|
|
||||||
# Set the parent prefix
|
# Set the parent prefix
|
||||||
self.prefix = Prefix.find_parent_prefix_range(
|
self.prefix = Prefix.find_parent_prefix(
|
||||||
networks=[netaddr.IPAddress(self.start_address), netaddr.IPAddress(self.end_address)],
|
networks=[self.start_address, self.end_address],
|
||||||
vrf=self.vrf
|
vrf=self.vrf
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -1100,7 +1088,7 @@ class IPAddress(ContactsMixin, PrimaryModel):
|
|||||||
self.dns_name = self.dns_name.lower()
|
self.dns_name = self.dns_name.lower()
|
||||||
|
|
||||||
# Set the parent prefix
|
# Set the parent prefix
|
||||||
self.prefix = Prefix.find_parent_prefix(netaddr.IPAddress(self.address), vrf=self.vrf)
|
self.prefix = Prefix.find_parent_prefix(networks=self.address, vrf=self.vrf)
|
||||||
|
|
||||||
super().save(*args, **kwargs)
|
super().save(*args, **kwargs)
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user