package com.yeshi.fanli.util.rocketmq.consumer.redpack;
|
|
import javax.annotation.Resource;
|
|
import org.springframework.stereotype.Component;
|
|
import com.aliyun.openservices.ons.api.Action;
|
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.order.OrderTopicTagEnum;
|
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;
|
|
/**
|
* 红包消费
|
*
|
* @author Administrator
|
*
|
*/
|
@Component
|
public class RedPackMessageListener implements MessageListener {
|
|
@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.getMsgID(), message.getTopic(), message.getTag(),
|
new String(message.getBody()));
|
String tag = message.getTag();
|
if (tag == null)
|
tag = "";
|
|
if (MQTopicName.TOPIC_ORDER.name().equalsIgnoreCase(message.getTopic())) {
|
if (tag.equalsIgnoreCase(OrderTopicTagEnum.orderStatistic.name())) {// 订单统
|
OrderMQMsg mqMsg = new Gson().fromJson(new String(message.getBody()), OrderMQMsg.class);
|
|
try {// 邀请奖励
|
redPackWinInviteService.winRedPackByOrder(mqMsg.getUid(), mqMsg.getOrderId(), mqMsg.getType(), mqMsg.getPlaceTime());
|
} catch (Exception e) {
|
LogHelper.errorDetailInfo(e);
|
}
|
|
// 发送48小时延时消息
|
boolean verifyOrder = redPackWinInviteService.verifyOrder(mqMsg.getUid(), mqMsg.getOrderId(), mqMsg.getType(), mqMsg.getPlaceTime());
|
if (verifyOrder) {
|
int hour = 48;
|
if (Constant.IS_TEST) {
|
hour = 1;
|
}
|
mqMsg.setDelayHour(hour);
|
Message msg = new Message(message.getTopic(), OrderTopicTagEnum.orderStatisticDelay.name(),
|
new Gson().toJson(mqMsg).getBytes());
|
if (mqMsg.getStaticticDate().getTime() + 1000 * 60 * 60L * hour > System.currentTimeMillis())// 时间是否已经过了
|
msg.setStartDeliverTime(mqMsg.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;
|
}
|
|
if (mqMsg.getDelayHour() == hour) {
|
try {
|
redPackWinInviteService.winFreeCoupon(mqMsg.getUid(), mqMsg.getOrderId(), mqMsg.getType(), mqMsg.getPlaceTime());
|
} catch (Exception e) {
|
LogHelper.errorDetailInfo(e);
|
return Action.ReconsumeLater;
|
}
|
}
|
return Action.CommitMessage;
|
}
|
}
|
return Action.CommitMessage;
|
}
|
}
|