vegvisir/pkg/cache/memory_datastore.go
Piotr Biernat 8c0f8d4151
All checks were successful
continuous-integration/drone/push Build is passing
continuous-integration/drone/pr Build is passing
[fix] Added support for headers cache
2021-07-25 20:54:42 +02:00

63 lines
1.3 KiB
Go

// ___ ____ ___ ___
// \ \ / / | _ | __| \ \ / / || | __ || || _ |
// \ \/ / |___ | |__ \ \/ / || |___ || ||___|
// \ / | _ | _ | \ / || __ | || ||\\
// \/ |___ |___ | \/ || ____| || || \\
//
// Copyright (c) 2021 Piotr Biernat. https://pbiernat.dev. MIT License
// Repo: https://git.pbiernat.dev/golang/vegvisir
package cache
import (
"errors"
"time"
)
type TtlItem struct {
ts int // timestamp
ttl int // ttl in seconds
}
func NewMemoryDatastore() *MemoryDatastore {
return &MemoryDatastore{
cache: make(map[string]interface{}),
ts: make(map[string]TtlItem),
}
}
type MemoryDatastore struct {
cache map[string]interface{}
ts map[string]TtlItem
}
func (ds *MemoryDatastore) SetKey(key string, data interface{}, ttl int) error {
ds.cache[key] = data
ds.ts[key] = TtlItem{
ts: time.Now().Second(),
ttl: ttl,
}
return nil
}
func (ds *MemoryDatastore) GetKey(key string) (interface{}, error) {
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)
}
func (ds *MemoryDatastore) IsConnected() bool {
return true
}
func (ds *MemoryDatastore) gc(key string) {
if item, ok := ds.ts[key]; ok && item.ts < time.Now().Second()-item.ttl {
delete(ds.cache, key)
}
}