When exporting or testing, set all variables defined in the params file

Signed-off-by: Tom Eastep <teastep@shorewall.net>
This commit is contained in:
Tom Eastep 2020-03-31 15:55:09 -07:00
parent 78da975989
commit f9003fab43
No known key found for this signature in database
GPG Key ID: 96E6B3F2423A4D10
2 changed files with 15 additions and 4 deletions

View File

@ -59,7 +59,7 @@ our $have_arptables; # True if we have arptables rules
# Initilize the package-globals in the other modules # Initilize the package-globals in the other modules
# #
sub initialize_package_globals( $$$ ) { sub initialize_package_globals( $$$ ) {
Shorewall::Config::initialize($family, $export, $_[1], $_[2]); Shorewall::Config::initialize($family, $export, $test, $_[1], $_[2]);
Shorewall::Chains::initialize ($family, 1, $export ); Shorewall::Chains::initialize ($family, 1, $export );
Shorewall::Zones::initialize ($family, $_[0]); Shorewall::Zones::initialize ($family, $_[0]);
Shorewall::Nat::initialize($family); Shorewall::Nat::initialize($family);

View File

@ -791,8 +791,16 @@ our %ipsets; # All required IPsets
# #
our %filecache; our %filecache;
#
# When we ran
#
our $compiletime; our $compiletime;
#
# The -t option was specified to the compile command
#
our $test;
sub process_shorewallrc($$); sub process_shorewallrc($$);
sub add_variables( \% ); sub add_variables( \% );
# #
@ -805,8 +813,8 @@ sub add_variables( \% );
# 2. The compiler can run multiple times in the same process so it has to be # 2. The compiler can run multiple times in the same process so it has to be
# able to re-initialize its dependent modules' state. # able to re-initialize its dependent modules' state.
# #
sub initialize($;$$$) { sub initialize($$;$$$) {
( $family, $export, my ( $shorewallrc, $shorewallrc1 ) ) = @_; ( $family, $export, $test, my ( $shorewallrc, $shorewallrc1 ) ) = @_;
if ( $family == F_IPV4 ) { if ( $family == F_IPV4 ) {
( $product, $Product, $toolname, $toolNAME ) = qw( shorewall Shorewall iptables IPTABLES ); ( $product, $Product, $toolname, $toolNAME ) = qw( shorewall Shorewall iptables IPTABLES );
@ -5999,11 +6007,14 @@ sub export_params() {
} else { } else {
$value =~ s/'"'"'/'/g; $value =~ s/'"'"'/'/g;
} }
# #
# Don't export pairs from %ENV # Don't export pairs from %ENV
# #
if ( defined $ENV{$param} ) { if ( defined $ENV{$param} ) {
next if $value eq $ENV{$param}; unless ( $export || $test ) {
next if $value eq $ENV{$param};
}
} elsif ( exists $ENV{$param} ) { } elsif ( exists $ENV{$param} ) {
next unless supplied $value; next unless supplied $value;
} }