Commit 661445dd authored by Franco Fichtner's avatar Franco Fichtner

filter: properly add nat reflection helper for IPv6; closes #1232

parent 9385d1fb
......@@ -1857,13 +1857,19 @@ function filter_nat_rules_generate(&$FilterIflist)
$natrules .= "{$nordr}rdr {$rdrpass}on {$natif} {$address_family} {$protocol_keyword} {$protocol} from {$srcaddr} to {$dstaddr}" . ($nordr == "" ? " -> {$target}{$localport}" : "");
/* Does this rule redirect back to a internal host? */
if (isset($rule['destination']['any']) && !isset($rule['nordr']) && !isset($config['system']['enablenatreflectionhelper']) && !interface_has_gateway($rule['interface'])) {
$rule_interface_ip = find_interface_ip($natif);
$rule_interface_subnet = find_interface_subnet($natif);
if (!empty($rule_interface_ip) && !empty($rule_interface_subnet)) {
if ($address_family == 'inet6') {
$rule_interface_subnet = find_interface_subnet6($natif);
$rule_interface_ip = find_interface_ipv6($natif);
$rule_subnet = gen_subnetv6($rule_interface_ip, $rule_interface_subnet);
} else {
$rule_interface_subnet = find_interface_subnet($natif);
$rule_interface_ip = find_interface_ip($natif);
$rule_subnet = gen_subnet($rule_interface_ip, $rule_interface_subnet);
}
if (!empty($rule_interface_ip) && !empty($rule_interface_subnet)) {
$natrules .= "\n";
$natrules .= "no nat on {$natif} proto tcp from ({$natif}) to {$rule_subnet}/{$rule_interface_subnet}\n";
$natrules .= "nat on {$natif} proto tcp from {$rule_subnet}/{$rule_interface_subnet} to {$target} port {$dstport[0]} -> ({$natif})\n";
$natrules .= "no nat on {$natif} {$address_family} proto tcp from ({$natif}) to {$rule_subnet}/{$rule_interface_subnet}\n";
$natrules .= "nat on {$natif} {$address_family} proto tcp from {$rule_subnet}/{$rule_interface_subnet} to {$target} port {$dstport[0]} -> ({$natif})\n";
}
}
......
......@@ -4380,6 +4380,17 @@ function find_interface_subnet($interface)
return null;
}
function find_interface_subnet6($interface)
{
$interface = trim($interface);
if (does_interface_exist($interface)) {
$ifinfo = legacy_get_interface_addresses($interface);
if (isset($ifinfo['subnetbits6'])) {
return $ifinfo['subnetbits6'];
}
}
return null;
}
function ip_in_interface_alias_subnet($interface, $ipalias)
{
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment