admin
2020-04-16 d525f0175016f802def58d244235bd0285df5235
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
package com.yeshi.fanli.util.rocketmq.consumer.order;
 
import java.util.Date;
 
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.dto.mq.order.body.TeamRewardPreRecieveMQMsg;
import com.yeshi.fanli.exception.ParamsException;
import com.yeshi.fanli.exception.money.OrderMoneySettleException;
import com.yeshi.fanli.exception.money.TeamEincomeRecordException;
import com.yeshi.fanli.exception.order.CommonOrderException;
import com.yeshi.fanli.exception.order.InviteOrderSubsidyException;
import com.yeshi.fanli.log.LogHelper;
import com.yeshi.fanli.service.inter.mq.MQUnSendInfoService;
import com.yeshi.fanli.service.inter.order.CommonOrderService;
import com.yeshi.fanli.service.inter.order.OrderMoneySettleService;
import com.yeshi.fanli.service.inter.user.UserSystemCouponRecordService;
import com.yeshi.fanli.service.manger.order.TeamSubsidyManager;
import com.yeshi.fanli.util.Constant;
import com.yeshi.fanli.util.TimeUtil;
import com.yeshi.fanli.util.rocketmq.MQTopicName;
 
/**
 * 邀请订单补贴消息消费
 * 
 * @author Administrator
 *
 */
@Component
public class InviteOrderSubsidyMessageListener implements MessageListener {
    @Resource
    private TeamSubsidyManager teamSubsidyManager;
 
    @Resource
    private UserSystemCouponRecordService userSystemCouponRecordService;
 
    @Resource(name = "producer")
    private Producer producer;
 
    @Resource
    private MQUnSendInfoService mqUnSendInfoService;
 
    @Resource
    private OrderMoneySettleService orderMoneySettleService;
 
    @Resource
    private CommonOrderService commonOrderService;
    
    public InviteOrderSubsidyMessageListener() {
 
    }
 
    @Override
    public Action consume(Message message, ConsumeContext context) {
        LogHelper.mqInfo("consumer:InviteOrderSubsidyMessageListener", message.getMsgID(), message.getTopic(),
                message.getTag(), new String(message.getBody()));
        String tag = message.getTag();
 
        if (MQTopicName.TOPIC_ORDER.name().equalsIgnoreCase(message.getTopic())) {
            if (tag.equalsIgnoreCase(OrderTopicTagEnum.orderStatistic.name())
                    || tag.equalsIgnoreCase(OrderTopicTagEnum.orderUpdate.name())) {
                // 查询上级红包
                OrderMQMsg dto = new Gson().fromJson(new String(message.getBody()), OrderMQMsg.class);
                if (dto != null) {
                    // 查询出订单创建时间
                    Date orderTime = commonOrderService.getThirdCreateTime(dto.getOrderId(), dto.getType());
                    if (orderTime.getTime() >= Constant.NEW_ORDER_FANLI_RULE_TIME) {
                        try {
                            teamSubsidyManager.addOrUpdateOrder(dto.getOrderId(), dto.getType());
                            return Action.CommitMessage;
                        } catch (InviteOrderSubsidyException e) {
                            e.printStackTrace();
                            LogHelper.errorDetailInfo(e, new Gson().toJson(dto), "");
                        } catch (CommonOrderException e) {
                            e.printStackTrace();
                            LogHelper.errorDetailInfo(e, new Gson().toJson(dto), "");
                        }
                        return Action.ReconsumeLater;
                    } else {
                        try {
                            teamSubsidyManager.addOrUpdateOrder(dto.getOrderId(), dto.getType());
                        } catch (Exception e) {
                            LogHelper.errorDetailInfo(e, new Gson().toJson(dto), "");
                            return Action.ReconsumeLater;
                        }
                    }
                }
            } else if (tag.equalsIgnoreCase(OrderTopicTagEnum.teamRewardPreRecieved.name())) {// 团队奖金预到账
                TeamRewardPreRecieveMQMsg dto = new Gson().fromJson(new String(message.getBody()),
                        TeamRewardPreRecieveMQMsg.class);
                try {
                    teamSubsidyManager.addToTeamEincome(dto.getUid(), message.getKey(), dto.getPreGetTime());
                    return Action.CommitMessage;
                } catch (OrderMoneySettleException e) {
                    e.printStackTrace();
                } catch (TeamEincomeRecordException e) {
                    e.printStackTrace();
                } catch (ParamsException e) {
                    e.printStackTrace();
                }
                return Action.ReconsumeLater;
            }
        }
        return Action.CommitMessage;
    }
}