From 573c491b4a1ba60e12a5678a01c1546c0077c1ee Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期二, 30 七月 2019 09:07:42 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 fanli/src/main/java/com/yeshi/fanli/job/UpdateOrderJob.java |  178 +++++++++++++++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 154 insertions(+), 24 deletions(-)

diff --git a/fanli/src/main/java/com/yeshi/fanli/job/UpdateOrderJob.java b/fanli/src/main/java/com/yeshi/fanli/job/UpdateOrderJob.java
index 546b7aa..25559c2 100644
--- a/fanli/src/main/java/com/yeshi/fanli/job/UpdateOrderJob.java
+++ b/fanli/src/main/java/com/yeshi/fanli/job/UpdateOrderJob.java
@@ -1,25 +1,30 @@
 package com.yeshi.fanli.job;
 
+import java.math.BigDecimal;
 import java.util.ArrayList;
 import java.util.Calendar;
 import java.util.Date;
+import java.util.HashMap;
+import java.util.HashSet;
 import java.util.Iterator;
 import java.util.List;
 import java.util.Map;
+import java.util.Set;
 
 import javax.annotation.Resource;
 
 import org.springframework.scheduling.annotation.Scheduled;
 import org.springframework.stereotype.Component;
 
+import com.yeshi.fanli.dto.taobao.WeiQuanOrderResult;
 import com.yeshi.fanli.entity.bus.user.LostOrder;
 import com.yeshi.fanli.entity.bus.user.Order;
-import com.yeshi.fanli.entity.taobao.PidUser;
+import com.yeshi.fanli.entity.order.CommonOrder;
 import com.yeshi.fanli.entity.taobao.TaoBaoOrder;
-import com.yeshi.fanli.entity.taobao.TaoBaoUnionConfig;
 import com.yeshi.fanli.entity.taobao.TaoBaoWeiQuanOrder;
 import com.yeshi.fanli.log.LogHelper;
 import com.yeshi.fanli.service.inter.common.DataMonitorService;
+import com.yeshi.fanli.service.inter.order.CommonOrderService;
 import com.yeshi.fanli.service.inter.order.LostOrderService;
 import com.yeshi.fanli.service.inter.order.OrderProcessService;
 import com.yeshi.fanli.service.inter.order.OrderService;
@@ -69,6 +74,9 @@
 
 	@Resource
 	private OrderService orderService;
+
+	@Resource
+	private CommonOrderService commonOrderService;
 
 	/**
 	 * 鏂扮増鑾峰彇鏅�氳鍗�
@@ -266,7 +274,7 @@
 		return orderList;
 	}
 
-	private void addOrder(List<TaoBaoOrder> orderList) {
+	public void addOrder(List<TaoBaoOrder> orderList) {
 
 		if (orderList != null)
 			for (int i = 0; i < orderList.size(); i++) {
@@ -293,11 +301,8 @@
 		try {
 			taoBaoOrderService.addTaoBaoOrderList(orderList);
 		} catch (Exception e) {
-			try {
-				LogHelper.errorDetailInfo(e);
-			} catch (Exception e1) {
-				e1.printStackTrace();
-			}
+			LogHelper.errorDetailInfo(e);
+
 		}
 
 		try {
@@ -318,7 +323,7 @@
 
 					}
 
-					CMQManager.getInstance().addTaoBaoOrderMsg(key, orders);
+					CMQManager.getInstance().addTaoBaoOrderMsg(key);
 
 					try {
 						// 6灏忔椂鍐呬笉鍐嶅鐞�
@@ -329,11 +334,7 @@
 				}
 			}
 		} catch (Exception e) {
-			try {
-				LogHelper.errorDetailInfo(e);
-			} catch (Exception e1) {
-				e1.printStackTrace();
-			}
+			LogHelper.errorDetailInfo(e);
 		}
 	}
 
@@ -371,8 +372,7 @@
 	public void doJob2() {
 		if (!Constant.IS_TASK)
 			return;
-		doTaoBaoWeiQuan();
-
+		doTaoBaoWeiQuan(10);
 		orderProcessService.fanli();
 	}
 
@@ -390,14 +390,40 @@
 	public void doTaoBaoWeiQuan() {
 		if (!Constant.IS_TASK)
 			return;
-		List<TaoBaoUnionConfig> configList = taoBaoUnionConfigService.getConfigByTypeCache(PidUser.TYPE_FANLI_ANDROID);
-		List<TaoBaoWeiQuanOrder> orderList = TaoBaoOrderUtil.getWeiQuanOrders(
-				System.currentTimeMillis() - 1000 * 60 * 60 * 24 * 60L, System.currentTimeMillis(), configList.get(0));
-		if (orderList != null)
+		// 鏂扮増缁存潈璁㈠崟澶勭悊
+		doTaoBaoWeiQuan(60);
+	}
+
+	private void doTaoBaoWeiQuan(int day) {
+		for (int i = 0; i < day; i++) {
+			List<TaoBaoWeiQuanOrder> orderList = new ArrayList<>();
+			WeiQuanOrderResult result = TaoKeOrderApiUtil
+					.getTaoBaoSpecialWeiQuanOrderList(new Date(TimeUtil.convertToTimeTemp(
+							TimeUtil.getGernalTime(System.currentTimeMillis() - 1000 * 60 * 60 * 24L * i, "yyyy-MM-dd"),
+							"yyyy-MM-dd")), 1, false);
+			orderList.addAll(result.orderList);
+
+			result = TaoKeOrderApiUtil.getTaoBaoSpecialWeiQuanOrderList(new Date(TimeUtil.convertToTimeTemp(
+					TimeUtil.getGernalTime(System.currentTimeMillis() - 1000 * 60 * 60 * 24L * i, "yyyy-MM-dd"),
+					"yyyy-MM-dd")), 1, true);
+			orderList.addAll(result.orderList);
+
+			result = TaoKeOrderApiUtil.getTaoBaoRelationWeiQuanOrderList(new Date(TimeUtil.convertToTimeTemp(
+					TimeUtil.getGernalTime(System.currentTimeMillis() - 1000 * 60 * 60 * 24L * i, "yyyy-MM-dd"),
+					"yyyy-MM-dd")), 1, false);
+			orderList.addAll(result.orderList);
+
+			result = TaoKeOrderApiUtil.getTaoBaoRelationWeiQuanOrderList(new Date(TimeUtil.convertToTimeTemp(
+					TimeUtil.getGernalTime(System.currentTimeMillis() - 1000 * 60 * 60 * 24L * i, "yyyy-MM-dd"),
+					"yyyy-MM-dd")), 1, true);
+			orderList.addAll(result.orderList);
+
 			for (TaoBaoWeiQuanOrder order : orderList)
 				taoBaoWeiQuanOrderService.addWeiQuanOrder(order);// 娣诲姞缁存潈璁㈠崟鍒版暟鎹簱
-		// 澶勭悊缁存潈璁㈠崟
-		orderProcessService.weiQuanOrder(orderList);
+			// 澶勭悊缁存潈璁㈠崟
+			orderProcessService.weiQuanOrder(orderList);
+		}
+
 	}
 
 	// 姣�6涓皬鏃舵墽琛屼竴娆�
@@ -413,6 +439,7 @@
 	public void addLostOrder() {
 		if (!Constant.IS_TASK)
 			return;
+		LogHelper.test("澶勭悊涓㈠け璁㈠崟");
 		List<LostOrder> list = lostOrderService.listByStateAndResultCode(LostOrder.STATE_PASS,
 				LostOrder.RESULT_CODE_VERFING, 1, 50);
 		if (list != null)
@@ -420,15 +447,16 @@
 				List<TaoBaoOrder> taoBaoOrderList = taoBaoOrderService.getTaoBaoOrderByOrderId(lo.getOrderId());
 				// 娓呴櫎棰戠巼闄愬埗
 				if (taoBaoOrderList != null && taoBaoOrderList.size() > 0) {
-					String key = "addorder-" + lo.getOrderId();
+					String key = "addorderqueue-" + lo.getOrderId();
 					redisManager.removeCommonString(key);
 					addOrder(taoBaoOrderList);
+					LogHelper.test("鑷姩澶勭悊娣樺疂璁㈠崟:" + lo.getOrderId());
 				}
 			}
 	}
 
 	/**
-	 * 澶勭悊娣樺疂缁撶畻璁㈠崟,姣忓皬鏃舵墽琛屼竴娆�
+	 * 澶勭悊娣樺疂缁撶畻璁㈠崟,30fen鎵ц涓�娆�
 	 */
 	@Scheduled(cron = "30 0 0/1 * * ? ")
 	public void doSettleOrders() {
@@ -449,4 +477,106 @@
 		addOrder(orderList);
 	}
 
+	/**
+	 * 13鍒嗛挓鏇存柊鏈�杩�13鍒嗛挓鐨勭粨绠楁暟鎹�
+	 */
+	@Scheduled(cron = "0 0/13 * * * ? ")
+	public void doSettleOrdersToday() {
+		if (!Constant.IS_TASK)
+			return;
+		// 澶勭悊3-15澶╁墠鐨勮鍗曪紝姣忓ぉ璺戜竴娆�
+		Calendar ca = Calendar.getInstance();
+		long startTime = ca.getTimeInMillis() - 1000 * 60 * 5L - 1000 * 60 * 13L;
+		long endTime = startTime + 1000 * 60 * 13L;
+		List<TaoBaoOrder> orderList = TaoKeOrderApiUtil.getTaoBaoSettleOrders(startTime, endTime, false);
+		List<TaoBaoOrder> tempOrderList = TaoKeOrderApiUtil.getTaoBaoSettleOrders(startTime, endTime, true);
+		if (tempOrderList != null && tempOrderList.size() > 0)
+			orderList.addAll(tempOrderList);
+		addOrder(orderList);
+	}
+
+	/**
+	 * 鏇存柊鏈湴璁㈠崟锛堝噷鏅�25鍒嗘洿鏂帮級
+	 */
+	@Scheduled(cron = "25 0 0 * * ? ")
+	public void doLocalTaoBaoOrder() {
+		if (!Constant.IS_TASK)
+			return;
+		// 澶勭悊3-15澶╁墠鐨勮鍗曪紝姣忓ぉ璺戜竴娆�
+		Long startTime = System.currentTimeMillis() - 1000 * 60 * 60 * 24 * 60L;
+		Long endTime = startTime + 1000 * 60 * 60 * 24 * 48L;
+		List<CommonOrder> commonOrderList = commonOrderService.listBySourceTypeAndStateAndThirdCrateTime(
+				Constant.SOURCE_TYPE_TAOBAO, CommonOrder.STATE_FK, startTime, endTime, 1, 500);
+		Set<String> orderIds = new HashSet<>();
+		for (CommonOrder co : commonOrderList) {
+			orderIds.add(co.getOrderNo());
+		}
+
+		for (Iterator<String> its = orderIds.iterator(); its.hasNext();) {
+			String orderId = its.next();
+			List<TaoBaoOrder> orderList = taoBaoOrderService.getTaoBaoOrderByOrderId(orderId);
+			Map<String, List<TaoBaoOrder>> orders = new HashMap<>();
+			orders.put(orderId, orderList);
+			orderProcessService.processOrder(orders);
+		}
+	}
+
+	/**
+	 * 鏇存柊鏈�杩戠殑鏈湴鍗�(30鍒嗛挓鏇存柊涓�娆�)
+	 */
+
+	@Scheduled(cron = "0 0/30 * * * ? ")
+	public void doLatestLocalTaoBaoOrder() {
+		if (!Constant.IS_TASK)
+			return;
+		Long endTime = System.currentTimeMillis() - 1000 * 60 * 10L;
+		Long startTime = endTime - 1000 * 60 * 60 * 12L;
+		updateLocalTaoBaoOrder(startTime, endTime, 1, 2000);
+
+	}
+
+	public void updateLocalTaoBaoOrder(Long startTime, Long endTime, int page, int count) {
+		List<TaoBaoOrder> list = taoBaoOrderService.listBySettlementTime(startTime, endTime, page, count);
+		Set<String> orderIds = new HashSet<>();
+		for (TaoBaoOrder co : list) {
+			orderIds.add(co.getOrderId());
+		}
+
+		for (Iterator<String> its = orderIds.iterator(); its.hasNext();) {
+			String orderId = its.next();
+			// 鏌ヨ鏄惁鏈夊浜庤鍗曚粯娆剧姸鎬佺殑鍗�
+			List<CommonOrder> commonOrderList = commonOrderService
+					.listBySourceTypeAndOrderId(Constant.SOURCE_TYPE_TAOBAO, orderId);
+			boolean update = false;
+			if (commonOrderList != null)
+				for (CommonOrder co : commonOrderList) {
+					if (co.getState() == CommonOrder.STATE_FK && co.getPayment().compareTo(new BigDecimal(0)) > 0) {
+						update = true;
+						break;
+					}
+				}
+
+			if (update) {
+				List<TaoBaoOrder> orderList = taoBaoOrderService.getTaoBaoOrderByOrderId(orderId);
+				Map<String, List<TaoBaoOrder>> orders = new HashMap<>();
+				orders.put(orderId, orderList);
+				orderProcessService.processOrder(orders);
+			}
+		}
+	}
+
+	@Scheduled(cron = "30 13 3 * * ? ")
+	public void doLatest5DayLocalTaoBaoOrder() {
+		if (!Constant.IS_TASK)
+			return;
+		Long endTime = System.currentTimeMillis() - 1000 * 60 * 60 * 12L;
+		Long startTime = endTime - 1000 * 60 * 60 * 24 * 5L;
+		long count = taoBaoOrderService.countBySettlementTime(startTime, endTime);
+		int pageSize = 100;
+		long page = count % pageSize == 0 ? count / pageSize : count / pageSize + 1;
+		for (int i = 0; i < page; i++) {
+			updateLocalTaoBaoOrder(startTime, endTime, i + 1, pageSize);
+		}
+	}
+
 }

--
Gitblit v1.8.0