File: //lib/ruby/vendor_ruby/moneta/expires.rb
module Moneta
# Adds expiration support to the underlying store
#
# `#store`, `#load` and `#key?` support the `:expires` option to set/update
# the expiration time.
#
# @api public
class Expires < Proxy
include ExpiresSupport
# @param [Moneta store] adapter The underlying store
# @param [Hash] options
# @option options [String] :expires Default expiration time
def initialize(adapter, options = {})
raise 'Store already supports feature :expires' if adapter.supports?(:expires)
super
self.default_expires = options[:expires]
end
# (see Proxy#key?)
def key?(key, options = {})
# Transformer might raise exception
load_entry(key, options) != nil
rescue Exception
super(key, Utils.without(options, :expires))
end
# (see Proxy#load)
def load(key, options = {})
return super if options.include?(:raw)
value, expires = load_entry(key, options)
value
end
# (see Proxy#store)
def store(key, value, options = {})
return super if options.include?(:raw)
expires = expires_at(options)
super(key, new_entry(value, expires), Utils.without(options, :expires))
value
end
# (see Proxy#delete)
def delete(key, options = {})
return super if options.include?(:raw)
value, expires = super
value if !expires || Time.now.to_i <= expires
end
# (see Proxy#store)
def create(key, value, options = {})
return super if options.include?(:raw)
expires = expires_at(options)
@adapter.create(key, new_entry(value, expires), Utils.without(options, :expires))
end
private
def load_entry(key, options)
new_expires = expires_at(options, nil)
options = Utils.without(options, :expires)
entry = @adapter.load(key, options)
if entry != nil
value, expires = entry
if expires && Time.now.to_i > expires
delete(key)
nil
elsif new_expires != nil
@adapter.store(key, new_entry(value, new_expires), options)
entry
else
entry
end
end
end
def new_entry(value, expires)
if expires
[value, expires.to_i]
elsif Array === value || value == nil
[value]
else
value
end
end
end
end