mirror of
https://gitlab.com/shorewall/code.git
synced 2025-01-25 23:19:03 +01:00
Make new optional interface code work with shared providers
This commit is contained in:
parent
3483e8052a
commit
b99444ab8b
@ -46,6 +46,7 @@ use constant { LOCAL_TABLE => 255,
|
|||||||
our @routemarked_providers;
|
our @routemarked_providers;
|
||||||
our %routemarked_interfaces;
|
our %routemarked_interfaces;
|
||||||
our @routemarked_interfaces;
|
our @routemarked_interfaces;
|
||||||
|
our %provider_interfaces;
|
||||||
|
|
||||||
our $balancing;
|
our $balancing;
|
||||||
our $fallback;
|
our $fallback;
|
||||||
@ -56,10 +57,10 @@ our %providers;
|
|||||||
|
|
||||||
our @providers;
|
our @providers;
|
||||||
|
|
||||||
our %provider_interfaces;
|
|
||||||
|
|
||||||
our $family;
|
our $family;
|
||||||
|
|
||||||
|
use constant { ROUTEMARKED_SHARED => 1, ROUTEMARKED_UNSHARED => 2 };
|
||||||
|
|
||||||
#
|
#
|
||||||
# Initialize globals -- we take this novel approach to globals initialization to allow
|
# Initialize globals -- we take this novel approach to globals initialization to allow
|
||||||
# the compiler to run multiple times in the same process. The
|
# the compiler to run multiple times in the same process. The
|
||||||
@ -266,9 +267,6 @@ sub add_a_provider( ) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fatal_error "Unknown Interface ($interface)" unless known_interface $interface;
|
fatal_error "Unknown Interface ($interface)" unless known_interface $interface;
|
||||||
fatal_error "Duplicate Provider Interface ($interface)" if $provider_interfaces{$interface};
|
|
||||||
|
|
||||||
$provider_interfaces{$interface} = $table;
|
|
||||||
|
|
||||||
my $provider = chain_base $table;
|
my $provider = chain_base $table;
|
||||||
my $base = uc chain_base $interface;
|
my $base = uc chain_base $interface;
|
||||||
@ -381,10 +379,10 @@ sub add_a_provider( ) {
|
|||||||
fatal_error "The 'track' option requires a numeric value in the MARK column" if $mark eq '-';
|
fatal_error "The 'track' option requires a numeric value in the MARK column" if $mark eq '-';
|
||||||
|
|
||||||
if ( $routemarked_interfaces{$interface} ) {
|
if ( $routemarked_interfaces{$interface} ) {
|
||||||
fatal_error "Interface $interface is tracked through an earlier provider" if $routemarked_interfaces{$interface} > 1;
|
fatal_error "Interface $interface is tracked through an earlier provider" if $routemarked_interfaces{$interface} == ROUTEMARKED_UNSHARED;
|
||||||
fatal_error "Multiple providers through the same interface must their IP address specified in the INTERFACES" unless $shared;
|
fatal_error "Multiple providers through the same interface must their IP address specified in the INTERFACES" unless $shared;
|
||||||
} else {
|
} else {
|
||||||
$routemarked_interfaces{$interface} = $shared ? 1 : 2;
|
$routemarked_interfaces{$interface} = $shared ? ROUTEMARKED_SHARED : ROUTEMARKED_UNSHARED;
|
||||||
push @routemarked_interfaces, $interface;
|
push @routemarked_interfaces, $interface;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -393,12 +391,16 @@ sub add_a_provider( ) {
|
|||||||
|
|
||||||
my $realm = '';
|
my $realm = '';
|
||||||
|
|
||||||
start_provider( $table, $number, qq(if [ -n "\$${base}_IS_USABLE" ]; then) ) if $optional;
|
if ( $optional && ! $shared ) {
|
||||||
|
start_provider( $table, $number, qq(if [ -n "\$${base}_IS_USABLE" ]; then) );
|
||||||
|
$provider_interfaces{$interface} = $table;
|
||||||
|
}
|
||||||
|
|
||||||
if ( $shared ) {
|
if ( $shared ) {
|
||||||
|
fatal_error "Interface $interface is associated with non-shared provider $provider_interfaces{$interface}" if $provider_interfaces{$table};
|
||||||
my $variable = $providers{$table}{mac} = get_interface_mac( $gateway, $interface , $table );
|
my $variable = $providers{$table}{mac} = get_interface_mac( $gateway, $interface , $table );
|
||||||
$realm = "realm $number";
|
$realm = "realm $number";
|
||||||
start_provider( $table, $number, qq(if interface_is_usable $interface && [ -n "$variable" ]; then) ) unless $optional;
|
start_provider( $table, $number, qq(if interface_is_usable $interface && [ -n "$variable" ]; then) );
|
||||||
} elsif ( $gatewaycase eq 'detect' ) {
|
} elsif ( $gatewaycase eq 'detect' ) {
|
||||||
start_provider( $table, $number, qq(if interface_is_usable $interface && [ -n "$gateway" ]; then) ) unless $optional;
|
start_provider( $table, $number, qq(if interface_is_usable $interface && [ -n "$gateway" ]; then) ) unless $optional;
|
||||||
} else {
|
} else {
|
||||||
@ -790,8 +792,6 @@ sub handle_optional_interfaces() {
|
|||||||
my $interfaces = find_interfaces_by_option 'optional';
|
my $interfaces = find_interfaces_by_option 'optional';
|
||||||
|
|
||||||
if ( @$interfaces ) {
|
if ( @$interfaces ) {
|
||||||
my $variable;
|
|
||||||
|
|
||||||
for my $interface ( @$interfaces ) {
|
for my $interface ( @$interfaces ) {
|
||||||
my $base = uc chain_base( $interface );
|
my $base = uc chain_base( $interface );
|
||||||
my $provider = $provider_interfaces{$interface};
|
my $provider = $provider_interfaces{$interface};
|
||||||
@ -804,16 +804,8 @@ sub handle_optional_interfaces() {
|
|||||||
#
|
#
|
||||||
my $providerref = $providers{$provider};
|
my $providerref = $providers{$provider};
|
||||||
|
|
||||||
if ( $providerref->{shared} ) {
|
if ( $providerref->{gatewaycase} eq 'detect' ) {
|
||||||
$variable = $providerref->{mac};
|
emit qq(if interface_is_usable $interface && [ -n "$providerref->{gateway}" ]; then);
|
||||||
} elsif ( $providerref->{gatewaycase} eq 'detect' ) {
|
|
||||||
$variable = $providerref->{gateway};
|
|
||||||
} else {
|
|
||||||
$variable = '';
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( $variable ) {
|
|
||||||
emit qq(if interface_is_usable $interface && [ -n "$variable" ]; then);
|
|
||||||
} else {
|
} else {
|
||||||
emit qq(if interface_is_usable $interface; then);
|
emit qq(if interface_is_usable $interface; then);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user