From 0fdccf0fa23d0f039f563de9b31c974342d00a48 Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期三, 28 八月 2019 11:19:16 +0800
Subject: [PATCH] 返利到账后获取金币的机制建立

---
 fanli/src/main/java/com/yeshi/fanli/service/impl/order/OrderProcessServiceImpl.java |   46 +++++++++++++++++++++++++++++++++-------------
 1 files changed, 33 insertions(+), 13 deletions(-)

diff --git a/fanli/src/main/java/com/yeshi/fanli/service/impl/order/OrderProcessServiceImpl.java b/fanli/src/main/java/com/yeshi/fanli/service/impl/order/OrderProcessServiceImpl.java
index 033ec71..65bdfcf 100644
--- a/fanli/src/main/java/com/yeshi/fanli/service/impl/order/OrderProcessServiceImpl.java
+++ b/fanli/src/main/java/com/yeshi/fanli/service/impl/order/OrderProcessServiceImpl.java
@@ -66,6 +66,7 @@
 import com.yeshi.fanli.util.StringUtil;
 import com.yeshi.fanli.util.TaoBaoConstant;
 import com.yeshi.fanli.util.TimeUtil;
+import com.yeshi.fanli.util.cmq.HongBaoRecieveCMQManager;
 import com.yeshi.fanli.util.factory.UserMoneyDetailFactory;
 import com.yeshi.fanli.util.jd.JDApiUtil;
 import com.yeshi.fanli.util.pinduoduo.PinDuoDuoApiUtil;
@@ -404,6 +405,11 @@
 			// 娣诲姞璧勯噾鏄庣粏涓庣孩鍖呯殑鏄犲皠鍏崇郴
 			for (HongBaoV2 v2 : userHongBao.get(uid)) {
 				accountDetailsHongBaoMapService.saveAccountDetailsHongBaoMap(v2.getId(), userMoneyDetail.getId());
+				try {
+					HongBaoRecieveCMQManager.getInstance().addHongBaoRecieveMsg(v2.getId());
+				} catch (Exception e) {
+					LogHelper.errorDetailInfo(e);
+				}
 			}
 
 			// 绔欏唴淇�+鎺ㄩ��
@@ -567,6 +573,7 @@
 	@Override
 	@Transactional
 	public void fanliInvaiteAndShare(Long uid) throws TaoBaoWeiQuanException {
+		List<Long> recieveHongBaoIds = new ArrayList<>();
 		/**
 		 * 澶勭悊閭�璇疯禋璁㈠崟
 		 */
@@ -574,14 +581,14 @@
 		List<Integer> types = new ArrayList<>();
 		types.add(HongBaoV2.TYPE_YIJI);
 		types.add(HongBaoV2.TYPE_ERJI);
-		long count=	hongBaoV2Mapper.countCanBalanceHongBaoByTypeAndUid(types, uid);
-		List<HongBaoV2> hongBaoList =new ArrayList<>();
-	    //1000鏉℃暟鎹负1椤�
-		int page=(int)	(count%1000==0?count/1000:count/1000+1);
-		for(int i=0;i<page;i++)
-		{
-			List<HongBaoV2> tempHongBaoList = hongBaoV2Mapper.listCanBalanceHongBaoByTypeAndUid(types, uid, i*1000,1000);
-			if(tempHongBaoList!=null&&tempHongBaoList.size()>0)
+		long count = hongBaoV2Mapper.countCanBalanceHongBaoByTypeAndUid(types, uid);
+		List<HongBaoV2> hongBaoList = new ArrayList<>();
+		// 1000鏉℃暟鎹负1椤�
+		int page = (int) (count % 1000 == 0 ? count / 1000 : count / 1000 + 1);
+		for (int i = 0; i < page; i++) {
+			List<HongBaoV2> tempHongBaoList = hongBaoV2Mapper.listCanBalanceHongBaoByTypeAndUid(types, uid, i * 1000,
+					1000);
+			if (tempHongBaoList != null && tempHongBaoList.size() > 0)
 				hongBaoList.addAll(tempHongBaoList);
 		}
 		// 鐏板害娴嬭瘯涓紝浜笢/鎷煎澶氳鍗曞垎浜�/閭�璇疯鍗曚笉杩斿埄
@@ -660,8 +667,8 @@
 		types.clear();
 		types.add(HongBaoV2.TYPE_SHARE_YIJI);
 		types.add(HongBaoV2.TYPE_SHARE_ERJI);
-		//TODO 闇�瑕佸鐞嗚秴杩�1w鏉℃暟鎹殑璁㈠崟
-		List<HongBaoV2> hbList = hongBaoV2Mapper.listCanBalanceHongBaoByTypeAndUid(types, uid,0, 10000);
+		// TODO 闇�瑕佸鐞嗚秴杩�1w鏉℃暟鎹殑璁㈠崟
+		List<HongBaoV2> hbList = hongBaoV2Mapper.listCanBalanceHongBaoByTypeAndUid(types, uid, 0, 10000);
 
 		if (hbList != null && hbList.size() > 0)
 			totalHongBaoList.addAll(hbList);
@@ -731,7 +738,8 @@
 			for (String orderId : drawBackOrders)
 				taoBaoWeiQuanDrawBackService.doWeiQuanInvite(orderId);
 		}
-
+		if (hbIdList.size() > 0)
+			recieveHongBaoIds.addAll(hbIdList);
 		hbIdList.clear();
 		drawBackOrders.clear();
 
@@ -745,8 +753,8 @@
 		// 鏌ヨUID鐨勫垎浜禋璁㈠崟
 		types.clear();
 		types.add(HongBaoV2.TYPE_SHARE_GOODS);
-		//TODO 闇�瑕佸鐞嗚秴杩�10000鏉℃暟鎹殑璁㈠崟
-		List<HongBaoV2> hongBaoShareList = hongBaoV2Mapper.listCanBalanceHongBaoByTypeAndUid(types, uid,0, 10000);
+		// TODO 闇�瑕佸鐞嗚秴杩�10000鏉℃暟鎹殑璁㈠崟
+		List<HongBaoV2> hongBaoShareList = hongBaoV2Mapper.listCanBalanceHongBaoByTypeAndUid(types, uid, 0, 10000);
 		for (HongBaoV2 hongBao : hongBaoShareList) {
 			hongBao = hongBaoV2Mapper.selectByPrimaryKeyForUpdate(hongBao.getId());
 			hongBao = filterWeiQuanINGHongBao(hongBao);
@@ -807,6 +815,8 @@
 
 				// 娣诲姞鍒扮孩鍖呰繑鍒╄褰曢泦鍚�
 				accountDetailsHongBaoMapService.saveAccountDetailsHongBaoMap(hbIdList, userMoneyDetail.getId());
+				if (hbIdList.size() > 0)
+					recieveHongBaoIds.addAll(hbIdList);
 			} catch (UserMoneyDetailException e) {
 				try {
 					LogHelper.errorDetailInfo(e);
@@ -823,6 +833,16 @@
 				taoBaoWeiQuanDrawBackService.doWeiQuanShare(orderId);
 		}
 
+		// 鎵�鏈夌殑杩斿埄鍒拌处绾㈠寘ID
+		for (Long hongBaoId : recieveHongBaoIds) {
+			try {
+				HongBaoRecieveCMQManager.getInstance().addHongBaoRecieveMsg(hongBaoId);
+			} catch (Exception e) {
+				LogHelper.errorDetailInfo(e);
+			}
+
+		}
+
 	}
 
 	@Transactional(propagation = Propagation.REQUIRED, rollbackFor = Exception.class)

--
Gitblit v1.8.0