admin
2020-05-20 98b1a0affd69bbe63223c21fdd2c404e8bedfccb
fanli/src/main/java/com/yeshi/fanli/job/order/taobao/UpdateOrderJob.java
@@ -13,7 +13,6 @@
import javax.annotation.Resource;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
import com.xxl.job.core.biz.model.ReturnT;
@@ -93,9 +92,22 @@
    * @return
    */
   private static List<TaoBaoOrder> getCommonOrder(long startTime, int span) {
      List<TaoBaoOrder> totalList = new ArrayList<>();
      List<TaoBaoOrder> orderList = TaoKeOrderApiUtil.getTaoBaoCommonOrderList(startTime, startTime + span * 1000L,
            1);
      return orderList;
      if (orderList != null && orderList.size() > 0)
         totalList.addAll(orderList);
      orderList = TaoKeOrderApiUtil.getTaoBaoCommonOrderList(startTime, startTime + span * 1000L, 2);
      if (orderList != null && orderList.size() > 0)
         totalList.addAll(orderList);
      orderList = TaoKeOrderApiUtil.getTaoBaoCommonOrderList(startTime, startTime + span * 1000L, 3);
      if (orderList != null && orderList.size() > 0)
         totalList.addAll(orderList);
      // 移除重复交易号的订单
      return totalList;
   }
   /**
@@ -106,8 +118,21 @@
    * @return
    */
   public static List<TaoBaoOrder> getCommonOrder(long startTime, long endTime) {
      List<TaoBaoOrder> totalList = new ArrayList<>();
      List<TaoBaoOrder> orderList = TaoKeOrderApiUtil.getTaoBaoCommonOrderList(startTime, endTime, 1);
      return orderList;
      if (orderList != null && orderList.size() > 0)
         totalList.addAll(orderList);
      orderList = TaoKeOrderApiUtil.getTaoBaoCommonOrderList(startTime, endTime, 2);
      if (orderList != null && orderList.size() > 0)
         totalList.addAll(orderList);
      orderList = TaoKeOrderApiUtil.getTaoBaoCommonOrderList(startTime, endTime, 3);
      if (orderList != null && orderList.size() > 0)
         totalList.addAll(orderList);
      // 移除重复交易号的订单
      return totalList;
   }
   /**
@@ -326,101 +351,82 @@
      }
   }
   // 每15分钟爬取一次
   @Scheduled(cron = "0 0/15 * * * ? ")
   public void pullCommonOrder() {
      if (!Constant.IS_TASK)
         return;
      LogHelper.job("正在执行15min订单爬取");
      long currentTime = System.currentTimeMillis() - 1000 * 60;
      String h = TimeUtil.getGernalTime(currentTime, "HH");
      String m = TimeUtil.getGernalTime(currentTime, "mm");
      int mm = Integer.parseInt(h) * 60 + Integer.parseInt(m);
      int pos = mm / 15;
      if (pos >= 90)
         pos = 89;
      long startTime = TimeUtil.convertToTimeTemp(TimeUtil.getGernalTime(currentTime, "yyyy-MM-dd"), "yyyy-MM-dd")
            - (1000 * 60 * 60 * 24L * (90 - pos));
      long endTime = startTime + 1000 * 60 * 60 * 24L;
      updateOrder(startTime, endTime);
   @XxlJob("updateTaoBaoCommonOrderHandler")
   public ReturnT<String> updateTaoBaoCommonOrder(String param) throws Exception {
      if ("1".equalsIgnoreCase(param)) {// 更新近20分钟内的单
         pullLatestCommonOrder();
      } else if ("1day".equalsIgnoreCase(param)) {// 爬取最近1天的订单(30分钟一次)
         pullLatestDayCommonOrder();
      } else if ("3day".equalsIgnoreCase(param)) {
         pullLatest3DayCommonOrder();
      }
      return ReturnT.SUCCESS;
   }
   // 淘宝推广订单 每隔1分执行一次
   @Scheduled(cron = "0 0/1 * * * ? ")
   public void pullLatestCommonOrder() {
      if (!Constant.IS_TASK)
         return;
   private void pullLatestCommonOrder() {
      LogHelper.job("pullLatestCommonOrder");
      Date systemDate = TaoKeApiUtil.getTaoBaoSystemTime();
      long endTime = systemDate != null ? systemDate.getTime() : System.currentTimeMillis();
      //
      updateOrder(endTime - 1000 * 60 * 20L, endTime);
   }
   // 返利
   @Scheduled(cron = "0 0/5 * * * ? ")
   public void fanli() {
      if (!Constant.IS_TASK)
         return;
   // 爬取最近一天的常规订单(30分钟一次)
   private void pullLatestDayCommonOrder() {
      LogHelper.job("pullLatestCommonOrder");
      Date systemDate = TaoKeApiUtil.getTaoBaoSystemTime();
      long endTime = systemDate != null ? systemDate.getTime() : System.currentTimeMillis();
      updateOrder(endTime - 1000 * 60 * 60 * 24L, endTime);
   }
   // 爬取最近三天的常规订单(6个小时一次)
   private void pullLatest3DayCommonOrder() {
      LogHelper.job("pullLatestCommonOrder");
      Date systemDate = TaoKeApiUtil.getTaoBaoSystemTime();
      long endTime = systemDate != null ? systemDate.getTime() : System.currentTimeMillis();
      updateOrder(endTime - 1000 * 60 * 60 * 24 * 3L, endTime);
   }
   // 5分钟执行一次
   @XxlJob("ownBuyFanLiHandler")
   public ReturnT<String> ownBuyFanLi(String param) throws Exception {
      LogHelper.job("处理返利到账前置");
      try {
         doTaoBaoWeiQuanOrder(2);
      } catch (Exception e) {
         LogHelper.errorDetailInfo(e);
      }
      LogHelper.job("开始处理返利");
      orderProcessService.fanli();
   }
   // 每月25号9点执行返利
   // @Scheduled(cron = "0 0 9 25 * ? ")
   @XxlJob("fanliInvaiteAndShareHandler")
   public ReturnT<String> fanliInvaiteAndShareHandler(String param) throws Exception {
      if (StringUtil.isNullOrEmpty(param))
         orderProcessService.fanliInvaiteAndShare();
      else
         orderProcessService.fanliInvaiteAndShare(Long.parseLong(param));
      return ReturnT.SUCCESS;
   }
   // 团队奖励到账
   @XxlJob("fanliOrderTeamRewardHandler")
   public ReturnT<String> fanliOrderTeamRewardHandler(String param) throws Exception {
      if (StringUtil.isNullOrEmpty(param))
         orderProcessService.fanliOrderTeamReward();
      else {
         orderProcessService.fanliOrderTeamReward(Long.parseLong(param));
      }
      return ReturnT.SUCCESS;
   }
   // 维权订单处理-处理最近60天的
   // 30分钟一次
   @Scheduled(cron = "0 0/30 * * * ? ")
   public void doTaoBaoWeiQuan() {
      if (!Constant.IS_TASK)
         return;
   @XxlJob("taoBaoWeiQuanOrderHandler")
   public ReturnT<String> doTaoBaoWeiQuan(String param) throws Exception {
      LogHelper.job("维权订单爬取");
      doTaoBaoWeiQuanOrder(5);
      return ReturnT.SUCCESS;
   }
   // 处理找回订单
   @XxlJob("doLostOrderHandler")
   public ReturnT<String> doLostOrder(String param) throws Exception {
      if ("fail".equalsIgnoreCase(param)) {// 更新最近的本地单(30分钟更新一次)
         doFailLostOrder();
      } else if ("success".equalsIgnoreCase(param)) {// 处理最近5天的本地订单
         addLostOrder();
      }
      return ReturnT.SUCCESS;
   }
   // 处理订单找回失败的情况 每6个小时执行一次
   @Scheduled(cron = "0 0 0/6 * * ? ")
   public void doFailLostOrder() {
      if (!Constant.IS_TASK)
         return;
   private void doFailLostOrder() {
      LogHelper.job("处理丢失订单自动找回失败的情况");
      lostOrderService.processFail();
   }
   // 每2分钟执行一次
   @Scheduled(cron = "0 0/2 * * * ? ")
   public void addLostOrder() {
      if (!Constant.IS_TASK)
         return;
   private void addLostOrder() {
      LogHelper.job("处理丢失订单");
      List<LostOrder> list = lostOrderService.listByStateAndResultCode(LostOrder.STATE_PASS,
            LostOrder.RESULT_CODE_VERFING, 1, 50);
@@ -438,77 +444,21 @@
         }
   }
   /**
    * 处理淘宝结算订单,30分执行一次
    */
   @Scheduled(cron = "30 0 0/1 * * ? ")
   public void doSettleOrders() {
      if (!Constant.IS_TASK)
         return;
      LogHelper.job("doSettleOrders");
      // 处理3-15天前的订单,每天跑一次
      Calendar ca = Calendar.getInstance();
      int hour = ca.get(Calendar.HOUR_OF_DAY);
      long startTime = TimeUtil.convertToTimeTemp(
            TimeUtil.getGernalTime(ca.getTimeInMillis() - 1000 * 60 * 60 * 24 * 3L, "yyyy-MM-dd"), "yyyy-MM-dd")
            - hour * (1000 * 60 * 60 * 12L);
      long endTime = startTime + 1000 * 60 * 60 * 12L;
      List<TaoBaoOrder> orderList = TaoKeOrderApiUtil.getTaoBaoCommonOrderList(startTime, endTime, 3);
      addOrder(orderList);
   }
   /**
    * 13分钟更新最近2小时的结算数据
    */
   @Scheduled(cron = "0 0/13 * * * ? ")
   public void doSettleOrdersToday() {
      if (!Constant.IS_TASK)
         return;
      LogHelper.job("doSettleOrdersToday");
      // 处理3-15天前的订单,每天跑一次
      Calendar ca = Calendar.getInstance();
      long startTime = ca.getTimeInMillis() - 1000 * 60 * 5L - 1000 * 60 * 60 * 2L;
      long endTime = startTime + 1000 * 60 * 60 * 2L;
      List<TaoBaoOrder> orderList = TaoKeOrderApiUtil.getTaoBaoCommonOrderList(startTime, endTime, 3);
      addOrder(orderList);
   }
   /**
    * 更新本地订单(凌晨25分更新)
    */
   @Scheduled(cron = "25 0 0 * * ? ")
   public void doLocalTaoBaoOrder() {
      if (!Constant.IS_TASK)
         return;
      LogHelper.job("doLocalTaoBaoOrder");
      // 处理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());
   // 处理淘宝本地订单
   @XxlJob("doLocalTaoBaoOrder")
   public ReturnT<String> updatePDDOrder(String param) throws Exception {
      if ("1".equalsIgnoreCase(param)) {// 更新最近的本地单(30分钟更新一次)
         doLatestLocalTaoBaoOrder();
      } else if ("5day".equalsIgnoreCase(param)) {// 处理最近5天的本地订单
         doLatest5DayLocalTaoBaoOrder();
      }
      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);
      }
      return ReturnT.SUCCESS;
   }
   /**
    * 更新最近的本地单(30分钟更新一次)
    */
   @Scheduled(cron = "0 0/30 * * * ? ")
   public void doLatestLocalTaoBaoOrder() {
      if (!Constant.IS_TASK)
         return;
   private void doLatestLocalTaoBaoOrder() {
      Long endTime = System.currentTimeMillis() - 1000 * 60 * 10L;
      Long startTime = endTime - 1000 * 60 * 60 * 12L;
      updateLocalTaoBaoOrder(startTime, endTime, 1, 2000);
@@ -517,10 +467,7 @@
   /**
    * 处理最近5天的本地订单
    */
   @Scheduled(cron = "30 13 3 * * ? ")
   public void doLatest5DayLocalTaoBaoOrder() {
      if (!Constant.IS_TASK)
         return;
   private void doLatest5DayLocalTaoBaoOrder() {
      LogHelper.job("doLatest5DayLocalTaoBaoOrder");
      Long endTime = System.currentTimeMillis() - 1000 * 60 * 60 * 12L;
      Long startTime = endTime - 1000 * 60 * 60 * 24 * 5L;
@@ -532,13 +479,9 @@
      }
   }
   /**
    * 处理上月订单成功
    */
   @Scheduled(cron = "0 0 12 25 * ? ")
   public void doSellerNotPayOrder() {
      if (!Constant.IS_TASK)
         return;
   // 淘宝商家跑路订单 每月25号12点处理上月的
   @XxlJob("doTaoBaoSellerNotPayOrderHandler")
   public ReturnT<String> doSellerNotPayOrder(String param) throws Exception {
      LogHelper.job("doSellerNotPayOrder");
      Calendar calender = Calendar.getInstance();
      long endTime = TimeUtil.convertToTimeTemp(TimeUtil.getGernalTime(calender.getTimeInMillis(), "yyyy-MM"),
@@ -557,6 +500,7 @@
            } catch (Exception e) {
               LogHelper.errorDetailInfo(e);
            }
      return ReturnT.SUCCESS;
   }
}