|
123456789101112131415161718192021222324252627282930313233343536373839404142434445 |
- package task
-
- import (
- "fmt"
- "time"
-
- "gitlink.org.cn/cloudream/common/pkgs/logger"
- "gitlink.org.cn/cloudream/common/pkgs/task"
- "gitlink.org.cn/cloudream/storage/common/pkgs/ioswitch"
- )
-
- // TODO 临时使用Task来等待Plan执行进度
- type ExecuteIOPlan struct {
- PlanID ioswitch.PlanID
- Result ioswitch.PlanResult
- }
-
- func NewExecuteIOPlan(planID ioswitch.PlanID) *ExecuteIOPlan {
- return &ExecuteIOPlan{
- PlanID: planID,
- }
- }
-
- func (t *ExecuteIOPlan) Execute(task *task.Task[TaskContext], ctx TaskContext, complete CompleteFn) {
- log := logger.WithType[ExecuteIOPlan]("Task")
- log.Debugf("begin with %v", logger.FormatStruct(t))
- defer log.Debugf("end")
-
- ret, err := ctx.sw.ExecutePlan(t.PlanID)
- if err != nil {
- err := fmt.Errorf("executing io plan: %w", err)
- log.WithField("PlanID", t.PlanID).Warn(err.Error())
-
- complete(err, CompleteOption{
- RemovingDelay: time.Minute,
- })
- return
- }
-
- t.Result = ret
-
- complete(nil, CompleteOption{
- RemovingDelay: time.Minute,
- })
- }
|