49 lines
1.4 KiB
Go
49 lines
1.4 KiB
Go
|
|
package task
|
||
|
|
|
||
|
|
import (
|
||
|
|
"context"
|
||
|
|
|
||
|
|
"git.huangwc.com/pig/pig-farm-controller/internal/domain/alarm"
|
||
|
|
"git.huangwc.com/pig/pig-farm-controller/internal/domain/plan"
|
||
|
|
"git.huangwc.com/pig/pig-farm-controller/internal/infra/logs"
|
||
|
|
"git.huangwc.com/pig/pig-farm-controller/internal/infra/models"
|
||
|
|
)
|
||
|
|
|
||
|
|
type RefreshNotificationTask struct {
|
||
|
|
ctx context.Context
|
||
|
|
taskLog *models.TaskExecutionLog
|
||
|
|
|
||
|
|
alarmService alarm.AlarmService
|
||
|
|
}
|
||
|
|
|
||
|
|
func NewRefreshNotificationTask(ctx context.Context, taskLog *models.TaskExecutionLog, alarmService alarm.AlarmService) plan.Task {
|
||
|
|
return &RefreshNotificationTask{
|
||
|
|
ctx: ctx,
|
||
|
|
taskLog: taskLog,
|
||
|
|
alarmService: alarmService,
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
func (r *RefreshNotificationTask) Execute(ctx context.Context) error {
|
||
|
|
taskCtx, logger := logs.Trace(ctx, r.ctx, "Execute")
|
||
|
|
logger.Infof("开始执行刷新通知任务, 任务ID: %d", r.taskLog.TaskID)
|
||
|
|
|
||
|
|
_, err := r.alarmService.ClearExpiredIgnoredAlarms(taskCtx)
|
||
|
|
if err != nil {
|
||
|
|
return err
|
||
|
|
}
|
||
|
|
|
||
|
|
logger.Infof("刷新通知任务执行完成, 任务ID: %d", r.taskLog.TaskID)
|
||
|
|
return nil
|
||
|
|
}
|
||
|
|
|
||
|
|
func (r *RefreshNotificationTask) OnFailure(ctx context.Context, executeErr error) {
|
||
|
|
logger := logs.TraceLogger(ctx, r.ctx, "OnFailure")
|
||
|
|
logger.Errorf("刷新通知任务执行失败, 任务ID: %d, 错误: %v", r.taskLog.TaskID, executeErr)
|
||
|
|
}
|
||
|
|
|
||
|
|
func (r *RefreshNotificationTask) ResolveDeviceIDs(ctx context.Context) ([]uint32, error) {
|
||
|
|
// 刷新通知任务不与具体设备绑定
|
||
|
|
return []uint32{}, nil
|
||
|
|
}
|