yujian
2019-03-07 e6cb7c27384f22b39ccee584028e23b56c30e9ee
fanli/src/main/java/com/yeshi/fanli/job/UpdateOrderJob.java
@@ -10,6 +10,8 @@
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
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.taobao.TaoBaoOrder;
import com.yeshi.fanli.entity.taobao.TaoBaoUnionConfig;
@@ -19,14 +21,18 @@
import com.yeshi.fanli.service.inter.common.DataMonitorService;
import com.yeshi.fanli.service.inter.hongbao.HongBaoService;
import com.yeshi.fanli.service.inter.hongbao.ThreeSaleGiftService;
import com.yeshi.fanli.service.inter.order.LostOrderService;
import com.yeshi.fanli.service.inter.order.OrderItemServcie;
import com.yeshi.fanli.service.inter.order.OrderProcessService;
import com.yeshi.fanli.service.inter.order.OrderService;
import com.yeshi.fanli.service.inter.order.PidOrderService;
import com.yeshi.fanli.service.inter.taobao.TaoBaoOrderService;
import com.yeshi.fanli.service.inter.taobao.TaoBaoUnionConfigService;
import com.yeshi.fanli.service.inter.taobao.TaoBaoWeiQuanOrderService;
import com.yeshi.fanli.util.CMQManager;
import com.yeshi.fanli.util.Constant;
import com.yeshi.fanli.util.RedisManager;
import com.yeshi.fanli.util.StringUtil;
import com.yeshi.fanli.util.TimeUtil;
import com.yeshi.fanli.util.taobao.TaoBao110Util;
import com.yeshi.fanli.util.taobao.TaoBaoOrderUtil;
@@ -69,6 +75,15 @@
   @Resource
   private DataMonitorService dataMonitorService;
   @Resource
   private RedisManager redisManager;
   @Resource
   private LostOrderService lostOrderService;
   @Resource
   private OrderService orderService;
   private void updateOrder(long startTime, long endTime) {
      List<TaoBaoUnionConfig> configList = taoBaoUnionConfigService.getConfigByTypeCache(PidUser.TYPE_FANLI_ANDROID);
      List<TaoBaoOrder> orderList = new ArrayList<>();
@@ -104,7 +119,7 @@
   }
   private void addOrder(List<TaoBaoOrder> orderList) {
   private void addRelationAndSpecialOrder(List<TaoBaoOrder> orderList) {
      try {
         taoBaoOrderService.addTaoBaoOrderList(orderList);
      } catch (Exception e) {
@@ -122,7 +137,96 @@
            while (its.hasNext()) {
               String key = its.next();
               List<TaoBaoOrder> orders = map.get(key);
               String redisKey = "addorderqueue-" + key;
               // redis做频率限制
               try {
                  if (!StringUtil.isNullOrEmpty(redisManager.getCommonString(redisKey))) {
                     continue;
                  }
               } catch (Exception e) {
               }
               CMQManager.getInstance().addTaoBaoOrderMsg(key, orders);
               try {
                  // 6小时内不再处理
                  redisManager.cacheCommonString(redisKey, "1", 60 * 60 * 6);
               } catch (Exception e) {
               }
            }
         }
      } catch (Exception e) {
         try {
            LogHelper.errorDetailInfo(e);
         } catch (Exception e1) {
            e1.printStackTrace();
         }
      }
   }
   private void addOrder(List<TaoBaoOrder> orderList) {
      if (orderList != null)
         for (int i = 0; i < orderList.size(); i++) {
            // 移除会员运营ID与渠道专属订单
            if (orderList.get(i).getAdPositionName().contains("会员运营")
                  || orderList.get(i).getAdPositionName().contains("渠道专属")) {
               if (orderList.get(i).getAdPositionName().contains("会员运营")) {// 处理订单申诉
                  Order order = orderService.findOrderByOrderIdAndType(orderList.get(i).getOrderId(),
                        Order.ORDER_TYPE_TAOBAO);
                  if (order != null && order.getBeizhu().contains("补单")) {// 不排除补单的情况
                  } else {
                     orderList.remove(i);
                     i--;
                     break;
                  }
               } else {
                  orderList.remove(i);
                  i--;
               }
            }
         }
      try {
         taoBaoOrderService.addTaoBaoOrderList(orderList);
      } catch (Exception e) {
         try {
            LogHelper.errorDetailInfo(e);
         } catch (Exception e1) {
            e1.printStackTrace();
         }
      }
      try {
         Map<String, List<TaoBaoOrder>> map = TaoBaoOrderUtil.classifyTaoBaoOrderByOrderId(orderList);
         if (map != null) {
            Iterator<String> its = map.keySet().iterator();
            while (its.hasNext()) {
               String key = its.next();
               List<TaoBaoOrder> orders = map.get(key);
               String redisKey = "addorderqueue-" + key;
               // redis做频率限制
               try {
                  if (!StringUtil.isNullOrEmpty(redisManager.getCommonString(redisKey))) {
                     continue;
                  }
               } catch (Exception e) {
               }
               CMQManager.getInstance().addTaoBaoOrderMsg(key, orders);
               try {
                  // 6小时内不再处理
                  redisManager.cacheCommonString(redisKey, "1", 60 * 60 * 6);
               } catch (Exception e) {
               }
            }
         }
      } catch (Exception e) {
@@ -154,7 +258,7 @@
   }
   // 淘宝推广订单 每隔3分13秒执行一次
   @Scheduled(cron = "13 0/3 0 24,25 * ? ")
   @Scheduled(cron = "13 0/3 * * * ? ")
   public void doJob6() {
      if (!Constant.IS_TASK)
         return;
@@ -198,7 +302,7 @@
   public void doJob2() {
      if (!Constant.IS_TASK)
         return;
      doJob4();
      doTaoBaoWeiQuan();
      orderProcessService.fanli();
   }
@@ -214,7 +318,7 @@
   // 维权订单处理-处理最近60天的
   // 30分钟一次
   @Scheduled(cron = "0 0/30 * * * ? ")
   public void doJob4() {
   public void doTaoBaoWeiQuan() {
      if (!Constant.IS_TASK)
         return;
      List<TaoBaoUnionConfig> configList = taoBaoUnionConfigService.getConfigByTypeCache(PidUser.TYPE_FANLI_ANDROID);
@@ -227,12 +331,18 @@
      orderProcessService.weiQuanOrder(orderList);
   }
   // 处理分享商品所产生的订单
   @Scheduled(cron = "0 0/2 * * * ? ")
   public void doJob7() {
      if (!Constant.IS_TASK)
         return;
      pidOrderService.doPidOrder();
   // 处理分享商品所产生的订单(后续版本废除)
   // @Scheduled(cron = "0 0/2 * * * ? ")
   // public void doPidOrder() {
   // if (!Constant.IS_TASK)
   // return;
   // pidOrderService.doPidOrder();
   // }
   // 每6个小时执行一次
   @Scheduled(cron = "0 0 0/6 * * ? ")
   public void doLostOrder() {
      lostOrderService.processFail();
   }
}