diff options
Diffstat (limited to 'actionpack/lib')
| -rwxr-xr-x | actionpack/lib/action_controller/request.rb | 18 |
1 files changed, 9 insertions, 9 deletions
diff --git a/actionpack/lib/action_controller/request.rb b/actionpack/lib/action_controller/request.rb index f54a00dd86..d58cf58543 100755 --- a/actionpack/lib/action_controller/request.rb +++ b/actionpack/lib/action_controller/request.rb @@ -33,17 +33,17 @@ module ActionController # delimited list in the case of multiple chained proxies; the first is # the originating IP. def remote_ip - if env['HTTP_CLIENT_IP'] - env['HTTP_CLIENT_IP'] - elsif env['HTTP_X_FORWARDED_FOR'] - remote_ip = env['HTTP_X_FORWARDED_FOR'].split(',').reject { |ip| + return env['HTTP_CLIENT_IP'] if env.include? 'HTTP_CLIENT_IP' + + if env.include? 'HTTP_X_FORWARDED_FOR' then + remote_ips = env['HTTP_X_FORWARDED_FOR'].split(',').reject do |ip| ip =~ /^unknown$|^(10|172\.16|192\.168)\./i - }.first - - remote_ip ? remote_ip.strip : env['REMOTE_ADDR'] - else - env['REMOTE_ADDR'] + end + + return remote_ips.first.strip unless remote_ips.empty? end + + return env['REMOTE_ADDR'] end def request_uri |
