From f4214b3e0764ab116fc6975dbbc5bb4fc80f9fcd Mon Sep 17 00:00:00 2001
From: zhangchao <zc857179121@qq.com>
Date: 星期四, 21 十一月 2024 16:08:15 +0800
Subject: [PATCH] rcs超时

---
 src/main/java/com/zy/asrs/service/impl/AgvWrkMastServiceImp.java |   90 ++++++++++++++++++++++++--------------------
 1 files changed, 49 insertions(+), 41 deletions(-)

diff --git a/src/main/java/com/zy/asrs/service/impl/AgvWrkMastServiceImp.java b/src/main/java/com/zy/asrs/service/impl/AgvWrkMastServiceImp.java
index 63faab5..d8d63ba 100644
--- a/src/main/java/com/zy/asrs/service/impl/AgvWrkMastServiceImp.java
+++ b/src/main/java/com/zy/asrs/service/impl/AgvWrkMastServiceImp.java
@@ -23,6 +23,7 @@
 
 import java.io.IOException;
 import java.util.*;
+import java.util.concurrent.TimeUnit;
 
 @Service
 @Slf4j
@@ -65,17 +66,17 @@
     public void updateWrkStsByWrkNo(int wrkNo, long wrkSts) {
         AgvWrkMast agvWrkMast = this.selectById(wrkNo);
         //鍒ゆ柇瑕佷慨鏀圭殑宸ヤ綔妗g姸鎬佹槸鍚﹀悎鐞嗭紝濡傛灉涓嶅悎鐞嗗垯鎶涘嚭寮傚父
-        checkWrkSts(agvWrkMast,wrkSts);
+        checkWrkSts(agvWrkMast, wrkSts);
         agvWrkMast.setWrkSts(wrkSts);
         agvWrkMast.setModiTime(new Date());
         this.updateById(agvWrkMast);
     }
 
-    public void updateWrkStsByWrkNo(int wrkNo, long wrkSts,String manuType,long userId) {
+    public void updateWrkStsByWrkNo(int wrkNo, long wrkSts, String manuType, long userId) {
         Date now = new Date();
         AgvWrkMast agvWrkMast = this.selectById(wrkNo);
         //鍒ゆ柇瑕佷慨鏀圭殑宸ヤ綔妗g姸鎬佹槸鍚﹀悎鐞嗭紝濡傛灉涓嶅悎鐞嗗垯鎶涘嚭寮傚父
-        checkWrkSts(agvWrkMast,wrkSts);
+        checkWrkSts(agvWrkMast, wrkSts);
         agvWrkMast.setWrkSts(wrkSts);
         agvWrkMast.setManuType(manuType);
         agvWrkMast.setModiTime(now);
@@ -84,8 +85,7 @@
     }
 
     // TODO 鍒ゆ柇瑙勫垯
-    private boolean checkWrkSts(AgvWrkMast agvWrkMast,long wrkSts){
-
+    private boolean checkWrkSts(AgvWrkMast agvWrkMast, long wrkSts) {
 
 
         return true;
@@ -96,9 +96,9 @@
         AgvTaskCreateParam agvTaskCreateParam = new AgvTaskCreateParam();
         //agvTaskCreateParam.setTaskType(taskType);
 
-        getRequestParam(agvTaskCreateParam,agvWrkMast);
+        getRequestParam(agvTaskCreateParam, agvWrkMast);
 
-        return doHttpRequest(agvTaskCreateParam,"鎼繍浠诲姟涓嬪彂",url, taskCreatePath,null,"127.0.0.1");
+        return doHttpRequest(agvTaskCreateParam, "鎼繍浠诲姟涓嬪彂", url, taskCreatePath, null, "127.0.0.1");
 
         //return containerMoveParam;
     }
@@ -106,7 +106,7 @@
     public int startAllcationIn(AgvWrkMast agvWrkMast) throws IOException {
         AgvBasDevp basDevp = agvBasDevpService.selectByDevNo(agvWrkMast.getSourceLocNo());
         //妫�绱㈠簱浣嶏紝閫夋嫨鍚堥�傜殑搴撲綅
-        AgvLocMast locMast = agvCommonService.getLocNo(basDevp.getLocType1(),basDevp.getFloor(),false,true);
+        AgvLocMast locMast = agvCommonService.getLocNo(basDevp.getLocType1(), basDevp.getFloor(), false, true);
         agvWrkMast.setLocNo(locMast.getLocNo());
         agvWrkMast.setWrkSts(201L);
         agvWrkMast.setLogErrMemo("startAllcationIn");
@@ -122,30 +122,30 @@
     //璐ф灦鍏ュ満
     public int containerMoveIn(List<AgvWrkMast> agvWrkMastList) throws IOException {
         //璋冪敤璐ф灦鍏ュ満鏃舵墍闇�瑕佸弬鏁�
-        Map<String,List<Map<String,String>>> containerMoveParam = new HashMap<>();
-        List<Map<String,String>> positionCodeMapList = new ArrayList<>();
-        containerMoveParam.put("containerMoveIns",positionCodeMapList);
+        Map<String, List<Map<String, String>>> containerMoveParam = new HashMap<>();
+        List<Map<String, String>> positionCodeMapList = new ArrayList<>();
+        containerMoveParam.put("containerMoveIns", positionCodeMapList);
 
-        getContainerMoveParam(agvWrkMastList,positionCodeMapList);
+        getContainerMoveParam(agvWrkMastList, positionCodeMapList);
 
-        if(Cools.isEmpty(positionCodeMapList)){
+        if (Cools.isEmpty(positionCodeMapList)) {
             return 0;
         }
-        return doHttpRequest(containerMoveParam,"璐ф灦鍏ュ満浠诲姟涓嬪彂",url, containerMoveInPath,null,"127.0.0.1");
+        return doHttpRequest(containerMoveParam, "璐ф灦鍏ュ満浠诲姟涓嬪彂", url, containerMoveInPath, null, "127.0.0.1");
 
     }
 
     //璐ф灦绂诲満
-    public int containerMoveOut(List<AgvWrkMast> agvWrkMastList){
-        Map<String,List<Map<String,String>>> containerMoveParam = new HashMap<>();
-        List<Map<String,String>> positionCodeMapList = new ArrayList<>();
-        containerMoveParam.put("containerMoveOuts",positionCodeMapList);
-        for(AgvWrkMast agvWrkMast : agvWrkMastList){
-            Map<String,String> positionCodeMap = new HashMap<>();
-            positionCodeMap.put("positionCode",agvWrkMast.getLocNo());
+    public int containerMoveOut(List<AgvWrkMast> agvWrkMastList) {
+        Map<String, List<Map<String, String>>> containerMoveParam = new HashMap<>();
+        List<Map<String, String>> positionCodeMapList = new ArrayList<>();
+        containerMoveParam.put("containerMoveOuts", positionCodeMapList);
+        for (AgvWrkMast agvWrkMast : agvWrkMastList) {
+            Map<String, String> positionCodeMap = new HashMap<>();
+            positionCodeMap.put("positionCode", agvWrkMast.getLocNo());
             positionCodeMapList.add(positionCodeMap);
         }
-        return doHttpRequest(containerMoveParam,"璐ф灦绂诲満浠诲姟涓嬪彂",url, containerMoveOutPath,null,"127.0.0.1");
+        return doHttpRequest(containerMoveParam, "璐ф灦绂诲満浠诲姟涓嬪彂", url, containerMoveOutPath, null, "127.0.0.1");
     }
 
     public boolean insertByIncrease(AgvWrkMast agvWrkMast) {
@@ -162,25 +162,25 @@
     //璐ф灦鍒拌揪閫氱煡
     public int containerArrived(AgvWrkMast agvWrkMast) {
 
-        Map<String,String> containerArrivedParam = new HashMap<>();
-        containerArrivedParam.put("slotCode",agvWrkMast.getSourceLocNo());
-        containerArrivedParam.put("containerCode",agvWrkMast.getBarcode());
+        Map<String, String> containerArrivedParam = new HashMap<>();
+        containerArrivedParam.put("slotCode", agvWrkMast.getSourceLocNo());
+        containerArrivedParam.put("containerCode", agvWrkMast.getBarcode());
 
-        return doHttpRequest(containerArrivedParam,"璐ф灦杈惧埌閫氱煡",url, containerArrivedPath,null,"127.0.0.1");
+        return doHttpRequest(containerArrivedParam, "璐ф灦杈惧埌閫氱煡", url, containerArrivedPath, null, "127.0.0.1");
     }
 
     @Override
     public List<AgvWrkMast> selectReadyAgvWrkMast() {
         List<String> stationCodes = agvBasDevpService.selectAllStationCode();
         Wrapper<AgvWrkMast> wrapper = new EntityWrapper<AgvWrkMast>().eq("wrk_sts", 21L).like(false, "loc_no", "@");
-        wrapper.in("loc_no",stationCodes);
+        wrapper.in("loc_no", stationCodes);
         return this.selectList(wrapper);
         //return this.baseMapper.selectReadyAgvWrkMast();
     }
 
     @Override
     public AgvWrkMast selectByContainerCode(String containerCode) {
-        return this.selectOne(new EntityWrapper<AgvWrkMast>().eq("barcode",containerCode));
+        return this.selectOne(new EntityWrapper<AgvWrkMast>().eq("barcode", containerCode));
     }
 
     @Override
@@ -189,25 +189,25 @@
         AgvTaskCreateParam agvTaskCreateParam = new AgvTaskCreateParam();
         agvTaskCreateParam.setTaskCode(wrkNo + "");
 
-        return doHttpRequest(agvTaskCreateParam,"鍙栨秷浠诲姟涓嬪彂",url, taskCancelPath,null,"127.0.0.1");
+        return doHttpRequest(agvTaskCreateParam, "鍙栨秷浠诲姟涓嬪彂", url, taskCancelPath, null, "127.0.0.1");
 
     }
 
 
-    private void getContainerMoveParam(List<AgvWrkMast> agvWrkMastList,List<Map<String,String>> positionCodeMapList){
+    private void getContainerMoveParam(List<AgvWrkMast> agvWrkMastList, List<Map<String, String>> positionCodeMapList) {
         //寰�璐ф灦鍏ュ満鍙傛暟涓斁鍏ユ簮绔欑偣浣嶇疆
-        for(AgvWrkMast agvWrkMast : agvWrkMastList){
+        for (AgvWrkMast agvWrkMast : agvWrkMastList) {
             //鍒ゆ柇鏄惁涓鸿緭閫佺嚎鍏ュ簱锛屾槸鍒欎笉闇�瑕佽揣鏋惰繘鍦鸿姹�
-            if("Y".equals(agvWrkMast.getMk())){
+            if ("Y".equals(agvWrkMast.getMk())) {
                 continue;
             }
-            Map<String,String> positionCodeMap = new HashMap<>();
-            positionCodeMap.put("positionCode",agvWrkMast.getSourceLocNo());
+            Map<String, String> positionCodeMap = new HashMap<>();
+            positionCodeMap.put("positionCode", agvWrkMast.getSourceLocNo());
             positionCodeMapList.add(positionCodeMap);
         }
     }
 
-    private void getRequestParam(AgvTaskCreateParam agvTaskCreateParam,AgvWrkMast agvWrkMast){
+    private void getRequestParam(AgvTaskCreateParam agvTaskCreateParam, AgvWrkMast agvWrkMast) {
 
         List<AgvTaskParam> agvTaskParamList = Arrays.asList(
                 //璧峰浣�
@@ -220,7 +220,7 @@
 //        //鐩爣浣�
 //        agvTaskParamList.add(new AgvTaskParam(agvWrkMast.getLocNo()));
 
-        if(agvWrkMast.getIoType() == 53 || agvWrkMast.getIoType() == 57 ){
+        if (agvWrkMast.getIoType() == 53 || agvWrkMast.getIoType() == 57) {
             agvWrkMast.setWrkNo(-agvWrkMast.getWrkNo());
         }
         agvTaskCreateParam.setTaskCode(agvWrkMast.getWrkNo().toString());
@@ -270,32 +270,40 @@
 
     }
 
-    private int doHttpRequest(Object requestParam, String namespace, String url, String path, String appkey, String ip){
+    private int doHttpRequest(Object requestParam, String namespace, String url, String path, String appkey, String ip) {
         String response = "";
         boolean success = false;
         try {
             response = new HttpHandler.Builder()
                     .setUri(url)
                     .setPath(path)
+                    .setTimeout(30, TimeUnit.SECONDS)
                     .setJson(JSONObject.toJSONString(requestParam))
                     .build()
                     .doPost();
             JSONObject jsonObject = JSON.parseObject(response);
 
             int code = Integer.parseInt(jsonObject.get("code").toString());
-            if(code != 0){
-                //TODO 寮犺秴
+            if (code != 0) {
+                if (code == 6) {
+                    log.info("AGV浠诲姟鍗曞彿宸蹭笂鎶�:{}", response);
+                    String message = jsonObject.getString("message");
+                    if (!Cools.isEmpty(message) && message.contains("宸插瓨鍦ㄤ换鍔″崟澶翠负")) {
+                        success = true;
+                        return 0;
+                    }
+                }
                 throw new CoolException("璋冪敤AGV鍝嶅簲閿欒");
                 //return code;
             }
             success = true;
             return code;
-        }catch (Exception e){
+        } catch (Exception e) {
             log.error(e.getMessage());
             //TODO 寮犺秴
             throw new CoolException("璋冪敤AGV鍝嶅簲閿欒");
             //return 1;
-        }finally {
+        } finally {
             apiLogService.save(
                     namespace,
                     url + path,

--
Gitblit v1.9.1