mirror of
https://gitlab.com/shorewall/code.git
synced 2025-01-17 19:18:32 +01:00
More Shorewall-init fixes
Signed-off-by: Tom Eastep <teastep@shorewall.net>
This commit is contained in:
parent
fe5d89b243
commit
c823b0e41e
@ -106,12 +106,6 @@ if [ -f /etc/debian_version ]; then
|
|||||||
else
|
else
|
||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
case "$PHASE" in
|
|
||||||
post-*)
|
|
||||||
exit 0
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
elif [ -f /etc/SuSE-release ]; then
|
elif [ -f /etc/SuSE-release ]; then
|
||||||
|
@ -1539,19 +1539,25 @@ sub compile_updown() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
emit( "*)",
|
if ( my @plain_interfaces = all_plain_interfaces ) {
|
||||||
' case $state in',
|
my $interfaces = join ( '|', map get_physical( $_ ), @plain_interfaces );
|
||||||
' started)',
|
|
||||||
' COMMAND=restart',
|
$interfaces =~ s/\+/*/g;
|
||||||
' progress_message3 "$g_product attempting restart"',
|
|
||||||
' detect_configuration',
|
emit( "$interfaces)",
|
||||||
' define_firewall',
|
' case $state in',
|
||||||
' ;;',
|
' started)',
|
||||||
' *)',
|
' COMMAND=restart',
|
||||||
' progress_message3 "$COMMAND on interface $1 ignored"',
|
' progress_message3 "$g_product attempting restart"',
|
||||||
' ;;',
|
' detect_configuration',
|
||||||
' esac',
|
' define_firewall',
|
||||||
);
|
' ;;',
|
||||||
|
' *)',
|
||||||
|
' progress_message3 "$COMMAND on interface $1 ignored"',
|
||||||
|
' ;;',
|
||||||
|
' esac',
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
pop_indent;
|
pop_indent;
|
||||||
|
|
||||||
|
@ -62,6 +62,7 @@ our @EXPORT = qw( NOTHING
|
|||||||
validate_interfaces_file
|
validate_interfaces_file
|
||||||
all_interfaces
|
all_interfaces
|
||||||
all_real_interfaces
|
all_real_interfaces
|
||||||
|
all_plain_interfaces
|
||||||
all_bridges
|
all_bridges
|
||||||
interface_number
|
interface_number
|
||||||
find_interface
|
find_interface
|
||||||
@ -72,6 +73,7 @@ our @EXPORT = qw( NOTHING
|
|||||||
port_to_bridge
|
port_to_bridge
|
||||||
source_port_to_bridge
|
source_port_to_bridge
|
||||||
interface_is_optional
|
interface_is_optional
|
||||||
|
interface_is_required
|
||||||
find_interfaces_by_option
|
find_interfaces_by_option
|
||||||
find_interfaces_by_option1
|
find_interfaces_by_option1
|
||||||
get_interface_option
|
get_interface_option
|
||||||
@ -1416,6 +1418,21 @@ sub interface_is_optional($) {
|
|||||||
$optionsref && $optionsref->{optional};
|
$optionsref && $optionsref->{optional};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# Return the 'required' setting of the passed interface
|
||||||
|
#
|
||||||
|
sub interface_is_required($) {
|
||||||
|
my $optionsref = $interfaces{$_[0]}{options};
|
||||||
|
$optionsref && $optionsref->{required};
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# Return a list of real interfaces that are neither
|
||||||
|
#
|
||||||
|
sub all_plain_interfaces() {
|
||||||
|
grep ! ( $_ eq '%vserver%' || interface_is_optional($_) || interface_is_required($_) ), @interfaces;
|
||||||
|
}
|
||||||
|
|
||||||
#
|
#
|
||||||
# Returns reference to array of interfaces with the passed option
|
# Returns reference to array of interfaces with the passed option
|
||||||
#
|
#
|
||||||
|
Loading…
Reference in New Issue
Block a user