From ea6e1675bbd411e30b21369698ed4b0587c21c0e Mon Sep 17 00:00:00 2001
From: java110 <928255095@qq.com>
Date: 星期六, 08 五月 2021 13:45:34 +0800
Subject: [PATCH] 优化代码

---
 service-job/src/main/java/com/java110/job/task/wechat/WeChatPushMessageTemplate.java |  228 +++++++++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 190 insertions(+), 38 deletions(-)

diff --git a/service-job/src/main/java/com/java110/job/task/wechat/WeChatPushMessageTemplate.java b/service-job/src/main/java/com/java110/job/task/wechat/WeChatPushMessageTemplate.java
old mode 100644
new mode 100755
index e1ffcc7..58e65fa
--- a/service-job/src/main/java/com/java110/job/task/wechat/WeChatPushMessageTemplate.java
+++ b/service-job/src/main/java/com/java110/job/task/wechat/WeChatPushMessageTemplate.java
@@ -1,8 +1,13 @@
 package com.java110.job.task.wechat;
 
 import com.alibaba.fastjson.JSON;
+import com.alibaba.fastjson.JSONArray;
+import com.alibaba.fastjson.JSONObject;
+import com.java110.core.annotation.Java110Synchronized;
 import com.java110.core.factory.WechatFactory;
+import com.java110.core.smo.ISaveTransactionLogSMO;
 import com.java110.dto.RoomDto;
+import com.java110.dto.app.AppDto;
 import com.java110.dto.community.CommunityDto;
 import com.java110.dto.notice.NoticeDto;
 import com.java110.dto.owner.OwnerAppUserDto;
@@ -12,6 +17,7 @@
 import com.java110.dto.task.TaskDto;
 import com.java110.entity.wechat.Content;
 import com.java110.entity.wechat.Data;
+import com.java110.entity.wechat.Miniprogram;
 import com.java110.entity.wechat.PropertyFeeTemplateMessage;
 import com.java110.intf.community.INoticeInnerServiceSMO;
 import com.java110.intf.community.IRoomInnerServiceSMO;
@@ -20,11 +26,15 @@
 import com.java110.intf.user.IOwnerAppUserInnerServiceSMO;
 import com.java110.intf.user.IOwnerRoomRelInnerServiceSMO;
 import com.java110.job.quartz.TaskSystemQuartz;
+import com.java110.po.transactionLog.TransactionLogPo;
 import com.java110.utils.cache.MappingCache;
+import com.java110.utils.constant.WechatConstant;
 import com.java110.utils.util.DateUtil;
+import com.java110.utils.util.StringUtil;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.http.HttpStatus;
 import org.springframework.http.ResponseEntity;
 import org.springframework.stereotype.Component;
 import org.springframework.web.client.RestTemplate;
@@ -60,12 +70,16 @@
 
     @Autowired
     private IOwnerRoomRelInnerServiceSMO ownerRoomRelInnerServiceSMOImpl;
+    @Autowired
+    private ISaveTransactionLogSMO saveTransactionLogSMOImpl;
+
 
     @Autowired
     private RestTemplate outRestTemplate;
 
     //妯℃澘淇℃伅鎺ㄩ�佸湴鍧�
     private static String sendMsgUrl = "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=";
+    private static String getUser = "https://api.weixin.qq.com/cgi-bin/user/get?access_token=ACCESS_TOKEN";
 
 
     @Override
@@ -121,13 +135,7 @@
         }
 
         //
-        NoticeDto noticeDto = new NoticeDto();
-        noticeDto.setCommunityId(communityDto.getCommunityId());
-        noticeDto.setPage(1);
-        noticeDto.setRow(50);
-        noticeDto.setState(NoticeDto.STATE_WAIT);
-        noticeDto.setNoticeTypeCd(NoticeDto.NOTICE_TYPE_OWNER_WECHAT);
-        List<NoticeDto> noticeDtos = noticeInnerServiceSMOImpl.queryNotices(noticeDto);
+        List<NoticeDto> noticeDtos = getNotices(communityDto.getCommunityId());
 
         if (noticeDtos == null || noticeDtos.size() < 1) {
             return;
@@ -135,7 +143,7 @@
 
         for (NoticeDto tmpNotice : noticeDtos) {
             try {
-                doSentWechat(tmpNotice, templateId, accessToken);
+                doSentWechat(tmpNotice, templateId, accessToken, weChatDto);
             } catch (Exception e) {
                 logger.error("閫氱煡寮傚父", e);
             }
@@ -143,7 +151,29 @@
 
     }
 
-    private void doSentWechat(NoticeDto noticeDto, String templateId, String accessToken) throws Exception {
+    @Java110Synchronized(value = "communityId")
+    private List<NoticeDto> getNotices(String communityId) {
+        NoticeDto noticeDto = new NoticeDto();
+        noticeDto.setCommunityId(communityId);
+        noticeDto.setPage(1);
+        noticeDto.setRow(50);
+        noticeDto.setState(NoticeDto.STATE_WAIT);
+        noticeDto.setNoticeTypeCd(NoticeDto.NOTICE_TYPE_OWNER_WECHAT);
+        List<NoticeDto> noticeDtos = noticeInnerServiceSMOImpl.queryNotices(noticeDto);
+
+        //鏇存柊涓哄彂閫佷腑
+        for (NoticeDto noticeDto1 : noticeDtos) {
+            noticeDto = new NoticeDto();
+            noticeDto.setNoticeId(noticeDto1.getNoticeId());
+            noticeDto.setState(NoticeDto.STATE_DOING);
+            noticeDto.setCommunityId(communityId);
+            noticeInnerServiceSMOImpl.updateNotice(noticeDto);
+        }
+
+        return noticeDtos;
+    }
+
+    private void doSentWechat(NoticeDto noticeDto, String templateId, String accessToken, SmallWeChatDto weChatDto) throws Exception {
 
         Date startTime = DateUtil.getDateFromString(noticeDto.getStartTime(), DateUtil.DATE_FORMATE_STRING_A);
         Date nowTime = DateUtil.getCurrentDate();
@@ -155,17 +185,20 @@
         String objType = noticeDto.getObjType();
 
         switch (objType) {
-            case NoticeDto.OBJ_TYPE_COMMUNITY:
-                sendAllOwner(noticeDto, templateId, accessToken);
+            case NoticeDto.OBJ_TYPE_ALL:
+                sendAllOwner(noticeDto, templateId, accessToken, weChatDto);
                 break;
             case NoticeDto.OBJ_TYPE_FLOOR:
-                sendFloorOwner(noticeDto, templateId, accessToken);
+                sendFloorOwner(noticeDto, templateId, accessToken, weChatDto);
                 break;
             case NoticeDto.OBJ_TYPE_UNIT:
-                sendUnitOwner(noticeDto, templateId, accessToken);
+                sendUnitOwner(noticeDto, templateId, accessToken, weChatDto);
                 break;
             case NoticeDto.OBJ_TYPE_ROOM:
-                sendRoomOwner(noticeDto, templateId, accessToken);
+                sendRoomOwner(noticeDto, templateId, accessToken, weChatDto);
+                break;
+            case NoticeDto.OBJ_TYPE_COMMUNITY:
+                sendCommunityOwner(noticeDto, templateId, accessToken, weChatDto);
                 break;
         }
 
@@ -176,7 +209,15 @@
 
     }
 
-    private void sendFloorOwner(NoticeDto noticeDto, String templateId, String accessToken) {
+    private void sendCommunityOwner(NoticeDto noticeDto, String templateId, String accessToken, SmallWeChatDto weChatDto) {
+        OwnerAppUserDto ownerAppUserDto = new OwnerAppUserDto();
+        ownerAppUserDto.setAppType(OwnerAppUserDto.APP_TYPE_WECHAT);
+        ownerAppUserDto.setCommunityId(noticeDto.getCommunityId());
+        List<OwnerAppUserDto> ownerAppUserDtos = ownerAppUserInnerServiceSMOImpl.queryOwnerAppUsers(ownerAppUserDto);
+        doSend(ownerAppUserDtos, noticeDto, templateId, accessToken, weChatDto);
+    }
+
+    private void sendFloorOwner(NoticeDto noticeDto, String templateId, String accessToken, SmallWeChatDto weChatDto) {
 
         RoomDto roomDto = new RoomDto();
         roomDto.setCommunityId(noticeDto.getCommunityId());
@@ -198,11 +239,11 @@
             ownerAppUserDto.setAppType(OwnerAppUserDto.APP_TYPE_WECHAT);
             ownerAppUserDto.setMemberId(ownerRoomRelDtos.get(0).getOwnerId());
             List<OwnerAppUserDto> ownerAppUserDtos = ownerAppUserInnerServiceSMOImpl.queryOwnerAppUsers(ownerAppUserDto);
-            doSend(ownerAppUserDtos, noticeDto, templateId, accessToken);
+            doSend(ownerAppUserDtos, noticeDto, templateId, accessToken, weChatDto);
         }
     }
 
-    private void sendUnitOwner(NoticeDto noticeDto, String templateId, String accessToken) {
+    private void sendUnitOwner(NoticeDto noticeDto, String templateId, String accessToken, SmallWeChatDto weChatDto) {
 
         RoomDto roomDto = new RoomDto();
         roomDto.setCommunityId(noticeDto.getCommunityId());
@@ -224,11 +265,11 @@
             ownerAppUserDto.setAppType(OwnerAppUserDto.APP_TYPE_WECHAT);
             ownerAppUserDto.setMemberId(ownerRoomRelDtos.get(0).getOwnerId());
             List<OwnerAppUserDto> ownerAppUserDtos = ownerAppUserInnerServiceSMOImpl.queryOwnerAppUsers(ownerAppUserDto);
-            doSend(ownerAppUserDtos, noticeDto, templateId, accessToken);
+            doSend(ownerAppUserDtos, noticeDto, templateId, accessToken, weChatDto);
         }
     }
 
-    private void sendRoomOwner(NoticeDto noticeDto, String templateId, String accessToken) {
+    private void sendRoomOwner(NoticeDto noticeDto, String templateId, String accessToken, SmallWeChatDto weChatDto) {
 
         RoomDto roomDto = new RoomDto();
         roomDto.setCommunityId(noticeDto.getCommunityId());
@@ -250,34 +291,145 @@
             ownerAppUserDto.setAppType(OwnerAppUserDto.APP_TYPE_WECHAT);
             ownerAppUserDto.setMemberId(ownerRoomRelDtos.get(0).getOwnerId());
             List<OwnerAppUserDto> ownerAppUserDtos = ownerAppUserInnerServiceSMOImpl.queryOwnerAppUsers(ownerAppUserDto);
-            doSend(ownerAppUserDtos, noticeDto, templateId, accessToken);
+            doSend(ownerAppUserDtos, noticeDto, templateId, accessToken, weChatDto);
         }
     }
 
-    private void sendAllOwner(NoticeDto noticeDto, String templateId, String accessToken) {
-        OwnerAppUserDto ownerAppUserDto = new OwnerAppUserDto();
-        ownerAppUserDto.setAppType(OwnerAppUserDto.APP_TYPE_WECHAT);
-        List<OwnerAppUserDto> ownerAppUserDtos = ownerAppUserInnerServiceSMOImpl.queryOwnerAppUsers(ownerAppUserDto);
-        doSend(ownerAppUserDtos, noticeDto, templateId, accessToken);
+    private void sendAllOwner(NoticeDto noticeDto, String templateId, String accessToken, SmallWeChatDto weChatDto) {
+        doSendToOpenId(noticeDto, templateId, accessToken, "", weChatDto);
     }
 
-    private void doSend(List<OwnerAppUserDto> ownerAppUserDtos, NoticeDto noticeDto, String templateId, String accessToken) {
+    private void doSend(List<OwnerAppUserDto> ownerAppUserDtos, NoticeDto noticeDto, String templateId, String accessToken, SmallWeChatDto weChatDto) {
         String wechatUrl = MappingCache.getValue("OWNER_WECHAT_URL") + "/#/pages/notice/detail/detail?noticeId=";
+        ResponseEntity<String> responseEntity = null;
+        String sendTemplate = MappingCache.getValue(WechatConstant.WECHAT_DOMAIN,WechatConstant.SEND_TEMPLATE_URL);
+        if(StringUtil.isEmpty(sendTemplate)){
+            sendTemplate = sendMsgUrl;
+        }
         for (OwnerAppUserDto appUserDto : ownerAppUserDtos) {
+            Date startTime = DateUtil.getCurrentDate();
+            PropertyFeeTemplateMessage templateMessage = new PropertyFeeTemplateMessage();
+            try {
+                Data data = new Data();
+                templateMessage.setTemplate_id(templateId);
+                templateMessage.setTouser(appUserDto.getOpenId());
+                data.setFirst(new Content(noticeDto.getTitle()));
+                data.setKeyword1(new Content(noticeDto.getTitle()));
+                data.setKeyword2(new Content(noticeDto.getStartTime()));
+                data.setKeyword3(new Content(StringUtil.delHtmlTag(noticeDto.getContext())));
+                data.setRemark(new Content("濡傛湁鐤戦棶璇疯仈绯荤浉鍏崇墿涓氫汉鍛�"));
+                templateMessage.setData(data);
+                templateMessage.setUrl(wechatUrl + noticeDto.getNoticeId() + "&wAppId=" + weChatDto.getAppId());
+                logger.info("鍙戦�佹ā鏉挎秷鎭唴瀹�:{}", JSON.toJSONString(templateMessage));
+                responseEntity = outRestTemplate.postForEntity(sendTemplate + accessToken, JSON.toJSONString(templateMessage), String.class);
+                logger.info("寰俊妯℃澘杩斿洖鍐呭:{}", responseEntity);
+            } catch (Exception e) {
+                logger.error("鍙戦�佸け璐�", e);
+            } finally {
+                doSaveLog(startTime, DateUtil.getCurrentDate(), "/pages/notice/detail/detail", JSON.toJSONString(templateMessage), responseEntity, appUserDto.getOpenId());
+            }
+        }
+    }
+
+    private void doSendToOpenId(NoticeDto noticeDto, String templateId, String accessToken, String nextOpenid, SmallWeChatDto weChatDto) {
+        String url = MappingCache.getValue(WechatConstant.WECHAT_DOMAIN,WechatConstant.GET_USER_URL);
+        if(StringUtil.isEmpty(url)){
+            url = getUser;
+        }
+        url = url.replace("ACCESS_TOKEN", accessToken);
+        if (!StringUtil.isEmpty(nextOpenid)) {
+            url += ("&next_openid=" + nextOpenid);
+        }
+        ResponseEntity<String> paramOut = outRestTemplate.getForEntity(url, String.class);
+
+        logger.info("鑾峰彇鐢ㄦ埛杩斿洖:{}", paramOut);
+
+        if (paramOut.getStatusCode() != HttpStatus.OK) {
+            throw new IllegalArgumentException(paramOut.getBody());
+        }
+
+        JSONObject paramOutObj = JSONObject.parseObject(paramOut.getBody());
+        if (paramOutObj.containsKey("errcode")) {
+            throw new IllegalArgumentException(paramOut.getBody());
+        }
+
+        if (!paramOutObj.containsKey("data")) {
+            return;
+        }
+        JSONObject dataObj = paramOutObj.getJSONObject("data");
+        JSONArray openids = dataObj.getJSONArray("openid");
+        nextOpenid = paramOutObj.getString("next_openid");
+        String wechatUrl = MappingCache.getValue("OWNER_WECHAT_URL");
+        Miniprogram miniprogram = null;
+        if (wechatUrl.startsWith("https://") || wechatUrl.startsWith("http://")) {
+
+        } else {
+            miniprogram = new Miniprogram();
+            miniprogram.setAppid(wechatUrl);
+        }
+
+        String sendTemplate = MappingCache.getValue(WechatConstant.WECHAT_DOMAIN,WechatConstant.SEND_TEMPLATE_URL);
+        if(StringUtil.isEmpty(sendTemplate)){
+            sendTemplate = sendMsgUrl;
+        }
+        ResponseEntity<String> responseEntity = null;
+        for (int openIndex = 0; openIndex < openids.size(); openIndex++) {
+            Date startTime = DateUtil.getCurrentDate();
             Data data = new Data();
             PropertyFeeTemplateMessage templateMessage = new PropertyFeeTemplateMessage();
-            templateMessage.setTemplate_id(templateId);
-            templateMessage.setTouser(appUserDto.getOpenId());
-            data.setFirst(new Content(noticeDto.getTitle()));
-            data.setKeyword1(new Content(noticeDto.getTitle()));
-            data.setKeyword2(new Content(noticeDto.getStartTime()));
-            data.setKeyword3(new Content(noticeDto.getContext()));
-            data.setRemark(new Content("濡傛湁鐤戦棶璇疯仈绯荤浉鍏崇墿涓氫汉鍛�"));
-            templateMessage.setData(data);
-            templateMessage.setUrl(wechatUrl + noticeDto.getNoticeId());
-            logger.info("鍙戦�佹ā鏉挎秷鎭唴瀹�:{}", JSON.toJSONString(templateMessage));
-            ResponseEntity<String> responseEntity = outRestTemplate.postForEntity(sendMsgUrl + accessToken, JSON.toJSONString(templateMessage), String.class);
-            logger.info("寰俊妯℃澘杩斿洖鍐呭:{}", responseEntity);
+            String openId = openids.getString(openIndex);
+            try {
+                templateMessage.setTemplate_id(templateId);
+                templateMessage.setTouser(openId);
+                data.setFirst(new Content(noticeDto.getTitle()));
+                data.setKeyword1(new Content(noticeDto.getTitle()));
+                data.setKeyword2(new Content(noticeDto.getStartTime()));
+                data.setKeyword3(new Content(StringUtil.delHtmlTag(noticeDto.getContext())));
+                data.setRemark(new Content("濡傛湁鐤戦棶璇疯仈绯荤浉鍏崇墿涓氫汉鍛�"));
+                templateMessage.setData(data);
+                if (!StringUtil.isEmpty(wechatUrl)) {
+                    if (miniprogram == null) {
+                        templateMessage.setUrl(wechatUrl + "/#/pages/notice/detail/detail?noticeId=" + noticeDto.getNoticeId() + "&wAppId=" + weChatDto.getAppId());
+                    } else {
+                        miniprogram.setPagepath("/pages/notice/detail/detail?noticeId=" + noticeDto.getNoticeId() + "&wAppId=" + weChatDto.getAppId());
+                        templateMessage.setMiniprogram(miniprogram);
+                    }
+                }
+                logger.info("鍙戦�佹ā鏉挎秷鎭唴瀹�:{}", JSON.toJSONString(templateMessage));
+                responseEntity = outRestTemplate.postForEntity(sendTemplate + accessToken, JSON.toJSONString(templateMessage), String.class);
+                logger.info("寰俊妯℃澘杩斿洖鍐呭:{}", responseEntity);
+            } catch (Exception e) {
+                logger.error("鍙戦�佸け璐�", e);
+            } finally {
+                doSaveLog(startTime, DateUtil.getCurrentDate(), "/pages/notice/detail/detail", JSON.toJSONString(templateMessage), responseEntity, openId);
+            }
+        }
+
+        //锛堝叧娉ㄨ�呭垪琛ㄥ凡杩斿洖瀹屾椂锛岃繑鍥瀗ext_openid涓虹┖锛�
+        if (!StringUtil.isEmpty(nextOpenid)) {
+            doSendToOpenId(noticeDto, templateId, accessToken, nextOpenid, weChatDto);
+        }
+    }
+
+    private void doSaveLog(Date startDate, Date endDate, String serviceCode, String reqJson, ResponseEntity<String> responseEntity, String userId) {
+        try {
+            TransactionLogPo transactionLogPo = new TransactionLogPo();
+            transactionLogPo.setAppId(AppDto.OWNER_WECHAT_PAY);
+            transactionLogPo.setCostTime((endDate.getTime() - startDate.getTime()) + "");
+            transactionLogPo.setIp("");
+            transactionLogPo.setServiceCode(serviceCode);
+            transactionLogPo.setSrcIp("127.0.0.1");
+            transactionLogPo.setState(responseEntity.getStatusCode() != HttpStatus.OK ? "F" : "S");
+            transactionLogPo.setTimestamp(DateUtil.getCurrentDate().getTime() + "");
+            transactionLogPo.setUserId(userId);
+            transactionLogPo.setTransactionId(userId);
+            transactionLogPo.setRequestHeader("");
+            transactionLogPo.setResponseHeader(responseEntity.getHeaders().toSingleValueMap().toString());
+            transactionLogPo.setRequestMessage(reqJson);
+            transactionLogPo.setResponseMessage(responseEntity.getBody());
+            saveTransactionLogSMOImpl.saveLog(transactionLogPo);
+        } catch (Exception e) {
+            logger.error("瀛樻棩蹇楀け璐�", e);
         }
     }
 

--
Gitblit v1.8.0