This repository has been archived on 2022-09-04. You can view files and clone it, but cannot push or open issues or pull requests.
dataupdater/internal/cron/tasks/task_delete_non_existent_villages.go

46 lines
1.1 KiB
Go
Raw Normal View History

package tasks
import (
"context"
"github.com/pkg/errors"
"github.com/tribalwarshelp/shared/models"
"github.com/tribalwarshelp/cron/internal/cron/queue"
)
type taskDeleteNonExistentVillages struct {
*task
}
func (t *taskDeleteNonExistentVillages) execute() error {
var servers []*models.Server
err := t.db.
Model(&servers).
Where("status = ?", models.ServerStatusOpen).
Relation("Version").
Select()
if err != nil {
err = errors.Wrap(err, "taskDeleteNonExistentVillages.execute")
log.Errorln(err)
return err
}
log.
WithField("numberOfServers", len(servers)).
Info("taskDeleteNonExistentVillages.execute: Servers have been loaded and added to the queue")
for _, server := range servers {
s := server
err := t.queue.Add(queue.MainQueue, Get(TaskNameServerDeleteNonExistentVillages).WithArgs(context.Background(), s))
if err != nil {
log.Warn(
errors.Wrapf(
err,
"taskDeleteNonExistentVillages.execute: %s: Couldn't add the task '%s' for this server",
server.Key,
TaskNameServerDeleteNonExistentVillages,
),
)
}
}
return nil
}