From 882d2ee2d9a35bf02e5fbb11a79c3abffe9cfe61 Mon Sep 17 00:00:00 2001
From: zjj <3272660260@qq.com>
Date: 星期四, 21 三月 2024 16:43:38 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/asrs/controller/CrnController.java |  206 ++++++++++++++++++++++++++++++++++++++-------------
 1 files changed, 154 insertions(+), 52 deletions(-)

diff --git a/src/main/java/com/zy/asrs/controller/CrnController.java b/src/main/java/com/zy/asrs/controller/CrnController.java
index eb9a0dd..b719ac1 100644
--- a/src/main/java/com/zy/asrs/controller/CrnController.java
+++ b/src/main/java/com/zy/asrs/controller/CrnController.java
@@ -1,6 +1,7 @@
 package com.zy.asrs.controller;
 
 import com.alibaba.fastjson.JSON;
+import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.mapper.EntityWrapper;
 import com.core.annotations.ManagerAuth;
 import com.core.common.Cools;
@@ -15,12 +16,15 @@
 import com.zy.asrs.domain.vo.CrnStateTableVo;
 import com.zy.asrs.entity.*;
 import com.zy.asrs.mapper.BasCrnErrorMapper;
+import com.zy.asrs.service.ApiLogService;
 import com.zy.asrs.service.BasCrnpService;
 import com.zy.asrs.service.LocMastService;
 import com.zy.asrs.service.WrkMastService;
 import com.zy.asrs.service.impl.MainServiceImpl;
 import com.zy.asrs.utils.CommandUtils;
+import com.zy.asrs.utils.Utils;
 import com.zy.asrs.utils.VersionUtils;
+import com.zy.common.utils.HttpHandler;
 import com.zy.core.CrnThread;
 import com.zy.core.cache.MessageQueue;
 import com.zy.core.cache.OutputQueue;
@@ -35,6 +39,7 @@
 import com.zy.core.properties.SlaveProperties;
 import com.zy.core.properties.SystemProperties;
 import lombok.extern.slf4j.Slf4j;
+import org.hibernate.validator.internal.engine.messageinterpolation.parser.ELState;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.beans.factory.annotation.Value;
 import org.springframework.web.bind.annotation.*;
@@ -59,7 +64,8 @@
     private String movePath;
 
 
-
+    @Autowired
+    private ApiLogService apiLogService;
     @Autowired
     private SlaveProperties slaveProperties;
     @Autowired
@@ -376,10 +382,10 @@
     @ManagerAuth(memo = "鍏ュ簱")
     @PostMapping("/crn/operator/put")
     public R crnPut(CrnOperatorParam param){
-        // 绯荤粺杩愯鐘舵�佸垽鏂�
-        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
-            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
-        }
+//        // 绯荤粺杩愯鐘舵�佸垽鏂�
+//        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
+//            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
+//        }
         CrnCommand command = new CrnCommand();
         command.setCrnNo(param.getCrnNo()); // 鍫嗗灈鏈虹紪鍙�
         command.setTaskNo((short) 0); // 宸ヤ綔鍙�
@@ -392,6 +398,12 @@
         command.setDestinationPosX(param.getBay());     // 鐩爣搴撲綅鍒�
         command.setDestinationPosY(param.getLev());     // 鐩爣搴撲綅灞�
         command.setCommand((short)1);
+        String locNo =String.format("%2d",param.getRow()) + String.format("%3d",param.getBay()) + String.format("%2d",param.getLev());
+        String startlocNo =String.format("%2d",param.getSourceRow()) + String.format("%3d",param.getSourceBay()) + String.format("%2d",param.getSourceLev());
+        boolean wmsLocStatus = toWmsLocStatus(1, startlocNo, locNo, param.getBarcode(), param.getBarcodeType(), param.getEmptyContainer());
+        if (!wmsLocStatus){
+            return R.error("搴撲綅鏇存柊澶辫触");
+        }
         return crnControl(command)?R.ok():R.error();
     }
 
@@ -399,9 +411,9 @@
     @PostMapping("/crn/operator/take")
     public R crnTake(CrnOperatorParam param){
         // 绯荤粺杩愯鐘舵�佸垽鏂�
-        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
-            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
-        }
+//        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
+//            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
+//        }
         CrnCommand command = new CrnCommand();
         command.setCrnNo(param.getCrnNo()); // 鍫嗗灈鏈虹紪鍙�
         command.setTaskNo((short) 0); // 宸ヤ綔鍙�
@@ -413,6 +425,12 @@
         command.setDestinationPosZ(param.getRow());     // 鐩爣搴撲綅鎺�
         command.setDestinationPosX(param.getBay());     // 鐩爣搴撲綅鍒�
         command.setDestinationPosY(param.getLev());     // 鐩爣搴撲綅灞�
+        String locNo =String.format("%2d",param.getRow()) + String.format("%3d",param.getBay()) + String.format("%2d",param.getLev());
+        String startlocNo =String.format("%2d",param.getSourceRow()) + String.format("%3d",param.getSourceBay()) + String.format("%2d",param.getSourceLev());
+        boolean wmsLocStatus = toWmsLocStatus(2, startlocNo, locNo, param.getBarcode(), param.getBarcodeType(), param.getEmptyContainer());
+        if (!wmsLocStatus){
+            return R.error("搴撲綅鏇存柊澶辫触");
+        }
         return crnControl(command)?R.ok():R.error();
     }
 
@@ -420,9 +438,9 @@
     @PostMapping("/crn/operator/stockMove")
     public R crnStockMove(CrnOperatorParam param){
         // 绯荤粺杩愯鐘舵�佸垽鏂�
-        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
-            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
-        }
+//        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
+//            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
+//        }
         CrnCommand command = new CrnCommand();
         command.setCrnNo(param.getCrnNo()); // 鍫嗗灈鏈虹紪鍙�
         command.setTaskNo((short) 0); // 宸ヤ綔鍙�
@@ -440,6 +458,12 @@
         LocMast loc = locMastService.selectOne(new EntityWrapper<LocMast>().eq("row1", command.getDestinationPosX())
                 .eq("bay1", command.getDestinationPosY()).eq("lev1", command.getDestinationPosZ()));
         VersionUtils.locMoveCheckLocType(sourceLoc, loc);
+        String locNo =String.format("%2d",param.getRow()) + String.format("%3d",param.getBay()) + String.format("%2d",param.getLev());
+        String startlocNo =String.format("%2d",param.getSourceRow()) + String.format("%3d",param.getSourceBay()) + String.format("%2d",param.getSourceLev());
+        boolean wmsLocStatus = toWmsLocStatus(3, startlocNo, locNo, param.getBarcode(), param.getBarcodeType(), param.getEmptyContainer());
+        if (!wmsLocStatus){
+            return R.error("搴撲綅鏇存柊澶辫触");
+        }
         return crnControl(command)?R.ok():R.error();
     }
 
@@ -447,9 +471,9 @@
     @PostMapping("/crn/operator/siteMove")
     public R crnSiteMove(CrnOperatorParam param){
         // 绯荤粺杩愯鐘舵�佸垽鏂�
-        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
-            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
-        }
+//        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
+//            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
+//        }
         CrnCommand command = new CrnCommand();
         command.setCrnNo(param.getCrnNo()); // 鍫嗗灈鏈虹紪鍙�
         command.setTaskNo((short) 0); // 宸ヤ綔鍙�
@@ -468,9 +492,9 @@
     @PostMapping("/crn/operator/bacOrigin")
     public R crnBacOrigin(CrnOperatorParam param){
         // 绯荤粺杩愯鐘舵�佸垽鏂�
-        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
-            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
-        }
+//        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
+//            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
+//        }
         CrnCommand command = new CrnCommand();
         command.setCrnNo(param.getCrnNo()); // 鍫嗗灈鏈虹紪鍙�
         command.setTaskNo((short) 0); // 宸ヤ綔鍙�
@@ -489,9 +513,9 @@
     @PostMapping("/crn/operator/reverseOrigin")
     public R reverseOrigin(CrnOperatorParam param){
         // 绯荤粺杩愯鐘舵�佸垽鏂�
-        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
-            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
-        }
+//        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
+//            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
+//        }
         CrnCommand command = new CrnCommand();
         command.setCrnNo(param.getCrnNo()); // 鍫嗗灈鏈虹紪鍙�
         command.setTaskNo((short) 0); // 宸ヤ綔鍙�
@@ -528,9 +552,9 @@
     @PostMapping("/crn/operator/taskComplete")
     public R crnTaskComplete(CrnOperatorParam param){
         // 绯荤粺杩愯鐘舵�佸垽鏂�
-        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
-            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
-        }
+//        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
+//            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
+//        }
         CrnCommand command = new CrnCommand();
         command.setCrnNo(param.getCrnNo()); // 鍫嗗灈鏈虹紪鍙�
         command.setTaskNo((short) 0); // 宸ヤ綔鍙�
@@ -561,9 +585,9 @@
     @PostMapping("/crn/operator/clearCommand")
     public R crnClearCommand(CrnOperatorParam param){
         // 绯荤粺杩愯鐘舵�佸垽鏂�
-        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
-            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
-        }
+//        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
+//            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
+//        }
         if (param.getCrnNo() == null) {
             throw new CoolException("璇烽�夋嫨鍫嗗灈鏈�");
         }
@@ -585,9 +609,9 @@
     @PostMapping("/crn/operator/handleReset")
     public R handleReset(CrnOperatorParam param) throws Exception {
         // 绯荤粺杩愯鐘舵�佸垽鏂�
-        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
-            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
-        }
+//        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
+//            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
+//        }
         if (param.getCrnNo() == null) {
             throw new CoolException("璇烽�夋嫨鍫嗗灈鏈�");
         }
@@ -610,7 +634,7 @@
                 crnCommand.setCommand((short) 0);  // 浠诲姟瀹屾垚纭浣�
                 // 寤舵椂鍙戦��
                 Thread.sleep(1000L);
-                if (CommandUtils.offer(SlaveType.Crn, crn.getId(), new Task(2, crnCommand), false)) {
+                if (CommandUtils.offer(SlaveType.Crn, crn.getId(), new Task(5, crnCommand), false)) {
                     return R.ok();
                 } else {
                     throw new CoolException("鍛戒护涓嬪彂澶辫触");
@@ -627,9 +651,9 @@
     @PostMapping("/crn/operator/auto")
     public R crnAuto(CrnOperatorParam param){
         // 绯荤粺杩愯鐘舵�佸垽鏂�
-        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
-            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
-        }
+//        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
+//            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
+//        }
         short[] array = new short[9];
         CrnCommand command = new CrnCommand();
         command.setCrnNo(param.getCrnNo()); // 鍫嗗灈鏈虹紪鍙�
@@ -642,9 +666,9 @@
     @PostMapping("/crn/operator/semiAutomatic")
     public R crnsemiAutomatic(CrnOperatorParam param){
         // 绯荤粺杩愯鐘舵�佸垽鏂�
-        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
-            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
-        }
+//        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
+//            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
+//        }
         short[] array = new short[9];
         CrnCommand command = new CrnCommand();
         command.setCrnNo(param.getCrnNo()); // 鍫嗗灈鏈虹紪鍙�
@@ -657,9 +681,9 @@
     @PostMapping("/crn/operator/hand")
     public R onlineWrk1(CrnOperatorParam param){
         // 绯荤粺杩愯鐘舵�佸垽鏂�
-        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
-            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
-        }
+//        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
+//            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
+//        }
         short[] array = new short[9];
         CrnCommand command = new CrnCommand();
         command.setCrnNo(param.getCrnNo()); // 鍫嗗灈鏈虹紪鍙�
@@ -672,9 +696,9 @@
     @PostMapping("/crn/operator/onlineWrk1")
     public R onlineWrk2(CrnOperatorParam param){
         // 绯荤粺杩愯鐘舵�佸垽鏂�
-        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
-            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
-        }
+//        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
+//            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
+//        }
         short[] array = new short[9];
         CrnCommand command = new CrnCommand();
         command.setCrnNo(param.getCrnNo()); // 鍫嗗灈鏈虹紪鍙�
@@ -687,9 +711,9 @@
     @PostMapping("/crn/operator/onlineWrk2")
     public R onlineWrk3(CrnOperatorParam param){
         // 绯荤粺杩愯鐘舵�佸垽鏂�
-        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
-            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
-        }
+//        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
+//            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
+//        }
         short[] array = new short[9];
         CrnCommand command = new CrnCommand();
         command.setCrnNo(param.getCrnNo()); // 鍫嗗灈鏈虹紪鍙�
@@ -702,9 +726,9 @@
     @PostMapping("/crn/operator/onlineWrk3")
     public R onlineWrk4(CrnOperatorParam param){
         // 绯荤粺杩愯鐘舵�佸垽鏂�
-        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
-            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
-        }
+//        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
+//            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
+//        }
         short[] array = new short[9];
         CrnCommand command = new CrnCommand();
         command.setCrnNo(param.getCrnNo()); // 鍫嗗灈鏈虹紪鍙�
@@ -717,14 +741,30 @@
     @PostMapping("/crn/operator/onlineWrk4")
     public R crnHand(CrnOperatorParam param){
         // 绯荤粺杩愯鐘舵�佸垽鏂�
-        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
-            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
-        }
+//        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
+//            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
+//        }
         short[] array = new short[9];
         CrnCommand command = new CrnCommand();
         command.setCrnNo(param.getCrnNo()); // 鍫嗗灈鏈虹紪鍙�
         command.setTaskNo((short) 0); // 宸ヤ綔鍙�
         command.setOnlineWrk4((short)1);
+
+        return crnControl2(command)?R.ok():R.error();
+    }
+
+    @ManagerAuth(memo = "澶嶄綅")
+    @PostMapping("/crn/operator/reset")
+    public R crnReset(CrnOperatorParam param){
+        // 绯荤粺杩愯鐘舵�佸垽鏂�
+//        if (SystemProperties.WCS_RUNNING_STATUS.get()) {
+//            return R.error("wcs绯荤粺鐘舵�佷负寮�鍚�");
+//        }
+        short[] array = new short[9];
+        CrnCommand command = new CrnCommand();
+        command.setCrnNo(param.getCrnNo()); // 鍫嗗灈鏈虹紪鍙�
+        command.setTaskNo((short) 0); // 宸ヤ綔鍙�
+        command.setReset((short)1);
 
         return crnControl2(command)?R.ok():R.error();
     }
@@ -748,7 +788,7 @@
                 }
                 // 绌洪棽鍒ゆ柇
 //                if (crnProtocol.getStatusType().equals(com.zy.core.enums.CrnStatusType.IDLE) && crnProtocol.getTaskNo() == 0) {
-                if (CommandUtils.offer(SlaveType.Crn, crn.getId(), new Task(4, command), false)) {
+                if (MessageQueue.offer(SlaveType.Crn, crn.getId(), new Task(4, command))) {
                     return true;
                 } else {
                     throw new CoolException("鍛戒护涓嬪彂澶辫触");
@@ -848,5 +888,67 @@
         return R.ok().add(list);
     }
 
+    public boolean toWmsLocStatus(Integer type,String startlocNo,String locNo,String barcode,String barcodeType,String emptyContainer){
+        Map<String, Object> map = new HashMap<>();
+        map.put("x-api-key","7a15b5db-29b6-552c-8cff-0cfec3756da2");
+        WmsLocStatus param = new WmsLocStatus();
+        param.setWarehouseId("1688469798893297665");
+        param.setLocationCode(Utils.getWmsLocNo(locNo));
+        if (emptyContainer.equals("1")){
+            param.setEmptyContainer("Y");
+        }else {
+            param.setEmptyContainer("N");
+        }
+        param.setStatus("QY");
+        param.setContainerCode(barcode);
+        param.setContainerTypeCode(barcodeType);
+
+        String response = null;
+        try {
+            response = new HttpHandler.Builder()
+                    .setHeaders(map)
+                    .setUri(wmsUrl)
+                    .setPath("wcsManager/wcsInterface/locationUpdate")
+                    .setJson(JSON.toJSONString(param))
+                    .build()
+                    .doPost();
+        }catch (Exception e){
+            log.error("搴撲綅鏇存柊澶辫触");
+        }
+        JSONObject jsonObject = JSON.parseObject(response);
+        if (jsonObject.getInteger("code").equals(200)){
+            LocMast originLoc = locMastService.selectByLocNo(startlocNo);
+            LocMast locMast = locMastService.selectByLocNo(locNo);
+            if (type == 1){
+                locMast.setBarcode(barcode);
+                locMast.setLocSts("Z");
+                locMastService.updateById(locMast);
+            }else if (type == 2){
+                originLoc.setLocSts("K");
+                originLoc.setBarcode("");
+                locMastService.updateById(originLoc);
+            }else if (type == 3){
+                originLoc.setLocSts("K");
+                originLoc.setBarcode("");
+                locMast.setBarcode(barcode);
+                locMast.setLocSts("Z");
+                locMastService.updateById(originLoc);
+                locMastService.updateById(locMast);
+            }
+
+            apiLogService.save("Wms鍙樻洿璐т綅鐘舵��"
+                    ,wmsUrl+"wcsManager/wcsInterface/inboundTaskApply"
+                    ,null
+                    ,"127.0.0.1"
+                    ,JSON.toJSONString(param)
+                    ,response
+                    ,true
+            );
+            return true;
+        }
+        return false;
+
+    }
+
 
 }

--
Gitblit v1.9.1