8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
|
# File 'lib/www/mechanize/cookie.rb', line 8
def self.parse(uri, str, log = Mechanize.log)
return str.split(/,(?=[^;,]*=)|,$/).collect { |c|
cookie_elem = c.split(/;+/)
first_elem = cookie_elem.shift
first_elem.strip!
key, value = first_elem.split(/=/, 2)
cookie = nil
begin
cookie = new(key, WEBrick::HTTPUtils.dequote(value))
rescue
log.warn("Couldn't parse key/value: #{first_elem}") if log
end
next unless cookie
cookie_elem.each{|pair|
pair.strip!
key, value = pair.split(/=/, 2)
if value
value = WEBrick::HTTPUtils.dequote(value.strip)
end
case key.downcase
when "domain" then cookie.domain = value.sub(/^\./, '')
when "path" then cookie.path = value
when 'expires'
begin
cookie.expires = Time::parse(value)
rescue
if log
log.warn("Couldn't parse expires: #{value}")
end
end
when "max-age" then
begin
cookie.max_age = Integer(value)
rescue
log.warn("Couldn't parse max age '#{value}'") if log
cookie.max_age = nil
end
when "comment" then cookie. = value
when "version" then
begin
cookie.version = Integer(value)
rescue
log.warn("Couldn't parse version '#{value}'") if log
cookie.version = nil
end
when "secure" then cookie.secure = true
end
}
cookie.path ||= uri.path.to_s.sub(/[^\/]*$/, '')
cookie.secure ||= false
cookie.domain ||= uri.host
yield cookie if block_given?
}
end
|