summaryrefslogtreecommitdiff
path: root/includes/bootstrap.inc
diff options
context:
space:
mode:
authorDries Buytaert <dries@buytaert.net>2008-06-26 11:29:20 +0000
committerDries Buytaert <dries@buytaert.net>2008-06-26 11:29:20 +0000
commitdf4ebc0135163025be3d0531a78586002c084033 (patch)
treee0c60dbe678e7aa77b7723e6c259c3c4dc5bbd3a /includes/bootstrap.inc
parentdf8dcc79b1a6bd47778df977056be0db6b3d58af (diff)
downloadbrdo-df4ebc0135163025be3d0531a78586002c084033.tar.gz
brdo-df4ebc0135163025be3d0531a78586002c084033.tar.bz2
- Patch #258397 by R.Muilwijk and myself: IP address detection improvements. Added support for clusters and wrote various IP address related tests.
Diffstat (limited to 'includes/bootstrap.inc')
-rw-r--r--includes/bootstrap.inc21
1 files changed, 16 insertions, 5 deletions
diff --git a/includes/bootstrap.inc b/includes/bootstrap.inc
index dda784822..6aca6d5c0 100644
--- a/includes/bootstrap.inc
+++ b/includes/bootstrap.inc
@@ -1160,16 +1160,20 @@ function language_default($property = NULL) {
/**
* If Drupal is behind a reverse proxy, we use the X-Forwarded-For header
- * instead of $_SERVER['REMOTE_ADDR'], which would be the IP address
- * of the proxy server, and not the client's.
+ * instead of $_SERVER['REMOTE_ADDR'], which would be the IP address of
+ * the proxy server, and not the client's. If Drupal is run in a cluster
+ * we use the X-Cluster-Client-Ip header instead.
*
+ * @param $reset
+ * Reset the current IP address saved in static.
* @return
- * IP address of client machine, adjusted for reverse proxy.
+ * IP address of client machine, adjusted for reverse proxy and/or cluster
+ * environments.
*/
-function ip_address() {
+function ip_address($reset = false) {
static $ip_address = NULL;
- if (!isset($ip_address)) {
+ if (!isset($ip_address) || $reset) {
$ip_address = $_SERVER['REMOTE_ADDR'];
if (variable_get('reverse_proxy', 0) && array_key_exists('HTTP_X_FORWARDED_FOR', $_SERVER)) {
// If an array of known reverse proxy IPs is provided, then trust
@@ -1181,6 +1185,13 @@ function ip_address() {
$ip_address = array_pop(explode(',', $_SERVER['HTTP_X_FORWARDED_FOR']));
}
}
+
+ // When Drupal is run in a cluster environment, REMOTE_ADDR contains the IP
+ // address of a server in the cluster, while the IP address of the client is
+ // stored in HTTP_X_CLUSTER_CLIENT_IP.
+ if (array_key_exists('HTTP_X_CLUSTER_CLIENT_IP', $_SERVER)) {
+ $ip_address = $_SERVER['HTTP_X_CLUSTER_CLIENT_IP'];
+ }
}
return $ip_address;