diff --git a/actionpack/lib/action_dispatch/middleware/cookies.rb b/actionpack/lib/action_dispatch/middleware/cookies.rb index 2b3538af255c1cfe74b89004bc40265b0a5eb154..d69ba39728a4072fdd72d6f316607142a6e64ab1 100644 --- a/actionpack/lib/action_dispatch/middleware/cookies.rb +++ b/actionpack/lib/action_dispatch/middleware/cookies.rb @@ -78,16 +78,18 @@ class CookieJar < Hash #:nodoc: def self.build(request) secret = request.env[TOKEN_KEY] - @@host = request.env["HTTP_HOST"] - new(secret).tap do |hash| + host = request.env["HTTP_HOST"] + + new(secret, host).tap do |hash| hash.update(request.cookies) end end - def initialize(secret=nil) + def initialize(secret = nil, host = nil) @secret = secret @set_cookies = {} @delete_cookies = {} + @host = host super() end @@ -97,6 +99,15 @@ def [](name) super(name.to_s) end + def handle_options(options) #:nodoc: + options[:path] ||= "/" + + if options[:domain] == :all + @host =~ DOMAIN_REGEXP + options[:domain] = ".#{$2}.#{$3}" + end + end + # Sets the cookie named +name+. The second argument may be the very cookie # value, or a hash of options as documented above. def []=(key, options) @@ -110,13 +121,8 @@ def []=(key, options) value = super(key.to_s, value) - options[:path] ||= "/" - - if options[:domain] == :all - @@host =~ DOMAIN_REGEXP - options[:domain] = ".#{$2}.#{$3}" - end - + handle_options(options) + @set_cookies[key] = options @delete_cookies.delete(key) value @@ -127,12 +133,8 @@ def []=(key, options) # an options hash to delete cookies with extra data such as a :path. def delete(key, options = {}) options.symbolize_keys! - options[:path] ||= "/" - if options[:domain] == :all - @@host =~ DOMAIN_REGEXP - options[:domain] = ".#{$2}.#{$3}" - end + handle_options(options) value = super(key.to_s) @delete_cookies[key] = options