Class: Cache
- Inherits:
-
Object
- Object
- Cache
- Defined in:
- lib/libcache/cache.rb
Direct Known Subclasses
Instance Attribute Summary collapse
-
#expiry_time ⇒ Object
Returns the value of attribute expiry_time.
-
#max_size ⇒ Object
Returns the value of attribute max_size.
-
#refresh ⇒ Object
Returns the value of attribute refresh.
-
#store ⇒ Object
Returns the value of attribute store.
Instance Method Summary collapse
-
#check_refresh(key) ⇒ Object
Refreshes an object if it has been invalidated.
-
#create_store ⇒ Object
Initializes the cache store.
-
#exists?(key) ⇒ Boolean
Checks if a key-value pair exists in the cache.
-
#get(key) ⇒ Object
Gets the object that corresponds with the key.
- #get_size ⇒ Object
-
#has_refresh? ⇒ Boolean
Checks if the cache has a refresh method.
-
#initialize ⇒ Cache
constructor
Creates a basic Cache with the UTC timezone.
-
#invalidate(key) ⇒ Object
Deletes a key-value pair from the cache.
-
#invalidate_all ⇒ Object
Clears all items in the cache.
-
#put(key, value) ⇒ Object
Places an object inside the cache and handles max size eviction.
Constructor Details
#initialize ⇒ Cache
Creates a basic Cache with the UTC timezone
9 10 11 12 13 |
# File 'lib/libcache/cache.rb', line 9 def initialize ENV['TZ'] = 'UTC' @scheduler = Rufus::Scheduler.new @time_tracker = Hash.new end |
Instance Attribute Details
#expiry_time ⇒ Object
Returns the value of attribute expiry_time.
6 7 8 |
# File 'lib/libcache/cache.rb', line 6 def expiry_time @expiry_time end |
#max_size ⇒ Object
Returns the value of attribute max_size.
6 7 8 |
# File 'lib/libcache/cache.rb', line 6 def max_size @max_size end |
#refresh ⇒ Object
Returns the value of attribute refresh.
6 7 8 |
# File 'lib/libcache/cache.rb', line 6 def refresh @refresh end |
#store ⇒ Object
Returns the value of attribute store.
6 7 8 |
# File 'lib/libcache/cache.rb', line 6 def store @store end |
Instance Method Details
#check_refresh(key) ⇒ Object
Refreshes an object if it has been invalidated
69 70 71 72 73 74 75 |
# File 'lib/libcache/cache.rb', line 69 def check_refresh(key) if @cache[key] == nil && !has_refresh? val = refresh.call(key) put(key, val) return val end end |
#create_store ⇒ Object
Initializes the cache store
16 17 18 |
# File 'lib/libcache/cache.rb', line 16 def create_store @cache = Hash.new end |
#exists?(key) ⇒ Boolean
Checks if a key-value pair exists in the cache
62 63 64 |
# File 'lib/libcache/cache.rb', line 62 def exists?(key) return @cache.key?(key) end |
#get(key) ⇒ Object
Gets the object that corresponds with the key
51 52 53 54 55 56 57 |
# File 'lib/libcache/cache.rb', line 51 def get(key) check_refresh(key) if(@cache[key]) == nil return nil end return @cache[key] end |
#get_size ⇒ Object
82 83 84 |
# File 'lib/libcache/cache.rb', line 82 def get_size return @cache.length end |
#has_refresh? ⇒ Boolean
Returns Checks if the cache has a refresh method.
78 79 80 |
# File 'lib/libcache/cache.rb', line 78 def has_refresh? return refresh == nil end |
#invalidate(key) ⇒ Object
Deletes a key-value pair from the cache
88 89 90 |
# File 'lib/libcache/cache.rb', line 88 def invalidate(key) @cache.delete key end |
#invalidate_all ⇒ Object
Clears all items in the cache
93 94 95 |
# File 'lib/libcache/cache.rb', line 93 def invalidate_all @cache.clear end |
#put(key, value) ⇒ Object
Places an object inside the cache and handles max size eviction
23 24 25 26 27 28 29 30 31 |
# File 'lib/libcache/cache.rb', line 23 def put(key, value) @cache[key] = value if expiry_time != nil @scheduler.in expiry_time, :blocking => true do invalidate key end end check_expiration(key) end |