From e726415232fd4141135a399aa51ffafd45d8deff Mon Sep 17 00:00:00 2001
From: pang.jiabao <pang_jiabao@163.com>
Date: 星期四, 07 十一月 2024 20:12:22 +0800
Subject: [PATCH] 一楼返修入库,和出库推送mes记录日志

---
 src/main/java/com/zy/common/constant/MesConstant.java                |    3 +
 src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java        |   61 +++++++++++++++++++
 src/main/java/com/zy/asrs/entity/param/GwmsGenerateInventoryDto.java |    4 +
 src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java          |   91 ++++++++++++++++++++++++++++++
 4 files changed, 157 insertions(+), 2 deletions(-)

diff --git a/src/main/java/com/zy/asrs/entity/param/GwmsGenerateInventoryDto.java b/src/main/java/com/zy/asrs/entity/param/GwmsGenerateInventoryDto.java
index e44f050..27741e9 100644
--- a/src/main/java/com/zy/asrs/entity/param/GwmsGenerateInventoryDto.java
+++ b/src/main/java/com/zy/asrs/entity/param/GwmsGenerateInventoryDto.java
@@ -1,5 +1,6 @@
 package com.zy.asrs.entity.param;
 
+import lombok.AllArgsConstructor;
 import lombok.Data;
 
 import java.util.List;
@@ -17,6 +18,8 @@
     public static class MatList{
         private String boxPos; // 绠卞瓙浣嶇疆
         private String packageGroupNo; // 鍖呰缁勫彿
+        private String outOrIn; // out鍑猴紝in鍏�
+        private String stockType; // 鍑哄叆绫诲瀷
         private String boxType; // 鏈ㄧ绫诲瀷
         private String rollType; // 绠¤姱绫诲瀷
         private String wideInWidth; // 瀹炴祴瀹藉箙锛堝垎鍒囨垚鍝佷笅鏂欙級
@@ -24,6 +27,7 @@
         private List<Rolls> rolls; // 鍗烽泦鍚�
     }
     @Data
+    @AllArgsConstructor
     public static class Rolls{
         private String rollNo; // 鍗峰彿
         private String boxNo; // 绠卞彿
diff --git a/src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java
index 619b6e9..37969e5 100644
--- a/src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java
@@ -1547,10 +1547,67 @@
             throw new CoolException(dto.getLocNo() + "鐩爣搴撲綅宸茶鍗犵敤");
         }
 
+        // 涓�妤艰繑淇叆搴撴帹閫乵es鍋氳褰�
+        pushFxrkToMes(param);
+
         // 杩斿洖GWCS鐩爣淇℃伅
         openServiceImpl.pushStaNoToGwcs(param.getPalletizingNo(), dto.getStaNo(), dto.getWorkNo(), param.getBarcode(), "浜屾ゼ杩斾慨鍏ュ簱鎺ㄩ�乬wcs");
 
         return R.ok("鍙嶄慨鍏ュ簱鎴愬姛");
+    }
+
+    private void pushFxrkToMes(GwmsGenerateInventoryDto param) {
+
+        for (GwmsGenerateInventoryDto.MatList matList : param.getMatList()){
+            matList.setOutOrIn("in");
+            matList.setStockType("杩斾慨鍏ュ簱");
+        }
+
+        boolean success = false;
+        // 鑾峰彇璇锋眰澶�
+        Map<String,Object> headers = new HashMap<>();
+        headers.put("Content-Type","application/json;charset=UTF-8");
+
+        // 鏋勯�犺姹備綋
+        String body = JSON.toJSONString(param);
+        String response = "";
+        try {
+            response = new HttpHandler.Builder()
+                    .setUri(MesConstant.MES_CC_IP_PORT)
+                    .setPath(MesConstant.MES_CC_FXRK_URL)
+                    .setHeaders(headers)
+                    .setJson(body)
+                    .build()
+                    .doGet();
+            if (!Cools.isEmpty(response)) {
+                JSONObject jsonObject1 = JSONObject.parseObject(response);
+                int code = (int) jsonObject1.get("code");
+                boolean state  = jsonObject1.getBoolean("state");
+                if (code == 200 && state) {
+                    success = true;
+                }
+            } else {
+                log.error("杩斾慨鍏ュ簱鎺ㄩ�乵es璁板綍澶辫触锛侊紒锛乽rl锛歿}锛況equest锛歿}锛況esponse锛歿}", MesConstant.MES_CC_IP_PORT + MesConstant.MES_CC_FXRK_URL, body, response);
+            }
+        } catch (Exception e) {
+            log.error("杩斾慨鍏ュ簱鎺ㄩ�乵es璁板綍寮傚父锛歿}", e.getMessage());
+        } finally {
+            try {
+                // 淇濆瓨鎺ュ彛鏃ュ織
+                apiLogService.save(
+                        "杩斾慨鍏ュ簱鎺ㄩ�乵es璁板綍",
+                        MesConstant.MES_CC_IP_PORT + MesConstant.MES_CC_FXRK_URL,
+                        null,
+                        "127.0.0.1",
+                        body,
+                        response,
+                        success
+                );
+            } catch (Exception e) {
+                log.error("", e);
+            }
+        }
+
     }
 
     @Override
@@ -1914,7 +1971,7 @@
                 }
                 throw new CoolException(msg);
             } else {
-                log.error("杩斾慨鍝佸叆搴撶粰mes鎺ㄩ�佸緟鍒ゅけ璐ワ紒锛侊紒url锛歿}锛況equest锛歿}锛況esponse锛歿}", MesConstant.MES_CC_IP_PORT + MesConstant.MES_CC_IP_PORT, body, response);
+                log.error("杩斾慨鍝佸叆搴撶粰mes鎺ㄩ�佸緟鍒ゅけ璐ワ紒锛侊紒url锛歿}锛況equest锛歿}锛況esponse锛歿}", MesConstant.MES_CC_IP_PORT + MesConstant.MES_CC_DP_URL, body, response);
                 throw new CoolException("杩斾慨鍝佸叆搴撶粰mes鎺ㄩ�佸緟鍒ゅけ璐�");
             }
         } catch (Exception e) {
@@ -1924,7 +1981,7 @@
                 // 淇濆瓨鎺ュ彛鏃ュ織
                 apiLogService.save(
                         "杩斾慨鍝佸叆搴撶粰mes鎺ㄩ�佸緟鍒�",
-                        MesConstant.MES_CC_IP_PORT + MesConstant.MES_CC_IP_PORT,
+                        MesConstant.MES_CC_IP_PORT + MesConstant.MES_CC_DP_URL,
                         null,
                         "127.0.0.1",
                         body,
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 f5ed658..abda48f 100644
--- a/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
@@ -1,5 +1,6 @@
 package com.zy.asrs.service.impl;
 
+import com.alibaba.fastjson.JSON;
 import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.mapper.EntityWrapper;
 import com.baomidou.mybatisplus.mapper.Wrapper;
@@ -1486,9 +1487,99 @@
             wrkMastService.updateById(wrkMast);
         }
 
+        // 鍑哄簱涓婃姤鎺ㄩ�乵es璁板綍
+        ckjgsbPushMes(wrkMast,wrkDetls);
+
         return "鍑哄簱缁撴灉涓婃姤鎴愬姛";
     }
 
+    private void ckjgsbPushMes(WrkMast wrkMast, List<WrkDetl> wrkDetls) {
+        GwmsGenerateInventoryDto gwmsGenerateInventoryDto = new GwmsGenerateInventoryDto();
+        gwmsGenerateInventoryDto.setBarcode(wrkMast.getBarcode());
+        gwmsGenerateInventoryDto.setPalletizingNo(wrkMast.getStaNo());
+        List<GwmsGenerateInventoryDto.MatList> matLists = new ArrayList<>();
+        for (WrkDetl wrkDetl:wrkDetls) {
+            boolean flag = true;
+            for (GwmsGenerateInventoryDto.MatList matList : matLists) {
+                if (matList.getPackageGroupNo().equals(wrkDetl.getBrand())) {
+                    matList.getRolls().add(new GwmsGenerateInventoryDto.Rolls(wrkDetl.getModel(),
+                                    wrkDetl.getUnit(),wrkDetl.getMaktx(),wrkDetl.getLength(),
+                                    Integer.parseInt(wrkDetl.getSpecs()),wrkDetl.getWeight(),wrkDetl.getVolume(),
+                                    wrkDetl.getManuDate()));
+                    flag = false;
+                    break;
+                }
+            }
+            if (flag) {
+                GwmsGenerateInventoryDto.MatList matList = new GwmsGenerateInventoryDto.MatList();
+                matList.setBoxPos(wrkDetl.getOrigin());
+                matList.setPackageGroupNo(wrkDetl.getBrand());
+                matList.setOutOrIn("out");
+                matList.setStockType(wrkMast.getStaNo() == 2041 ? "杩斾慨鍑哄簱" : "鎴愬搧鍑哄簱");
+                matList.setBoxType(wrkDetl.getColor());
+                matList.setRollType(wrkDetl.getManu());
+                matList.setWideInWidth(wrkDetl.getSku());
+                matList.setThickness(wrkDetl.getItemNum());
+                List<GwmsGenerateInventoryDto.Rolls> rollsList = new ArrayList<>();
+                GwmsGenerateInventoryDto.Rolls roll = new GwmsGenerateInventoryDto.Rolls(wrkDetl.getModel(),
+                        wrkDetl.getUnit(),wrkDetl.getMaktx(),wrkDetl.getLength(),
+                        Integer.parseInt(wrkDetl.getSpecs()),wrkDetl.getWeight(),wrkDetl.getVolume(),
+                        wrkDetl.getManuDate());
+                rollsList.add(roll);
+                matList.setRolls(rollsList);
+                matLists.add(matList);
+            }
+        }
+       gwmsGenerateInventoryDto.setMatList(matLists);
+
+
+
+        boolean success = false;
+        // 鑾峰彇璇锋眰澶�
+        Map<String,Object> headers = new HashMap<>();
+        headers.put("Content-Type","application/json;charset=UTF-8");
+
+        // 鏋勯�犺姹備綋
+        String body = JSON.toJSONString(gwmsGenerateInventoryDto);
+        String response = "";
+        try {
+            response = new HttpHandler.Builder()
+                    .setUri(MesConstant.MES_CC_IP_PORT)
+                    .setPath(MesConstant.MES_CC_FXRK_URL)
+                    .setHeaders(headers)
+                    .setJson(body)
+                    .build()
+                    .doGet();
+            if (!Cools.isEmpty(response)) {
+                JSONObject jsonObject1 = JSONObject.parseObject(response);
+                int code = (int) jsonObject1.get("code");
+                boolean state  = jsonObject1.getBoolean("state");
+                if (code == 200 && state) {
+                    success = true;
+                }
+            } else {
+                log.error("鍑哄簱涓婃姤鎺ㄩ�乵es璁板綍澶辫触锛侊紒锛乽rl锛歿}锛況equest锛歿}锛況esponse锛歿}", MesConstant.MES_CC_IP_PORT + MesConstant.MES_CC_FXRK_URL, body, response);
+            }
+        } catch (Exception e) {
+            log.error("鍑哄簱涓婃姤鎺ㄩ�乵es璁板綍寮傚父锛歿}", e.getMessage());
+        } finally {
+            try {
+                // 淇濆瓨鎺ュ彛鏃ュ織
+                apiLogService.save(
+                        "鍑哄簱涓婃姤鎺ㄩ�乵es璁板綍",
+                        MesConstant.MES_CC_IP_PORT + MesConstant.MES_CC_FXRK_URL,
+                        null,
+                        "127.0.0.1",
+                        body,
+                        response,
+                        success
+                );
+            } catch (Exception e) {
+                log.error("", e);
+            }
+        }
+    }
+
     @Autowired
     private BasCrnpService basCrnpService;
 
diff --git a/src/main/java/com/zy/common/constant/MesConstant.java b/src/main/java/com/zy/common/constant/MesConstant.java
index 580093b..e1b51c3 100644
--- a/src/main/java/com/zy/common/constant/MesConstant.java
+++ b/src/main/java/com/zy/common/constant/MesConstant.java
@@ -27,6 +27,9 @@
     // 缁欎粨鍌∕ES鎺ㄩ�佺洏鐐瑰紓甯歌皟鏁寸粨鏋�
     public static final String MES_CC_YCTZ_URL = "/productInventory/v1/exception";
 
+    // 涓�妤艰繑淇叆搴撴帹閫乵es鍋氳褰�
+    public static final String MES_CC_FXRK_URL = "/productInventory/v1/saveDto";
+
     // MES璐ㄩ噺IP鍦板潃**********************************************************
     public static final String MES_ZL_IP_PORT = "http://172.22.152.3:8157";
 

--
Gitblit v1.9.1