vegvisir/pkg/cache/memory_datastore.go

74 lines
1.6 KiB
Go
Raw Normal View History

// ___ ____ ___ ___
// \ \ / / | _ | __| \ \ / / || | __ || || _ |
// \ \/ / |___ | |__ \ \/ / || |___ || ||___|
// \ / | _ | _ | \ / || __ | || ||\\
// \/ |___ |___ | \/ || ____| || || \\
//
// Copyright (c) 2021 Piotr Biernat. https://pbiernat.dev. MIT License
// Repo: https://git.pbiernat.dev/golang/vegvisir
package cache
import (
"errors"
"sync"
2021-07-25 01:44:50 +02:00
"time"
)
2021-08-03 00:13:14 +02:00
// TTLItem struct
type TTLItem struct {
2021-07-25 01:44:50 +02:00
ts int // timestamp
2021-07-25 20:13:03 +02:00
ttl int // ttl in seconds
2021-07-25 01:44:50 +02:00
}
2021-08-03 00:13:14 +02:00
// NewMemoryDatastore function
func NewMemoryDatastore() *MemoryDatastore {
return &MemoryDatastore{
cache: make(map[string]interface{}),
2021-08-03 00:13:14 +02:00
ts: make(map[string]TTLItem),
}
}
2021-08-03 00:13:14 +02:00
// MemoryDatastore struct
type MemoryDatastore struct {
cache map[string]interface{}
2021-08-03 00:13:14 +02:00
ts map[string]TTLItem
2021-11-15 21:41:38 +01:00
lock sync.RWMutex
}
2021-08-03 00:13:14 +02:00
// SetKey function
func (ds *MemoryDatastore) SetKey(key string, data interface{}, ttl int) error {
ds.lock.Lock()
ds.cache[key] = data
2021-08-03 00:13:14 +02:00
ds.ts[key] = TTLItem{
2021-07-25 01:44:50 +02:00
ts: time.Now().Second(),
ttl: ttl,
}
ds.lock.Unlock()
return nil
}
2021-08-03 00:13:14 +02:00
// GetKey function
func (ds *MemoryDatastore) GetKey(key string) (interface{}, error) {
ds.lock.RLock()
defer ds.lock.RUnlock()
2021-07-25 01:44:50 +02:00
ds.gc(key) // remove key is time of creation is outdated
if data, ok := ds.cache[key]; ok {
return data, nil
}
return nil, errors.New("Key not found" + key)
}
2021-08-03 00:13:14 +02:00
// IsConnected function
func (ds *MemoryDatastore) IsConnected() bool {
return true
}
2021-07-25 01:44:50 +02:00
func (ds *MemoryDatastore) gc(key string) {
if item, ok := ds.ts[key]; ok && item.ts < time.Now().Second()-item.ttl {
delete(ds.cache, key)
}
}