2020-10-26 12:15:42 +00:00
|
|
|
package cache
|
|
|
|
|
|
|
|
import (
|
|
|
|
lru "github.com/hashicorp/golang-lru"
|
2021-07-28 21:23:44 +00:00
|
|
|
slashpb "github.com/prysmaticlabs/prysm/proto/prysm/v1alpha1"
|
2021-09-02 10:36:54 +00:00
|
|
|
lruwrpr "github.com/prysmaticlabs/prysm/shared/lru"
|
2020-10-26 12:15:42 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
// highestAttCacheSize defines the max number of sets of highest attestation in cache.
|
|
|
|
highestAttCacheSize = 3000
|
|
|
|
)
|
|
|
|
|
|
|
|
// HighestAttestationCache is used to store per validator id highest attestation in cache.
|
|
|
|
type HighestAttestationCache struct {
|
|
|
|
cache *lru.Cache
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewHighestAttestationCache initializes the cache.
|
|
|
|
func NewHighestAttestationCache(size int, onEvicted func(key interface{}, value interface{})) (*HighestAttestationCache, error) {
|
|
|
|
if size != 0 {
|
|
|
|
highestAttCacheSize = size
|
|
|
|
}
|
2021-09-02 10:36:54 +00:00
|
|
|
return &HighestAttestationCache{cache: lruwrpr.NewWithEvict(highestAttCacheSize, onEvicted)}, nil
|
2020-10-26 12:15:42 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Get returns an ok bool and the cached value for the requested validator id key, if any.
|
|
|
|
func (c *HighestAttestationCache) Get(setKey uint64) (map[uint64]*slashpb.HighestAttestation, bool) {
|
|
|
|
item, exists := c.cache.Get(setKey)
|
|
|
|
if exists && item != nil {
|
|
|
|
return item.(map[uint64]*slashpb.HighestAttestation), true
|
|
|
|
}
|
|
|
|
return nil, false
|
|
|
|
}
|
|
|
|
|
|
|
|
// Set the response in the cache.
|
|
|
|
func (c *HighestAttestationCache) Set(setKey uint64, highest *slashpb.HighestAttestation) {
|
|
|
|
set, ok := c.Get(setKey)
|
|
|
|
if ok {
|
2021-07-23 18:01:01 +00:00
|
|
|
set[highest.ValidatorIndex] = highest
|
2020-10-26 12:15:42 +00:00
|
|
|
} else {
|
|
|
|
set = map[uint64]*slashpb.HighestAttestation{
|
2021-07-23 18:01:01 +00:00
|
|
|
highest.ValidatorIndex: highest,
|
2020-10-26 12:15:42 +00:00
|
|
|
}
|
|
|
|
c.cache.Add(setKey, set)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Delete removes a validator id from the cache and returns if it existed or not.
|
|
|
|
// Performs the onEviction function before removal.
|
|
|
|
func (c *HighestAttestationCache) Delete(setKey uint64) bool {
|
|
|
|
return c.cache.Remove(setKey)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Has returns true if the key exists in the cache.
|
|
|
|
func (c *HighestAttestationCache) Has(setKey uint64) bool {
|
|
|
|
return c.cache.Contains(setKey)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Clear removes all keys from the ValidatorCache.
|
|
|
|
func (c *HighestAttestationCache) Clear() {
|
|
|
|
c.cache.Purge()
|
|
|
|
}
|
|
|
|
|
|
|
|
// Purge removes all keys from cache and evicts all current data.
|
|
|
|
func (c *HighestAttestationCache) Purge() {
|
|
|
|
log.Info("Saving all highest attestation cache data to DB, please wait for completion.")
|
|
|
|
c.cache.Purge()
|
|
|
|
}
|