micro/client/cache.go

67 lines
1.4 KiB
Go
Raw Permalink Normal View History

2020-05-22 18:52:24 +03:00
package client
import (
"context"
"encoding/json"
"fmt"
"hash/fnv"
2020-05-22 18:52:24 +03:00
"time"
cache "github.com/patrickmn/go-cache"
"github.com/unistack-org/micro/v3/metadata"
2020-05-22 18:52:24 +03:00
)
// NewCache returns an initialised cache.
func NewCache() *Cache {
return &Cache{
cache: cache.New(cache.NoExpiration, 30*time.Second),
2020-05-22 18:52:24 +03:00
}
}
// Cache for responses
type Cache struct {
cache *cache.Cache
2020-05-22 18:52:24 +03:00
}
// Get a response from the cache
func (c *Cache) Get(ctx context.Context, req Request) (interface{}, bool) {
return c.cache.Get(key(ctx, req))
2020-05-22 18:52:24 +03:00
}
// Set a response in the cache
func (c *Cache) Set(ctx context.Context, req Request, rsp interface{}, expiry time.Duration) {
c.cache.Set(key(ctx, req), rsp, expiry)
2020-05-22 18:52:24 +03:00
}
2020-05-24 20:45:57 +03:00
// List the key value pairs in the cache
func (c *Cache) List() map[string]string {
items := c.cache.Items()
rsp := make(map[string]string, len(items))
for k, v := range items {
bytes, _ := json.Marshal(v.Object)
rsp[k] = string(bytes)
}
return rsp
}
// key returns a hash for the context and request
func key(ctx context.Context, req Request) string {
2020-05-27 11:07:59 +03:00
ns, _ := metadata.Get(ctx, "Micro-Namespace")
2020-05-22 18:52:24 +03:00
bytes, _ := json.Marshal(map[string]interface{}{
2020-05-27 11:07:59 +03:00
"namespace": ns,
"request": map[string]interface{}{
"service": req.Service(),
"endpoint": req.Endpoint(),
"method": req.Method(),
"body": req.Body(),
},
})
h := fnv.New64()
2020-05-22 18:52:24 +03:00
h.Write(bytes)
return fmt.Sprintf("%x", h.Sum(nil))
}