From 2dfc6ef573baffba33d21fc596e1372a306ab17e Mon Sep 17 00:00:00 2001
From: java110 <928255095@qq.com>
Date: 星期五, 08 一月 2021 18:07:26 +0800
Subject: [PATCH] 优化代码
---
service-job/src/main/java/com/java110/job/adapt/payment/notice/MachinePaymentNoticeAdapt.java | 283 ++++++++++++++++++++++++++++++++++++++++++++++++--------
1 files changed, 243 insertions(+), 40 deletions(-)
diff --git a/service-job/src/main/java/com/java110/job/adapt/payment/notice/MachinePaymentNoticeAdapt.java b/service-job/src/main/java/com/java110/job/adapt/payment/notice/MachinePaymentNoticeAdapt.java
index cba8d1d..d79356a 100644
--- a/service-job/src/main/java/com/java110/job/adapt/payment/notice/MachinePaymentNoticeAdapt.java
+++ b/service-job/src/main/java/com/java110/job/adapt/payment/notice/MachinePaymentNoticeAdapt.java
@@ -3,9 +3,25 @@
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
+import com.alibaba.fastjson.serializer.SerializerFeature;
+import com.aliyuncs.CommonRequest;
+import com.aliyuncs.CommonResponse;
+import com.aliyuncs.DefaultAcsClient;
+import com.aliyuncs.IAcsClient;
+import com.aliyuncs.exceptions.ClientException;
+import com.aliyuncs.exceptions.ServerException;
+import com.aliyuncs.http.MethodType;
+import com.aliyuncs.profile.DefaultProfile;
import com.java110.core.factory.WechatFactory;
+import com.java110.core.smo.IComputeFeeSMO;
import com.java110.dto.basePrivilege.BasePrivilegeDto;
import com.java110.dto.community.CommunityDto;
+import com.java110.dto.fee.FeeDetailDto;
+import com.java110.dto.fee.FeeDto;
+import com.java110.dto.owner.OwnerAppUserDto;
+import com.java110.dto.owner.OwnerCarDto;
+import com.java110.dto.owner.OwnerDto;
+import com.java110.dto.owner.OwnerRoomRelDto;
import com.java110.dto.smallWeChat.SmallWeChatDto;
import com.java110.dto.smallWechatAttr.SmallWechatAttrDto;
import com.java110.dto.staffAppAuth.StaffAppAuthDto;
@@ -15,15 +31,18 @@
import com.java110.entity.wechat.Data;
import com.java110.entity.wechat.PropertyFeeTemplateMessage;
import com.java110.intf.community.ICommunityInnerServiceSMO;
+import com.java110.intf.fee.IFeeDetailInnerServiceSMO;
+import com.java110.intf.fee.IFeeInnerServiceSMO;
import com.java110.intf.order.IPrivilegeInnerServiceSMO;
import com.java110.intf.store.ISmallWeChatInnerServiceSMO;
import com.java110.intf.store.ISmallWechatAttrInnerServiceSMO;
-import com.java110.intf.user.IStaffAppAuthInnerServiceSMO;
-import com.java110.intf.user.IUserInnerServiceSMO;
+import com.java110.intf.user.*;
import com.java110.job.adapt.DatabusAdaptImpl;
import com.java110.po.fee.PayFeeDetailPo;
import com.java110.utils.cache.MappingCache;
+import com.java110.utils.util.Assert;
import com.java110.utils.util.BeanConvertUtil;
+import com.java110.utils.util.StringUtil;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
@@ -49,9 +68,6 @@
private ICommunityInnerServiceSMO communityInnerServiceSMO;
@Autowired
- private IUserInnerServiceSMO userInnerServiceSMO;
-
- @Autowired
private ISmallWeChatInnerServiceSMO smallWeChatInnerServiceSMOImpl;
@Autowired
@@ -66,48 +82,81 @@
@Autowired
private IStaffAppAuthInnerServiceSMO staffAppAuthInnerServiceSMO;
+ @Autowired
+ private IFeeInnerServiceSMO feeInnerServiceSMOImpl;
+
+ @Autowired
+ private IFeeDetailInnerServiceSMO feeDetailInnerServiceSMOImpl;
+
+ @Autowired
+ private IComputeFeeSMO computeFeeSMOImpl;
+
+ @Autowired
+ private IOwnerRoomRelInnerServiceSMO ownerRoomRelInnerServiceSMO;
+
+ @Autowired
+ private IOwnerCarInnerServiceSMO ownerCarInnerServiceSMO;
+
+ @Autowired
+ private IOwnerInnerServiceSMO ownerInnerServiceSMO;
+
+ @Autowired
+ private IOwnerAppUserInnerServiceSMO ownerAppUserInnerServiceSMO;
+
//妯℃澘淇℃伅鎺ㄩ�佸湴鍧�
private static String sendMsgUrl = "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=";
+
+ public final static String ALI_SMS_DOMAIN = "ALI_SMS";
@Override
public void execute(Business business, List<Business> businesses) {
JSONObject data = business.getData();
- if (data.containsKey(PayFeeDetailPo.class.getSimpleName())) {
+ JSONArray businessPayFeeDetails = null;
+ if (data == null) {
+ FeeDetailDto feeDetailDto = new FeeDetailDto();
+ feeDetailDto.setbId(business.getbId());
+ List<FeeDetailDto> feeDetailDtos = feeDetailInnerServiceSMOImpl.queryFeeDetails(feeDetailDto);
+ Assert.listOnlyOne(feeDetailDtos, "鏈煡璇㈠埌缂磋垂璁板綍");
+ businessPayFeeDetails = JSONArray.parseArray(JSONArray.toJSONString(feeDetailDtos, SerializerFeature.WriteDateUseDateFormat));
+ } else if (data.containsKey(PayFeeDetailPo.class.getSimpleName())) {
Object bObj = data.get(PayFeeDetailPo.class.getSimpleName());
- JSONArray businessMachines = null;
if (bObj instanceof JSONObject) {
- businessMachines = new JSONArray();
- businessMachines.add(bObj);
+ businessPayFeeDetails = new JSONArray();
+ businessPayFeeDetails.add(bObj);
} else if (bObj instanceof Map) {
- businessMachines = new JSONArray();
- businessMachines.add(JSONObject.parseObject(JSONObject.toJSONString(bObj)));
+ businessPayFeeDetails = new JSONArray();
+ businessPayFeeDetails.add(JSONObject.parseObject(JSONObject.toJSONString(bObj)));
} else if (bObj instanceof List) {
- businessMachines = JSONArray.parseArray(JSONObject.toJSONString(bObj));
+ businessPayFeeDetails = JSONArray.parseArray(JSONObject.toJSONString(bObj));
} else {
- businessMachines = (JSONArray) bObj;
+ businessPayFeeDetails = (JSONArray) bObj;
}
- //JSONObject businessMachine = data.getJSONObject("businessMachine");
- for (int bMachineIndex = 0; bMachineIndex < businessMachines.size(); bMachineIndex++) {
- JSONObject businessMachine = businessMachines.getJSONObject(bMachineIndex);
- doSendPayFeeDetail(business, businessMachine);
- }
+ } else {
+ return;
+ }
+ for (int bPayFeeDetailIndex = 0; bPayFeeDetailIndex < businessPayFeeDetails.size(); bPayFeeDetailIndex++) {
+ JSONObject businessPayFeeDetail = businessPayFeeDetails.getJSONObject(bPayFeeDetailIndex);
+ doSendPayFeeDetail(business, businessPayFeeDetail);
}
}
- private void doSendPayFeeDetail(Business business, JSONObject businessMachine) {
+ private void doSendPayFeeDetail(Business business, JSONObject businessPayFeeDetail) {
//鏌ヨ缂磋垂鏄庣粏
- PayFeeDetailPo payFeeDetailPo = BeanConvertUtil.covertBean(businessMachine, PayFeeDetailPo.class);
- //鎷垮埌鍛樺伐淇℃伅
- UserDto userDto = new UserDto();
- List<UserDto> users = userInnerServiceSMO.getUsers(userDto);
+ PayFeeDetailPo payFeeDetailPo = BeanConvertUtil.covertBean(businessPayFeeDetail, PayFeeDetailPo.class);
//鏌ヨ灏忓尯淇℃伅
CommunityDto communityDto = new CommunityDto();
communityDto.setCommunityId(payFeeDetailPo.getCommunityId());
List<CommunityDto> communityDtos = communityInnerServiceSMO.queryCommunitys(communityDto);
+ FeeDto feeDto = new FeeDto();
+ feeDto.setFeeId(payFeeDetailPo.getFeeId());
+ feeDto.setCommunityId(payFeeDetailPo.getCommunityId());
+ List<FeeDto> feeDtos = feeInnerServiceSMOImpl.queryFees(feeDto);
+
+ Assert.listOnlyOne(feeDtos, "鏈煡璇㈠埌璐圭敤淇℃伅");
//鑾峰彇璐圭敤绫诲瀷
- String feeTypeCdName = businessMachine.get("feeTypeCdName").toString();
+ String feeTypeCdName = feeDtos.get(0).getFeeTypeCdName();
//鑾峰彇缂磋垂鐢ㄦ埛妤兼爧鍗曞厓鎴块棿鍙�
- String payerObjName = businessMachine.get("payerObjName").toString();
+ String payerObjName = computeFeeSMOImpl.getFeeObjName(feeDtos.get(0));
//鑾峰緱鐢ㄦ埛缂磋垂寮�濮嬫椂闂�
String startTime = payFeeDetailPo.getStartTime();
//鑾峰彇鐢ㄦ埛缂磋垂鍒版湡鏃堕棿
@@ -121,11 +170,92 @@
paramIn.put("feeTypeCdName", feeTypeCdName);
paramIn.put("payFeeTime", startTime + "鑷�" + endTime);
paramIn.put("receivedAmount", receivedAmount);
+ paramIn.put("startTime", startTime);
paramIn.put("endTime", endTime);
- publishMsg(paramIn, communityDtos.get(0));
+ sendMessage(paramIn, communityDtos.get(0), payFeeDetailPo);
+ publishMsg(paramIn, communityDtos.get(0), payFeeDetailPo);
}
- private void publishMsg(JSONObject paramIn, CommunityDto communityDto) {
+ /**
+ * 缁欏憳宸ユ帹閫佷俊鎭�
+ *
+ * @param paramIn
+ * @param communityDto
+ * @param payFeeDetailPo
+ */
+ private void publishMsg(JSONObject paramIn, CommunityDto communityDto, PayFeeDetailPo payFeeDetailPo) {
+ //鏌ヨ鍏紬鍙烽厤缃�
+ SmallWeChatDto smallWeChatDto = new SmallWeChatDto();
+ smallWeChatDto.setWeChatType("1100");
+ smallWeChatDto.setObjType(SmallWeChatDto.OBJ_TYPE_COMMUNITY);
+ smallWeChatDto.setObjId(communityDto.getCommunityId());
+ List<SmallWeChatDto> smallWeChatDtos = smallWeChatInnerServiceSMOImpl.querySmallWeChats(smallWeChatDto);
+ if (smallWeChatDto == null || smallWeChatDtos.size() <= 0) {
+ logger.info("鏈厤缃井淇″叕浼楀彿淇℃伅,瀹氭椂浠诲姟鎵ц缁撴潫");
+ return;
+ }
+ SmallWeChatDto weChatDto = smallWeChatDtos.get(0);
+ SmallWechatAttrDto smallWechatAttrDto = new SmallWechatAttrDto();
+ smallWechatAttrDto.setCommunityId(communityDto.getCommunityId());
+ smallWechatAttrDto.setWechatId(weChatDto.getWeChatId());
+ smallWechatAttrDto.setSpecCd(SmallWechatAttrDto.SPEC_CD_WECHAT_SUCCESS_TEMPLATE);
+ List<SmallWechatAttrDto> smallWechatAttrDtos = smallWechatAttrInnerServiceSMOImpl.querySmallWechatAttrs(smallWechatAttrDto);
+ if (smallWechatAttrDtos == null || smallWechatAttrDtos.size() <= 0) {
+ logger.info("鏈厤缃井淇″叕浼楀彿娑堟伅妯℃澘");
+ return;
+ }
+ String templateId = smallWechatAttrDtos.get(0).getValue();
+ String accessToken = WechatFactory.getAccessToken(weChatDto.getAppId(), weChatDto.getAppSecret());
+ if (StringUtil.isEmpty(accessToken)) {
+ logger.info("鎺ㄩ�佸井淇℃ā鏉�,鑾峰彇accessToken澶辫触:{}", accessToken);
+ return;
+ }
+ FeeDto feeDto = new FeeDto();
+ feeDto.setFeeId(payFeeDetailPo.getFeeId());
+ feeDto.setCommunityId(payFeeDetailPo.getCommunityId());
+ List<FeeDto> feeDtos = feeInnerServiceSMOImpl.queryFees(feeDto);
+ Assert.listOnlyOne(feeDtos, "璐圭敤涓嶅瓨鍦�");
+ // 鏍规嵁鐗瑰畾鏉冮檺鏌ヨ 鏈夎鏉冮檺鐨� 鍛樺伐
+ BasePrivilegeDto basePrivilegeDto = new BasePrivilegeDto();
+ //basePrivilegeDto.setPId("502020121454780004");
+ basePrivilegeDto.setResource("/wechatNotification");
+ basePrivilegeDto.setStoreId(feeDtos.get(0).getIncomeObjId());
+ List<UserDto> userDtos = privilegeInnerServiceSMO.queryPrivilegeUsers(basePrivilegeDto);
+ String url = sendMsgUrl + accessToken;
+ for (UserDto userDto : userDtos) {
+ //鏍规嵁 userId 鏌ヨ鍒皁penId
+ StaffAppAuthDto staffAppAuthDto = new StaffAppAuthDto();
+ staffAppAuthDto.setStaffId(userDto.getUserId());
+ staffAppAuthDto.setAppType("WECHAT");
+ List<StaffAppAuthDto> staffAppAuthDtos = staffAppAuthInnerServiceSMO.queryStaffAppAuths(staffAppAuthDto);
+ String openId = staffAppAuthDtos.get(0).getOpenId();
+ Data data = new Data();
+ PropertyFeeTemplateMessage templateMessage = new PropertyFeeTemplateMessage();
+ templateMessage.setTemplate_id(templateId);
+ templateMessage.setTouser(openId);
+ data.setFirst(new Content("鏈缂磋垂宸插埌璐�"));
+ data.setKeyword1(new Content(paramIn.getString("payFeeRoom")));
+ data.setKeyword2(new Content(paramIn.getString("feeTypeCdName")));
+ data.setKeyword3(new Content(paramIn.getString("payFeeTime")));
+ data.setKeyword4(new Content(paramIn.getString("receivedAmount") + "鍏�"));
+ data.setRemark(new Content("鎰熻阿鎮ㄧ殑浣跨敤,濡傛湁鐤戦棶璇疯仈绯荤浉鍏崇墿涓氫汉鍛�"));
+ templateMessage.setData(data);
+ String wechatUrl = MappingCache.getValue("OWNER_WECHAT_URL");
+ templateMessage.setUrl(wechatUrl);
+ logger.info("鍙戦�佹ā鏉挎秷鎭唴瀹�:{}", JSON.toJSONString(templateMessage));
+ ResponseEntity<String> responseEntity = outRestTemplate.postForEntity(url, JSON.toJSONString(templateMessage), String.class);
+ logger.info("寰俊妯℃澘杩斿洖鍐呭:{}", responseEntity);
+ }
+ }
+
+ /**
+ * 缁欎笟涓绘帹閫佹秷鎭�
+ *
+ * @param paramIn
+ * @param communityDto
+ * @param payFeeDetailPo
+ */
+ private void sendMessage(JSONObject paramIn, CommunityDto communityDto, PayFeeDetailPo payFeeDetailPo) {
//鏌ヨ鍏紬鍙烽厤缃�
SmallWeChatDto smallWeChatDto = new SmallWeChatDto();
smallWeChatDto.setWeChatType("1100");
@@ -152,19 +282,46 @@
logger.info("鎺ㄩ�佸井淇℃ā鏉�,鑾峰彇accessToken澶辫触:{}", accessToken);
return;
}
- // 鏍规嵁鐗瑰畾鏉冮檺鏌ヨ 鏈夎鏉冮檺鐨� 鍛樺伐
- BasePrivilegeDto basePrivilegeDto = new BasePrivilegeDto();
- basePrivilegeDto.setPId("502020121454780004");
- basePrivilegeDto.setStoreId("402020112366290004");
- List<UserDto> userDtos = privilegeInnerServiceSMO.queryPrivilegeUsers(basePrivilegeDto);
- String url = sendMsgUrl + accessToken;
- for (UserDto userDto : userDtos) {
- //鏍规嵁 userId 鏌ヨ鍒皁penId
- StaffAppAuthDto staffAppAuthDto = new StaffAppAuthDto();
- staffAppAuthDto.setStaffId(userDto.getUserId());
- staffAppAuthDto.setAppType("WECHAT");
- List<StaffAppAuthDto> staffAppAuthDtos = staffAppAuthInnerServiceSMO.queryStaffAppAuths(staffAppAuthDto);
- String openId = staffAppAuthDtos.get(0).getOpenId();
+ FeeDto feeDto = new FeeDto();
+ feeDto.setFeeId(payFeeDetailPo.getFeeId());
+ feeDto.setCommunityId(payFeeDetailPo.getCommunityId());
+ List<FeeDto> feeDtos = feeInnerServiceSMOImpl.queryFees(feeDto);
+ Assert.listOnlyOne(feeDtos, "璐圭敤涓嶅瓨鍦�");
+ //鏀粯鎴块棿id
+ String payerObjId = feeDtos.get(0).getPayerObjId();
+ //鏀粯绫诲瀷(鎴垮眿銆佽溅杈�)
+ String payerObjType = feeDtos.get(0).getPayerObjType();
+ String ownerId = "";
+ //3333 鎴垮眿缂磋垂 6666 鏄溅浣嶇即璐�
+ if (payerObjType.equals("3333")) {
+ OwnerRoomRelDto ownerRoomRelDto = new OwnerRoomRelDto();
+ ownerRoomRelDto.setRoomId(payerObjId);
+ List<OwnerRoomRelDto> ownerRoomRelDtos = ownerRoomRelInnerServiceSMO.queryOwnerRoomRels(ownerRoomRelDto);
+ //鍙栧緱涓氫富id
+ ownerId = ownerRoomRelDtos.get(0).getOwnerId();
+ } else if (payerObjType.equals("6666")) {
+ OwnerCarDto ownerCarDto = new OwnerCarDto();
+ ownerCarDto.setPsId(payerObjId);
+ List<OwnerCarDto> ownerCarDtos = ownerCarInnerServiceSMO.queryOwnerCars(ownerCarDto);
+ //鍙栧緱涓氫富id
+ ownerId = ownerCarDtos.get(0).getOwnerId();
+ }
+ OwnerDto ownerDto = new OwnerDto();
+ ownerDto.setOwnerId(ownerId);
+ //1001 涓氫富鏈汉 1002 瀹跺涵鎴愬憳
+ ownerDto.setOwnerTypeCd("1001");
+ //鏌ヨ涓氫富
+ List<OwnerDto> ownerDtos = ownerInnerServiceSMO.queryOwners(ownerDto);
+ //鑾峰緱鎴愬憳id
+ String memberId = ownerDtos.get(0).getMemberId();
+ OwnerAppUserDto ownerAppUserDto = new OwnerAppUserDto();
+ ownerAppUserDto.setMemberId(memberId);
+ ownerAppUserDto.setAppType("WECHAT");
+ List<OwnerAppUserDto> ownerAppUserDtos = ownerAppUserInnerServiceSMO.queryOwnerAppUsers(ownerAppUserDto);
+ if (ownerAppUserDtos.size() > 0) {
+ //鑾峰彇openId
+ String openId = ownerAppUserDtos.get(0).getOpenId();
+ String url = sendMsgUrl + accessToken;
Data data = new Data();
PropertyFeeTemplateMessage templateMessage = new PropertyFeeTemplateMessage();
templateMessage.setTemplate_id(templateId);
@@ -181,6 +338,52 @@
logger.info("鍙戦�佹ā鏉挎秷鎭唴瀹�:{}", JSON.toJSONString(templateMessage));
ResponseEntity<String> responseEntity = outRestTemplate.postForEntity(url, JSON.toJSONString(templateMessage), String.class);
logger.info("寰俊妯℃澘杩斿洖鍐呭:{}", responseEntity);
+ } else {
+ //鑾峰彇涓氫富鎵嬫満鍙�
+ String tel = ownerDtos.get(0).getLink();
+ //鑾峰彇涓氫富濮撳悕
+ String name = ownerDtos.get(0).getName();
+ //鑾峰彇璐圭敤绫诲瀷
+ String feeTypeCdName = paramIn.getString("feeTypeCdName");
+ //鑾峰彇璐圭敤寮�濮嬫椂闂�
+ String startTime = paramIn.getString("startTime");
+ //鑾峰彇璐圭敤缁撴潫鏃堕棿
+ String endTime = paramIn.getString("endTime");
+ //鑾峰彇缂磋垂閲戦
+ String receivedAmount = paramIn.getString("receivedAmount");
+ //鑾峰彇鎴垮眿鍙�
+ String payFeeRoom = paramIn.getString("payFeeRoom");
+ DefaultProfile profile = DefaultProfile.getProfile(MappingCache.getValue(ALI_SMS_DOMAIN, "region"),
+ MappingCache.getValue(ALI_SMS_DOMAIN, "accessKeyId"),
+ MappingCache.getValue(ALI_SMS_DOMAIN, "accessSecret"));
+ IAcsClient client = new DefaultAcsClient(profile);
+
+ CommonRequest request = new CommonRequest();
+ request.setSysMethod(MethodType.POST);
+ request.setSysDomain("dysmsapi.aliyuncs.com");
+ request.setSysVersion("2017-05-25");
+ request.setSysAction("SendSms");
+ request.putQueryParameter("RegionId", MappingCache.getValue(ALI_SMS_DOMAIN, "region"));
+ request.putQueryParameter("PhoneNumbers", tel);
+ request.putQueryParameter("SignName", MappingCache.getValue(ALI_SMS_DOMAIN, "signName"));
+ //鑾峰彇妯℃澘缂栫爜(SMS_207160078涓虹即璐规垚鍔熸彁绀烘ā鏉跨紪鐮�)
+ String payFeeCode = MappingCache.getValue(ALI_SMS_DOMAIN, "PayFeeCode");
+ String substring = "";
+ if (!StringUtil.isEmpty(payFeeCode)) {
+ substring = payFeeCode.substring(0, 4);
+ }
+ if (substring.equals("SMS_")) {
+ request.putQueryParameter("TemplateCode", payFeeCode);
+ }
+ request.putQueryParameter("TemplateParam", "{\"user\":" + "\"" + name + "\"" + "," + "\"house\":" + "\"" + payFeeRoom + "\"" + "," + "\"feeType\":" + "\"" + feeTypeCdName + "\"" + "," + "\"startTime\":" + "\"" + startTime + "\"" + "," + "\"endTime\":" + "\"" + endTime + "\"" + "," + "\"mount\":" + "\"" + receivedAmount + "\"" + "}");
+ try {
+ CommonResponse response = client.getCommonResponse(request);
+ logger.debug("鍙戦�佺煭淇★細{}", response.getData());
+ } catch (ServerException e) {
+ e.printStackTrace();
+ } catch (ClientException e) {
+ e.printStackTrace();
+ }
}
}
}
--
Gitblit v1.8.0