zhangqian
2023-11-25 8b88bcc370b0b2e22fbbf872c2c460fe2a208181
api/v1/task.go
@@ -108,7 +108,7 @@
   nowTs := time.Now().Unix()
   flagMap := make(map[int32]struct{}, 0)
   for _, task := range taskResponse.Tasks {
      if _, ok := flagMap[task.Channel]; !ok && !service.TaskFlagGet(task.Channel) && task.Procedure.StartTime <= nowTs {
      if _, ok := flagMap[task.Channel]; !ok && !service.TaskFlagGet(conf.Conf.CurrentDeviceID, task.Channel) && task.Procedure.StartTime <= nowTs {
         task.CanStarted = true
         flagMap[task.Channel] = struct{}{}
      }
@@ -153,14 +153,21 @@
   var processModel *model.ProcessModel
   if procedure.ProcessModelNumber != "" {
      processModel, err = service.GetProcessModelByNumber(procedure.ProcessModelNumber)
      if err != nil || processModel == nil || processModel.ParamsMap == nil {
         ctx.FailWithMsg(ecode.ParamsErr, "未获取到工艺参数,请在工艺模型库中上传!")
         return
      }
   } else {
      processModel, err = service.NewTaskService().GetProcessParams(procedure, order)
      if err != nil || processModel == nil || processModel.ParamsMap == nil {
   }
   if err != nil || processModel == nil || processModel.ParamsMap == nil {
      device, err := service.GetCurrentDevice()
      if err != nil {
         ctx.FailWithMsg(ecode.UnknownErr, err.Error())
         return
      }
      if device.NeedSetProcessParams {
         ctx.FailWithMsg(ecode.ParamsErr, "未获取到工艺参数,请在工艺模型库中上传!")
         return
      } else {
         ctx.OkWithDetailed(response.ProcessParamsResponse{})
         return
      }
   }
@@ -233,8 +240,8 @@
      return
   }
   service.TaskFlagUnset(procedure.Channel)
   service.TaskEndTimeSet(procedure.Channel, time.Now().Unix()) //设置工序运行结束时间
   service.TaskFlagUnset(conf.Conf.CurrentDeviceID, procedure.Channel)
   service.TaskEndTimeSet(conf.Conf.CurrentDeviceID, procedure.Channel, time.Now().Unix()) //设置工序运行结束时间
   ctx.Ok()
}
@@ -284,6 +291,7 @@
      ctx.FailWithMsg(ecode.DBErr, err.Error())
      return
   }
   var processModelNumber string
   if device.NeedSetProcessParams {
      processModel, err := taskService.GetProcessParams(procedure, order)
      if err != nil || processModel == nil || processModel.ParamsMap == nil {
@@ -295,6 +303,7 @@
         ctx.FailWithMsg(ecode.NeedConfirmedErr, "PLC请求失败,请检查PLC配置!")
         return
      }
      processModelNumber = processModel.Number
   }
   plcConfig.CurrentTryTimes = 0
@@ -304,7 +313,7 @@
      return
   }
   err = model.WithTransaction(func(db *gorm.DB) error {
      err = taskService.UpdateProcedureStatusAndChannel(db, params.ProcedureId, model.ProcedureStatusProcessing, procedure.Channel, processModel.Number)
      err = taskService.UpdateProcedureStatusAndChannel(db, params.ProcedureId, model.ProcedureStatusProcessing, procedure.Channel, processModelNumber)
      if err != nil {
         return err
      }
@@ -331,9 +340,9 @@
      return
   }
   service.TaskFlagSet(procedure.Channel, int(procedure.ID))
   service.TaskStartTimeSet(procedure.Channel, time.Now().Unix()) //设置工序运行开始时间
   service.TaskEndTimeSet(procedure.Channel, 0)                   //设置工序运行结束时间
   service.TaskFlagSet(conf.Conf.CurrentDeviceID, procedure.Channel, int(procedure.ID))
   service.TaskStartTimeSet(conf.Conf.CurrentDeviceID, procedure.Channel, time.Now().Unix()) //设置工序运行开始时间
   service.TaskEndTimeSet(conf.Conf.CurrentDeviceID, procedure.Channel, 0)                   //设置工序运行结束时间
   ctx.Ok()
}
@@ -492,7 +501,7 @@
   nowTs := time.Now().Unix()
   flagMap := make(map[int32]struct{}, 0)
   for _, task := range taskResponse.Tasks {
      if _, ok := flagMap[task.Channel]; !ok && !service.TaskFlagGet(task.Channel) && task.Procedure.StartTime <= nowTs {
      if _, ok := flagMap[task.Channel]; !ok && !service.TaskFlagGet(conf.Conf.CurrentDeviceID, task.Channel) && task.Procedure.StartTime <= nowTs {
         task.CanStarted = true
         flagMap[task.Channel] = struct{}{}
      }