From 4c1d7f6d8ff3744be0ac79148f59578aa9d2d39f Mon Sep 17 00:00:00 2001 From: akr Date: Sat, 12 Feb 2005 08:40:23 +0000 Subject: [PATCH] * lib/open-uri.rb (OpenURI.open_loop): send authentication only for the URI directly specified. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@7952 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 5 +++++ lib/open-uri.rb | 8 +++++++- 2 files changed, 12 insertions(+), 1 deletion(-) diff --git a/ChangeLog b/ChangeLog index 59cfb14794..93bc95dcd4 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +Sat Feb 12 17:29:19 2005 Tanaka Akira + + * lib/open-uri.rb (OpenURI.open_loop): send authentication only for + the URI directly specified. + Sat Feb 12 15:07:23 2005 Nobuyoshi Nakada * random.c (rand_init): suppress warning. diff --git a/lib/open-uri.rb b/lib/open-uri.rb index b78da5461b..83bb756bb1 100644 --- a/lib/open-uri.rb +++ b/lib/open-uri.rb @@ -176,6 +176,11 @@ module OpenURI unless OpenURI.redirectable?(uri, redirect) raise "redirection forbidden: #{uri} -> #{redirect}" end + if options.include? :http_basic_authentication + # send authentication only for the URI directly specified. + options = options.dup + options.delete :http_basic_authentication + end uri = redirect raise "HTTP redirection loop: #{uri}" if uri_set.include? uri.to_s uri_set[uri.to_s] = true @@ -201,7 +206,8 @@ module OpenURI raise "Non-HTTP proxy URI: #{proxy}" if proxy.class != URI::HTTP end - if target.userinfo + if target.userinfo && "1.9.0" <= RUBY_VERSION + # don't raise for 1.8 because compatibility. raise "userinfo not supported. [RFC3986]" end