mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
15e7e472e6
r31228 was for allowing the 'Cookie:' header which did not have no SP after ';' for separating cookie-pairs but RFC6265 requires single SP after ';' there. We allow multiple SPs here for compatibility with older WEBrick version. * test/webrick/test_cookie.rb: Test it. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@32175 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
110 lines
3 KiB
Ruby
110 lines
3 KiB
Ruby
#
|
|
# cookie.rb -- Cookie class
|
|
#
|
|
# Author: IPR -- Internet Programming with Ruby -- writers
|
|
# Copyright (c) 2000, 2001 TAKAHASHI Masayoshi, GOTOU Yuuzou
|
|
# Copyright (c) 2002 Internet Programming with Ruby writers. All rights
|
|
# reserved.
|
|
#
|
|
# $IPR: cookie.rb,v 1.16 2002/09/21 12:23:35 gotoyuzo Exp $
|
|
|
|
require 'time'
|
|
require 'webrick/httputils'
|
|
|
|
module WEBrick
|
|
class Cookie
|
|
|
|
attr_reader :name
|
|
attr_accessor :value, :version
|
|
attr_accessor :domain, :path, :secure
|
|
attr_accessor :comment, :max_age
|
|
#attr_accessor :comment_url, :discard, :port
|
|
|
|
def initialize(name, value)
|
|
@name = name
|
|
@value = value
|
|
@version = 0 # Netscape Cookie
|
|
|
|
@domain = @path = @secure = @comment = @max_age =
|
|
@expires = @comment_url = @discard = @port = nil
|
|
end
|
|
|
|
def expires=(t)
|
|
@expires = t && (t.is_a?(Time) ? t.httpdate : t.to_s)
|
|
end
|
|
|
|
def expires
|
|
@expires && Time.parse(@expires)
|
|
end
|
|
|
|
def to_s
|
|
ret = ""
|
|
ret << @name << "=" << @value
|
|
ret << "; " << "Version=" << @version.to_s if @version > 0
|
|
ret << "; " << "Domain=" << @domain if @domain
|
|
ret << "; " << "Expires=" << @expires if @expires
|
|
ret << "; " << "Max-Age=" << @max_age.to_s if @max_age
|
|
ret << "; " << "Comment=" << @comment if @comment
|
|
ret << "; " << "Path=" << @path if @path
|
|
ret << "; " << "Secure" if @secure
|
|
ret
|
|
end
|
|
|
|
# Cookie::parse()
|
|
# It parses Cookie field sent from the user agent.
|
|
def self.parse(str)
|
|
if str
|
|
ret = []
|
|
cookie = nil
|
|
ver = 0
|
|
str.split(/[;,]\s+/).each{|x|
|
|
key, val = x.split(/=/,2)
|
|
val = val ? HTTPUtils::dequote(val) : ""
|
|
case key
|
|
when "$Version"; ver = val.to_i
|
|
when "$Path"; cookie.path = val
|
|
when "$Domain"; cookie.domain = val
|
|
when "$Port"; cookie.port = val
|
|
else
|
|
ret << cookie if cookie
|
|
cookie = self.new(key, val)
|
|
cookie.version = ver
|
|
end
|
|
}
|
|
ret << cookie if cookie
|
|
ret
|
|
end
|
|
end
|
|
|
|
def self.parse_set_cookie(str)
|
|
cookie_elem = str.split(/;/)
|
|
first_elem = cookie_elem.shift
|
|
first_elem.strip!
|
|
key, value = first_elem.split(/=/, 2)
|
|
cookie = new(key, HTTPUtils.dequote(value))
|
|
cookie_elem.each{|pair|
|
|
pair.strip!
|
|
key, value = pair.split(/=/, 2)
|
|
if value
|
|
value = HTTPUtils.dequote(value.strip)
|
|
end
|
|
case key.downcase
|
|
when "domain" then cookie.domain = value
|
|
when "path" then cookie.path = value
|
|
when "expires" then cookie.expires = value
|
|
when "max-age" then cookie.max_age = Integer(value)
|
|
when "comment" then cookie.comment = value
|
|
when "version" then cookie.version = Integer(value)
|
|
when "secure" then cookie.secure = true
|
|
end
|
|
}
|
|
return cookie
|
|
end
|
|
|
|
def self.parse_set_cookies(str)
|
|
return str.split(/,(?=[^;,]*=)|,$/).collect{|c|
|
|
parse_set_cookie(c)
|
|
}
|
|
end
|
|
end
|
|
end
|