From bedd0a1cef215538df64470df6b8d4a022189136 Mon Sep 17 00:00:00 2001
From: liusheng <337615773@qq.com>
Date: 星期三, 28 八月 2024 14:05:16 +0800
Subject: [PATCH] 代码提交

---
 ruoyi-admin/src/main/java/com/ruoyi/web/component/RedisMqReceiver.java |  201 ++++++++++++++++++++++++++++++-------------------
 1 files changed, 122 insertions(+), 79 deletions(-)

diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/component/RedisMqReceiver.java b/ruoyi-admin/src/main/java/com/ruoyi/web/component/RedisMqReceiver.java
index 4f60fee..f2fedf4 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/component/RedisMqReceiver.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/component/RedisMqReceiver.java
@@ -14,24 +14,16 @@
 import com.smartor.mapper.ServiceTaskMapper;
 import com.smartor.mapper.SvyTaskMapper;
 import com.smartor.mapper.SvyTaskSingleMapper;
-import com.smartor.service.IBaseSmsaccountService;
-import com.smartor.service.IIvrTaskTemplateService;
-import com.smartor.service.IServiceSubtaskRecordService;
-import com.smartor.service.ISvyTaskTemplateService;
+import com.smartor.service.*;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.beans.factory.annotation.Value;
 import org.springframework.data.redis.connection.Message;
 import org.springframework.data.redis.listener.KeyExpirationEventMessageListener;
 import org.springframework.data.redis.listener.RedisMessageListenerContainer;
-import org.springframework.scheduling.annotation.Async;
 import org.springframework.stereotype.Component;
 
-import javax.annotation.Syntax;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
-import java.util.UUID;
+import java.util.*;
 import java.util.concurrent.ExecutorService;
 import java.util.concurrent.Executors;
 import java.util.concurrent.TimeUnit;
@@ -95,56 +87,48 @@
     @Override
     public void onMessage(Message message, byte[] pattern) {
         log.info("鐩戝惉Redis key杩囨湡锛宬ey锛歿}锛宑hannel锛歿}", message.toString(), new String(pattern));
-        synchronized (RedisMqReceiver.class) {
-            String ip = localIP;
-            log.error("鏈満鐨勭綉缁淚P涓�:{}", ip);
-            String content = message.toString();
-            //鍒ゆ柇鏄笉鏄换鍔′俊鎭紝濡傛灉涓嶆槸锛岀洿鎺ヨ繑鍥烇紝涓嶉渶瑕佹墽琛�
-            if (!content.contains("taskid")) {
-                log.info("涓嶆槸浠诲姟淇℃伅");
-                return;
+        String ip = localIP;
+        log.error("鏈満鐨勭綉缁淚P涓�:{}", ip);
+        String content = message.toString();
+        //鍒ゆ柇鏄笉鏄换鍔′俊鎭紝濡傛灉涓嶆槸锛岀洿鎺ヨ繑鍥烇紝涓嶉渶瑕佹墽琛�
+        if (!content.contains("taskid")) {
+            log.info("涓嶆槸浠诲姟淇℃伅");
+            return;
+        }
+        CommonTaskcallMQ commonTaskcallMQ = null;
+        try {
+            ObjectMapper mapper = new ObjectMapper();
+            if (!content.startsWith("{")) {
+                commonTaskcallMQ = mapper.readValue("{" + content + "}", CommonTaskcallMQ.class);
+            } else {
+                commonTaskcallMQ = mapper.readValue(content, CommonTaskcallMQ.class);
             }
-            CommonTaskcallMQ commonTaskcallMQ = null;
-            try {
-                ObjectMapper mapper = new ObjectMapper();
-                if (!content.startsWith("{")) {
-                    commonTaskcallMQ = mapper.readValue("{" + content + "}", CommonTaskcallMQ.class);
-                } else {
-                    commonTaskcallMQ = mapper.readValue(content, CommonTaskcallMQ.class);
-                }
-                //杩欓噷涔嬫墍浠ヨ繖鏍峰仛涓�涓嬶紝鏄悶涓嶆噦锛屼负鍟ヤ細杩涙潵涓ら亶
-                Boolean aBoolean = redisCache.hasKey(commonTaskcallMQ.getTaskid().toString());
-                if (aBoolean) {
-                    return;
-                } else {
-                    redisCache.setCacheObject(commonTaskcallMQ.getTaskid().toString(), commonTaskcallMQ.getTaskid().toString(), 60, TimeUnit.SECONDS);
-                }
-                if (commonTaskcallMQ.getTaskType() == 1) {
-                    //闅忚
-                    sfHandle(commonTaskcallMQ, ip);
-                } else if (commonTaskcallMQ.getTaskType() == 2) {
-                    //闂嵎
-                    wjHandle(commonTaskcallMQ, ip);
-                } else if (commonTaskcallMQ.getTaskType() == 3) {
-                    //瀹f暀
-                    xjHandle(commonTaskcallMQ, ip);
-                }
-                //澶勭悊瀹屾垚锛岀Щ闄edis
-                redisCache.deleteObject(message.toString());
 
-            } catch (Exception e) {
-                Integer integer = redisCache.getCacheObject(commonTaskcallMQ.getTaskid().toString());
-                if (integer != null && integer == 2) {
-                    //灏嗘秷鎭粠闃熷垪涓垹闄�
-                } else if (integer == null) {
-                    redisCache.setCacheObject(commonTaskcallMQ.getTaskid().toString(), 1, 120, TimeUnit.MINUTES);
-                } else {
-                    redisCache.setCacheObject(commonTaskcallMQ.getTaskid().toString(), integer + 1, 120, TimeUnit.MINUTES);
-                }
-
-                log.error("============娑堣垂澶辫触,灏濊瘯娑堟伅琛ュ彂鍐嶆娑堣垂!==============  {}", e.getMessage());
-                redisCache.setCacheObject(message.toString(), message.toString(), 60, TimeUnit.SECONDS);
+            if (commonTaskcallMQ.getTaskType() == 1) {
+                //闅忚
+                sfHandle(commonTaskcallMQ, ip);
+            } else if (commonTaskcallMQ.getTaskType() == 2) {
+                //闂嵎
+                wjHandle(commonTaskcallMQ, ip);
+            } else if (commonTaskcallMQ.getTaskType() == 3) {
+                //瀹f暀
+                xjHandle(commonTaskcallMQ, ip);
             }
+            //澶勭悊瀹屾垚锛岀Щ闄edis
+            redisCache.deleteObject(message.toString());
+
+        } catch (Exception e) {
+            Integer integer = redisCache.getCacheObject(commonTaskcallMQ.getTaskid().toString());
+            if (integer != null && integer == 2) {
+                //灏嗘秷鎭粠闃熷垪涓垹闄�
+            } else if (integer == null) {
+                redisCache.setCacheObject(commonTaskcallMQ.getTaskid().toString(), 1, 120, TimeUnit.MINUTES);
+            } else {
+                redisCache.setCacheObject(commonTaskcallMQ.getTaskid().toString(), integer + 1, 120, TimeUnit.MINUTES);
+            }
+
+            log.error("============娑堣垂澶辫触,灏濊瘯娑堟伅琛ュ彂鍐嶆娑堣垂!==============  {}", e.getMessage());
+            redisCache.setCacheObject(message.toString(), message.toString(), 60, TimeUnit.SECONDS);
         }
     }
 
@@ -153,7 +137,7 @@
      *
      * @param commonTaskcallMQ
      */
-    private void sfHandle(CommonTaskcallMQ commonTaskcallMQ, String ip) {
+    public void sfHandle(CommonTaskcallMQ commonTaskcallMQ, String ip) {
         //鍒ゆ柇涓�涓媍ommonTaskcallMQ涓殑stopstate鏄惁涓巌vr_task涓殑涓�鑷达紝涓嶄竴鑷达紝鍒欒鏄庢槸鏆傚仠浜�
         ServiceTask ivrTask1 = ivrTaskMapper.selectServiceTaskByTaskid(commonTaskcallMQ.getTaskid());
         if (ivrTask1.getStopState() != commonTaskcallMQ.getStopState()) {
@@ -169,10 +153,10 @@
                 String descByCode = ServiceFromEnum.getDescByCode(Integer.valueOf(serviceFrom));
                 //杩欓噷鍙互鑰冭檻鐢ㄧ瓥鐣ユā寮忎紭鍖栦竴涓嬶紝涓嶇劧澶毦鐪嬩簡
 
-                //閫氳繃妯℃澘ID鑾峰彇妯℃澘闂
-                IvrTaskTemplateVO ivrTaskTemplateVO = new IvrTaskTemplateVO();
-                ivrTaskTemplateVO.setId(Long.valueOf(commonTaskcallMQ.getTemplateid()));
-                IvrTaskTemplateVO ivrTaskTemplateVO1 = ivrTaskTemplateService.selectInfoByCondition(ivrTaskTemplateVO);
+//                //閫氳繃妯℃澘ID鑾峰彇妯℃澘闂
+//                IvrTaskTemplateVO ivrTaskTemplateVO = new IvrTaskTemplateVO();
+//                ivrTaskTemplateVO.setId(Long.valueOf(commonTaskcallMQ.getTemplateid()));
+//                IvrTaskTemplateVO ivrTaskTemplateVO1 = ivrTaskTemplateService.selectInfoByCondition(ivrTaskTemplateVO);
 
                 //閫氳繃浠诲姟ID鎷垮埌鎮h�呬俊鎭�
                 ServiceSubtask ivrTaskcall = new ServiceSubtask();
@@ -185,6 +169,37 @@
                             //濡備綍浠诲姟琚�滄殏鍋溾�濇垨鈥滅粓姝⑩��
                             break;
                         }
+                        //鑾峰彇鍒皏alue鍊兼渶灏戠殑key
+                        String key = getKey();
+                        if (commonTaskcallMQ.getSendType().equals("2")) {
+                            //璇存槑鏄珛鍗冲彂閫�
+                            String value = redisCache.getCacheObject("cache-0");
+                            ServiceSubtask serviceSubtask1 = new ServiceSubtask();
+                            serviceSubtask1.setTaskid(commonTaskcallMQ.getTaskid());
+                            List<ServiceSubtask> selectServiceSubtaskList1 = ivrTaskcallMapper.selectServiceSubtaskList(serviceSubtask1);
+                            for (ServiceSubtask serviceSubtask2 : selectServiceSubtaskList1) {
+                                if (StringUtils.isEmpty(value)) {
+                                    value = "," + serviceSubtask2.getId().toString() + ",";
+                                } else {
+                                    value = value + "," + serviceSubtask2.getId().toString() + ",";
+                                }
+                            }
+                            redisCache.setCacheObject("cache-0", value);
+                        } else {
+                            //闈炵珛鍗冲彂閫�
+                            String value = redisCache.getCacheObject(key);
+                            ServiceSubtask serviceSubtask1 = new ServiceSubtask();
+                            serviceSubtask1.setTaskid(commonTaskcallMQ.getTaskid());
+                            List<ServiceSubtask> selectServiceSubtaskList1 = ivrTaskcallMapper.selectServiceSubtaskList(serviceSubtask1);
+                            for (ServiceSubtask serviceSubtask2 : selectServiceSubtaskList1) {
+                                if (StringUtils.isEmpty(value)) {
+                                    value = "," + serviceSubtask2.getId().toString() + ",";
+                                } else {
+                                    value = value + "," + serviceSubtask2.getId().toString() + ",";
+                                }
+                            }
+                            redisCache.setCacheObject(key, value);
+                        }
 
                         //浠诲姟鍙戦�佽褰曪紙杩欎釜浠g爜搴旇鍐欏湪phoneTask涓紝鍏堝啓鍦ㄨ繖锛屽悗闈㈠啀鏀癸級
                         ServiceSubtaskRecord serviceSubtaskRecord = new ServiceSubtaskRecord();
@@ -195,8 +210,8 @@
                         serviceSubtaskRecord.setStartTime(System.currentTimeMillis());
                         serviceSubtaskRecordService.insertServiceSubtaskRecord(serviceSubtaskRecord);
 
-                        //閫氳繃澶氱嚎绋嬬殑鏂瑰紡鍘绘墦鐢佃瘽
-                        executorService.submit(new PhoneTask(serviceSubtask, ivrTaskTemplateVO1, redisCache, sendService, phonePath, robotPhoneUtils));
+//                        //閫氳繃澶氱嚎绋嬬殑鏂瑰紡鍘绘墦鐢佃瘽
+//                        executorService.submit(new PhoneTask(serviceSubtask, ivrTaskTemplateVO1, redisCache, sendService, phonePath, robotPhoneUtils));
                     }
                 } else if (descByCode.equals("澶氬獟浣�")) {
                     //澶氬獟浣�
@@ -215,7 +230,7 @@
                         String patid = rsaPublicKeyExample.encryptedData(serviceSubtask.getPatid().toString(), pub_key);
                         SendMagParam sendMagParam = new SendMagParam();
                         sendMagParam.setType("4");
-                        sendMagParam.setUrl(ip + ":" + req_path + "/followvisit/particty?param1=" + taskId + "&param2=" + patid);
+                        sendMagParam.setUrl(ip + ":" + req_path + "/followvisit/particty?param1=" + taskId + "&param2=" + patid + "&param5=false");
                         Boolean aBoolean = sendService.sendMsg(sendMagParam);
 
 
@@ -230,7 +245,6 @@
                         serviceSubtaskRecordService.insertServiceSubtaskRecord(serviceSubtaskRecord);
                     }
                 } else if (descByCode.equals("鍏紬鍙�")) {
-
                     //鍏紬鍙�
                     RSAPublicKeyExample rsaPublicKeyExample = new RSAPublicKeyExample();
                     String taskId = rsaPublicKeyExample.encryptedData(ivrTask1.getTaskid().toString(), pub_key);
@@ -238,15 +252,14 @@
                         String patid = rsaPublicKeyExample.encryptedData(serviceSubtask.getPatid().toString(), pub_key);
                         SendMagParam sendMagParam = new SendMagParam();
                         sendMagParam.setType("5");
-                        sendMagParam.setUrl(ip + ":" + req_path + "/outsideChain?param1=" + ivrTask1.getTaskid().toString() + "&param2=" + serviceSubtask.getPatid().toString() + "&param3=" + ivrTask1.getTaskName());
-                        log.info("閾炬帴瀹屾暣璺緞锛歿}", req_path + "/outsideChain?param1=" + taskId + "&param2=" + patid + "&param3=" + ivrTask1.getTaskName());
+                        sendMagParam.setUrl(ip + ":" + req_path + "/outsideChain?param1=" + taskId + "&param2=" + patid + "&param3=" + ivrTask1.getTaskName() + "&param5=false");
+                        log.info("閾炬帴瀹屾暣璺緞锛歿}", ip + ":" + req_path + "/outsideChain?param1=" + taskId + "&param2=" + patid + "&param3=" + ivrTask1.getTaskName() + "&param5=false");
                         //杩欎釜妯℃澘ID鍏堝啓姝伙紝鍚庨潰鍋氭垚鍙��
                         sendMagParam.setTmpCode("oG3pJHPVWpE81DmZsua_2tKwgJ97r0qz37z56ns7NB4");
                         Map map = new HashMap();
                         map.put("first", ivrTask1.getTaskName());
                         sendMagParam.setContent(JSON.toJSONString(map));
                         sendMagParam.setOpenid(serviceSubtask.getOpenid());
-
                         Boolean aBoolean = sendService.sendMsg(sendMagParam);
 
                         //浠诲姟鍙戦�佽褰�
@@ -287,10 +300,12 @@
                 //杩欓噷鍙互鑰冭檻鐢ㄧ瓥鐣ユā寮忎紭鍖栦竴涓嬶紝涓嶇劧澶毦鐪嬩簡
 
                 //閫氳繃妯℃澘ID鑾峰彇妯℃澘闂
-                IvrTaskTemplateVO ivrTaskTemplateVO = new IvrTaskTemplateVO();
-                ivrTaskTemplateVO.setId(Long.valueOf(commonTaskcallMQ.getTemplateid()));
-                IvrTaskTemplateVO ivrTaskTemplateVO1 = ivrTaskTemplateService.selectInfoByCondition(ivrTaskTemplateVO);
-
+                IvrTaskTemplateVO ivrTaskTemplateVO1 = null;
+                if (commonTaskcallMQ.getTaskType().equals("1")) {
+                    IvrTaskTemplateVO ivrTaskTemplateVO = new IvrTaskTemplateVO();
+                    ivrTaskTemplateVO.setId(Long.valueOf(commonTaskcallMQ.getTemplateid()));
+                    ivrTaskTemplateVO1 = ivrTaskTemplateService.selectInfoByCondition(ivrTaskTemplateVO);
+                }
                 //閫氳繃浠诲姟ID鎷垮埌鎮h�呬俊鎭�
                 ServiceSubtask ivrTaskcall = new ServiceSubtask();
                 ivrTaskcall.setTaskid(commonTaskcallMQ.getTaskid());
@@ -331,7 +346,7 @@
                         String patid = rsaPublicKeyExample.encryptedData(ivrTaskSingle.getPatid().toString(), pub_key);
                         SendMagParam sendMagParam = new SendMagParam();
                         sendMagParam.setType("4");
-                        sendMagParam.setUrl(ip + ":" + req_path + "/followvisit/particty?param1=" + taskId + "&param2=" + patid);
+                        sendMagParam.setUrl(ip + ":" + req_path + "/followvisit/particty?param1=" + taskId + "&param2=" + patid + "&param5=false");
                         Boolean aBoolean = sendService.sendMsg(sendMagParam);
 
                         //浠诲姟鍙戦�佽褰�
@@ -352,13 +367,14 @@
                         String patid = rsaPublicKeyExample.encryptedData(ivrTaskSingle.getPatid().toString(), pub_key);
                         SendMagParam sendMagParam = new SendMagParam();
                         sendMagParam.setType("5");
-                        sendMagParam.setUrl(ip + ":" + req_path + "/outsideChain?param1=" + taskId + "&param2=" + patid + "&param3=" + ivrTask1.getTaskName());
-                        log.info("閾炬帴瀹屾暣璺緞锛歿}", req_path + "/outsideChain?param1=" + taskId + "&param2=" + patid + "&param3=" + ivrTask1.getTaskName());
+                        sendMagParam.setUrl(ip + ":" + req_path + "/outsideChainxj?param1=" + taskId + "&param2=" + patid + "&param3=" + ivrTask1.getTaskName() + "&param5=false");
+                        log.info("閾炬帴瀹屾暣璺緞锛歿}", req_path + "/outsideChainxj?param1=" + taskId + "&param2=" + patid + "&param3=" + ivrTask1.getTaskName() + "&param5=false");
                         //杩欎釜妯℃澘ID鍏堝啓姝伙紝鍚庨潰鍋氭垚鍙��
                         sendMagParam.setTmpCode("oG3pJHPVWpE81DmZsua_2tKwgJ97r0qz37z56ns7NB4");
                         Map map = new HashMap();
                         map.put("first", ivrTask1.getTaskName());
                         sendMagParam.setContent(JSON.toJSONString(map));
+                        sendMagParam.setOpenid(ivrTaskSingle.getOpenid());
                         Boolean aBoolean = sendService.sendMsg(sendMagParam);
 
                         //浠诲姟鍙戦�佽褰�
@@ -440,8 +456,8 @@
                         String patid = rsaPublicKeyExample.encryptedData(svyTaskSingle1.getPatid().toString(), pub_key);
                         SendMagParam sendMagParam = new SendMagParam();
                         sendMagParam.setType("5");
-                        sendMagParam.setUrl(ip + ":" + req_path + "/outsideChain?param1=" + taskId + "&param2=" + patid + "&param3=" + svyTask.getTaskName());
-                        log.info("閾炬帴瀹屾暣璺緞锛歿}", req_path + "/outsideChain?param1=" + taskId + "&param2=" + patid + "&param3=" + svyTask.getTaskName());
+                        sendMagParam.setUrl(ip + ":" + req_path + "//outsideChainwt?param1=" + taskId + "&param2=" + patid + "&param3=" + svyTask.getTaskName() + "&param5=false");
+                        log.info("閾炬帴瀹屾暣璺緞锛歿}", req_path + "//outsideChainwt?param1=" + taskId + "&param2=" + patid + "&param3=" + svyTask.getTaskName() + "&param5=false");
                         //杩欎釜妯℃澘ID鍏堝啓姝伙紝鍚庨潰鍋氭垚鍙��
                         sendMagParam.setTmpCode("oG3pJHPVWpE81DmZsua_2tKwgJ97r0qz37z56ns7NB4");
                         Map map = new HashMap();
@@ -466,7 +482,7 @@
     }
 
 
-//    /**
+    //    /**
 //     * 鏈哄櫒浜虹涓�鍙ヨ瘽璇煶
 //     * concurrency = "50"  骞跺彂鏁颁负50
 //     */
@@ -501,5 +517,32 @@
 //            channel.basicReject(message.getMessageProperties().getDeliveryTag(), true);
 //        }
 //    }
+    private String getKey() {
+        Map<String, String> map = new HashMap<>();
+        for (int i = 0; i < 6; i++) {
+            Boolean aBoolean = redisCache.hasKey("cache-" + i);
+            if (!aBoolean) {
+                redisCache.setCacheObject("cache-" + i, "");
+                map.put("cache-" + i, "");
+            } else {
+                map.put("cache-" + i, redisCache.getCacheObject("cache-" + i));
+            }
+        }
+
+        String key = null;
+        String value = "";
+        for (Map.Entry<String, String> entry : map.entrySet()) {
+            if (StringUtils.isEmpty(value)) {
+                value = entry.getValue();
+                key = entry.getKey();
+            } else {
+                if (entry.getValue().split(",").length < value.split(",").length) {
+                    value = entry.getValue();
+                    key = entry.getKey();
+                }
+            }
+        }
+        return key;
+    }
 
 }

--
Gitblit v1.9.3