2021-08-31 16:31:16 +02:00
|
|
|
package cache
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"sync"
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
|
|
|
type memCache struct {
|
|
|
|
opts Options
|
|
|
|
|
|
|
|
items map[string]Item
|
2023-04-26 02:16:34 +02:00
|
|
|
sync.RWMutex
|
2021-08-31 16:31:16 +02:00
|
|
|
}
|
|
|
|
|
2022-06-21 21:05:00 +02:00
|
|
|
func (c *memCache) Get(ctx context.Context, key string) (interface{}, time.Time, error) {
|
2022-01-09 12:20:08 +02:00
|
|
|
c.RWMutex.RLock()
|
|
|
|
defer c.RWMutex.RUnlock()
|
2021-08-31 16:31:16 +02:00
|
|
|
|
|
|
|
item, found := c.items[key]
|
|
|
|
if !found {
|
|
|
|
return nil, time.Time{}, ErrKeyNotFound
|
|
|
|
}
|
|
|
|
if item.Expired() {
|
|
|
|
return nil, time.Time{}, ErrItemExpired
|
|
|
|
}
|
|
|
|
|
|
|
|
return item.Value, time.Unix(0, item.Expiration), nil
|
|
|
|
}
|
|
|
|
|
2022-06-21 21:05:00 +02:00
|
|
|
func (c *memCache) Put(ctx context.Context, key string, val interface{}, d time.Duration) error {
|
2021-08-31 16:31:16 +02:00
|
|
|
var e int64
|
|
|
|
if d == DefaultExpiration {
|
|
|
|
d = c.opts.Expiration
|
|
|
|
}
|
|
|
|
if d > 0 {
|
|
|
|
e = time.Now().Add(d).UnixNano()
|
|
|
|
}
|
|
|
|
|
|
|
|
c.RWMutex.Lock()
|
|
|
|
defer c.RWMutex.Unlock()
|
|
|
|
|
|
|
|
c.items[key] = Item{
|
|
|
|
Value: val,
|
|
|
|
Expiration: e,
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2022-06-21 21:05:00 +02:00
|
|
|
func (c *memCache) Delete(ctx context.Context, key string) error {
|
2021-08-31 16:31:16 +02:00
|
|
|
c.RWMutex.Lock()
|
|
|
|
defer c.RWMutex.Unlock()
|
|
|
|
|
|
|
|
_, found := c.items[key]
|
|
|
|
if !found {
|
|
|
|
return ErrKeyNotFound
|
|
|
|
}
|
|
|
|
|
|
|
|
delete(c.items, key)
|
|
|
|
return nil
|
|
|
|
}
|
2022-06-21 21:05:00 +02:00
|
|
|
|
|
|
|
func (m *memCache) String() string {
|
|
|
|
return "memory"
|
|
|
|
}
|