1234567891011121314151617181920212223242526272829303132333435363738394041 |
- 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
- }
|