From 91c235d583d3f6579d060fac9fa91faa65a1b42c Mon Sep 17 00:00:00 2001
From: cl <1442464845@qq.com>
Date: 星期二, 07 四月 2026 14:52:56 +0800
Subject: [PATCH] 取消还原

---
 src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java |  220 ++++++++++++++++++++++++++++++++++--------------------
 1 files changed, 139 insertions(+), 81 deletions(-)

diff --git a/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
index 707bbb7..541a141 100644
--- a/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
@@ -33,7 +33,6 @@
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
-import javax.rmi.CORBA.Util;
 import java.util.*;
 import java.util.stream.Collectors;
 
@@ -98,6 +97,8 @@
     private WorkService workService;
     @Autowired
     private BasCrnpService basCrnpService;
+    @Autowired
+    private ApiLogService apiLogService;
 
     @Override
     @Transactional
@@ -374,77 +375,88 @@
     @Override
     @Transactional
     public R pakoutOrderPause(OpenOrderPakoutPauseParam param) {
-        if (param == null || Cools.isEmpty(param.getOrderNo())) {
-            throw new CoolException("orderNo is empty");
+        if (param == null || Cools.isEmpty(param.getOrderId())) {
+            throw new CoolException("orderNo涓嶈兘涓虹┖");
         }
-        Order order = orderService.selectByNo(param.getOrderNo());
-        if (order == null) {
-            order = OrderInAndOutUtil.selectByNo(Boolean.FALSE, param.getOrderNo());
-        }
-        if (order == null) {
-            throw new CoolException("order not found: " + param.getOrderNo());
+        if (param.getExecute() == null) {
+            throw new CoolException("execute涓嶈兘涓虹┖");
         }
 
-        List<WrkMast> activeTasks = findActiveOutboundTasks(param.getOrderNo());
-        if (activeTasks.isEmpty()) {
-            return R.ok("no active out tasks");
-        }
-
-        Date now = new Date();
-        int pausedCount = 0;
-        List<WrkMast> issuedTasks = new ArrayList<>();
-        for (WrkMast wrkMast : activeTasks) {
-            if (wrkMast == null || "Y".equalsIgnoreCase(wrkMast.getPauseMk())) {
-                continue;
+        List<WrkMast> activeTasks = findActiveOutboundTasks(param.getOrderId());
+        if (Objects.equals(param.getExecute(), 1)) {
+            // ERP纭绔嬪嵆鎵ц锛屼粎澶勭悊寰呬笅鍙戠殑鍑哄簱浠诲姟銆�
+            List<WrkMast> pendingTasks = activeTasks.stream()
+                    .filter(wrkMast -> wrkMast != null && Objects.equals(wrkMast.getWrkSts(), 11L))
+                    .collect(Collectors.toList());
+            Map<String, Object> result = new HashMap<>();
+            result.put("orderNo", param.getOrderId());
+            result.put("taskCount", pendingTasks.size());
+            if (pendingTasks.isEmpty()) {
+                result.put("confirmedCount", 0);
+                return R.ok("鏃犳湁鏁堝嚭搴撲换鍔�").add(result);
             }
-            wrkMast.setPauseMk("Y");
-            wrkMast.setUpdMk(needNotifyWcsStop(wrkMast) ? "WCS_STOP_REQUESTED" : "WMS_PAUSED");
-            wrkMast.setManuType("ERP_PAUSE");
-            wrkMast.setModiTime(now);
-            wrkMast.setModiUser(9527L);
-            if (!wrkMastService.updateById(wrkMast)) {
-                throw new CoolException("pause out task failed: " + wrkMast.getWrkNo());
+
+            Date now = new Date();
+            int confirmedCount = 0;
+            for (WrkMast wrkMast : pendingTasks) {
+                if (wrkMast == null || "Y".equalsIgnoreCase(wrkMast.getPdcType())) {
+                    continue;
+                }
+                wrkMast.setPdcType("Y");
+//            wrkMast.setUpdMk("ERP_CONFIRMED");
+//            wrkMast.setManuType("ERP_CONFIRM_OUT");
+                wrkMast.setModiTime(now);
+                wrkMast.setModiUser(9527L);
+                if (!wrkMastService.updateById(wrkMast)) {
+                    throw new CoolException("纭鎵ц鍑哄簱浠诲姟澶辫触: " + wrkMast.getWrkNo());
+                }
+                confirmedCount++;
             }
-            pausedCount++;
-            if (needNotifyWcsStop(wrkMast)) {
-                issuedTasks.add(wrkMast);
+
+            result.put("confirmedCount", confirmedCount);
+            return R.ok(confirmedCount == 0 ? "浠诲姟宸茬‘璁ゆ墽琛�" : "ERP纭鎵ц鍑哄簱鎴愬姛").add(result);
+        }
+        if (Objects.equals(param.getExecute(), 2)) {
+            // ERP璇锋眰鍙栨秷浠诲姟锛氱洿鎺ユ敹闆嗕换鍔″彿锛屾寜 taskList 鏍煎紡鍙戦�佺粰 WCS銆�
+            Map<String, Object> result = new HashMap<>();
+            result.put("orderNo", param.getOrderId());
+            result.put("execute", param.getExecute());
+            result.put("taskCount", activeTasks.size());
+            if (activeTasks.isEmpty()) {
+                return R.ok("鏃犳湁鏁堝嚭搴撲换鍔�").add(result);
             }
+            List<HashMap<String,Object>> taskList = new ArrayList<>();
+            for (WrkMast wrkMast : activeTasks) {
+                HashMap<String,Object> hashMap = new HashMap<>();
+                hashMap.put("taskNo", wrkMast.getWrkNo());
+                if (!Cools.isEmpty(wrkMast) && wrkMast.getWrkSts() ==11L) {
+                    workService.cancelWrkMast(wrkMast.getWrkNo()+"", 9955L);
+                    continue;
+                }
+                taskList.add(hashMap);
+            }
+            wcsApiService.pauseOutTasks(taskList);
+            return R.ok("鍙栨秷浠诲姟宸插彂閫佽嚦WCS").add(result);
         }
+        throw new CoolException("reason浠呮敮鎸�1鎴�2");
+    }
 
-        if (pausedCount == 0) {
-            return R.ok("tasks already paused");
+    /** WCS 杩斿洖闈炴垚鍔熺爜鏃舵姏閿� */
+    private void requireWcsPauseOk(R wcsR) {
+        if (wcsR == null) {
+            throw new CoolException("WCS鍙栨秷鍑哄簱浠诲姟鏃犺繑鍥�");
         }
-
-        if (!issuedTasks.isEmpty()) {
-            wcsApiService.pauseOutTasks(buildStopOutTaskParams(param, issuedTasks));
+        Object codeObj = wcsR.get("code");
+        int code = codeObj instanceof Number ? ((Number) codeObj).intValue() : -1;
+        if (code != 200) {
+            Object msgObj = wcsR.get("msg");
+            throw new CoolException(msgObj == null ? "WCS鍙栨秷鍑哄簱浠诲姟澶辫触" : String.valueOf(msgObj));
         }
-
-        Map<String, Object> result = new HashMap<>();
-        result.put("orderNo", param.getOrderNo());
-        result.put("pausedCount", pausedCount);
-        result.put("wcsStopCount", issuedTasks.size());
-        return R.ok("pause out success").add(result);
     }
 
     @Override
-    @Transactional
     public R pakoutOrderExecute(OpenOrderPakoutExecuteParam param) {
-        if (param == null || Cools.isEmpty(param.getOrderId())) {
-            throw new CoolException("orderId is empty");
-        }
-        if (param.getExecute() == null) {
-            throw new CoolException("execute is empty");
-        }
-        if (Objects.equals(param.getExecute(), 1)) {
-            return createPakoutTasks(param.getOrderId());
-        }
-        if (Objects.equals(param.getExecute(), 2)) {
-            OpenOrderPakoutPauseParam pauseParam = new OpenOrderPakoutPauseParam();
-            pauseParam.setOrderNo(param.getOrderId());
-            pauseParam.setReason("OPEN_API_PAUSE");
-            return pakoutOrderPause(pauseParam);
-        }
-        throw new CoolException("execute only supports 1 or 2");
+        return null;
     }
 
     private List<WrkMast> findActiveOutboundTasks(String orderNo) {
@@ -461,8 +473,8 @@
         }
         List<WrkMast> wrkMasts = wrkMastService.selectList(new EntityWrapper<WrkMast>()
                 .in("wrk_no", wrkNos)
-                .in("io_type", Arrays.asList(101, 103, 107, 108, 110))
-                .lt("wrk_sts", 14L));
+                .in("io_type", Arrays.asList(101, 103, 104, 107, 108, 110))
+                .in("wrk_sts", Arrays.asList(11L, 12L, 13L)));
         if (wrkMasts == null || wrkMasts.isEmpty()) {
             return Collections.emptyList();
         }
@@ -573,24 +585,12 @@
         return orderDetl.getMatnr() + "|batch=" + (orderDetl.getBatch() == null ? "" : orderDetl.getBatch()) + "|lack=" + lackQty;
     }
 
-    private boolean needNotifyWcsStop(WrkMast wrkMast) {
-        return wrkMast != null
-                && wrkMast.getWrkSts() != null
-                && wrkMast.getWrkSts() >= 12L
-                && wrkMast.getWrkSts() < 14L;
-    }
-
-    private StopOutTaskParams buildStopOutTaskParams(OpenOrderPakoutPauseParam param, List<WrkMast> wrkMasts) {
+    private StopOutTaskParams buildStopOutTaskParams(List<WrkMast> wrkMasts) {
         StopOutTaskParams stopParams = new StopOutTaskParams();
-        stopParams.setOrderNo(param.getOrderNo());
-        stopParams.setReason(param.getReason());
+        // WCS鍙栨秷鎺ュ彛浠呮帴鏀� taskList.taskNo銆�
         for (WrkMast wrkMast : wrkMasts) {
             StopOutTaskParams.TaskItem item = new StopOutTaskParams.TaskItem();
             item.setTaskNo(String.valueOf(wrkMast.getWrkNo()));
-            if (wrkMast.getStaNo() != null) {
-                item.setStaNo(String.valueOf(wrkMast.getStaNo()));
-            }
-            item.setLocNo(wrkMast.getSourceLocNo());
             stopParams.getTasks().add(item);
         }
         return stopParams;
@@ -1239,7 +1239,10 @@
                 stationParams.add(stationParam);
             }
         }
+        String requestJson = JSON.toJSONString(stationParams);
         String response = "";
+        boolean pushOk = false;
+        String pushUrl = buildMesStationRequestUrl();
         try {
             //鑾峰彇Cookie鍊�
             HashMap<String, Object> headers = new HashMap<>();
@@ -1249,19 +1252,50 @@
                     .setHeaders(headers)
                     .setUri(mesUrl)
                     .setPath(stationAddress)
-                    .setJson(JSON.toJSONString(stationParams))
+                    .setJson(requestJson)
                     .build()
                     .doPost();
             JSONObject jsonResponse = JSON.parseObject(response);
-            if (jsonResponse.getInteger("code") == 200) {
-
+            if (jsonResponse != null && Integer.valueOf(200).equals(jsonResponse.getInteger("code"))) {
+                pushOk = true;
             } else {
                 return R.error();
             }
         } catch (Exception e) {
             e.printStackTrace();
+        } finally {
+            try {
+                apiLogService.save(
+                        "鎺‥RP-绔欑偣鍚屾",
+                        pushUrl,
+                        null,
+                        "127.0.0.1",
+                        requestJson,
+                        response,
+                        pushOk,
+                        "绔欑偣鍚屾鎺ㄥ鏂�"
+                );
+            } catch (Exception logEx) {
+                log.error("save station sync api log failed", logEx);
+            }
         }
         return R.ok();
+    }
+
+    private String buildMesStationRequestUrl() {
+        if (Cools.isEmpty(mesUrl)) {
+            return stationAddress;
+        }
+        if (stationAddress == null) {
+            return mesUrl;
+        }
+        if (mesUrl.endsWith("/") && stationAddress.startsWith("/")) {
+            return mesUrl + stationAddress.substring(1);
+        }
+        if (!mesUrl.endsWith("/") && !stationAddress.startsWith("/")) {
+            return mesUrl + "/" + stationAddress;
+        }
+        return mesUrl + stationAddress;
     }
 
     @Override
@@ -1276,7 +1310,12 @@
 
             if (param.getFull() == 1) {
                 //婊℃墭鐩�
-                mat = matService.selectByMatnr(param.getMatnr());
+                if(param.getBoxType1().equals("aws")){
+                    mat = matService.selectByMatnr("amazon");
+                }else {
+                    mat = matService.selectByMatnr("cloudWarehouse");
+                }
+
             } else if (param.getFull() == 0) {
                 //绌烘墭鐩�
                 mat = matService.selectByMatnr("emptyPallet");
@@ -1285,6 +1324,7 @@
 
         WaitPakin waitPakin = new WaitPakin();
         waitPakin.sync(mat);
+//        waitPakin.setMatnr(param.getMatnr());
         waitPakin.setBatch(String.valueOf(param.getBatchId()));
         waitPakin.setZpallet(param.getPalletId());   // 鎵樼洏鐮�
 
@@ -1300,17 +1340,19 @@
         waitPakin.setManu(String.valueOf(param.getLocId()));//mes鍏蜂綋搴撲綅缂栧彿
         waitPakin.setThreeCode(param.getBizNo());
         waitPakin.setBeBatch(param.getPackage1());//鏄惁鏁h揣锛�0 闈炴暎璐э紱1 鏁h揣锛涗负浜嗙鎺у嚭璐ч�熺巼锛屾暎璐у彲浠ュ嚭鎱㈢偣銆�
+        // ERP 鍏ュ彛榛樿鎵� erp锛孧QTT 缁勬墭浼氬湪鍙傛暟閲屾樉寮忎紶 aws銆�
+        waitPakin.setBoxType1(Cools.isEmpty(param.getBoxType1()) ? "erp" : param.getBoxType1());
         if (!waitPakinService.insert(waitPakin)) {
             throw new CoolException("淇濆瓨鍏ュ簱閫氱煡妗eけ璐�");
         }
-        return null;
+        return R.ok().add(Cools.add("palletId", param.getPalletId()).add("orderId", param.getOrderId()));
     }
 
     @Override
-    public R outOrder(OutTaskParam param) {
+    public R outOrder(OutTaskParam param,int count) {
         LocMast locMast = locMastService.selectOne(new EntityWrapper<LocMast>().eq("loc_sts", "F").eq("barcode", param.getPalletId()));
         if (locMast == null) {
-            return R.error("娌℃湁鎵惧埌鎵樼洏鐮�=" + param.getPalletId() + "瀵瑰簲鐨勫簱浣�");
+            throw new CoolException("娌℃湁鎵惧埌鎵樼洏鐮�=" + param.getPalletId() + "瀵瑰簲鐨勫簱浣�");
         }
         Integer ioType = 101;
         // 鑾峰彇璺緞
@@ -1335,6 +1377,7 @@
         wrkMast.setExitMk("N"); // 閫�鍑�
         wrkMast.setEmptyMk("N"); // 绌烘澘
         wrkMast.setLinkMis("N");
+        wrkMast.setPdcType("N");
         wrkMast.setUserNo(param.getOrderId());//璁㈠崟鍙�
         wrkMast.setPltType(param.getSeq());//鍑哄簱椤哄簭锛屼粠1寮�濮�
         wrkMast.setTakeNone("0");  //0闈炶嚜鍔�
@@ -1362,6 +1405,7 @@
             wrkDetl.setAppeUser(9995L);
             wrkDetl.setModiTime(now);
             wrkDetl.setModiUser(9995L);
+            wrkDetl.setSupp(param.getSeq()+"/"+count);
 
             if (!wrkDetlService.insert(wrkDetl)) {
                 throw new CoolException("淇濆瓨宸ヤ綔妗f槑缁嗗け璐�");
@@ -1380,7 +1424,21 @@
             log.error(locMast.getLocNo() + "搴撲綅涓嶆槸鍦ㄥ簱鐘舵��");
             throw new CoolException(locMast.getLocNo() + "搴撲綅涓嶆槸鍦ㄥ簱鐘舵��");
         }
+        return R.ok().add(Cools.add("wrkNo", workNo).add("orderId", param.getOrderId()));
+    }
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public R outOrderBatch(List<OutTaskParam> params) {
+        int n = params.size();
+        for (OutTaskParam outTaskParam : params) {
+            R r = outOrder(outTaskParam, n);
+            if (!Objects.equals(r.get("code"), 200)) {
+                throw new CoolException("鍑哄簱寤哄崟澶辫触");
+            }
+        }
         return R.ok();
     }
 }
 
+

--
Gitblit v1.9.1