2022-05-15 12:16:43 +03:00
|
|
|
package cache
|
|
|
|
|
|
|
|
import "time"
|
|
|
|
|
|
|
|
// Cache represents a TTL cache with customizable callbacks, it
|
|
|
|
// exists here to abstract away the "unsafe" methods in the case that
|
|
|
|
// you do not want your own implementation atop TTLCache{}.
|
|
|
|
type Cache[Key comparable, Value any] interface {
|
|
|
|
// Start will start the cache background eviction routine with given sweep frequency.
|
|
|
|
// If already running or a freq <= 0 provided, this is a no-op. This will block until
|
|
|
|
// the eviction routine has started
|
|
|
|
Start(freq time.Duration) bool
|
|
|
|
|
|
|
|
// Stop will stop cache background eviction routine. If not running this is a no-op. This
|
|
|
|
// will block until the eviction routine has stopped
|
|
|
|
Stop() bool
|
|
|
|
|
|
|
|
// SetEvictionCallback sets the eviction callback to the provided hook
|
|
|
|
SetEvictionCallback(hook Hook[Key, Value])
|
|
|
|
|
|
|
|
// SetInvalidateCallback sets the invalidate callback to the provided hook
|
|
|
|
SetInvalidateCallback(hook Hook[Key, Value])
|
|
|
|
|
|
|
|
// SetTTL sets the cache item TTL. Update can be specified to force updates of existing items in
|
|
|
|
// the cache, this will simply add the change in TTL to their current expiry time
|
|
|
|
SetTTL(ttl time.Duration, update bool)
|
|
|
|
|
|
|
|
// Get fetches the value with key from the cache, extending its TTL
|
|
|
|
Get(key Key) (value Value, ok bool)
|
|
|
|
|
|
|
|
// Put attempts to place the value at key in the cache, doing nothing if
|
|
|
|
// a value with this key already exists. Returned bool is success state
|
|
|
|
Put(key Key, value Value) bool
|
|
|
|
|
|
|
|
// Set places the value at key in the cache. This will overwrite any
|
|
|
|
// existing value, and call the update callback so. Existing values
|
|
|
|
// will have their TTL extended upon update
|
|
|
|
Set(key Key, value Value)
|
|
|
|
|
|
|
|
// CAS will attempt to perform a CAS operation on 'key', using provided
|
|
|
|
// comparison and swap values. Returned bool is success.
|
|
|
|
CAS(key Key, cmp, swp Value) bool
|
|
|
|
|
|
|
|
// Swap will attempt to perform a swap on 'key', replacing the value there
|
|
|
|
// and returning the existing value. If no value exists for key, this will
|
|
|
|
// set the value and return the zero value for V.
|
|
|
|
Swap(key Key, swp Value) Value
|
|
|
|
|
|
|
|
// Has checks the cache for a value with key, this will not update TTL
|
|
|
|
Has(key Key) bool
|
|
|
|
|
|
|
|
// Invalidate deletes a value from the cache, calling the invalidate callback
|
|
|
|
Invalidate(key Key) bool
|
|
|
|
|
|
|
|
// Clear empties the cache, calling the invalidate callback
|
|
|
|
Clear()
|
|
|
|
|
|
|
|
// Size returns the current size of the cache
|
|
|
|
Size() int
|
|
|
|
}
|
|
|
|
|
|
|
|
// New returns a new initialized Cache.
|
|
|
|
func New[K comparable, V any]() Cache[K, V] {
|
2022-07-10 18:18:21 +03:00
|
|
|
c := &TTLCache[K, V]{}
|
2022-05-15 12:16:43 +03:00
|
|
|
c.Init()
|
2022-07-10 18:18:21 +03:00
|
|
|
return c
|
2022-05-15 12:16:43 +03:00
|
|
|
}
|