From 3e4ef41ffacd7f5fda2e81c3810cd11a6375b83c Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期一, 15 六月 2020 16:32:35 +0800
Subject: [PATCH] 好单库转链支持

---
 fanli/src/main/java/com/yeshi/fanli/util/SpringContext.java |  268 +++++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 255 insertions(+), 13 deletions(-)

diff --git a/fanli/src/main/java/com/yeshi/fanli/util/SpringContext.java b/fanli/src/main/java/com/yeshi/fanli/util/SpringContext.java
index 29d9980..9d172f9 100644
--- a/fanli/src/main/java/com/yeshi/fanli/util/SpringContext.java
+++ b/fanli/src/main/java/com/yeshi/fanli/util/SpringContext.java
@@ -18,8 +18,10 @@
 import org.yeshi.utils.tencentcloud.COSManager;
 import org.yeshi.utils.tencentcloud.entity.COSInitParams;
 
+import com.google.gson.Gson;
 import com.yeshi.fanli.dto.ad.DouYinDeviceActiveQueueDTO;
 import com.yeshi.fanli.dto.money.UserMoneyChangeDTO;
+import com.yeshi.fanli.dto.mq.UidDateDTO;
 import com.yeshi.fanli.entity.ad.DouYinClickEvent;
 import com.yeshi.fanli.entity.bus.user.AlipayTransferResultInfo;
 import com.yeshi.fanli.entity.bus.user.HongBaoV2;
@@ -32,10 +34,13 @@
 import com.yeshi.fanli.entity.pdd.PDDOrder;
 import com.yeshi.fanli.entity.push.DeviceActive;
 import com.yeshi.fanli.entity.push.PushQueueRecord;
+import com.yeshi.fanli.entity.suning.SuningOrderInfo;
 import com.yeshi.fanli.entity.taobao.TaoBaoGoodsBrief;
 import com.yeshi.fanli.entity.taobao.TaoBaoOrder;
 import com.yeshi.fanli.entity.taobao.TaoBaoWeiQuanOrder;
+import com.yeshi.fanli.entity.vipshop.VipShopOrder;
 import com.yeshi.fanli.exception.order.TaoBaoWeiQuanException;
+import com.yeshi.fanli.exception.order.dividents.TeamDividentsRecordException;
 import com.yeshi.fanli.log.LogHelper;
 import com.yeshi.fanli.service.inter.ad.DouYinClickEventService;
 import com.yeshi.fanli.service.inter.lable.BoutiqueAutoRuleService;
@@ -48,7 +53,9 @@
 import com.yeshi.fanli.service.inter.order.OrderProcessService;
 import com.yeshi.fanli.service.inter.order.jd.JDOrderService;
 import com.yeshi.fanli.service.inter.order.pdd.PDDOrderService;
+import com.yeshi.fanli.service.inter.order.suning.SuningOrderService;
 import com.yeshi.fanli.service.inter.order.tb.TaoBaoOrderService;
+import com.yeshi.fanli.service.inter.order.vipshop.VipShopOrderService;
 import com.yeshi.fanli.service.inter.push.DeviceActiveService;
 import com.yeshi.fanli.service.inter.push.IOSPushService;
 import com.yeshi.fanli.service.inter.taobao.TaoBaoGoodsUpdateService;
@@ -57,13 +64,18 @@
 import com.yeshi.fanli.service.inter.user.integral.IntegralGetService;
 import com.yeshi.fanli.service.inter.user.integral.IntegralTaskRecordService;
 import com.yeshi.fanli.service.inter.user.invite.ThreeSaleSerivce;
+import com.yeshi.fanli.service.manger.money.TeamEincomeManager;
+import com.yeshi.fanli.service.manger.order.TeamDividentsManager;
 import com.yeshi.fanli.util.ad.DouYinAdUtil;
 import com.yeshi.fanli.util.cmq.DouYinDeviceActiveCMQManager;
 import com.yeshi.fanli.util.cmq.HongBaoRecieveCMQManager;
-import com.yeshi.fanli.util.cmq.JDOrderCMQManager;
-import com.yeshi.fanli.util.cmq.PDDOrderCMQManager;
-import com.yeshi.fanli.util.cmq.PlaceOrderCMQManager;
 import com.yeshi.fanli.util.cmq.UserMoneyChangeCMQManager;
+import com.yeshi.fanli.util.cmq.order.JDOrderCMQManager;
+import com.yeshi.fanli.util.cmq.order.PDDOrderCMQManager;
+import com.yeshi.fanli.util.cmq.order.PlaceOrderCMQManager;
+import com.yeshi.fanli.util.cmq.order.SuningOrderCMQManager;
+import com.yeshi.fanli.util.cmq.order.TeamOrderCMQManager;
+import com.yeshi.fanli.util.cmq.order.VipShopOrderCMQManager;
 import com.yeshi.fanli.util.taobao.TaoKeApiUtil;
 
 /**
@@ -138,6 +150,18 @@
 	@Resource
 	private DeviceActiveService deviceActiveService;
 
+	@Resource
+	private TeamDividentsManager teamDividentsManager;
+
+	@Resource
+	private TeamEincomeManager teamEincomeManager;
+
+	@Resource
+	private VipShopOrderService vipShopOrderService;
+	
+	@Resource
+	private SuningOrderService suningOrderService;
+
 	private static boolean isInited = false;
 
 	public void onApplicationEvent(ContextRefreshedEvent arg0) {
@@ -162,7 +186,7 @@
 			doTaoBaoOrders();// 澶勭悊娣樺疂璁㈠崟
 			doTaoBaoNewOrders();// 澶勭悊娣樺疂璁㈠崟锛堝垰鍒氫骇鐢熺殑锛�
 			doOrderFanLiNew();// 鏂扮増杩斿埄
-//			doOrderTiChengFanLi();// 澶勭悊璁㈠崟鎻愭垚杩斿埄
+			doOrderShareFanLi();
 			doWeiQuanOrder();// 澶勭悊缁存潈璁㈠崟
 			doPushIOS();// 澶勭悊鍙戦�両OS娑堟伅
 			doUserMoneyDebtJob();// 鍊哄姟鍋胯繕
@@ -170,11 +194,19 @@
 			doUpdateGoodsJob(); // 鏇存柊鍟嗗搧闃熷垪
 			doJDOrderJob();// 浜笢璁㈠崟澶勭悊
 			doPDDOrderJob();// 鎷煎澶氳鍗曞鐞�
+			doVipShopOrderJob();// 鍞搧浼氳鍗曞鐞�
+			doSuningOrderJob();// 鑻忓畞璁㈠崟澶勭悊
 			doImportantTaoBaoGoodsUpdateJob();// 娣樺疂閲嶈鍟嗗搧鐨勪俊鎭洿鏂�
 			doHongBaoRecieveIntegralGetJob();// 杩斿埄鍒拌处锛岄噾甯佸鍔�
 			// doPlaceOrderIntegralJob();// 涓嬪崟璧犻�侀噾甯佷换鍔�
 			// doDouYinDeviceActiveJob();// 鎶栭煶璁惧婵�娲诲箍鍛婄洃娴�
+			doOrderTeamIncomePreFanLi();// 澶勭悊璁㈠崟鎻愭垚杩斿埄
+			doDividentsPreJob();
+
+			doOrderTeamIncomeFanLi();
+			doDividentsJob();
 		}
+		
 	}
 
 	/**
@@ -327,7 +359,8 @@
 								try {
 									HongBaoV2 hongbao = map.get(handler);
 									if (hongbao != null) {
-										String key = RedisKeyEnum.getRedisKey(RedisKeyEnum.hongBaoFanLi, hongbao.getId() + "");
+										String key = RedisKeyEnum.getRedisKey(RedisKeyEnum.hongBaoFanLi,
+												hongbao.getId() + "");
 										if (StringUtil.isNullOrEmpty(redisManager.getCommonString(key))) {
 											// 澶勭悊涔嬪悗瑕侀殧2灏忔椂鍐嶆杩涜澶勭悊
 											redisManager.cacheCommonString(key, "1", 60 * 60 * 2);
@@ -360,29 +393,94 @@
 	}
 
 	/**
-	 * 澶勭悊娣樺疂鎻愭垚璁㈠崟杩斿埄
+	 * 澶勭悊鍥㈤槦璁㈠崟杩斿埄
 	 */
-	public void doOrderTiChengFanLi() {
+	public void doOrderTeamIncomePreFanLi() {
 		executor.execute(new Runnable() {
 			@Override
 			public void run() {
 				while (true) {
 					try {
-
-						Map<String, Long> map = CMQManager.getInstance().consumeFanLiTiChengMsg(16);
+						Map<String, UidDateDTO> map = TeamOrderCMQManager.getInstance()
+								.consumeFanLiTeamIncomePreMsg(16);
 						if (map != null) {
 							Iterator<String> its = map.keySet().iterator();
 							while (its.hasNext()) {
 								String handler = its.next();
 								try {
-									orderProcessService.fanliInvaiteAndShare(map.get(handler));
-									CMQManager.getInstance().deleteFanLiTiChengMsg(handler);
-								} catch (TaoBaoWeiQuanException e) {
+									UidDateDTO dto = map.get(handler);
+									orderProcessService.fanliPreInvaite(dto.getUid(), dto.getDate());
+									TeamOrderCMQManager.getInstance().deleteTeamIncomePreMsg(handler);
+								} catch (Exception e) {
 									try {
-										LogHelper.errorDetailInfo(e);
+										LogHelper.errorDetailInfo(e,new Gson().toJson(map.get(handler)).toString(), "");
 									} catch (Exception e1) {
 										e1.printStackTrace();
 									}
+								}
+							}
+						}
+					} catch (Exception e) {
+
+					}
+				}
+			}
+		});
+	}
+
+	/**
+	 * 澶勭悊鍥㈤槦璁㈠崟杩斿埄
+	 */
+	public void doOrderTeamIncomeFanLi() {
+		executor.execute(new Runnable() {
+			@Override
+			public void run() {
+				while (true) {
+					try {
+						Map<String, UidDateDTO> map = TeamOrderCMQManager.getInstance().consumeFanLiTeamIncomeMsg(16);
+						if (map != null) {
+							Iterator<String> its = map.keySet().iterator();
+							while (its.hasNext()) {
+								String handler = its.next();
+								try {
+									UidDateDTO dto = map.get(handler);
+									teamEincomeManager.addTeamIncomeTOUserAccount(dto.getDate(), dto.getUid());
+									TeamOrderCMQManager.getInstance().deleteTeamIncomeMsg(handler);
+								} catch (Exception e) {
+									try {
+										LogHelper.errorDetailInfo(e, map.get(handler).toString(), "");
+									} catch (Exception e1) {
+										e1.printStackTrace();
+									}
+								}
+							}
+						}
+					} catch (Exception e) {
+
+					}
+				}
+			}
+		});
+	}
+
+	/**
+	 * 澶勭悊鍒嗕韩璁㈠崟杩斿埄
+	 */
+	public void doOrderShareFanLi() {
+		executor.execute(new Runnable() {
+			@Override
+			public void run() {
+				while (true) {
+					try {
+						Map<String, UidDateDTO> map = CMQManager.getInstance().consumeFanLiShareMsg(16);
+						if (map != null) {
+							Iterator<String> its = map.keySet().iterator();
+							while (its.hasNext()) {
+								String handler = its.next();
+								try {
+									UidDateDTO dto = map.get(handler);
+									orderProcessService.fanliShare(dto.getUid(), dto.getDate());
+									CMQManager.getInstance().deleteFanLiShareMsg(handler);
 								} catch (Exception e) {
 									try {
 										LogHelper.errorDetailInfo(e, map.get(handler).toString(), "");
@@ -617,6 +715,76 @@
 						}
 					} catch (Exception e) {
 						LogHelper.error("鎷煎澶氳鍗�:" + e.getMessage());
+					}
+				}
+			}
+		});
+
+	}
+
+	public void doVipShopOrderJob() {
+		executor.execute(new Runnable() {
+			@Override
+			public void run() {
+				while (true) {
+					try {
+						Map<String, String> map = VipShopOrderCMQManager.getInstance().consumeVipShopOrder(16);
+						if (map != null) {
+							Iterator<String> its = map.keySet().iterator();
+							while (its.hasNext()) {
+								String key = its.next();
+								try {
+									String orderId = map.get(key);
+									LogHelper.test("鍞搧浼氳鍗曟秷璐�:"+orderId);
+									if (!StringUtil.isNullOrEmpty(orderId)) {
+										List<VipShopOrder> orderList = vipShopOrderService.listDetailByOrderSn(orderId);
+										if (orderList != null)
+											for (VipShopOrder order : orderList)
+												orderProcessService.processVipShopOrder(order);
+									}
+									VipShopOrderCMQManager.getInstance().deleteVipShopOrder(key);
+								} catch (Exception e) {
+									LogHelper.errorDetailInfo(e);
+								}
+							}
+						}
+					} catch (Exception e) {
+						LogHelper.errorDetailInfo(e);
+					}
+				}
+			}
+		});
+
+	}
+	
+	
+	public void doSuningOrderJob() {
+		executor.execute(new Runnable() {
+			@Override
+			public void run() {
+				while (true) {
+					try {
+						Map<String, String> map = SuningOrderCMQManager.getInstance().consumeSuningOrder(16);
+						if (map != null) {
+							Iterator<String> its = map.keySet().iterator();
+							while (its.hasNext()) {
+								String key = its.next();
+								try {
+									String orderId = map.get(key);
+									if (!StringUtil.isNullOrEmpty(orderId)) {
+										List<SuningOrderInfo> orderList = suningOrderService.listByOrderCode(orderId);
+										if (orderList != null)
+											for (SuningOrderInfo order : orderList)
+												orderProcessService.processSuningOrder(order);
+									}
+									SuningOrderCMQManager.getInstance().deleteSuningOrder(key);
+								} catch (Exception e) {
+									LogHelper.errorDetailInfo(e);
+								}
+							}
+						}
+					} catch (Exception e) {
+						LogHelper.errorDetailInfo(e);
 					}
 				}
 			}
@@ -1065,4 +1233,78 @@
 		});
 	}
 
+	// 鍒嗙孩
+	public void doDividentsPreJob() {
+		executor.execute(new Runnable() {
+			@Override
+			public void run() {
+				while (true) {
+					Map<String, UidDateDTO> map = TeamOrderCMQManager.getInstance().consumeTeamDividentsPreMsg(16);
+					if (map != null) {
+						Iterator<String> its = map.keySet().iterator();
+						while (its.hasNext()) {
+							String key = its.next();
+							UidDateDTO dto = map.get(key);
+							try {
+								teamDividentsManager.addToTeamEincome(dto.getUid(), dto.getDate());
+								TeamOrderCMQManager.getInstance().deleteTeamDividentsPreMsg(key);
+							} catch (TeamDividentsRecordException e1) {
+								if (e1.getCode() == TeamDividentsRecordException.CODE_EXIST) {
+									TeamOrderCMQManager.getInstance().deleteTeamDividentsPreMsg(key);
+								} else {
+									try {
+										LogHelper.errorDetailInfo(e1);
+									} catch (Exception e2) {
+										e2.printStackTrace();
+									}
+								}
+							}
+
+							catch (Exception e) {
+								try {
+									LogHelper.errorDetailInfo(e);
+								} catch (Exception e1) {
+									e1.printStackTrace();
+								}
+							} finally {
+
+							}
+						}
+					}
+				}
+			}
+		});
+	}
+
+	// 鍒嗙孩
+	public void doDividentsJob() {
+		executor.execute(new Runnable() {
+			@Override
+			public void run() {
+				while (true) {
+					Map<String, UidDateDTO> map = TeamOrderCMQManager.getInstance().consumeTeamDividentsMsg(16);
+					if (map != null) {
+						Iterator<String> its = map.keySet().iterator();
+						while (its.hasNext()) {
+							String key = its.next();
+							UidDateDTO dto = map.get(key);
+							try {
+								teamEincomeManager.addTeamDividentsTOUserAccount(dto.getDate(), dto.getUid());
+								TeamOrderCMQManager.getInstance().deleteTeamDividentsMsg(key);
+							} catch (Exception e) {
+								try {
+									LogHelper.errorDetailInfo(e);
+								} catch (Exception e1) {
+									e1.printStackTrace();
+								}
+							} finally {
+
+							}
+						}
+					}
+				}
+			}
+		});
+	}
+
 }

--
Gitblit v1.8.0