admin
2025-02-25 30d8e227e8d823b6c38c3b9c90ac2df03b63befe
fanli/src/main/java/com/yeshi/fanli/util/rocketmq/consumer/redpack/RedPackMessageListener.java
@@ -1,89 +1,74 @@
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 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;
            }
            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;
   }
}
package com.yeshi.fanli.util.rocketmq.consumer.redpack;
import javax.annotation.Resource;
import com.yeshi.fanli.entity.SystemEnum;
import com.yeshi.fanli.entity.SystemFunction;
import com.yeshi.fanli.service.inter.user.UserInfoService;
import com.yeshi.fanli.service.manger.msg.RocketMQManager;
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.OrderConfirmMQMsg;
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.rocketmq.MQTopicName;
/**
 * 红包消费
 *
 * @author Administrator
 */
@Component
public class RedPackMessageListener implements MessageListener {
    @Resource
    private UserSystemCouponService userSystemCouponService;
    @Resource
    private RedPackWinInviteService redPackWinInviteService;
    @Resource
    private RedPackGiveRecordService redPackGiveRecordService;
    @Resource
    private RocketMQManager rocketMQManager;
    @Resource
    private UserInfoService userInfoService;
    @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.orderConfirm.name())) {
                OrderConfirmMQMsg mqMsg = new Gson().fromJson(new String(message.getBody()), OrderConfirmMQMsg.class);
                //判断系统是否包含红包功能
                Long sourceUid = mqMsg.getSourceUid();
                SystemEnum system = userInfoService.getUserSystem(sourceUid);
                if (!system.getFunctionSet().contains(SystemFunction.redPack))
                    return Action.CommitMessage;
                try {// 邀请奖励
                    redPackWinInviteService.winRedPackByOrder(mqMsg.getSourceUid(), mqMsg.getOrderNo(), mqMsg.getSourceType());
                } catch (Exception e) {
                    LogHelper.errorDetailInfo(e);
                }
            }
        }
        return Action.CommitMessage;
    }
}