summaryrefslogtreecommitdiffstats
path: root/etc/inc/auth.inc
diff options
context:
space:
mode:
authorsmos <seth.mos@dds.nl>2011-08-21 13:13:11 +0200
committersmos <seth.mos@dds.nl>2011-08-21 13:13:11 +0200
commite6f7e0be56b8b2ea643cefb477a6ffe15380cdbb (patch)
tree49a91fade60eac6c6535af150cf3caf444952347 /etc/inc/auth.inc
parent4cf79fdd9b71f2b597a799aef6721511d1baa4de (diff)
downloadpfsense-e6f7e0be56b8b2ea643cefb477a6ffe15380cdbb.zip
pfsense-e6f7e0be56b8b2ea643cefb477a6ffe15380cdbb.tar.gz
Fix the referrer checks for IPv6 addresses Ticket #1583
Diffstat (limited to 'etc/inc/auth.inc')
-rw-r--r--etc/inc/auth.inc8
1 files changed, 8 insertions, 0 deletions
diff --git a/etc/inc/auth.inc b/etc/inc/auth.inc
index 7ad5291..b551be0 100644
--- a/etc/inc/auth.inc
+++ b/etc/inc/auth.inc
@@ -117,6 +117,7 @@ if(function_exists("display_error_form") && !isset($config['system']['webgui']['
}
$found_host = false;
$referrer_host = parse_url($_SERVER['HTTP_REFERER'], PHP_URL_HOST);
+ $referrer_host = str_replace(array("[", "]"), "", $referrer_host);
if($referrer_host) {
if(strcasecmp($referrer_host, $config['system']['hostname'] . "." . $config['system']['domain']) == 0
|| strcasecmp($referrer_host, $config['system']['hostname']) == 0)
@@ -138,6 +139,13 @@ if(function_exists("display_error_form") && !isset($config['system']['webgui']['
break;
}
}
+ $interface_list_ipv6s = get_configured_ipv6_addresses();
+ foreach($interface_list_ipv6s as $ilipv6s) {
+ if(strcasecmp($referrer_host, $ilipv6s) == 0) {
+ $found_host = true;
+ break;
+ }
+ }
if($referrer_host == "127.0.0.1" || $referrer_host == "localhost") {
// allow SSH port forwarded connections and links from localhost
$found_host = true;
OpenPOWER on IntegriCloud