From 880238957a973ecd9676237672276b0e99d31115 Mon Sep 17 00:00:00 2001
From: yujian <yujian@163.com>
Date: 星期一, 29 六月 2020 13:55:28 +0800
Subject: [PATCH] 免单

---
 fanli/src/main/java/com/yeshi/fanli/util/rocketmq/consumer/redpack/RedPackMessageListener.java |   72 +++++++++++++++++++++++-------------
 1 files changed, 46 insertions(+), 26 deletions(-)

diff --git a/fanli/src/main/java/com/yeshi/fanli/util/rocketmq/consumer/redpack/RedPackMessageListener.java b/fanli/src/main/java/com/yeshi/fanli/util/rocketmq/consumer/redpack/RedPackMessageListener.java
index e8a6432..5416749 100644
--- a/fanli/src/main/java/com/yeshi/fanli/util/rocketmq/consumer/redpack/RedPackMessageListener.java
+++ b/fanli/src/main/java/com/yeshi/fanli/util/rocketmq/consumer/redpack/RedPackMessageListener.java
@@ -8,15 +8,13 @@
 import com.aliyun.openservices.ons.api.ConsumeContext;
 import com.aliyun.openservices.ons.api.Message;
 import com.aliyun.openservices.ons.api.MessageListener;
+import com.aliyun.openservices.ons.api.Producer;
 import com.google.gson.Gson;
-import com.yeshi.fanli.dto.mq.BaseMQMsgBody;
 import com.yeshi.fanli.dto.mq.order.OrderTopicTagEnum;
-import com.yeshi.fanli.dto.mq.user.UserTopicTagEnum;
-import com.yeshi.fanli.dto.mq.user.body.IntegralTaskMQMsg;
-import com.yeshi.fanli.dto.mq.user.body.UserAccountBindingMQMsg;
-import com.yeshi.fanli.dto.mq.user.body.UserInviteMQMsg;
-import com.yeshi.fanli.dto.mq.user.body.UserRegisterMQMsg;
+import com.yeshi.fanli.dto.mq.order.body.OrderMQMsg;
 import com.yeshi.fanli.log.LogHelper;
+import com.yeshi.fanli.service.inter.redpack.RedPackGiveRecordService;
+import com.yeshi.fanli.service.inter.redpack.RedPackWinInviteService;
 import com.yeshi.fanli.service.inter.user.UserSystemCouponService;
 import com.yeshi.fanli.util.Constant;
 import com.yeshi.fanli.util.rocketmq.MQTopicName;
@@ -33,35 +31,57 @@
 	@Resource
 	private UserSystemCouponService userSystemCouponService;
 
+	@Resource
+	private RedPackWinInviteService redPackWinInviteService;
+
+	@Resource
+	private RedPackGiveRecordService redPackGiveRecordService;
+
+	@Resource(name = "producer")
+	private Producer producer;
+
 	@Override
 	public Action consume(Message message, ConsumeContext context) {
-		LogHelper.mqInfo("consumer-RedPackMessageListener", message.getTopic(), message.getTag(),
+		LogHelper.mqInfo("consumer-RedPackMessageListener", message.getMsgID(), message.getTopic(), message.getTag(),
 				new String(message.getBody()));
 		String tag = message.getTag();
 		if (tag == null)
 			tag = "";
-		BaseMQMsgBody baseBody = new Gson().fromJson(new String(message.getBody()), BaseMQMsgBody.class);
-		if (baseBody.isTest() != Constant.IS_TEST)
-			return Action.ReconsumeLater;
 
 		if (MQTopicName.TOPIC_ORDER.name().equalsIgnoreCase(message.getTopic())) {
-			if (tag.equalsIgnoreCase(OrderTopicTagEnum.orderFanLiActual.name())) {// 杩斿埄鍒拌处
+			if (tag.equalsIgnoreCase(OrderTopicTagEnum.orderStatistic.name())) {// 璁㈠崟缁�
+				OrderMQMsg orderMQMsg = new Gson().fromJson(new String(message.getBody()), OrderMQMsg.class);
+				// 鍙戦��24灏忔椂寤舵椂娑堟伅
+				// 娴嬭瘯鏃跺彂閫�
+				int hour = 48;
+				if (Constant.IS_TEST) {
+					hour = 1;
+				}
+				orderMQMsg.setDelayHour(hour);
+				Message msg = new Message(message.getTopic(), OrderTopicTagEnum.orderStatisticDelay.name(),
+						new Gson().toJson(orderMQMsg).getBytes());
+				if (orderMQMsg.getStaticticDate().getTime() + 1000 * 60 * 60L * hour > System.currentTimeMillis())// 鏃堕棿鏄惁宸茬粡杩囦簡
+					msg.setStartDeliverTime(orderMQMsg.getStaticticDate().getTime() + 1000 * 60 * 60L * hour);
+				else
+					msg.setStartDeliverTime(System.currentTimeMillis() + 1000 * 60);
+				producer.send(msg);
+				return Action.CommitMessage;
+			} else if (tag.equalsIgnoreCase(OrderTopicTagEnum.orderStatisticDelay.name())) {// 璁㈠崟缁熻
+				OrderMQMsg mqMsg = new Gson().fromJson(new String(message.getBody()), OrderMQMsg.class);
+				int hour = 48;
+				if (Constant.IS_TEST) {
+					hour = 1;
+				}
 
-			} else if (tag.equalsIgnoreCase(OrderTopicTagEnum.orderStatistic.name())) {// 璁㈠崟缁熻
-
-			}
-		} else if (MQTopicName.TOPIC_USER.name().equalsIgnoreCase(message.getTopic())) {
-			if (tag.equalsIgnoreCase(UserTopicTagEnum.userAccountBinding.name())) {// 璐﹀彿缁戝畾
-				UserAccountBindingMQMsg userAccountBindingMQMsg = new Gson().fromJson(new String(message.getBody()),
-						UserAccountBindingMQMsg.class);
-
-			} else if (tag.equalsIgnoreCase(UserTopicTagEnum.inviteSuccess.name())) {// 閭�璇锋垚鍔�
-				UserInviteMQMsg userInviteMQMsg = new Gson().fromJson(new String(message.getBody()),
-						UserInviteMQMsg.class);
-
-			} else if (tag.equalsIgnoreCase(UserTopicTagEnum.integralTaskFinish.name())) {// 閲戝竵浠诲姟瀹屾垚
-				IntegralTaskMQMsg integralTaskMQMsg = new Gson().fromJson(new String(message.getBody()),
-						IntegralTaskMQMsg.class);
+				if (mqMsg.getDelayHour() == hour) {
+					try {// 閭�璇峰鍔�
+						redPackWinInviteService.winRedPackByOrder(mqMsg.getUid(), mqMsg.getOrderId(), mqMsg.getType());
+					} catch (Exception e) {
+						LogHelper.errorDetailInfo(e);
+						return Action.ReconsumeLater;
+					}
+				}
+				return Action.CommitMessage;
 			}
 		}
 		return Action.CommitMessage;

--
Gitblit v1.8.0