diff options
author | Daniel Dickinson <crazycshore@gmail.com> | 2011-07-06 06:26:12 +0000 |
---|---|---|
committer | Daniel Dickinson <crazycshore@gmail.com> | 2011-07-06 06:26:12 +0000 |
commit | 05c45f0f5e9ef0209b6c105f911eca94a96eec49 (patch) | |
tree | 85c175beb66d135e5342737a4f4af2b8a5407285 /package/firewall/files | |
parent | 44fb344da02e21ba3d93de882f3218cb2327ef0d (diff) | |
download | upstream-05c45f0f5e9ef0209b6c105f911eca94a96eec49.tar.gz upstream-05c45f0f5e9ef0209b6c105f911eca94a96eec49.tar.bz2 upstream-05c45f0f5e9ef0209b6c105f911eca94a96eec49.zip |
firewall: fix udp rules for tcpudp proto rules using src_port and dest_port after modification by the parsing of the tcp rule
SVN-Revision: 27469
Diffstat (limited to 'package/firewall/files')
-rw-r--r-- | package/firewall/files/lib/core_rule.sh | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/package/firewall/files/lib/core_rule.sh b/package/firewall/files/lib/core_rule.sh index 64a510df92..55381598b5 100644 --- a/package/firewall/files/lib/core_rule.sh +++ b/package/firewall/files/lib/core_rule.sh @@ -65,8 +65,15 @@ fw_load_rule() { fw_get_negation src_spec '-s' "${rule_src_ip:+$rule_src_ip/$rule_src_ip_prefixlen}" fw_get_negation dest_spec '-d' "${rule_dest_ip:+$rule_dest_ip/$rule_dest_ip_prefixlen}" + local rule_src_port_copy + local rule_dest_port_copy + [ "$rule_proto" == "tcpudp" ] && rule_proto="tcp udp" + rule_src_port_copy="$rule_src_port" + rule_dest_port_copy="$rule_dest_port" for rule_proto in $rule_proto; do + rule_src_port="$rule_src_port_copy" + rule_dest_port="$rule_dest_port_copy" fw_get_negation rule_proto '-p' "$rule_proto" for rule_src_port in ${rule_src_port:-""}; do fw_get_port_range rule_src_port $rule_src_port |