Add Move retention policy

* Currently not testet!
This commit is contained in:
2023-05-15 16:57:31 +02:00
parent 6731b8b1e0
commit 0f9b83e636
3 changed files with 46 additions and 2 deletions

View File

@@ -446,7 +446,7 @@ func main() {
switch cfg.Retention.Policy {
case "delete":
log.Info("Register retention service")
log.Info("Register retention delete service")
s.Every(1).Day().At("4:00").Do(func() {
startTime := time.Now().Unix() - int64(cfg.Retention.Age*24*3600)
@@ -469,7 +469,28 @@ func main() {
}
})
case "move":
log.Warn("Retention policy move not implemented")
log.Info("Register retention move service")
s.Every(1).Day().At("4:00").Do(func() {
startTime := time.Now().Unix() - int64(cfg.Retention.Age*24*3600)
jobs, err := jobRepo.FindJobsBefore(startTime)
if err != nil {
log.Warnf("Error while looking for retention jobs: %s", err.Error())
}
archive.GetHandle().Move(jobs, cfg.Retention.Location)
if cfg.Retention.IncludeDB {
cnt, err := jobRepo.DeleteJobsBefore(startTime)
if err != nil {
log.Errorf("Error while deleting retention jobs from db: %s", err.Error())
} else {
log.Infof("Retention: Removed %d jobs from db", cnt)
}
if err = jobRepo.Optimize(); err != nil {
log.Errorf("Error occured in db optimization: %s", err.Error())
}
}
})
}
if cfg.Compression > 0 {