Class: Sinatra::Cookies::Jar

Inherits:
Object
  • Object
show all
Includes:
Enumerable
Defined in:
lib/sinatra/cookies.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(app) ⇒ Jar

Returns a new instance of Jar.



60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
# File 'lib/sinatra/cookies.rb', line 60

def initialize(app)
  @response_string = nil
  @response_hash   = {}
  @response        = app.response
  @request         = app.request
  @deleted         = []

  @options = {
    :path => @request.script_name.to_s.empty? ? '/' : @request.script_name,
    :domain => @request.host == 'localhost' ? nil : @request.host,
    :secure   => @request.secure?,
    :httponly => true
  }

  if app.settings.respond_to? :cookie_options
    @options.merge! app.settings.cookie_options
  end
end

Instance Attribute Details

#optionsObject (readonly)

Returns the value of attribute options.



58
59
60
# File 'lib/sinatra/cookies.rb', line 58

def options
  @options
end

Instance Method Details

#==(other) ⇒ Object



79
80
81
# File 'lib/sinatra/cookies.rb', line 79

def ==(other)
  other.respond_to? :to_hash and to_hash == other.to_hash
end

#[](key) ⇒ Object



83
84
85
# File 'lib/sinatra/cookies.rb', line 83

def [](key)
  response_cookies[key.to_s] || request_cookies[key.to_s]
end

#[]=(key, value) ⇒ Object Also known as: store



87
88
89
# File 'lib/sinatra/cookies.rb', line 87

def []=(key, value)
  set(key, value: value)
end

#assoc(key) ⇒ Object



91
92
93
# File 'lib/sinatra/cookies.rb', line 91

def assoc(key)
  to_hash.assoc(key.to_s)
end

#clearObject



95
96
97
# File 'lib/sinatra/cookies.rb', line 95

def clear
  each_key { |k| delete(k) }
end

#compare_by_identity?Boolean

Returns:

  • (Boolean)


99
100
101
# File 'lib/sinatra/cookies.rb', line 99

def compare_by_identity?
  false
end

#defaultObject Also known as: default_proc



103
104
105
# File 'lib/sinatra/cookies.rb', line 103

def default
  nil
end

#delete(key) ⇒ Object



109
110
111
112
113
# File 'lib/sinatra/cookies.rb', line 109

def delete(key)
  result = self[key]
  @response.delete_cookie(key.to_s, @options)
  result
end

#delete_ifObject Also known as: reject!



115
116
117
118
119
# File 'lib/sinatra/cookies.rb', line 115

def delete_if
  return enum_for(__method__) unless block_given?
  each { |k, v| delete(k) if yield(k, v) }
  self
end

#each(&block) ⇒ Object Also known as: each_pair



121
122
123
124
# File 'lib/sinatra/cookies.rb', line 121

def each(&block)
  return enum_for(__method__) unless block_given?
  to_hash.each(&block)
end

#each_key(&block) ⇒ Object



126
127
128
129
# File 'lib/sinatra/cookies.rb', line 126

def each_key(&block)
  return enum_for(__method__) unless block_given?
  to_hash.each_key(&block)
end

#each_value(&block) ⇒ Object



133
134
135
136
# File 'lib/sinatra/cookies.rb', line 133

def each_value(&block)
  return enum_for(__method__) unless block_given?
  to_hash.each_value(&block)
end

#empty?Boolean

Returns:

  • (Boolean)


138
139
140
# File 'lib/sinatra/cookies.rb', line 138

def empty?
  to_hash.empty?
end

#fetch(key, &block) ⇒ Object



142
143
144
145
146
# File 'lib/sinatra/cookies.rb', line 142

def fetch(key, &block)
  response_cookies.fetch(key.to_s) do
    request_cookies.fetch(key.to_s, &block)
  end
end

#flattenObject



148
149
150
# File 'lib/sinatra/cookies.rb', line 148

def flatten
  to_hash.flatten
end

#has_key?(key) ⇒ Boolean Also known as: include?, member?, key?

Returns:

  • (Boolean)


152
153
154
# File 'lib/sinatra/cookies.rb', line 152

def has_key?(key)
  response_cookies.has_key? key.to_s or request_cookies.has_key? key.to_s
end

#has_value?(value) ⇒ Boolean Also known as: value?

Returns:

  • (Boolean)


156
157
158
# File 'lib/sinatra/cookies.rb', line 156

def has_value?(value)
  response_cookies.has_value? value or request_cookies.has_value? value
end

#hashObject



160
161
162
# File 'lib/sinatra/cookies.rb', line 160

def hash
  to_hash.hash
end

#index(value) ⇒ Object



167
168
169
170
# File 'lib/sinatra/cookies.rb', line 167

def index(value)
  warn "Hash#index is deprecated; use Hash#key"
  key(value)
end

#inspectObject



172
173
174
# File 'lib/sinatra/cookies.rb', line 172

def inspect
  "<##{self.class}: #{to_hash.inspect[1..-2]}>"
end

#invertObject



176
177
178
# File 'lib/sinatra/cookies.rb', line 176

def invert
  to_hash.invert
end

#keep_ifObject Also known as: select!



180
181
182
183
# File 'lib/sinatra/cookies.rb', line 180

def keep_if
  return enum_for(__method__) unless block_given?
  delete_if { |*a| not yield(*a) }
end

#key(value) ⇒ Object



185
186
187
# File 'lib/sinatra/cookies.rb', line 185

def key(value)
  to_hash.key(value)
end

#keysObject



191
192
193
# File 'lib/sinatra/cookies.rb', line 191

def keys
  to_hash.keys
end

#lengthObject Also known as: size



195
196
197
# File 'lib/sinatra/cookies.rb', line 195

def length
  to_hash.length
end

#merge(other, &block) ⇒ Object



199
200
201
# File 'lib/sinatra/cookies.rb', line 199

def merge(other, &block)
  to_hash.merge(other, &block)
end

#merge!(other) ⇒ Object Also known as: update



203
204
205
206
207
208
209
210
211
# File 'lib/sinatra/cookies.rb', line 203

def merge!(other)
  other.each_pair do |key, value|
    if block_given? and include? key
      self[key] = yield(key.to_s, self[key], value)
    else
      self[key] = value
    end
  end
end

#rassoc(value) ⇒ Object



213
214
215
# File 'lib/sinatra/cookies.rb', line 213

def rassoc(value)
  to_hash.rassoc(value)
end

#rehashObject



217
218
219
220
221
# File 'lib/sinatra/cookies.rb', line 217

def rehash
  response_cookies.rehash
  request_cookies.rehash
  self
end

#reject(&block) ⇒ Object



223
224
225
226
# File 'lib/sinatra/cookies.rb', line 223

def reject(&block)
  return enum_for(__method__) unless block_given?
  to_hash.reject(&block)
end

#replace(other) ⇒ Object



230
231
232
233
# File 'lib/sinatra/cookies.rb', line 230

def replace(other)
  select! { |k, v| other.include?(k) or other.include?(k.to_s)  }
  merge! other
end

#select(&block) ⇒ Object



235
236
237
238
# File 'lib/sinatra/cookies.rb', line 235

def select(&block)
  return enum_for(__method__) unless block_given?
  to_hash.select(&block)
end

#set(key, options = {}) ⇒ Object



242
243
244
# File 'lib/sinatra/cookies.rb', line 242

def set(key, options = {})
  @response.set_cookie key.to_s, @options.merge(options)
end

#shiftObject



246
247
248
249
250
# File 'lib/sinatra/cookies.rb', line 246

def shift
  key, value = to_hash.shift
  delete(key)
  [key, value]
end

#sort(&block) ⇒ Object



254
255
256
# File 'lib/sinatra/cookies.rb', line 254

def sort(&block)
  to_hash.sort(&block)
end

#to_aObject



264
265
266
# File 'lib/sinatra/cookies.rb', line 264

def to_a
  to_hash.to_a
end

#to_hashObject



260
261
262
# File 'lib/sinatra/cookies.rb', line 260

def to_hash
  request_cookies.merge(response_cookies)
end

#to_sObject



268
269
270
# File 'lib/sinatra/cookies.rb', line 268

def to_s
  to_hash.to_s
end

#valuesObject



275
276
277
# File 'lib/sinatra/cookies.rb', line 275

def values
  to_hash.values
end

#values_at(*list) ⇒ Object



279
280
281
# File 'lib/sinatra/cookies.rb', line 279

def values_at(*list)
  list.map { |k| self[k] }
end