bilibili-backup/app/admin/ep/merlin/dao/mysql_task.go

42 lines
1.5 KiB
Go
Raw Normal View History

2019-04-22 10:59:20 +08:00
package dao
import (
"go-common/app/admin/ep/merlin/model"
pkgerr "github.com/pkg/errors"
)
// FindDeleteMachineTasks find delete machine tasks.
func (d *Dao) FindDeleteMachineTasks() (tasks []*model.Task, err error) {
tasks = []*model.Task{}
err = pkgerr.WithStack(d.db.Where("status=? AND type=? AND DATEDIFF(NOW(),execute_time)=0 AND execute_time < NOW()", model.TaskInit, model.DeleteMachine).Find(&tasks).Error)
return
}
// UpdateTaskStatusByMachines update task status by machines.
func (d *Dao) UpdateTaskStatusByMachines(machineIDs []int64, status int) (err error) {
return pkgerr.WithStack(d.db.Model(&model.Task{}).Where("machine_id IN (?)", machineIDs).Update("status", status).Error)
}
// UpdateTaskStatusByTaskID update task status by taskId.
func (d *Dao) UpdateTaskStatusByTaskID(taskID int64, status int) (err error) {
return pkgerr.WithStack(d.db.Model(&model.Task{}).Where("id IN (?)", taskID).Update("status", status).Error)
}
// InsertDeleteMachinesTasks insert delete machines tasks.
// TODO:这块逻辑不是很好如果一个写入失败希望继续写入失败的话最好返回失败list后续联调时优化
func (d *Dao) InsertDeleteMachinesTasks(ms []*model.Machine) (err error) {
for _, machine := range ms {
mrTask := &model.Task{
TYPE: model.DeleteMachine,
ExecuteTime: machine.EndTime,
MachineID: machine.ID,
Status: model.TaskInit,
}
if tempErr := d.db.Create(mrTask).Error; tempErr != nil {
err = pkgerr.WithStack(tempErr)
}
}
return
}