mirror of
https://gitlab.com/shorewall/code.git
synced 2025-06-20 09:47:51 +02:00
Verify that parent and child zones have a common interface
Signed-off-by: Tom Eastep <teastep@shorewall.net>
This commit is contained in:
parent
d0861e813b
commit
c31397532c
@ -701,6 +701,40 @@ sub haveipseczones() {
|
|||||||
0;
|
0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# Returns 1 if the two interfaces passed are related
|
||||||
|
#
|
||||||
|
sub interface_match( $$ ) {
|
||||||
|
my ( $piface, $ciface ) = @_;
|
||||||
|
|
||||||
|
return 1 if $piface eq $ciface;
|
||||||
|
|
||||||
|
my ( $pifaceref, $cifaceref ) = @interfaces{$piface, $ciface};
|
||||||
|
|
||||||
|
return 1 if $piface eq $cifaceref->{bridge};
|
||||||
|
return 1 if $ciface eq $pifaceref->{bridge};
|
||||||
|
|
||||||
|
if ( $minroot ) {
|
||||||
|
if ( $piface =~ /\+$/ ) {
|
||||||
|
my $root = $pifaceref->{root};
|
||||||
|
my $rlength = length( $root );
|
||||||
|
while ( length( $ciface ) >= $rlength ) {
|
||||||
|
return 1 if $ciface eq $root;
|
||||||
|
chop $ciface;
|
||||||
|
}
|
||||||
|
} elsif ( $ciface =~ /\+$/ ) {
|
||||||
|
my $root = $cifaceref->{root};
|
||||||
|
my $rlength = length( $root );
|
||||||
|
while ( length( $piface ) >= $rlength ) {
|
||||||
|
return 1 if $piface eq $root;
|
||||||
|
chop $piface;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
0;
|
||||||
|
}
|
||||||
|
|
||||||
#
|
#
|
||||||
# Report about zones.
|
# Report about zones.
|
||||||
#
|
#
|
||||||
@ -738,7 +772,7 @@ sub zone_report()
|
|||||||
if ( $family == F_IPV4 ) {
|
if ( $family == F_IPV4 ) {
|
||||||
progress_message_nocompress " $iref->{physical}:$grouplist";
|
progress_message_nocompress " $iref->{physical}:$grouplist";
|
||||||
} else {
|
} else {
|
||||||
progress_message_nocompress " $iref->{physical}:<$grouplist>";
|
progress_message_nocompress " $iref->{physical}:[$grouplist]";
|
||||||
}
|
}
|
||||||
$printed = 1;
|
$printed = 1;
|
||||||
}
|
}
|
||||||
@ -747,6 +781,17 @@ sub zone_report()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
PARENT:
|
||||||
|
for my $p ( @{$zoneref->{parents}} ) {
|
||||||
|
for my $pi ( keys ( %{$zones{$p}{interfaces}} ) ) {
|
||||||
|
for my $ci ( keys( %{$zoneref->{interfaces}} ) ) {
|
||||||
|
next PARENT if interface_match( $pi, $ci );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
warning_message "Zone $zone is defined as a sub-zone of $p, yet the two zones have no interface in common";
|
||||||
|
}
|
||||||
|
|
||||||
unless ( $printed ) {
|
unless ( $printed ) {
|
||||||
fatal_error "No bridge has been associated with zone $zone" if $type & BPORT && ! $zoneref->{bridge};
|
fatal_error "No bridge has been associated with zone $zone" if $type & BPORT && ! $zoneref->{bridge};
|
||||||
warning_message "*** $zone is an EMPTY ZONE ***" unless $type == FIREWALL;
|
warning_message "*** $zone is an EMPTY ZONE ***" unless $type == FIREWALL;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user