From 580f358ce4e50816211d69ff6e31817b6593d731 Mon Sep 17 00:00:00 2001
From: liusheng <337615773@qq.com>
Date: 星期二, 22 十月 2024 17:32:50 +0800
Subject: [PATCH] 代码提交

---
 ruoyi-admin/src/main/java/com/ruoyi/web/component/RedisMqReceiver.java |  571 ++++++++++++++++++++++++++++++++++++++++++++------------
 1 files changed, 442 insertions(+), 129 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 6429cb2..2db096c 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
@@ -1,20 +1,25 @@
 package com.ruoyi.web.component;
 
 import com.alibaba.fastjson2.JSON;
-import com.fasterxml.jackson.core.JsonProcessingException;
+import com.alibaba.fastjson2.JSONObject;
 import com.fasterxml.jackson.databind.ObjectMapper;
+import com.google.gson.Gson;
 import com.ruoyi.common.core.redis.RedisCache;
 import com.ruoyi.common.enums.ServiceFromEnum;
 import com.ruoyi.common.utils.RSAPublicKeyExample;
 import com.ruoyi.common.utils.StringUtils;
+import com.ruoyi.common.utils.http.HttpUtils;
 import com.ruoyi.web.task.PhoneTask;
 import com.smartor.common.SendService;
 import com.smartor.config.RobotPhoneUtils;
 import com.smartor.domain.*;
-import com.smartor.mapper.IvrTaskMapper;
-import com.smartor.mapper.IvrTaskSingleMapper;
-import com.smartor.service.IIvrTaskTemplateService;
+import com.smartor.mapper.ServiceSubtaskMapper;
+import com.smartor.mapper.ServiceTaskMapper;
+import com.smartor.mapper.SvyTaskMapper;
+import com.smartor.mapper.SvyTaskSingleMapper;
+import com.smartor.service.*;
 import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.collections4.CollectionUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.beans.factory.annotation.Value;
 import org.springframework.data.redis.connection.Message;
@@ -22,9 +27,12 @@
 import org.springframework.data.redis.listener.RedisMessageListenerContainer;
 import org.springframework.stereotype.Component;
 
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
+import java.io.UnsupportedEncodingException;
+import java.net.URLEncoder;
+import java.nio.charset.StandardCharsets;
+import java.time.LocalDateTime;
+import java.time.format.DateTimeFormatter;
+import java.util.*;
 import java.util.concurrent.ExecutorService;
 import java.util.concurrent.Executors;
 import java.util.concurrent.TimeUnit;
@@ -39,21 +47,49 @@
     @Value("${pub_key}")
     private String pub_key;
 
+    @Value("${localIP}")
+    private String localIP;
+
     @Value("${req_path}")
     private String req_path;
 
-    private static IIvrTaskTemplateService ivrTaskTemplateService;
+    @Value("${thirdWXUrl}")
+    private String thirdWXUrl;
 
-    private static IvrTaskSingleMapper ivrTaskcallMapper;
+    @Autowired
+    private IIvrTaskTemplateService ivrTaskTemplateService;
+    @Autowired
+    private ISvyTaskTemplateService svyTaskTemplateService;
 
-    private static IvrTaskMapper ivrTaskMapper;
+    @Autowired
+    private ServiceSubtaskMapper ivrTaskcallMapper;
 
-    private static SendService sendService;
+    @Autowired
+    private ServiceTaskMapper ivrTaskMapper;
 
-    private static RedisCache redisCache;
+    @Autowired
+    private SendService sendService;
 
-    private static RobotPhoneUtils robotPhoneUtils;
+    @Autowired
+    private RedisCache redisCache;
 
+    @Autowired
+    private RobotPhoneUtils robotPhoneUtils;
+
+    @Autowired
+    private ServiceTaskMapper svyTaskMapper;
+
+    @Autowired
+    private ServiceSubtaskMapper serviceSubtaskMapper;
+
+    @Autowired
+    private ISvyTaskTemplateService iSvyTaskTemplateService;
+
+    @Autowired
+    private IServiceSubtaskRecordService serviceSubtaskRecordService;
+
+    @Autowired
+    IBaseSmsaccountService baseSmsaccountService;
 
     // 鍒涘缓鍥哄畾澶у皬鐨勭嚎绋嬫睜
     private static final ExecutorService executorService = Executors.newFixedThreadPool(10);
@@ -62,165 +98,400 @@
         super(listenerContainer);
     }
 
-
-    @Autowired
-    public void setIIvrTaskTemplateService(IIvrTaskTemplateService ivrTaskTemplateService) {
-        RedisMqReceiver.ivrTaskTemplateService = ivrTaskTemplateService;
-    }
-
-    @Autowired
-    public void setRobotPhoneUtilsService(RobotPhoneUtils robotPhoneUtils) {
-        RedisMqReceiver.robotPhoneUtils = robotPhoneUtils;
-    }
-
-    @Autowired
-    public void setSendService(SendService sendService) {
-        RedisMqReceiver.sendService = sendService;
-    }
-
-    @Autowired
-    public void setIvrTaskcallMapper(IvrTaskSingleMapper ivrTaskcallMapper) {
-        RedisMqReceiver.ivrTaskcallMapper = ivrTaskcallMapper;
-    }
-
-    @Autowired
-    public void setIvrTaskMapper(IvrTaskMapper ivrTaskMapper) {
-        RedisMqReceiver.ivrTaskMapper = ivrTaskMapper;
-    }
-
-    @Autowired
-    public void setRedisCache(RedisCache redisCache) {
-        RedisMqReceiver.redisCache = redisCache;
-    }
-
     @Override
     public void onMessage(Message message, byte[] pattern) {
         log.info("鐩戝惉Redis key杩囨湡锛宬ey锛歿}锛宑hannel锛歿}", message.toString(), new String(pattern));
+        String ip = localIP;
+        log.error("鏈満鐨勭綉缁淚P涓�:{}", ip);
         String content = message.toString();
         //鍒ゆ柇鏄笉鏄换鍔′俊鎭紝濡傛灉涓嶆槸锛岀洿鎺ヨ繑鍥烇紝涓嶉渶瑕佹墽琛�
         if (!content.contains("taskid")) {
             log.info("涓嶆槸浠诲姟淇℃伅");
             return;
         }
-        IvrTaskcallMQ ivrTaskcallMQ = null;
+        CommonTaskcallMQ commonTaskcallMQ = null;
         try {
             ObjectMapper mapper = new ObjectMapper();
-            try {
-                if (!content.startsWith("{")) {
-                    ivrTaskcallMQ = mapper.readValue("{" + content + "}", IvrTaskcallMQ.class);
-                } else {
-                    ivrTaskcallMQ = mapper.readValue(content, IvrTaskcallMQ.class);
+            if (!content.startsWith("{")) {
+                commonTaskcallMQ = mapper.readValue("{" + content + "}", CommonTaskcallMQ.class);
+            } else {
+                commonTaskcallMQ = mapper.readValue(content, CommonTaskcallMQ.class);
+            }
+            if (commonTaskcallMQ != null) tsakHandle(commonTaskcallMQ, ip, commonTaskcallMQ.getTaskType());
+
+            //澶勭悊瀹屾垚锛岀Щ闄edis
+            redisCache.deleteObject(message.toString());
+            //灏嗙姸鎬佹敼鎴愬畬鎴�
+            ServiceTask serviceTask = new ServiceTask();
+            serviceTask.setTaskid(Long.valueOf(commonTaskcallMQ.getTaskid()));
+            serviceTask.setSendState(5L);
+            serviceTask.setFail(1L);
+            svyTaskMapper.updateServiceTask(serviceTask);
+        } catch (Exception e) {
+            Integer integer = redisCache.getCacheObject(commonTaskcallMQ.getTaskid().toString());
+            if (integer != null && integer == 3) {
+                redisCache.deleteObject(message.toString());
+                ServiceTask serviceTask = new ServiceTask();
+                serviceTask.setTaskid(Long.valueOf(commonTaskcallMQ.getTaskid().toString()));
+                serviceTask.setFail(0L);
+                svyTaskMapper.updateServiceTask(serviceTask);
+                //灏嗘秷鎭粠闃熷垪涓垹闄�
+            } 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);
+        }
+    }
+
+    /**
+     * 浠诲姟澶勭悊
+     *
+     * @param commonTaskcallMQ
+     */
+    public void tsakHandle(CommonTaskcallMQ commonTaskcallMQ, String ip, Integer type) {
+        log.error("杩涗换鍔′簡鍚楋紵{}", commonTaskcallMQ);
+        //鍒ゆ柇涓�涓媍ommonTaskcallMQ涓殑stopstate鏄惁涓巌vr_task涓殑涓�鑷达紝涓嶄竴鑷达紝鍒欒鏄庢槸鏆傚仠浜�
+        ServiceTask ivrTask1 = ivrTaskMapper.selectServiceTaskByTaskid(commonTaskcallMQ.getTaskid());
+        if (ivrTask1.getStopState() != commonTaskcallMQ.getStopState()) {
+            //灏嗘秷鎭粠闃熷垪涓墧闄�
+            return;
+        }
+
+        if (StringUtils.isNotEmpty(commonTaskcallMQ.getPreachform())) {
+            //濡備綍浠诲姟鍙戦�佹柟寮忎笉涓虹┖
+            String[] split = commonTaskcallMQ.getPreachform().split(",");
+            log.error("split鐨勫�间负锛歿}", split);
+
+            //瀹氫箟涓�涓泦鍚堬紝鐢ㄤ笌瀛樻病鏈夋墽琛岀殑瀛愪换鍔D
+            List<Long> subIds = new ArrayList<>();
+            //涓存椂瀛樻病鏈夋墽琛岀殑瀛愪换鍔D
+            List<Long> lssubIds = new ArrayList<>();
+            //鏄惁灏嗗叏閮ㄦ偅鑰呰�呭彂閫佸畬
+            Boolean isSend = false;
+
+            aa:
+            for (String serviceFrom : split) {
+                String descByCode = ServiceFromEnum.getDescByCode(Integer.valueOf(serviceFrom));
+                if (isSend == true) {
+                    break aa;
                 }
-            } catch (JsonProcessingException e) {
-                e.printStackTrace();
-            }
-            //鍒ゆ柇涓�涓媔vrTaskcallMQ涓殑stopstate鏄惁涓巌vr_task涓殑涓�鑷达紝涓嶄竴鑷达紝鍒欒鏄庢槸鏆傚仠浜�
-            IvrTask ivrTask1 = ivrTaskMapper.selectIvrTaskByTaskid(ivrTaskcallMQ.getTaskid());
-            if (ivrTask1.getStopState() != ivrTaskcallMQ.getStopState()) {
-                //灏嗘秷鎭粠闃熷垪涓墧闄�
-                return;
-            }
 
-            if (StringUtils.isNotEmpty(ivrTaskcallMQ.getPreachform())) {
-                //濡備綍浠诲姟鍙戦�佹柟寮忎笉涓虹┖
-                String[] split = ivrTaskcallMQ.getPreachform().split(",");
-                System.out.println("split鐨勫�间负锛�" + split);
-                for (String serviceFrom : split) {
-                    String descByCode = ServiceFromEnum.getDescByCode(Integer.valueOf(serviceFrom));
-                    //杩欓噷鍙互鑰冭檻鐢ㄧ瓥鐣ユā寮忎紭鍖栦竴涓嬶紝涓嶇劧澶毦鐪嬩簡
+                //閫氳繃浠诲姟ID鎷垮埌鎮h�呬俊鎭�
+                ServiceSubtaskVO ivrTaskcall = new ServiceSubtaskVO();
+                ivrTaskcall.setTaskid(commonTaskcallMQ.getTaskid());
+                ivrTaskcall.setSendstate(1L);
+                List<ServiceSubtask> selectServiceSubtaskList = ivrTaskcallMapper.selectServiceSubtaskList(ivrTaskcall);
+                if (descByCode.equals("鐢佃瘽")) {
+                    for (ServiceSubtask serviceSubtask : selectServiceSubtaskList) {
+                        //鍏堝垽鏂竴涓嬶紝subIds鏄惁涓虹┖锛屽鏋滀笉涓虹┖锛屽彧鎵цsubIds閲岀殑鎮h��
+                        if (CollectionUtils.isNotEmpty(subIds)) {
+                            boolean contains = subIds.contains(serviceSubtask.getId());
+                            //濡傛灉contains涓嶄负true,璇存槑褰撳墠鐨勬偅鑰呭凡缁忓彂閫佹垚鍔燂紝鐩存帴寰幆涓嬩竴涓汉灏辫
+                            if (!contains) continue;
+                        }
 
-                    //閫氳繃妯℃澘ID鑾峰彇妯℃澘闂
-                    IvrTaskTemplateVO ivrTaskTemplateVO = new IvrTaskTemplateVO();
-                    ivrTaskTemplateVO.setID(Long.valueOf(ivrTaskcallMQ.getTemplateid()));
-                    IvrTaskTemplateVO ivrTaskTemplateVO1 = ivrTaskTemplateService.selectInfoByCondition(ivrTaskTemplateVO);
-
-                    //閫氳繃浠诲姟ID鎷垮埌鎮h�呬俊鎭�
-                    IvrTaskSingle ivrTaskcall = new IvrTaskSingle();
-                    ivrTaskcall.setTaskid(ivrTaskcallMQ.getTaskid());
-                    List<IvrTaskSingle> ivrTaskcalls = ivrTaskcallMapper.selectIvrTaskcallList(ivrTaskcall);
-                    if (descByCode.equals("鐢佃瘽")) {
-                        for (IvrTaskSingle ivrTaskcall1 : ivrTaskcalls) {
-                            IvrTask ivrTask = ivrTaskMapper.selectIvrTaskByTaskid(ivrTaskcall1.getTaskid());
+                        try {
+                            ServiceTask ivrTask = ivrTaskMapper.selectServiceTaskByTaskid(serviceSubtask.getTaskid());
                             if (ivrTask.getSendState() != null && ivrTask.getSendState() == 3 || ivrTask.getSendState() != null && ivrTask.getSendState() == 4) {
                                 //濡備綍浠诲姟琚�滄殏鍋溾�濇垨鈥滅粓姝⑩��
                                 break;
                             }
-                            //閫氳繃澶氱嚎绋嬬殑鏂瑰紡鍘绘墦鐢佃瘽
-                            executorService.submit(new PhoneTask(ivrTaskcall1, ivrTaskTemplateVO1, redisCache, sendService, phonePath, robotPhoneUtils));
+                            //鑾峰彇鍒皏alue鍊兼渶灏戠殑key
+                            String key = getKey();
+                            if (commonTaskcallMQ.getSendType().equals("2")) {
+                                //璇存槑鏄珛鍗冲彂閫�
+                                String value = redisCache.getCacheObject("cache-0");
+                                ServiceSubtaskVO serviceSubtask1 = new ServiceSubtaskVO();
+                                serviceSubtask1.setTaskid(commonTaskcallMQ.getTaskid());
+                                List<ServiceSubtask> selectServiceSubtaskList1 = ivrTaskcallMapper.selectServiceSubtaskList(serviceSubtask1);
+                                for (ServiceSubtask serviceSubtask2 : selectServiceSubtaskList1) {
+                                    if (StringUtils.isEmpty(value)) {
+                                        value = "," + serviceSubtask2.getId().toString() + ",";
+                                    } else {
+                                        if (!value.contains("," + serviceSubtask2.getId().toString()))
+                                            value = value + "," + serviceSubtask2.getId().toString() + ",";
+                                    }
+                                }
+                                redisCache.setCacheObject("cache-0", value);
+                            } else {
+                                //闈炵珛鍗冲彂閫�
+                                String value = redisCache.getCacheObject(key);
+                                ServiceSubtaskVO serviceSubtask1 = new ServiceSubtaskVO();
+                                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);
+                            }
+                        } catch (Exception exception) {
+                            ServiceSubtaskRecord serviceSubtaskRecord = new ServiceSubtaskRecord();
+                            serviceSubtaskRecord.setTaskid(serviceSubtask.getTaskid().toString());
+                            serviceSubtaskRecord.setSubtaskId(serviceSubtask.getId());
+                            serviceSubtaskRecord.setUuid(UUID.randomUUID().toString());
+                            serviceSubtaskRecord.setTasktype(serviceSubtask.getType());
+                            serviceSubtaskRecord.setPreachform("3");
+                            serviceSubtaskRecord.setResult("fail");
+                            serviceSubtaskRecord.setStartTime(System.currentTimeMillis());
+                            serviceSubtaskRecord.setRemark("鐢佃瘽鍙戦�佸け璐�");
+                            log.error("鐢佃瘽鍙戦�佸け璐ワ細{}", exception.getMessage());
+                            lssubIds.add(serviceSubtask.getId());
+                            serviceSubtaskRecordService.insertServiceSubtaskRecord(serviceSubtaskRecord);
+                            continue;
                         }
-                    } else if (descByCode.equals("澶氬獟浣�")) {
-                        //澶氬獟浣�
-                    } else if (descByCode.equals("绾歌川")) {
-                        //绾歌川
-                    } else if (descByCode.equals("鐭俊")) {
-                        //鐭俊
+                        //鍦ㄥ瓙浠诲姟琛ㄩ噷璁板綍涓�涓�
+                        String uuid = UUID.randomUUID().toString();
+                        serviceSubtask.setResult("success");
+                        serviceSubtask.setRemark("鐢佃瘽鍙戦�佹垚鍔�");
+                        serviceSubtask.setGuid(uuid);
+                        serviceSubtask.setSendstate(6L);
+                        serviceSubtask.setFinishtime(new Date());
+                        serviceSubtaskMapper.updateServiceSubtask(serviceSubtask);
+
+                        //浠诲姟鍙戦�佽褰�
+                        ServiceSubtaskRecord serviceSubtaskRecord = new ServiceSubtaskRecord();
+                        serviceSubtaskRecord.setTaskid(serviceSubtask.getTaskid().toString());
+                        serviceSubtaskRecord.setSubtaskId(serviceSubtask.getId());
+                        serviceSubtaskRecord.setUuid(uuid);
+                        serviceSubtaskRecord.setTasktype(serviceSubtask.getType());
+                        serviceSubtaskRecord.setPreachform("3");
+                        serviceSubtaskRecord.setStartTime(System.currentTimeMillis());
+                        serviceSubtaskRecord.setRemark("鐢佃瘽鍙戦�佹垚鍔�");
+                        serviceSubtaskRecordService.insertServiceSubtaskRecord(serviceSubtaskRecord);
+                    }
+                    if (CollectionUtils.isEmpty(lssubIds)) {
+                        //濡傛灉鈥滀复鏃跺瓙浠诲姟鈥濅负绌猴紝璇存槑鍏ㄥ彂閫佸畬浜�
+                        isSend = true;
+                    }
+                    //灏嗗瓙浠诲姟ID娓呯┖锛屽皢鈥滀复鏃跺瓙浠诲姟鈥濇暟鎹� 鏀惧埌 鈥滃瓙浠诲姟鈥� 涓�
+                    subIds.clear();
+                    subIds.addAll(lssubIds);
+                    lssubIds.clear();
+                } else if (descByCode.equals("澶氬獟浣�")) {
+                    //澶氬獟浣�
+                    continue;
+                } else if (descByCode.equals("绾歌川")) {
+                    //绾歌川
+                    continue;
+                } else if (descByCode.equals("鐭俊")) {
+                    //鐭俊
 //                        http://localhost:8099/followvisit/particty?param1=3&param2=348
-                        //瀵箄rl涓袱涓弬鏁板姞瀵�
-                        RSAPublicKeyExample rsaPublicKeyExample = new RSAPublicKeyExample();
-                        String taskId = rsaPublicKeyExample.encryptedData(ivrTask1.getTaskid().toString(), pub_key);
+                    //瀵箄rl涓袱涓弬鏁板姞瀵�
+                    RSAPublicKeyExample rsaPublicKeyExample = new RSAPublicKeyExample();
+                    String taskId = rsaPublicKeyExample.encryptedData(ivrTask1.getTaskid().toString(), pub_key);
 
+                    for (ServiceSubtask serviceSubtask : selectServiceSubtaskList) {
+                        //鍏堝垽鏂竴涓嬶紝subIds鏄惁涓虹┖锛屽鏋滀笉涓虹┖锛屽彧鎵цsubIds閲岀殑鎮h��
+                        if (CollectionUtils.isNotEmpty(subIds)) {
+                            boolean contains = subIds.contains(serviceSubtask.getId());
+                            //濡傛灉contains涓嶄负true,璇存槑褰撳墠鐨勬偅鑰呭凡缁忓彂閫佹垚鍔燂紝鐩存帴寰幆涓嬩竴涓汉灏辫
+                            if (!contains) continue;
+                        }
 
-                        for (IvrTaskSingle ivrTaskSingle : ivrTaskcalls) {
-                            String patid = rsaPublicKeyExample.encryptedData(ivrTaskSingle.getPatid().toString(), pub_key);
+                        try {
+                            String patid = rsaPublicKeyExample.encryptedData(serviceSubtask.getPatid().toString(), pub_key);
                             SendMagParam sendMagParam = new SendMagParam();
                             sendMagParam.setType("4");
-                            sendMagParam.setUrl(req_path + "/followvisit/particty?param1=" + taskId + "&param2=" + patid);
-                            sendService.sendMsg(sendMagParam);
+                            if (type == 1) {
+                                sendMagParam.setUrl(ip + ":" + req_path + "/followvisit/particty?param1=" + taskId + "&param2=" + patid + "&param5=false");
+                            } else if (type == 1) {
+                                sendMagParam.setUrl(ip + ":" + req_path + "/outsideChainwt?param1=" + taskId + "&param2=" + patid + "&param3=" + URLEncoder.encode(ivrTask1.getTaskName(), StandardCharsets.UTF_8.toString()) + "&param5=false");
+                            } else if (type == 3) {
+                                sendMagParam.setUrl(ip + ":" + req_path + "/outsideChainxj?param1=" + taskId + "&param2=" + patid + "&param3=" + URLEncoder.encode(ivrTask1.getTaskName(), StandardCharsets.UTF_8.toString()) + "&param5=false");
+                            }
+                            Boolean aBoolean = sendService.sendMsg(sendMagParam);
+
+                            if (!aBoolean) {
+                                ServiceSubtaskRecord serviceSubtaskRecord = new ServiceSubtaskRecord();
+                                serviceSubtaskRecord.setTaskid(serviceSubtask.getTaskid().toString());
+                                serviceSubtaskRecord.setSubtaskId(serviceSubtask.getId());
+                                serviceSubtaskRecord.setUuid(UUID.randomUUID().toString());
+                                serviceSubtaskRecord.setTasktype(serviceSubtask.getType());
+                                serviceSubtaskRecord.setPreachform("4");
+                                serviceSubtaskRecord.setStartTime(System.currentTimeMillis());
+                                serviceSubtaskRecord.setRemark("鐭俊鍙戦�佸け璐�");
+                                lssubIds.add(serviceSubtask.getId());
+                                serviceSubtaskRecordService.insertServiceSubtaskRecord(serviceSubtaskRecord);
+                                continue;
+                            }
+                        } catch (Exception e) {
+                            ServiceSubtaskRecord serviceSubtaskRecord = new ServiceSubtaskRecord();
+                            serviceSubtaskRecord.setTaskid(serviceSubtask.getTaskid().toString());
+                            serviceSubtaskRecord.setSubtaskId(serviceSubtask.getId());
+                            serviceSubtaskRecord.setUuid(UUID.randomUUID().toString());
+                            serviceSubtaskRecord.setTasktype(serviceSubtask.getType());
+                            serviceSubtaskRecord.setPreachform("4");
+                            serviceSubtaskRecord.setResult("fail");
+                            serviceSubtaskRecord.setStartTime(System.currentTimeMillis());
+                            serviceSubtaskRecord.setRemark("鐭俊鍙戦�佸け璐�");
+                            log.error("鐭俊鍙戦�佸け璐ワ細{}", e.getMessage());
+                            lssubIds.add(serviceSubtask.getId());
+                            serviceSubtaskRecordService.insertServiceSubtaskRecord(serviceSubtaskRecord);
+                            continue;
                         }
-                    } else if (descByCode.equals("鍏紬鍙�")) {
-                        //鍏紬鍙�
-                        RSAPublicKeyExample rsaPublicKeyExample = new RSAPublicKeyExample();
-                        String taskId = rsaPublicKeyExample.encryptedData(ivrTask1.getTaskid().toString(), pub_key);
-                        for (IvrTaskSingle ivrTaskSingle : ivrTaskcalls) {
-                            String patid = rsaPublicKeyExample.encryptedData(ivrTaskSingle.getPatid().toString(), pub_key);
-                            SendMagParam sendMagParam = new SendMagParam();
-                            sendMagParam.setType("5");
-                            sendMagParam.setUrl(req_path + "/outsideChain?param1=" + taskId + "&param2=" + patid + "&param3=" + ivrTask1.getTaskName());
-                            log.info("閾炬帴瀹屾暣璺緞锛歿}", req_path + "/outsideChain?param1=" + taskId + "&param2=" + patid + "&param3=" + ivrTask1.getTaskName());
-                            //杩欎釜妯℃澘ID鍏堝啓姝伙紝鍚庨潰鍋氭垚鍙��
-                            sendMagParam.setTmpCode("oG3pJHPVWpE81DmZsua_2tKwgJ97r0qz37z56ns7NB4");
-                            Map map = new HashMap();
-                            map.put("first", ivrTask1.getTaskName());
-                            sendMagParam.setContent(JSON.toJSONString(map));
-                            sendService.sendMsg(sendMagParam);
-                        }
+
+                        //鍦ㄥ瓙浠诲姟琛ㄩ噷璁板綍涓�涓�
+                        String uuid = UUID.randomUUID().toString();
+                        serviceSubtask.setResult("success");
+                        serviceSubtask.setRemark("鐭俊鍙戦�佹垚鍔�");
+                        serviceSubtask.setGuid(uuid);
+                        serviceSubtask.setSendstate(3L);
+                        serviceSubtask.setFinishtime(new Date());
+                        serviceSubtaskMapper.updateServiceSubtask(serviceSubtask);
+
+                        //浠诲姟鍙戦�佽褰�
+                        ServiceSubtaskRecord serviceSubtaskRecord = new ServiceSubtaskRecord();
+                        serviceSubtaskRecord.setTaskid(serviceSubtask.getTaskid().toString());
+                        serviceSubtaskRecord.setSubtaskId(serviceSubtask.getId());
+                        serviceSubtaskRecord.setUuid(uuid);
+                        serviceSubtaskRecord.setTasktype(serviceSubtask.getType());
+                        serviceSubtaskRecord.setPreachform("5");
+                        serviceSubtaskRecord.setStartTime(System.currentTimeMillis());
+                        serviceSubtaskRecord.setResult("success");
+                        serviceSubtaskRecord.setRemark("鐭俊鍙戦�佹垚鍔�");
+                        serviceSubtaskRecordService.insertServiceSubtaskRecord(serviceSubtaskRecord);
+
                     }
-                    //閫氱煡 MQ 娑堟伅宸茶鎺ユ敹,鍙互ACK(浠庨槦鍒椾腑鍒犻櫎)浜�   锛堣繖涓渶瑕佹牴鎹笟鍔″啀鍘诲鐞咥CK锛�
+                    if (CollectionUtils.isEmpty(lssubIds)) {
+                        //濡傛灉鈥滀复鏃跺瓙浠诲姟鈥濅负绌猴紝璇存槑鍏ㄥ彂閫佸畬浜�
+                        isSend = true;
+                    }
+                    //灏嗗瓙浠诲姟ID娓呯┖锛屽皢鈥滀复鏃跺瓙浠诲姟鈥濇暟鎹� 鏀惧埌 鈥滃瓙浠诲姟鈥� 涓�
+                    subIds.clear();
+                    subIds.addAll(lssubIds);
+                    lssubIds.clear();
+                } else if (descByCode.equals("鍏紬鍙�")) {
+                    //鍏紬鍙�
+                    RSAPublicKeyExample rsaPublicKeyExample = new RSAPublicKeyExample();
+                    String taskId = rsaPublicKeyExample.encryptedData(ivrTask1.getTaskid().toString(), pub_key);
+                    for (ServiceSubtask serviceSubtask : selectServiceSubtaskList) {
+                        String patid = rsaPublicKeyExample.encryptedData(serviceSubtask.getPatid().toString(), pub_key);
+
+//                        SendMagParam sendMagParam = new SendMagParam();
+//                        sendMagParam.setType("5");
+//                        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);
+                        String url = null;
+                        try {
+                            if (type == 1) {
+                                url = ip + ":" + req_path + "/outsideChain?param1=" + taskId + "&param2=" + patid + "&param3=" + URLEncoder.encode(ivrTask1.getTaskName(), StandardCharsets.UTF_8.toString()) + "&param5=false";
+                            } else if (type == 2) {
+                                url = ip + ":" + req_path + "/outsideChainwt?param1=" + taskId + "&param2=" + patid + "&param3=" + URLEncoder.encode(ivrTask1.getTaskName(), StandardCharsets.UTF_8.toString()) + "&param5=false";
+                            } else if (type == 3) {
+                                url = ip + ":" + req_path + "/outsideChainxj?param1=" + taskId + "&param2=" + patid + "&param3=" + URLEncoder.encode(ivrTask1.getTaskName(), StandardCharsets.UTF_8.toString()) + "&param5=false";
+                            }
+
+                            String wxCode = getWXCode(serviceSubtask.getSfzh(), url, serviceSubtask.getTaskName(), serviceSubtask.getTaskDesc(), "鏃�");
+                            Map<String, Object> map = JSONObject.parseObject(wxCode, Map.class);
+                            if (!map.isEmpty()) {
+                                serviceSubtask.setResult("success");
+                                serviceSubtask.setSendstate(3L);
+                                if ((Boolean) map.get("succ") == false) {
+                                    ServiceSubtaskRecord serviceSubtaskRecord = new ServiceSubtaskRecord();
+                                    serviceSubtaskRecord.setTaskid(serviceSubtask.getTaskid().toString());
+                                    serviceSubtaskRecord.setSubtaskId(serviceSubtask.getId());
+                                    serviceSubtaskRecord.setUuid(UUID.randomUUID().toString());
+                                    serviceSubtaskRecord.setTasktype(serviceSubtask.getType());
+                                    serviceSubtaskRecord.setPreachform("5");
+                                    serviceSubtaskRecord.setStartTime(System.currentTimeMillis());
+                                    serviceSubtaskRecord.setRemark(map.get("msg").toString());
+                                    lssubIds.add(serviceSubtask.getId());
+                                    serviceSubtaskRecordService.insertServiceSubtaskRecord(serviceSubtaskRecord);
+                                    continue;
+                                }
+                            }
+                        } catch (Exception e) {
+                            ServiceSubtaskRecord serviceSubtaskRecord = new ServiceSubtaskRecord();
+                            serviceSubtaskRecord.setTaskid(serviceSubtask.getTaskid().toString());
+                            serviceSubtaskRecord.setSubtaskId(serviceSubtask.getId());
+                            serviceSubtaskRecord.setUuid(UUID.randomUUID().toString());
+                            serviceSubtaskRecord.setTasktype(serviceSubtask.getType());
+                            serviceSubtaskRecord.setPreachform("5");
+                            serviceSubtaskRecord.setResult("fail");
+                            serviceSubtaskRecord.setStartTime(System.currentTimeMillis());
+                            serviceSubtaskRecord.setRemark("鍏紬鍙峰彂閫佸け璐�");
+                            log.error("鍏紬鍙峰彂閫佸け璐ワ細{}", e.getMessage());
+                            lssubIds.add(serviceSubtask.getId());
+                            serviceSubtaskRecordService.insertServiceSubtaskRecord(serviceSubtaskRecord);
+                            continue;
+                        }
+                        //鍦ㄥ瓙浠诲姟琛ㄩ噷璁板綍涓�涓�
+                        String uuid = UUID.randomUUID().toString();
+                        serviceSubtask.setResult("success");
+                        serviceSubtask.setRemark("鍏紬鍙峰彂閫佹垚鍔�");
+                        serviceSubtask.setGuid(uuid);
+                        serviceSubtask.setSendstate(3L);
+                        serviceSubtask.setFinishtime(new Date());
+                        serviceSubtaskMapper.updateServiceSubtask(serviceSubtask);
+
+                        //浠诲姟鍙戦�佽褰�
+                        ServiceSubtaskRecord serviceSubtaskRecord = new ServiceSubtaskRecord();
+                        serviceSubtaskRecord.setTaskid(serviceSubtask.getTaskid().toString());
+                        serviceSubtaskRecord.setUuid(uuid);
+                        serviceSubtaskRecord.setTasktype(serviceSubtask.getType());
+                        serviceSubtaskRecord.setPreachform("5");
+                        serviceSubtaskRecord.setStartTime(System.currentTimeMillis());
+                        serviceSubtaskRecord.setResult("success");
+                        serviceSubtaskRecord.setRemark("鍏紬鍙峰彂閫佹垚鍔�");
+                        serviceSubtaskRecordService.insertServiceSubtaskRecord(serviceSubtaskRecord);
+                    }
+                    if (CollectionUtils.isEmpty(lssubIds)) {
+                        //濡傛灉鈥滀复鏃跺瓙浠诲姟鈥濅负绌猴紝璇存槑鍏ㄥ彂閫佸畬浜�
+                        isSend = true;
+                    }
+                    //灏嗗瓙浠诲姟ID娓呯┖锛屽皢鈥滀复鏃跺瓙浠诲姟鈥濇暟鎹� 鏀惧埌 鈥滃瓙浠诲姟鈥� 涓�
+                    subIds.clear();
+                    subIds.addAll(lssubIds);
+                    lssubIds.clear();
+                }
+                //閫氱煡 MQ 娑堟伅宸茶鎺ユ敹,鍙互ACK(浠庨槦鍒椾腑鍒犻櫎)浜�   锛堣繖涓渶瑕佹牴鎹笟鍔″啀鍘诲鐞咥CK锛�
+            }
+            if (CollectionUtils.isNotEmpty(subIds)) {
+                //濡傛灉鍏ㄩ儴鐨勫彂閫佹柟寮忛兘鍙戝畬浜嗭紝杩樻湁鏄湭鍙戦�佺殑,闇�瑕佸幓subTask琛ㄤ腑锛岃褰曚竴涓嬶紝鍙戦�佸け璐�
+                for (Long id : subIds) {
+                    ServiceSubtask serviceSubtask = new ServiceSubtask();
+                    serviceSubtask.setResult("error");
+                    serviceSubtask.setRemark("鍙戦�佸け璐�");
+                    serviceSubtask.setSendstate(5L);
+                    serviceSubtask.setId(id);
+                    serviceSubtask.setFinishtime(new Date());
+                    serviceSubtaskMapper.updateServiceSubtask(serviceSubtask);
                 }
             }
-        } catch (Exception e) {
-            Integer integer = redisCache.getCacheObject(ivrTaskcallMQ.getTaskid().toString());
-            if (integer != null && integer == 2) {
-                //灏嗘秷鎭粠闃熷垪涓垹闄�
-            } else if (integer == null) {
-                redisCache.setCacheObject(ivrTaskcallMQ.getTaskid().toString(), 1, 120, TimeUnit.MINUTES);
-            } else {
-                redisCache.setCacheObject(ivrTaskcallMQ.getTaskid().toString(), integer + 1, 120, TimeUnit.MINUTES);
-            }
-
-            log.error("============娑堣垂澶辫触,灏濊瘯娑堟伅琛ュ彂鍐嶆娑堣垂!==============");
-            log.error(e.getMessage());
-            redisCache.setCacheObject(message.toString(), message.toString(), 60, TimeUnit.SECONDS);
         }
 
     }
 
-//    /**
+    //    /**
 //     * 鏈哄櫒浜虹涓�鍙ヨ瘽璇煶
 //     * concurrency = "50"  骞跺彂鏁颁负50
 //     */
 //    @RabbitListener(queues = "ob_queue", concurrency = "50")
 //    public void obVisit(String content, Message message, Channel channel) throws IOException {
 //        try {
-//            IvrTaskcallPhoneMQ ivrTaskcallMQ = null;
+//            IvrTaskcallPhoneMQ commonTaskcallMQ = null;
 //            ObjectMapper mapper = new ObjectMapper();
-//            ivrTaskcallMQ = mapper.readValue(content, IvrTaskcallPhoneMQ.class);
+//            commonTaskcallMQ = mapper.readValue(content, IvrTaskcallPhoneMQ.class);
 //            //鍒ゆ柇鎮h�呮槸鍚﹀凡缁忔帴鐢佃瘽
-//            String str = redisCache.getCacheObject(ivrTaskcallMQ.getUuid() + "state_id");
+//            String str = redisCache.getCacheObject(commonTaskcallMQ.getUuid() + "state_id");
 //            System.out.println("-----------------" + str);
 //            if (StringUtils.isNotEmpty(str) && str.equals("0")) {
 //                //鎮h�呭凡缁忔帴鍚簡鐢佃瘽
-//                new PhoneUtils().ttsPlayback(ivrTaskcallMQ.getScript(), ivrTaskcallMQ.getUuid());
+//                new PhoneUtils().ttsPlayback(commonTaskcallMQ.getScript(), commonTaskcallMQ.getUuid());
 //            } else if (StringUtils.isNotEmpty(str) && str.equals("-10")) {
 //                //杩欎釜璇存槑,宸茬粡鎵撲簡鎸囧畾閬嶆暟杩樻槸娌℃湁浜烘帴锛屽彲浠ュ皢娑堟伅浠庨槦鍒椾腑绉婚櫎浜�
 //                channel.basicAck(message.getMessageProperties().getDeliveryTag(), false);
@@ -240,5 +511,47 @@
 //            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;
+    }
+
+    private String getWXCode(String idcard, String url, String taskName, String taskDesc, String submitprompt) {
+        XinHuaWXReq xinHuaWXReq = new XinHuaWXReq();
+        xinHuaWXReq.setIdcard(idcard);
+        xinHuaWXReq.setUrl(url);
+        xinHuaWXReq.setKeyword1("娴欎腑鍖诲ぇ浜岄櫌鍑洪櫌闅忚");
+        xinHuaWXReq.setKeyword2(LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyy-MM-dd")));
+        xinHuaWXReq.setKeyword3(taskName);
+        xinHuaWXReq.setKeyword4("鐤剧梾搴峰娉ㄦ剰浜嬮」");
+
+        String result = HttpUtils.sendPost(thirdWXUrl, new Gson().toJson(xinHuaWXReq));
+        JSONObject jsonObject = JSONObject.parseObject(result);
+        String code = (String) jsonObject.toString();
+        return code;
+    }
 
 }

--
Gitblit v1.9.3