aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJamis Buck <jamis@37signals.com>2005-09-02 09:10:31 +0000
committerJamis Buck <jamis@37signals.com>2005-09-02 09:10:31 +0000
commit6c44d35268d66374c5e2f0337183d5255c499a3c (patch)
tree5f9ba8c8de57b55b21d7a4b29759e6eace997394
parentd54aea29fc46bbf222abc3774569d074354273b2 (diff)
downloadrails-6c44d35268d66374c5e2f0337183d5255c499a3c.tar.gz
rails-6c44d35268d66374c5e2f0337183d5255c499a3c.tar.bz2
rails-6c44d35268d66374c5e2f0337183d5255c499a3c.zip
AbstractRequest#domain returns nil when host is an ip address #2012 [kevin.clark@gmail.com]
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@2098 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
-rw-r--r--actionpack/CHANGELOG2
-rwxr-xr-xactionpack/lib/action_controller/request.rb2
-rw-r--r--actionpack/test/controller/request_test.rb3
3 files changed, 7 insertions, 0 deletions
diff --git a/actionpack/CHANGELOG b/actionpack/CHANGELOG
index c77c4d3329..db3ad9662b 100644
--- a/actionpack/CHANGELOG
+++ b/actionpack/CHANGELOG
@@ -1,5 +1,7 @@
*SVN*
+* AbstractRequest#domain returns nil when host is an ip address #2012 [kevin.clark@gmail.com]
+
* ActionController documentation update #2051 [fbeausoleil@ftml.net]
* Yield @content_for_ variables to templates #2058 [Sam Stephenson]
diff --git a/actionpack/lib/action_controller/request.rb b/actionpack/lib/action_controller/request.rb
index 3a29834b42..ca8dfff161 100755
--- a/actionpack/lib/action_controller/request.rb
+++ b/actionpack/lib/action_controller/request.rb
@@ -109,6 +109,8 @@ module ActionController
# Returns the domain part of a host, such as rubyonrails.org in "www.rubyonrails.org". You can specify
# a different <tt>tld_length</tt>, such as 2 to catch rubyonrails.co.uk in "www.rubyonrails.co.uk".
def domain(tld_length = 1)
+ return nil if !/\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}/.match(host).nil?
+
host.split('.').last(1 + tld_length).join('.')
end
diff --git a/actionpack/test/controller/request_test.rb b/actionpack/test/controller/request_test.rb
index 8b079df5dd..5bb5bc3469 100644
--- a/actionpack/test/controller/request_test.rb
+++ b/actionpack/test/controller/request_test.rb
@@ -44,6 +44,9 @@ class RequestTest < Test::Unit::TestCase
@request.host = "www.rubyonrails.co.uk"
assert_equal "rubyonrails.co.uk", @request.domain(2)
+
+ @request.host = "192.168.1.200"
+ assert_nil @request.domain
end
def test_subdomains