From 7cc8431906315822e8107143920bbca85e5b53ce Mon Sep 17 00:00:00 2001 From: Mark Wells Date: Tue, 10 Dec 2013 20:44:01 -0800 Subject: [PATCH] actually make auto-assignment avoid forbidden ranges, #25530 --- FS/FS/addr_block.pm | 12 +++++++++++- FS/FS/addr_range.pm | 7 +------ 2 files changed, 12 insertions(+), 7 deletions(-) diff --git a/FS/FS/addr_block.pm b/FS/FS/addr_block.pm index 6a62777be..1f4000b75 100755 --- a/FS/FS/addr_block.pm +++ b/FS/FS/addr_block.pm @@ -256,7 +256,17 @@ sub next_free_addr { # just do a linear search of the block my $freeaddr = $selfaddr->network + 1; while ( $freeaddr < $selfaddr->broadcast ) { - return $freeaddr unless $used{ $freeaddr->addr }; + # also make sure it's not blocked from assignment by an address range + if ( !$used{$freeaddr->addr } ) { + my ($range) = grep { !$_->allow_use } + FS::addr_range->any_contains($freeaddr); + if ( !$range ) { + # then we've found a free address + return $freeaddr; + } + # otherwise, skip to the end of the range + $freeaddr = NetAddr::IP->new($range->end, $self->ip_netmask); + } $freeaddr++; } return; diff --git a/FS/FS/addr_range.pm b/FS/FS/addr_range.pm index 5faa4438a..18ae1e2ea 100644 --- a/FS/FS/addr_range.pm +++ b/FS/FS/addr_range.pm @@ -219,11 +219,6 @@ sub desc { $status_desc{ $self->status }; } -sub allow_auto { - my $self = shift; - $status_allow_auto{ $self->status }; -} - sub allow_use { my $self = shift; $status_allow_use{ $self->status }; @@ -250,7 +245,7 @@ sub any_contains { L objects have netmasks. When using them to represent range endpoints, be sure to set the netmask to I so that math on the address doesn't stop at the subnet boundary. (The default is /32, -which doesn't work very well. Address ranges ignore subnet boundaries. +which doesn't work very well. Address ranges ignore subnet boundaries.) =head1 BUGS -- 2.11.0