aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAaron Patterson <aaron.patterson@gmail.com>2015-08-27 11:12:03 -0700
committerAaron Patterson <aaron.patterson@gmail.com>2015-08-27 11:13:11 -0700
commit14af136371bbd9e14c58aaabe0ce73a515cd09a4 (patch)
tree7716fc9fc9c0cd9dde33786ce348f39dc65be214
parent97d088ebf249c47a79aea419add1007fa24c1489 (diff)
downloadrails-14af136371bbd9e14c58aaabe0ce73a515cd09a4.tar.gz
rails-14af136371bbd9e14c58aaabe0ce73a515cd09a4.tar.bz2
rails-14af136371bbd9e14c58aaabe0ce73a515cd09a4.zip
implement the API required by the abstract Rack request.
-rw-r--r--Gemfile.lock2
-rw-r--r--actionpack/lib/action_dispatch/http/response.rb24
2 files changed, 9 insertions, 17 deletions
diff --git a/Gemfile.lock b/Gemfile.lock
index 289b915a58..ae2f00df2e 100644
--- a/Gemfile.lock
+++ b/Gemfile.lock
@@ -27,7 +27,7 @@ GIT
GIT
remote: git://github.com/rack/rack.git
- revision: fd20c3fa80128b19341ba8a0e0fae3bdc7c4c483
+ revision: 2fe4a79667603a0c3d636daec06281459b10f7f8
specs:
rack (2.0.0.alpha)
json
diff --git a/actionpack/lib/action_dispatch/http/response.rb b/actionpack/lib/action_dispatch/http/response.rb
index 0987efc474..16782a894e 100644
--- a/actionpack/lib/action_dispatch/http/response.rb
+++ b/actionpack/lib/action_dispatch/http/response.rb
@@ -150,6 +150,11 @@ module ActionDispatch # :nodoc:
yield self if block_given?
end
+ def have_header?(key); headers.key? key; end
+ def get_header(key); headers[key]; end
+ def set_header(key, v); headers[key] = v; end
+ def delete_header(key); headers.delete key; end
+
def await_commit
synchronize do
@cv.wait_until { @committed }
@@ -256,22 +261,9 @@ module ActionDispatch # :nodoc:
parts
end
- def set_cookie(key, value)
- header[SET_COOKIE] = ::Rack::Utils.add_cookie_to_header(header[SET_COOKIE], key, value)
- end
-
- def delete_cookie(key, value={})
- header[SET_COOKIE] = ::Rack::Utils.add_remove_cookie_to_header(header[SET_COOKIE], key, value)
- end
-
# The location header we'll be responding with.
alias_method :redirect_url, :location
- # Sets the location header we'll be responding with.
- def location=(url)
- headers[LOCATION] = url
- end
-
def close
stream.close if stream.respond_to?(:close)
end
@@ -302,7 +294,7 @@ module ActionDispatch # :nodoc:
# assert_equal 'AuthorOfNewPage', r.cookies['author']
def cookies
cookies = {}
- if header = self[SET_COOKIE]
+ if header = get_header(SET_COOKIE)
header = header.split("\n") if header.respond_to?(:to_str)
header.each do |cookie|
if pair = cookie.split(';').first
@@ -338,14 +330,14 @@ module ActionDispatch # :nodoc:
end
def assign_default_content_type_and_charset!
- return if self[CONTENT_TYPE].present?
+ return if get_header(CONTENT_TYPE).present?
@content_type ||= Mime::HTML
type = @content_type.to_s.dup
type << "; charset=#{charset}" if append_charset?
- self[CONTENT_TYPE] = type
+ set_header CONTENT_TYPE, type
end
def append_charset?