Breaking change: Add ScanSchedule, allows interval and cron based configurations.

See https://pkg.go.dev/github.com/robfig/cron#hdr-CRON_Expression_Format for expression syntax.

`ScanInterval` will still work for the time being. The only situation it does not work is when you want to disable periodic scanning by setting `ScanInterval=0`. If you want to disable it, please set `ScanSchedule=""`

Closes #1085
This commit is contained in:
Deluan
2021-05-06 17:56:10 -04:00
parent 1d6aa70033
commit f8dbc41b6d
9 changed files with 164 additions and 30 deletions

24
scheduler/log_adapter.go Normal file
View File

@@ -0,0 +1,24 @@
package scheduler
import (
"github.com/navidrome/navidrome/log"
)
type logger struct{}
func (l *logger) Info(msg string, keysAndValues ...interface{}) {
args := []interface{}{
"Scheduler: " + msg,
}
args = append(args, keysAndValues...)
log.Debug(args...)
}
func (l *logger) Error(err error, msg string, keysAndValues ...interface{}) {
args := []interface{}{
"Scheduler: " + msg,
}
args = append(args, keysAndValues...)
args = append(args, err)
log.Error(args...)
}

34
scheduler/scheduler.go Normal file
View File

@@ -0,0 +1,34 @@
package scheduler
import (
"context"
"github.com/robfig/cron/v3"
)
type Scheduler interface {
Run(ctx context.Context)
Add(crontab string, cmd func()) error
}
func New() Scheduler {
c := cron.New(cron.WithLogger(&logger{}))
return &scheduler{
c: c,
}
}
type scheduler struct {
c *cron.Cron
}
func (s *scheduler) Run(ctx context.Context) {
s.c.Start()
<-ctx.Done()
s.c.Stop()
}
func (s *scheduler) Add(crontab string, cmd func()) error {
_, err := s.c.AddFunc(crontab, cmd)
return err
}