From c93dfa3912f0fed74faa2f5f3ef42c318a04a7a2 Mon Sep 17 00:00:00 2001
From: yujian <yujian@163.com>
Date: 星期一, 13 四月 2020 11:04:14 +0800
Subject: [PATCH] 消息

---
 fanli/src/main/java/com/yeshi/fanli/service/impl/money/extract/ExtractServiceImpl.java |   62 +++++++++++++++++-------------
 1 files changed, 35 insertions(+), 27 deletions(-)

diff --git a/fanli/src/main/java/com/yeshi/fanli/service/impl/money/extract/ExtractServiceImpl.java b/fanli/src/main/java/com/yeshi/fanli/service/impl/money/extract/ExtractServiceImpl.java
index 6099276..2f11736 100644
--- a/fanli/src/main/java/com/yeshi/fanli/service/impl/money/extract/ExtractServiceImpl.java
+++ b/fanli/src/main/java/com/yeshi/fanli/service/impl/money/extract/ExtractServiceImpl.java
@@ -53,6 +53,7 @@
 import com.yeshi.fanli.entity.common.AdminUser;
 import com.yeshi.fanli.entity.money.UserMoneyDetail;
 import com.yeshi.fanli.entity.money.UserMoneyDetail.UserMoneyDetailTypeEnum;
+import com.yeshi.fanli.entity.system.ConfigKeyEnum;
 import com.yeshi.fanli.exception.ExtractException;
 import com.yeshi.fanli.exception.NotExistObjectException;
 import com.yeshi.fanli.exception.ObjectStateException;
@@ -67,6 +68,7 @@
 import com.yeshi.fanli.service.inter.money.extract.ExtractService;
 import com.yeshi.fanli.service.inter.money.extract.ExtractWeiXinRecordService;
 import com.yeshi.fanli.service.inter.money.msg.UserMoneyMsgNotificationService;
+import com.yeshi.fanli.service.inter.order.CommonOrderCountService;
 import com.yeshi.fanli.service.inter.order.HongBaoV2Service;
 import com.yeshi.fanli.service.inter.order.OrderUserStatisticService;
 import com.yeshi.fanli.service.inter.push.PushService;
@@ -77,6 +79,7 @@
 import com.yeshi.fanli.util.GsonUtil;
 import com.yeshi.fanli.util.MoneyBigDecimalUtil;
 import com.yeshi.fanli.util.StringUtil;
+import com.yeshi.fanli.util.ThreadUtil;
 import com.yeshi.fanli.util.TimeUtil;
 import com.yeshi.fanli.util.factory.UserMoneyDetailFactory;
 
@@ -150,6 +153,9 @@
 
 	@Resource
 	private ExtractWeiXinRecordService extractWeiXinRecordService;
+
+	@Resource
+	private CommonOrderCountService commonOrderCountService;
 
 	@Transactional
 	public Integer addExtract(Extract extract) {
@@ -268,9 +274,9 @@
 				&& (System.currentTimeMillis() - history.getCreateTime().getTime()) < 1000 * 60 * 60 * 24 * 7L)
 			return 111;
 
-		final String autoExtract = configService.get("extract_way"); // 鏄惁鑷姩杞处
-		final String maxCount = configService.get("extract_count_day");
-		final String maxMoney = configService.get("extract_money_day");
+		final String autoExtract = configService.get(ConfigKeyEnum.extractWay.getKey()); // 鏄惁鑷姩杞处
+		final String maxCount = configService.get(ConfigKeyEnum.extractDayCount.getKey());
+		final String maxMoney = configService.get(ConfigKeyEnum.extractMoneyDay.getKey());
 
 		UserInfo user = userInfoMapper.selectByPrimaryKeyForUpdate(extract.getUserInfo().getId());
 		// 浣欓涓嶈冻
@@ -291,20 +297,32 @@
 
 		extractMapper.insertSelective(extract);
 
-		ExtractAuditRecord auditRecord = new ExtractAuditRecord();
+		final ExtractAuditRecord auditRecord = new ExtractAuditRecord();
 		auditRecord.setBeforeMoney(user.getMyHongBao());
 		auditRecord.setExtract(extract);
 
 		Date minTime = new Date(System.currentTimeMillis() - 1000 * 60 * 60 * 24 * 180L);
-		// 缁熻鏁版嵁
-		int orderCount50More = orderUserStatisticService.countOrderCount100MoreByUidAndMinTime(user.getId(), minTime);
 
-		BigDecimal weiQuanOrderFanAmount = orderUserStatisticService.sumWeiQuanOrderFanAmountByUid(user.getId(),
-				minTime);
-		int weiQuanOrderCount = orderUserStatisticService.countWeiQuanOrderByUid(user.getId(), minTime);
-		auditRecord.setExtraInfoStr(new Gson()
-				.toJson(new ExtractOrderStatisticDTO(orderCount50More, weiQuanOrderCount, weiQuanOrderFanAmount, 0)));
 		extractAuditRecordMapper.insertSelective(auditRecord);
+
+		ThreadUtil.run(new Runnable() {
+
+			@Override
+			public void run() {
+				// 缁熻鏁版嵁
+				int less10Count = commonOrderCountService.countOderByUidAndLess10(user.getId());
+				ExtractAuditRecord update = new ExtractAuditRecord();
+				update.setId(auditRecord.getId());
+				int orderCount50More = orderUserStatisticService.countOrderCount100MoreByUidAndMinTime(user.getId(),
+						minTime);
+				BigDecimal weiQuanOrderFanAmount = orderUserStatisticService.sumWeiQuanOrderFanAmountByUid(user.getId(),
+						minTime);
+				int weiQuanOrderCount = orderUserStatisticService.countWeiQuanOrderByUid(user.getId(), minTime);
+				update.setExtraInfoStr(new Gson().toJson(new ExtractOrderStatisticDTO(orderCount50More,
+						weiQuanOrderCount, weiQuanOrderFanAmount, 0, less10Count)));
+				extractAuditRecordMapper.updateByPrimaryKeySelective(update);
+			}
+		});
 
 		// 鏂扮増璧勯噾璇︽儏
 		UserMoneyDetail userMoneyDetail = null;
@@ -529,8 +547,13 @@
 		} catch (Exception e) {
 			e.printStackTrace();
 		}
+		List<PayInfo> payInfoList = payInfoMapper.getListbyExtractId(extract.getId());
+		String alipayNo = "";
+		if (payInfoList != null && payInfoList.size() > 0)
+			alipayNo = payInfoList.get(0).getOrderId();
+
 		// 鏂扮増閫氱煡
-		userMoneyMsgNotificationService.extractSuccess(extract);
+		userMoneyMsgNotificationService.extractSuccess(extract, alipayNo);
 	}
 
 	/**
@@ -883,10 +906,6 @@
 			LogHelper.errorDetailInfo(e);
 		}
 
-		// 4銆佸彂閫佹秷鎭�氱煡
-		String desc = "涓轰繚闅滀綘鐨勮处鎴蜂綑棰濆畨鍏紝鑷姩鎻愮幇閲戦灏嗕笉浼氶珮浜�5鍏�";
-		String beizu = "璐︽埛涓墿浣欎綑棰濊鍦ㄦ湰App鍐呭畬鎴愭彁鐜�";
-		userMoneyMsgNotificationService.extractAuto(extractRecord, "鏈鍙�-鎻愮幇涓�", desc, beizu);
 	}
 
 	private boolean parseSendResult(String result) {
@@ -1225,11 +1244,6 @@
 			// 璧勯噾璁$畻
 			userMoneyService.subUserMoney(userInfo.getId(), money, detail);
 
-			// 4銆佸彂閫佹秷鎭�氱煡
-			String desc = "涓轰繚闅滀綘鐨勮处鎴蜂綑棰濆畨鍏紝鑷姩鎻愮幇閲戦灏嗕笉浼氶珮浜�5鍏�";
-			String beizu = "璐︽埛涓墿浣欎綑棰濊鍦ㄦ湰App鍐呭畬鎴愭彁鐜�";
-			userMoneyMsgNotificationService.extractAuto(extractRecord, "鏈鍙�-鎻愮幇涓�", desc, beizu);
-
 			// 婊¤冻鏉′欢杩斿洖淇℃伅
 			return userInfo;
 		}
@@ -1315,8 +1329,6 @@
 		extractWeiXinRecordService.updateByPrimaryKeySelective(updeteRecord);
 
 		if (ExtractWeiXinRecord.RECEIVED.equals(status)) {
-			// 鍙戦�佹秷鎭�氱煡
-			userMoneyMsgNotificationService.extractAuto(record, "宸查鍙�-宸叉彁鐜�", null, null);
 		} else if (ExtractWeiXinRecord.REFUND.equals(status)) {
 			// 璧勯噾鏄庣粏
 			UserMoneyDetail detail = new UserMoneyDetail();
@@ -1328,12 +1340,8 @@
 			detail.setType(UserMoneyDetailTypeEnum.extractAutoWXRefund);
 			detail.setUpdateTime(new Date());
 			detail.setUserInfo(new UserInfo(record.getUid()));
-
 			// 璧勯噾璁$畻
 			userMoneyService.addUserMoney(record.getUid(), record.getMoney(), detail);
-
-			// 鍙戦�佹秷鎭�氱煡
-			userMoneyMsgNotificationService.extractAuto(record, "宸查��鍥�-浣欓涓�", null, null);
 		}
 	}
 

--
Gitblit v1.8.0