mirror of
https://github.com/github/rails.git
synced 2026-04-26 03:00:59 -04:00
Refactored duplication into a separate method. Dropped class variable.
This commit is contained in:
@@ -78,16 +78,18 @@ module ActionDispatch
|
||||
|
||||
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 @@ module ActionDispatch
|
||||
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 @@ module ActionDispatch
|
||||
|
||||
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 @@ module ActionDispatch
|
||||
# an options hash to delete cookies with extra data such as a <tt>:path</tt>.
|
||||
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
|
||||
|
||||
Reference in New Issue
Block a user