fiber/middleware/cache/manager.go
Muhammed Efe Cetin c2ae40c6b8
fix linter
2025-07-07 14:39:18 +03:00

140 lines
3.1 KiB
Go

package cache
import (
"context"
"sync"
"time"
"github.com/gofiber/fiber/v3"
"github.com/gofiber/fiber/v3/internal/memory"
)
// msgp -file="manager.go" -o="manager_msgp.go" -tests=true -unexported
//
//go:generate msgp -o=manager_msgp.go -tests=true -unexported
type item struct {
headers map[string][]byte
body []byte
ctype []byte
cencoding []byte
status int
age uint64
exp uint64
ttl uint64
// used for finding the item in an indexed heap
heapidx int
}
//msgp:ignore manager
type manager struct {
pool sync.Pool
memory *memory.Storage
storage fiber.Storage
}
func newManager(storage fiber.Storage) *manager {
// Create new storage handler
manager := &manager{
pool: sync.Pool{
New: func() any {
return new(item)
},
},
}
if storage != nil {
// Use provided storage if provided
manager.storage = storage
} else {
// Fallback to memory storage
manager.memory = memory.New()
}
return manager
}
// acquire returns an *entry from the sync.Pool
func (m *manager) acquire() *item {
return m.pool.Get().(*item) //nolint:forcetypeassert,errcheck // We store nothing else in the pool
}
// release and reset *entry to sync.Pool
func (m *manager) release(e *item) {
// don't release item if we using in-memory storage
if m.storage == nil {
return
}
e.body = nil
e.ctype = nil
e.status = 0
e.age = 0
e.exp = 0
e.ttl = 0
e.headers = nil
m.pool.Put(e)
}
// get data from storage or memory
func (m *manager) get(ctx context.Context, key string) *item {
if m.storage != nil {
raw, err := m.storage.GetWithContext(ctx, key)
if err != nil || raw == nil {
return nil
}
it := m.acquire()
if _, err := it.UnmarshalMsg(raw); err != nil {
m.release(it)
return nil
}
return it
}
if it, _ := m.memory.Get(key).(*item); it != nil { //nolint:errcheck // We store nothing else in the pool
return it
}
return nil
}
// get raw data from storage or memory
func (m *manager) getRaw(ctx context.Context, key string) []byte {
var raw []byte
if m.storage != nil {
raw, _ = m.storage.GetWithContext(ctx, key) //nolint:errcheck // TODO: Handle error here
} else {
raw, _ = m.memory.Get(key).([]byte) //nolint:errcheck // TODO: Handle error here
}
return raw
}
// set data to storage or memory
func (m *manager) set(ctx context.Context, key string, it *item, exp time.Duration) {
if m.storage != nil {
if raw, err := it.MarshalMsg(nil); err == nil {
_ = m.storage.SetWithContext(ctx, key, raw, exp) //nolint:errcheck // TODO: Handle error here
}
// we can release data because it's serialized to database
m.release(it)
} else {
m.memory.Set(key, it, exp)
}
}
// set data to storage or memory
func (m *manager) setRaw(ctx context.Context, key string, raw []byte, exp time.Duration) {
if m.storage != nil {
_ = m.storage.SetWithContext(ctx, key, raw, exp) //nolint:errcheck // TODO: Handle error here
} else {
m.memory.Set(key, raw, exp)
}
}
// delete data from storage or memory
func (m *manager) del(ctx context.Context, key string) {
if m.storage != nil {
_ = m.storage.DeleteWithContext(ctx, key) //nolint:errcheck // TODO: Handle error here
} else {
m.memory.Delete(key)
}
}