summaryrefslogtreecommitdiff
path: root/scripts/vyatta-update-src-nat.pl
diff options
context:
space:
mode:
Diffstat (limited to 'scripts/vyatta-update-src-nat.pl')
-rwxr-xr-xscripts/vyatta-update-src-nat.pl13
1 files changed, 12 insertions, 1 deletions
diff --git a/scripts/vyatta-update-src-nat.pl b/scripts/vyatta-update-src-nat.pl
index af77e22..2c481e1 100755
--- a/scripts/vyatta-update-src-nat.pl
+++ b/scripts/vyatta-update-src-nat.pl
@@ -40,7 +40,19 @@ sub raw_cleanup {
ipt_disable_conntrack('iptables', 'NAT_CONNTRACK');
}
+my $all_deleted = 1;
+
my $config = new Vyatta::Config;
+
+$config->setLevel("nat destination rule");
+my %rules_dst = $config->listNodeStatus();
+my $rule_dst;
+for $rule_dst (keys %rules_dst) {
+ if ($rules_dst{$rule_dst} ne "deleted") {
+ $all_deleted = 0;
+ }
+}
+
$config->setLevel($CONFIG_LEVEL." rule");
my %rules = $config->listNodeStatus();
my $rule;
@@ -69,7 +81,6 @@ system("$IPTABLES -t nat -L -n >& /dev/null");
# we have some nat rule(s). make sure conntrack is enabled.
ipt_enable_conntrack('iptables', 'NAT_CONNTRACK');
-my $all_deleted = 1;
for $rule (@rule_keys) {
print OUT "$rule: $rules{$rule}\n";
my $tmp = `iptables -L -nv --line -t nat`;