Files
pig-farm-controller/internal/domain/task/task.go

46 lines
1.5 KiB
Go
Raw Normal View History

2025-09-17 16:55:56 +08:00
package task
import (
2025-10-29 15:30:16 +08:00
"git.huangwc.com/pig/pig-farm-controller/internal/domain/device"
2025-11-02 18:16:44 +08:00
"git.huangwc.com/pig/pig-farm-controller/internal/domain/plan"
2025-10-29 15:30:16 +08:00
"git.huangwc.com/pig/pig-farm-controller/internal/infra/logs"
2025-09-17 16:55:56 +08:00
"git.huangwc.com/pig/pig-farm-controller/internal/infra/models"
2025-10-29 15:30:16 +08:00
"git.huangwc.com/pig/pig-farm-controller/internal/infra/repository"
2025-09-17 16:55:56 +08:00
)
2025-10-29 15:30:16 +08:00
type taskFactory struct {
logger *logs.Logger
sensorDataRepo repository.SensorDataRepository
deviceRepo repository.DeviceRepository
deviceService device.Service
}
2025-10-29 15:30:16 +08:00
func NewTaskFactory(
logger *logs.Logger,
sensorDataRepo repository.SensorDataRepository,
deviceRepo repository.DeviceRepository,
deviceService device.Service,
2025-11-02 18:16:44 +08:00
) plan.TaskFactory {
2025-10-29 15:30:16 +08:00
return &taskFactory{
logger: logger,
sensorDataRepo: sensorDataRepo,
deviceRepo: deviceRepo,
deviceService: deviceService,
}
}
2025-11-02 18:16:44 +08:00
func (t *taskFactory) Production(claimedLog *models.TaskExecutionLog) plan.Task {
2025-10-29 15:30:16 +08:00
switch claimedLog.Task.Type {
2025-09-17 16:55:56 +08:00
case models.TaskTypeWaiting:
2025-10-29 15:30:16 +08:00
return NewDelayTask(t.logger, claimedLog)
case models.TaskTypeReleaseFeedWeight:
return NewReleaseFeedWeightTask(claimedLog, t.sensorDataRepo, t.deviceRepo, t.deviceService, t.logger)
2025-10-29 16:37:05 +08:00
case models.TaskTypeFullCollection:
return NewFullCollectionTask(claimedLog, t.deviceRepo, t.deviceService, t.logger)
2025-09-17 16:55:56 +08:00
default:
2025-10-29 15:30:16 +08:00
// TODO 这里直接panic合适吗? 不过这个场景确实不该出现任何异常的任务类型
t.logger.Panicf("不支持的任务类型: %s", claimedLog.Task.Type)
panic("不支持的任务类型") // 显式panic防编译器报错
2025-09-17 16:55:56 +08:00
}
}