From 184980deb3f854a98eb112e7998875113ebbba9a Mon Sep 17 00:00:00 2001
From: lsh <lsh@163.com>
Date: 星期一, 28 四月 2025 17:10:39 +0800
Subject: [PATCH] *

---
 src/main/java/com/zy/asrs/controller/OpenController.java |  137 ++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 120 insertions(+), 17 deletions(-)

diff --git a/src/main/java/com/zy/asrs/controller/OpenController.java b/src/main/java/com/zy/asrs/controller/OpenController.java
index 7af2501..fbc8ff3 100644
--- a/src/main/java/com/zy/asrs/controller/OpenController.java
+++ b/src/main/java/com/zy/asrs/controller/OpenController.java
@@ -8,13 +8,20 @@
 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.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 +37,8 @@
 @RequestMapping("/open")
 public class OpenController extends BaseController {
 
+    @Autowired
+    private SlaveProperties slaveProperties;
     @Autowired
     private OpenService openService;
     @Autowired
@@ -48,6 +57,10 @@
     private StaDescService staDescService;
     @Autowired
     private LocMastService locMastService;
+    @Autowired
+    private BasRgvErrService basRgvErrService;
+    @Autowired
+    private BasCrnErrorServiceImpl basCrnErrorService;
 
     @Value("${wms.url}")
     private String wmsUrl;
@@ -57,6 +70,7 @@
     public static final ArrayList<String> APP_KEY_LIST = new ArrayList<String>() {{
         add("ea1f0459efc02a79f046f982767939ae");
     }};
+
     //agv浠诲姟瀹屾垚
     @PostMapping("/toAgvTaskOver")
     @AppAuth(memo = "agv浠诲姟瀹屾垚鎺ュ彛")
@@ -78,9 +92,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 +106,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();
@@ -313,14 +332,17 @@
     }
 
     //浠诲姟涓嬪彂鎺ュ彛
-    @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锛氱Щ搴�
 
             if (Cools.isEmpty(param)){
                 return R.error("鍙傛暟涓虹┖锛�");
@@ -344,14 +366,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()));
+
+            }else if(param.getIoType() == 2){
                 //鍑哄簱浠诲姟鍒涘缓
                 StaDesc staDesc = staDescService.selectOne(new EntityWrapper<StaDesc>()
                         .eq("type_no",2)
@@ -362,6 +402,13 @@
                 }
                 r = openService.taskCreate(new TaskCreateParam(param,staDesc.getCrnNo()));
             }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 +430,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())){
@@ -444,12 +492,67 @@
         List<BasDevp> basDevps = basDevpService.selectList(new EntityWrapper<>());
         List<Object> list = new ArrayList<>();
         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);
         }
-        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());
+            basCrnpWmsParamList.add(basCrnpWmsParam);
+
+            try{
+                BasCrnError basCrnError = basCrnErrorService.selectById(basCrnp.getCrnErr());
+                basCrnpWmsParam.setCrnErrM(basCrnError.getErrName());
+            } catch (Exception e){
+                basCrnpWmsParam.setCrnErrM("鏈煡寮傚父");
+            }
+
+            list.add(basCrnpWmsParam);
         }
+        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());
+            try{
+                BasRgvErr basRgvErr = basRgvErrService.selectById(rgvStatus.getAlarm().longValue());
+
+                basRgvWmsParam.setSteErrM(basRgvErr.getErrName());
+            } catch (Exception e){
+                basRgvWmsParam.setSteErrM("鏈煡寮傚父");
+            }
+            list.add(basRgvWmsParam);
+        }
+//        List<BasCrnp> basCrnps = basCrnpService.selectList(new EntityWrapper<>());
+//        for (BasCrnp basCrnp:basCrnps){
+//            list.add(basCrnp);
+//        }
         return R.ok(list);
     }
 

--
Gitblit v1.9.1