dendrite/common/caching/inmemorylru.go
2020-04-22 10:12:14 +01:00

47 lines
1 KiB
Go

package caching
import (
"fmt"
"sync"
"github.com/golang/groupcache/lru"
"github.com/matrix-org/gomatrixserverlib"
)
type InMemoryLRUCache struct {
roomVersions *lru.Cache
roomVersionsMutex sync.RWMutex
}
func NewInMemoryLRUCache() *InMemoryLRUCache {
return &InMemoryLRUCache{
roomVersions: lru.New(128),
}
}
func (c *InMemoryLRUCache) GetRoomVersion(roomID string) (gomatrixserverlib.RoomVersion, bool) {
fmt.Println("Cache hit for", roomID)
if c == nil {
return "", false
}
c.roomVersionsMutex.RLock()
val, found := c.roomVersions.Get(roomID)
c.roomVersionsMutex.RUnlock()
if found && val != nil {
if roomVersion, ok := val.(gomatrixserverlib.RoomVersion); ok {
return roomVersion, true
}
}
return "", false
}
func (c *InMemoryLRUCache) StoreRoomVersion(roomID string, roomVersion gomatrixserverlib.RoomVersion) {
fmt.Println("Cache store for", roomID)
if c == nil {
return
}
c.roomVersionsMutex.Lock()
defer c.roomVersionsMutex.Unlock()
c.roomVersions.Add(roomID, roomVersion)
}