From 08d8933d3fe66fb83f1e2e7e4038e62b3c5143e1 Mon Sep 17 00:00:00 2001
From: cpT <1@123>
Date: 星期四, 19 六月 2025 11:10:43 +0800
Subject: [PATCH] #改造

---
 src/main/java/com/zy/asrs/controller/OpenController.java |  260 ++++++++++++++++++++++++++++++++++++++++-----------
 1 files changed, 204 insertions(+), 56 deletions(-)

diff --git a/src/main/java/com/zy/asrs/controller/OpenController.java b/src/main/java/com/zy/asrs/controller/OpenController.java
index 0e360c4..9dfc007 100644
--- a/src/main/java/com/zy/asrs/controller/OpenController.java
+++ b/src/main/java/com/zy/asrs/controller/OpenController.java
@@ -8,13 +8,21 @@
 import com.core.common.R;
 import com.core.exception.CoolException;
 import com.zy.asrs.entity.*;
-import com.zy.asrs.entity.param.CarryParam;
-import com.zy.asrs.entity.param.TaskOverParam;
-import com.zy.asrs.entity.param.WMSAndAGVInterfaceParam;
-import com.zy.asrs.entity.param.TaskCreateParam;
+import com.zy.asrs.entity.param.*;
 import com.zy.asrs.service.*;
+import com.zy.asrs.service.impl.BasCrnErrorServiceImpl;
+import com.zy.asrs.service.impl.TaskWrkLogServiceImpl;
 import com.zy.asrs.utils.Utils;
 import com.zy.common.web.BaseController;
+import com.zy.core.CrnThread;
+import com.zy.core.cache.RgvStatusCache;
+import com.zy.core.cache.SlaveConnection;
+import com.zy.core.enums.SlaveType;
+import com.zy.core.model.CrnSlave;
+import com.zy.core.model.RgvSlave;
+import com.zy.core.model.protocol.CrnProtocol;
+import com.zy.core.model.protocol.RgvProtocol;
+import com.zy.core.properties.SlaveProperties;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.beans.factory.annotation.Value;
@@ -30,6 +38,8 @@
 @RequestMapping("/open")
 public class OpenController extends BaseController {
 
+    @Autowired
+    private SlaveProperties slaveProperties;
     @Autowired
     private OpenService openService;
     @Autowired
@@ -48,6 +58,10 @@
     private StaDescService staDescService;
     @Autowired
     private LocMastService locMastService;
+    @Autowired
+    private BasRgvErrService basRgvErrService;
+    @Autowired
+    private BasCrnErrorServiceImpl basCrnErrorService;
 
     @Value("${wms.url}")
     private String wmsUrl;
@@ -57,6 +71,9 @@
     public static final ArrayList<String> APP_KEY_LIST = new ArrayList<String>() {{
         add("ea1f0459efc02a79f046f982767939ae");
     }};
+    @Autowired
+    private TaskWrkLogServiceImpl taskWrkLogService;
+
     //agv浠诲姟瀹屾垚
     @PostMapping("/toAgvTaskOver")
     @AppAuth(memo = "agv浠诲姟瀹屾垚鎺ュ彛")
@@ -78,9 +95,10 @@
     }
 
     //鍒涘缓浠诲姟
-    @PostMapping("/taskCreate")
+    @PostMapping("/taskCreate2")
+    @AppAuth(memo = "WMS浠诲姟涓嬪彂")
     @Transactional
-    public R taskCreate(@RequestHeader String appkey,
+    public synchronized R taskCreate(@RequestHeader String appkey,
                           @RequestBody List<TaskCreateParam> param1,
                           HttpServletRequest request) {
         auth(appkey, param1, request);
@@ -91,15 +109,19 @@
                 if (Cools.isEmpty(param)) {
                     return R.parse(BaseRes.PARAM);
                 }
+
                 if (Cools.isEmpty(param.getTaskNo())) {
                     return R.error("浠诲姟鍙穂taskNo]涓嶈兘涓虹┖");
                 }
                 if (Cools.isEmpty(param.getIoType())) {
                     return R.error("浠诲姟绫诲瀷[ioType]涓嶈兘涓虹┖");
                 }
+                param.updateIoTyoe(param.getIoType());//涓埅涓嬪彂  1锛氬嚭搴擄紝2锛氱Щ搴� 3锛氬叆搴�   ====杞崲涓�====>  1锛氬叆搴擄紝2锛氬嚭搴擄紝3锛氱Щ搴�
+
                 if (Cools.isEmpty(param.getBarcode())) {
                     return R.error("鏉$爜[barcode]涓嶈兘涓虹┖");
                 }
+
                 String locNo=null;
                 if(param.getIoType()==1){
                     locNo=param.getTargetPoint();
@@ -154,43 +176,43 @@
         return R.ok().add(taskWrk);
     }
 
-    //鍙栨斁璐х敵璇�
-    @PostMapping("/pick/and/place/v1")
-    @AppAuth(memo = "agv鍙栨斁璐х敵璇�")
-    public R getAgvPickAndPlaceV1(@RequestHeader String appkey,
-                            @RequestBody TaskOverParam param,
-                            HttpServletRequest request){
-        auth(appkey, param, request);
-        if (Cools.isEmpty(param)) {
-            return R.parse(BaseRes.PARAM);
-        }
-        if (Cools.isEmpty(param.getStaNo())){
-            return R.error("鐮佸ご[staNo]涓嶈兘涓虹┖");
-        }
-        if (Cools.isEmpty(param.getType())){
-            return R.error("绫诲瀷[type]涓嶈兘涓虹┖");
-        }
-        return openService.getAgvPickAndPlaceV1(param);
-    }
+//    //鍙栨斁璐х敵璇�
+//    @PostMapping("/pick/and/place/v1")
+//    @AppAuth(memo = "agv鍙栨斁璐х敵璇�")
+//    public R getAgvPickAndPlaceV1(@RequestHeader String appkey,
+//                            @RequestBody TaskOverParam param,
+//                            HttpServletRequest request){
+//        auth(appkey, param, request);
+//        if (Cools.isEmpty(param)) {
+//            return R.parse(BaseRes.PARAM);
+//        }
+//        if (Cools.isEmpty(param.getStaNo())){
+//            return R.error("鐮佸ご[staNo]涓嶈兘涓虹┖");
+//        }
+//        if (Cools.isEmpty(param.getType())){
+//            return R.error("绫诲瀷[type]涓嶈兘涓虹┖");
+//        }
+//        return openService.getAgvPickAndPlaceV1(param);
+//    }
 
-    //鍙栨斁璐у畬鎴愬弽棣�
-    @PostMapping("/pick/and/place/v2")
-    @AppAuth(memo = "agv鍙栨斁璐у畬鎴愬弽棣�")
-    public R getAgvPickAndPlaceV2(@RequestHeader String appkey,
-                                  @RequestBody TaskOverParam param,
-                                  HttpServletRequest request){
-        auth(appkey, param, request);
-        if (Cools.isEmpty(param)) {
-            return R.parse(BaseRes.PARAM);
-        }
-        if (Cools.isEmpty(param.getStaNo())){
-            return R.error("鐮佸ご[staNo]涓嶈兘涓虹┖");
-        }
-        if (Cools.isEmpty(param.getType())){
-            return R.error("绫诲瀷[type]涓嶈兘涓虹┖");
-        }
-        return openService.getAgvPickAndPlaceV2(param);
-    }
+//    //鍙栨斁璐у畬鎴愬弽棣�
+//    @PostMapping("/pick/and/place/v2")
+//    @AppAuth(memo = "agv鍙栨斁璐у畬鎴愬弽棣�")
+//    public R getAgvPickAndPlaceV2(@RequestHeader String appkey,
+//                                  @RequestBody TaskOverParam param,
+//                                  HttpServletRequest request){
+//        auth(appkey, param, request);
+//        if (Cools.isEmpty(param)) {
+//            return R.parse(BaseRes.PARAM);
+//        }
+//        if (Cools.isEmpty(param.getStaNo())){
+//            return R.error("鐮佸ご[staNo]涓嶈兘涓虹┖");
+//        }
+//        if (Cools.isEmpty(param.getType())){
+//            return R.error("绫诲瀷[type]涓嶈兘涓虹┖");
+//        }
+//        return openService.getAgvPickAndPlaceV2(param);
+//    }
 
     //鏌ヨ浠诲姟鎸囦护闆嗗悎
     @GetMapping("/queryTaskCommand")
@@ -313,15 +335,18 @@
     }
 
     //浠诲姟涓嬪彂鎺ュ彛
-    @PostMapping("/outboundTaskSend")
+//    @PostMapping("/outboundTaskSend")
+    @PostMapping("/taskCreate")
+    @AppAuth(memo = "浠诲姟涓嬪彂鎺ュ彛")
     @Transactional
     public R outboundTaskSend(@RequestHeader String appkey,
-                              @RequestBody List<CarryParam> params,
+                              @RequestBody List<CarryParam> params,//涓埅涓嬪彂  1锛氬嚭搴擄紝2锛氱Щ搴� 3锛氬叆搴�
                               HttpServletRequest request) {
-        //auth(appkey, params, request);
-        List<WMSAndAGVInterfaceParam> params1 =new ArrayList<>();
+        auth(appkey, params, request);
+//        List<WMSAndAGVInterfaceParam> params1 =new ArrayList<>();
         for (CarryParam param:params){
-
+            param.updateIoTyoe(param.getIoType());//涓埅涓嬪彂  1锛氬嚭搴擄紝2锛氱Щ搴� 3锛氬叆搴�   ====杞崲涓�====>  1锛氬叆搴擄紝2锛氬嚭搴擄紝3锛氱Щ搴�
+            param.updateLocNo();
             if (Cools.isEmpty(param)){
                 return R.error("鍙傛暟涓虹┖锛�");
             } else if (Cools.isEmpty(param.getTaskNo())){
@@ -344,14 +369,32 @@
 //                }
 //            }
 
-            LocMast locMast = locMastService.selectByLocNo(param.getStartPoint());
+
+            String locNo=null;
+            if(param.getIoType()==1){
+                locNo=param.getTargetPoint();
+            }else{
+                locNo=param.getStartPoint();
+            }
+            LocMast locMast = locMastService.selectByLocNo(locNo);
             if(Cools.isEmpty(locMast)){
                 return R.error("鍒濆搴撲綅鏃犳硶鎵惧埌");
             }
 
             R r = null;
 
-            if(param.getIoType() == 2){
+            if(param.getIoType() == 1){
+                //鍏ュ簱浠诲姟鍒涘缓
+                StaDesc staDesc = staDescService.selectOne(new EntityWrapper<StaDesc>()
+                        .eq("type_no",1)
+                        .eq("crn_no",locMast.getCrnNo())
+                        .eq("stn_no",param.getStartPoint()));
+                if(Cools.isEmpty(staDesc)){
+                    return R.error("鍏ュ簱璺姴涓嶅瓨鍦�");
+                }
+                r = openService.taskCreate(new TaskCreateParam(param,staDesc.getCrnNo(),staDesc.getCrnStn()));
+
+            }else if(param.getIoType() == 2){
                 //鍑哄簱浠诲姟鍒涘缓
                 StaDesc staDesc = staDescService.selectOne(new EntityWrapper<StaDesc>()
                         .eq("type_no",2)
@@ -360,8 +403,15 @@
                 if(Cools.isEmpty(staDesc)){
                     return R.error("鍑哄簱璺姴涓嶅瓨鍦�");
                 }
-                r = openService.taskCreate(new TaskCreateParam(param,staDesc.getCrnNo()));
+                r = openService.taskCreate(new TaskCreateParam(param,staDesc.getCrnNo(),staDesc.getStnNo()));
             }else if (param.getIoType() == 3){
+                LocMast locMast2 = locMastService.selectByLocNo(param.getTargetPoint());
+                if(Cools.isEmpty(locMast2)){
+                    return R.error("鐩爣搴撲綅鏃犳硶鎵惧埌");
+                }
+                if (!locMast2.getCrnNo().equals(locMast.getCrnNo())){
+                    return R.error("璧峰搴撲綅涓庣洰鏍囧簱浣嶄笉鍐嶅悓涓�宸烽亾");
+                }
                 //绉诲簱浠诲姟鍒涘缓
                 r = openService.taskCreate(new TaskCreateParam(param,locMast.getCrnNo()));
             }
@@ -383,9 +433,10 @@
     //浠诲姟鍙栨秷鎺ュ彛
     @PostMapping("/taskCancel")
     public R taskCancel(@RequestHeader String appkey,
-                               @RequestBody WMSAndAGVInterfaceParam param,
+                               @RequestBody WMSAndAGVInterfaceParam param,//涓埅涓嬪彂  1锛氬嚭搴擄紝2锛氱Щ搴� 3锛氬叆搴�    1锛氬彇娑�  2 瀹屾垚
                                HttpServletRequest request) {
         auth(appkey, param, request);
+//        param.updateTaskStatus(param.getTaskStatus());
         if (Cools.isEmpty(param)){
             return R.error("鍙傛暟涓虹┖锛�");
         } else if (Cools.isEmpty(param.getTaskNo())){
@@ -443,14 +494,111 @@
         auth(appkey, "璁惧鐘舵�佹煡璇㈡帴鍙�", request);
         List<BasDevp> basDevps = basDevpService.selectList(new EntityWrapper<>());
         List<Object> list = new ArrayList<>();
+        WcsStatusResponseModel wcsStatusResponseModel = new WcsStatusResponseModel();
         for (BasDevp basDevp:basDevps){
-            list.add(basDevp);
+            BasDevpWmsParam basDevpWmsParam = new BasDevpWmsParam();
+            basDevpWmsParam.setDevNo(basDevp.getDevNo());
+            basDevpWmsParam.setWrkNo(basDevp.getWrkNo().longValue());
+            basDevpWmsParam.setAutoing(basDevp.getAutoing());
+            basDevpWmsParam.setLoading(basDevp.getLoading());
+            basDevpWmsParam.setInEnable(basDevp.getInEnable());
+            basDevpWmsParam.setOutEnable(basDevp.getOutEnable());
+            basDevpWmsParam.setDevErr(basDevp.getStaErr().longValue());
+            basDevpWmsParam.setDevErrM(basDevpWmsParam.getDevErr$());
+//            list.add(basDevpWmsParam);
+            wcsStatusResponseModel.getChainList().add(basDevpWmsParam);
         }
-        List<BasCrnp> basCrnps = basCrnpService.selectList(new EntityWrapper<>());
-        for (BasCrnp basCrnp:basCrnps){
-            list.add(basCrnp);
+        List<BasCrnpWmsParam> basCrnpWmsParamList = new ArrayList<>();
+        for (CrnSlave crn : slaveProperties.getCrn()) {
+            // 鑾峰彇鍫嗗灈鏈轰俊鎭�
+            CrnThread crnThread = (CrnThread) SlaveConnection.get(SlaveType.Crn, crn.getId());
+            CrnProtocol crnProtocol = crnThread.getCrnProtocol();
+            if (crnProtocol == null) { continue; }
+            BasCrnp basCrnp = basCrnpService.selectById(crn.getId());
+            if (basCrnp == null) {
+                log.error("{}鍙峰爢鍨涙満灏氭湭鍦ㄦ暟鎹簱杩涜缁存姢锛�", crn.getId());
+                continue;
+            }
+            BasCrnpWmsParam basCrnpWmsParam = new BasCrnpWmsParam();
+            basCrnpWmsParam.sync(basCrnp);
+
+            basCrnpWmsParam.setCrnNoH(crnProtocol.getLaneNo());
+            basCrnpWmsParam.setCrnSts(crnProtocol.getStatus().intValue());
+
+            try{
+                BasCrnError basCrnError = basCrnErrorService.selectById(crnProtocol.getAlarm());
+                basCrnpWmsParam.setCrnErrM(basCrnError.getErrName());
+            } catch (Exception e){
+                basCrnpWmsParam.setCrnErrM("鏈煡寮傚父");
+            }
+            if (crnProtocol.getMode()!=3){
+                basCrnpWmsParam.setCrnErr(999L);
+                basCrnpWmsParam.setCrnErrM("闈炶嚜鍔紒锛侊紒");
+            }
+            basCrnpWmsParamList.add(basCrnpWmsParam);
+
+//            list.add(basCrnpWmsParam);
         }
-        return R.ok(list);
+        wcsStatusResponseModel.setPilingCarList(basCrnpWmsParamList);
+        for (RgvSlave rgvSlave : slaveProperties.getRgv()) {
+            RgvProtocol rgvStatus = RgvStatusCache.getRgvStatus(rgvSlave.getId());
+            if (Cools.isEmpty(rgvStatus)){
+                continue;
+            }
+            BasRgvWmsParam basRgvWmsParam = new BasRgvWmsParam();
+            basRgvWmsParam.setWrkNo(rgvStatus.getTaskNo());
+            basRgvWmsParam.setCrnSts(rgvStatus.getStatus().intValue());
+            basRgvWmsParam.setStatusType(rgvStatus.getStatusType().desc);
+            basRgvWmsParam.setSteNo(rgvSlave.getId());
+            basRgvWmsParam.setSteErr(rgvStatus.getAlarm().longValue());
+            basRgvWmsParam.setSteErrM(rgvStatus.getAlarmM());
+//            try{
+//                BasRgvErr basRgvErr = basRgvErrService.selectById((long)rgvStatus.getAlarm$());
+//
+//                basRgvWmsParam.setSteErrM(basRgvErr.getErrName());
+//            } catch (Exception e){
+//                basRgvWmsParam.setSteErrM("鏈煡寮傚父");
+//            }
+            if (rgvStatus.getMode()!=1){
+                basRgvWmsParam.setSteErr(999L);
+                basRgvWmsParam.setSteErrM("闈炶嚜鍔紒锛侊紒");
+            }
+//            list.add(basRgvWmsParam);
+            wcsStatusResponseModel.getRgvList().add(basRgvWmsParam);
+
+        }
+//        List<BasCrnp> basCrnps = basCrnpService.selectList(new EntityWrapper<>());
+//        for (BasCrnp basCrnp:basCrnps){
+//            list.add(basCrnp);
+//        }
+        return R.ok(wcsStatusResponseModel);
+    }
+
+    //璁惧鐘舵�佹煡璇㈡帴鍙�
+    @PostMapping("/taskWrkLogs")
+    @Transactional
+    public R taskWrkLogs(@RequestHeader String appkey,
+                          HttpServletRequest request) {
+        List<TaskWrkLog> taskWrkLogs = taskWrkLogService.selectList(new EntityWrapper<>());
+        return R.ok(taskWrkLogs);
+    }
+
+    //璁惧鐘舵�佹煡璇㈡帴鍙�
+    @PostMapping("/error")
+    @Transactional
+    public R errorRgv(@RequestHeader String appkey,
+                      HttpServletRequest request) {
+        List<TaskWrkLog> taskWrkLogs = taskWrkLogService.selectList(new EntityWrapper<>());
+        return R.ok(taskWrkLogs);
+    }
+
+    //璁惧鐘舵�佹煡璇㈡帴鍙�
+    @PostMapping("/wrkNo/wmsTaskNo")
+    @Transactional
+    public R wrkNoWmsTaskNo(@RequestHeader String appkey,
+                      HttpServletRequest request) {
+        List<TaskWrkLog> taskWrkLogs = taskWrkLogService.selectList(new EntityWrapper<>());
+        return R.ok(taskWrkLogs);
     }
 
 

--
Gitblit v1.9.1