2023-02-21 21:13:13 +02:00
|
|
|
package timecache
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"context"
|
|
|
|
|
"sync"
|
|
|
|
|
"time"
|
|
|
|
|
)
|
|
|
|
|
|
2025-07-03 11:37:53 -07:00
|
|
|
const backgroundSweepInterval = time.Minute
|
2023-02-21 21:13:13 +02:00
|
|
|
|
2025-07-03 11:37:53 -07:00
|
|
|
func background(ctx context.Context, lk sync.Locker, m map[string]time.Time, tickerDur time.Duration) {
|
|
|
|
|
ticker := time.NewTicker(tickerDur)
|
2023-02-21 21:13:13 +02:00
|
|
|
defer ticker.Stop()
|
|
|
|
|
|
|
|
|
|
for {
|
|
|
|
|
select {
|
|
|
|
|
case now := <-ticker.C:
|
|
|
|
|
sweep(lk, m, now)
|
|
|
|
|
|
|
|
|
|
case <-ctx.Done():
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func sweep(lk sync.Locker, m map[string]time.Time, now time.Time) {
|
|
|
|
|
lk.Lock()
|
|
|
|
|
defer lk.Unlock()
|
|
|
|
|
|
|
|
|
|
for k, expiry := range m {
|
|
|
|
|
if expiry.Before(now) {
|
|
|
|
|
delete(m, k)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|