diff --git a/Shorewall-init/shorewall-init b/Shorewall-init/shorewall-init index b3e0bad6f..4e8e8c1dc 100644 --- a/Shorewall-init/shorewall-init +++ b/Shorewall-init/shorewall-init @@ -25,6 +25,7 @@ # ############################################################################### # set the STATEDIR variable + setstatedir() { local statedir if [ -f ${CONFDIR}/${PRODUCT}/vardir ]; then @@ -59,8 +60,9 @@ else exit 1 fi -# Initialize the firewall -shorewall_start () { +# Initialize the firewalls + +shorewall_init_start () { local PRODUCT local STATEDIR @@ -86,12 +88,14 @@ shorewall_start () { return 0 } -# Clear the firewall -shorewall_stop () { +# Clear the firewalls + +shorewall_init_stop () { local PRODUCT local STATEDIR printf "Clearing \"Shorewall-based firewalls\": " + for PRODUCT in $PRODUCTS; do if setstatedir; then # @@ -119,10 +123,10 @@ shorewall_stop () { case "$1" in start) - shorewall_start + shorewall_init_start ;; stop) - shorewall_stop + shorewall_init_stop ;; *) echo "Usage: $0 {start|stop}" diff --git a/Shorewall/Perl/Shorewall/Chains.pm b/Shorewall/Perl/Shorewall/Chains.pm index 3b2906eb8..8c45ce7f9 100644 --- a/Shorewall/Perl/Shorewall/Chains.pm +++ b/Shorewall/Perl/Shorewall/Chains.pm @@ -726,6 +726,7 @@ our %opttype = ( rule => CONTROL, 'icmpv6-type' => UNIQUE, comment => CONTROL, + digest => CONTROL, policy => MATCH, state => EXCLUSIVE, @@ -3521,6 +3522,33 @@ sub irule_to_string( $ ) { $string; } +# +# This one omits the comment +# +sub irule_to_string1( $ ) { + my ( $ruleref ) = @_; + + return $ruleref->{cmd} if exists $ruleref->{cmd}; + + my $string = ''; + + for ( grep ! ( get_opttype( $_, 0 ) & ( CONTROL | TARGET ) ), @{$ruleref->{matches}}) { + my $value = $ruleref->{$_}; + if ( reftype $value ) { + $string .= "$_=" . join( ',', @$value ) . ' '; + } else { + $string .= "$_=$value "; + } + } + + if ( $ruleref->{target} ) { + $string .= join( ' ', " -$ruleref->{jump}", $ruleref->{target} ); + $string .= join( '', ' ', $ruleref->{targetopts} ) if $ruleref->{targetopts}; + } + + $string; +} + sub calculate_digest( $ ) { my $chainref = shift; my $rules = ''; @@ -4193,7 +4221,7 @@ sub get_multi_sports( $ ) { # Return an array of keys for the passed rule. 'dport', 'comment', and 'origin' are omitted; # sub get_keys( $ ) { - my %skip = ( dport => 1, comment => 1, origin => 1 ); + my %skip = ( dport => 1, comment => 1, origin => 1, digest => 1 ); sort grep ! $skip{$_}, keys %{$_[0]}; } @@ -4374,64 +4402,55 @@ sub delete_duplicates { my @rules; my $chainref = shift; my $lastrule = @_; - my $baseref = pop; my $ruleref; my %skip = ( comment => 1, origin => 1 ); + for ( @_ ) { + $_->{digest} = sha1_hex irule_to_string1( $_ ); + } + + my $baseref = pop; + while ( @_ ) { my $docheck; my $duplicate = 0; if ( $baseref->{mode} == CAT_MODE && $baseref->{target} ) { my $ports1; - my @keys1 = sort( grep ! $skip{$_}, keys( %$baseref ) ); + my $bad_key; my $rulenum = @_; my $adjacent = 1; - - { - RULE: + my $digest = $baseref->{digest}; - while ( --$rulenum >= 0 ) { - $ruleref = $_[$rulenum]; + for ( grep ! $skip{$_}, keys( %$baseref ) ) { + $bad_key = 1, last if $bad_match{$_}; + } - last unless $ruleref->{mode} == CAT_MODE; + while ( --$rulenum >= 0 ) { + $ruleref = $_[$rulenum]; - my @keys2 = sort(grep ! $skip{$_}, keys( %$ruleref ) ); - - next unless @keys1 == @keys2 ; + last unless $ruleref->{mode} == CAT_MODE; + next unless $digest eq $ruleref->{digest}; my $keynum = 0; - if ( $adjacent > 0 ) { - # - # There are no non-duplicate rules between this rule and the base rule - # - for my $key ( @keys1 ) { - next RULE unless $key eq $keys2[$keynum++]; - next RULE unless compare_values( $baseref->{$key}, $ruleref->{$key} ); - } - } else { - # - # There are non-duplicate rules between this rule and the base rule - # - for my $key ( @keys1 ) { - next RULE unless $key eq $keys2[$keynum++]; - next RULE unless compare_values( $baseref->{$key}, $ruleref->{$key} ); - last RULE if $bad_match{$key}; - } - } + unless ( $adjacent > 0 ) { # - # This rule is a duplicate + # There are non-duplicate rules between this rule and the base rule # - $duplicate = 1; - # - # Increment $adjacent so that the continue block won't set it to zero - # - $adjacent++; - - } continue { - $adjacent--; + last if $bad_key; } + # + # This rule is a duplicate + # + $duplicate = 1; + # + # Increment $adjacent so that the continue block won't set it to zero + # + $adjacent++; + + } continue { + $adjacent--; } } @@ -4471,7 +4490,7 @@ sub get_conntrack( $ ) { # Return an array of keys for the passed rule. 'conntrack', 'comment' & 'origin' are omitted; # sub get_keys1( $ ) { - my %skip = ( comment => 1, origin => 1 , 'conntrack --ctstate' => 1 ); + my %skip = ( comment => 1, origin => 1 , digest => 1, 'conntrack --ctstate' => 1 ); sort grep ! $skip{$_}, keys %{$_[0]}; }