2021-02-14 16:18:26 +00:00
|
|
|
package cache
|
|
|
|
|
|
|
|
|
|
import (
|
2021-02-19 22:20:02 +00:00
|
|
|
"context"
|
2021-02-14 16:18:26 +00:00
|
|
|
"fmt"
|
2022-04-01 20:42:05 +01:00
|
|
|
"time"
|
|
|
|
|
|
2021-02-19 22:20:02 +00:00
|
|
|
"github.com/dgraph-io/badger/v3"
|
|
|
|
|
"github.com/lefelys/state"
|
2021-02-14 16:18:26 +00:00
|
|
|
"github.com/rs/zerolog"
|
2022-04-14 16:18:06 +01:00
|
|
|
|
|
|
|
|
"github.com/l3uddz/nabarr/logger"
|
2021-02-14 16:18:26 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
type Client struct {
|
|
|
|
|
log zerolog.Logger
|
2021-02-19 22:20:02 +00:00
|
|
|
st state.State
|
2021-02-14 16:18:26 +00:00
|
|
|
|
2021-02-19 22:20:02 +00:00
|
|
|
db *badger.DB
|
2021-02-14 16:18:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func New(path string) (*Client, error) {
|
2021-02-19 22:20:02 +00:00
|
|
|
opts := badger.DefaultOptions(path)
|
|
|
|
|
opts.Logger = nil
|
|
|
|
|
db, err := badger.Open(opts)
|
2021-02-14 16:18:26 +00:00
|
|
|
if err != nil {
|
|
|
|
|
return nil, fmt.Errorf("open: %w", err)
|
|
|
|
|
}
|
|
|
|
|
|
2022-04-14 16:18:06 +01:00
|
|
|
log := logger.Child()
|
2021-02-14 16:18:26 +00:00
|
|
|
|
2021-02-19 22:20:02 +00:00
|
|
|
// start cleaner
|
|
|
|
|
st, tail := state.WithShutdown()
|
|
|
|
|
ticker := time.NewTicker(6 * time.Hour)
|
|
|
|
|
go func() {
|
|
|
|
|
for {
|
|
|
|
|
select {
|
|
|
|
|
case <-tail.End():
|
|
|
|
|
ticker.Stop()
|
|
|
|
|
tail.Done()
|
|
|
|
|
return
|
|
|
|
|
case <-ticker.C:
|
|
|
|
|
// clean cache
|
|
|
|
|
for {
|
|
|
|
|
if db.RunValueLogGC(0.5) == nil {
|
|
|
|
|
continue
|
|
|
|
|
}
|
|
|
|
|
break
|
|
|
|
|
}
|
|
|
|
|
log.Debug().Msg("Cleaned cache")
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}()
|
|
|
|
|
|
2021-02-14 16:18:26 +00:00
|
|
|
return &Client{
|
|
|
|
|
log: log,
|
2021-02-19 22:20:02 +00:00
|
|
|
st: st,
|
2021-02-19 19:15:38 +00:00
|
|
|
|
|
|
|
|
db: db,
|
2021-02-14 16:18:26 +00:00
|
|
|
}, nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (c *Client) Close() error {
|
2021-02-19 22:20:02 +00:00
|
|
|
// shutdown cleaner
|
|
|
|
|
if c.st != nil {
|
|
|
|
|
ctx, cancel := context.WithTimeout(context.Background(), 60*time.Second)
|
|
|
|
|
defer cancel()
|
|
|
|
|
if err := c.st.Shutdown(ctx); err != nil {
|
|
|
|
|
c.log.Error().
|
|
|
|
|
Err(err).
|
|
|
|
|
Msg("Failed shutting down cache cleaner gracefully")
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-02-14 16:18:26 +00:00
|
|
|
// close cache
|
|
|
|
|
return c.db.Close()
|
|
|
|
|
}
|