Browse Source

优化逻辑

zhifei 1 year ago
parent
commit
bc1b0f629a

+ 3 - 6
ruoyi-admin/src/main/java/com/ruoyi/web/controller/warewms/tianao/TianaoApiContoller.java

@@ -34,17 +34,14 @@ public class TianaoApiContoller extends BaseController {
 
     /**
      * 任务管理接口
-     * TODO To志飞:
-     * 1,更新任务目标库位:一般只有队列等待的任务才可以修改起始/目标库位,本项目中(开始~取货完成)目标库位修改需先发m消息给TS,然后TS会请求新增目标点位
-     * 2,新增、更新任务时,判断目标库位是否有货(base_location_info.is_empty),有货则返回失败;
-     * 3,任务下发去重,lcsTaskId若我方任务中已存在,则返回失败;(Redis锁解决)
-     * 4,任务队列:目前系统已实现,WMS下发任务后可进入wcs_task任务池。但暂不支持输送线的任务池。后面优化
      */
     @PostMapping(value = "/taskManage")
-    public JSONObject addTestTask(@Validated @RequestBody TianaoTask tianaoTask) {
+    public JSONObject taskManage(@Validated @RequestBody TianaoTask tianaoTask) {
+        //新增任务
         if ("0".equals(tianaoTask.getTaskType())){
             return  tianaoService.addTask(tianaoTask);
         }
+        //修改任务目标卸货点
         if ("5".equals(tianaoTask.getTaskType())){
             return  tianaoService.updateTask(tianaoTask);
         }

+ 4 - 1
warewms-base/src/main/java/com/ruoyi/base/service/impl/BaseLocationInfoServiceImpl.java

@@ -425,10 +425,13 @@ public class BaseLocationInfoServiceImpl implements IBaseLocationInfoService {
 
     @Override
     public AjaxResult syncLocStatus(List<BaseLocationInfo> locationInfoList) {
+        ArrayList<String> msg = new ArrayList<>();
         try {
             for (BaseLocationInfo baseLocationInfo : locationInfoList) {
                 baseLocationInfo.setUpdateTime(DateUtils.getNowDate());
-                //TODO To志飞:更新时间、更新人(WMS),另外判断传入内容的合法性
+                if (!"N".equals(baseLocationInfo.getIsEmpty()) && !"Y".equals(baseLocationInfo.getIsEmpty())){
+                    msg.add(baseLocationInfo.getLocationNo());
+                }
                 baseLocationInfoMapper.updateAddress(baseLocationInfo);
             }
         }catch (Exception e){

+ 13 - 3
warewms-tianao/src/main/java/com/ruoyi/tianao/service/impl/TianaoServiceImpl.java

@@ -14,6 +14,7 @@ import com.ruoyi.base.constant.Constant;
 import com.ruoyi.base.domain.BaseLocationInfo;
 import com.ruoyi.base.service.IBaseLocationInfoService;
 import com.ruoyi.common.core.domain.AjaxResult;
+import com.ruoyi.common.core.redis.RedisCache;
 import com.ruoyi.common.exception.base.BaseException;
 import com.ruoyi.common.utils.DateUtils;
 import com.ruoyi.common.utils.StringUtils;
@@ -29,6 +30,7 @@ import org.springframework.transaction.annotation.Transactional;
 import java.util.Arrays;
 import java.util.Date;
 import java.util.List;
+import java.util.concurrent.TimeUnit;
 
 /**
  * Created with IntelliJ IDEA.
@@ -65,10 +67,15 @@ public class TianaoServiceImpl implements TianaoService {
 
     private final List<Long> statusLsit = Arrays.asList(11L,12L,5L,6L,7L);
 
+    @Autowired
+    private RedisCache redisCache;
+
 
     @Override
     public JSONObject addTask(TianaoTask tianaoTask) {
-
+        if (redisCache.checkIsLock(tianaoTask.getLcsTaskId())){
+            return returnJson("e0001","任务Id已重复","fail");
+        }
         if (tianaoTask.getFromLocation().equals(tianaoTask.getToLocation())) {
             throw new BaseException("起始库位与目标库位不能相同");
         }
@@ -96,6 +103,7 @@ public class TianaoServiceImpl implements TianaoService {
         wcsTask.setExt7(tianaoTask.getLcsTaskId());
         wcsTask.setExt8(tianaoTask.getContainerNo());
         if (wcsTaskService.insertWcsTask(wcsTask) ==1){
+            redisCache.setCacheObject(tianaoTask.getLcsTaskId(),tianaoTask.getLcsTaskId(),30,TimeUnit.SECONDS);
             return returnJson("00000","任务发起成功","ok");
         }
         return returnJson("e0001","任务发起出错","fail");
@@ -124,6 +132,9 @@ public class TianaoServiceImpl implements TianaoService {
         if (statusLsit.contains(wcsTask.getState())){
             return returnJson("e0001","当前任务无法修改卸货点","fail");
         }
+        if("N".equals( iBaseLocationInfoService.selectBaseLocationInfoByIdOrNo(tianaoTask.getToLocation(), Constant.WAREHOUSE_ID).getIsEmpty())){
+            return returnJson("e0001","目标卸货点不为空","fail");
+        }
         if (wcsTask.getState()!=9) {
             try {
                 AmsTask amsTask = new AmsTask();
@@ -131,11 +142,10 @@ public class TianaoServiceImpl implements TianaoService {
                 amsTask = amsTaskService.selectAmsTaskByModel(amsTask);
                 Integer carNo = Integer.getInteger(wcsTask.getAgvNo());
                 if (ObjectUtil.isNotNull(carNo)){
-                    //TODO To志飞:这一步是做什么的?
+                    //修改AGV任务目标地址
                     statusUpdateService.confirmAnalysis(wcsTask.getTaskNo(), amsTask.getAciIndex(),carNo
                             , "02", tianaoTask.getToLocation());
                     Thread.sleep(1000);
-                    //TODO To志飞:这一步是做什么的?
                     statusUpdateService.confirmAnalysis(wcsTask.getTaskNo(),  amsTask.getAciIndex(), carNo
                             , "10", "1");
                     Thread.sleep(1000);