From a6f34b99ee20e528b766c8ed5a61bd9c5aa0e7ae Mon Sep 17 00:00:00 2001 From: admin <weikou2014> Date: 星期六, 16 十一月 2019 18:10:33 +0800 Subject: [PATCH] 淘宝相似商品推荐接口优化,根据商品ID搜索商品基本信息优化 --- fanli/src/main/java/com/yeshi/fanli/util/rocketmq/consumer/redpack/RedPackMessageListener.java | 75 +++++++++++++++++++++++++++++++++---- 1 files changed, 66 insertions(+), 9 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..5f74637 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 @@ -11,12 +11,16 @@ 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.order.body.OrderMQMsg; +import com.yeshi.fanli.dto.mq.order.body.OrderMoneyRecievedMQMsg; 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.user.body.UserRedPackGiftMQMsg; 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,36 +37,89 @@ @Resource private UserSystemCouponService userSystemCouponService; + @Resource + private RedPackWinInviteService redPackWinInviteService; + + @Resource + private RedPackGiveRecordService redPackGiveRecordService; + @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())) {// 杩斿埄鍒拌处 - + OrderMoneyRecievedMQMsg orderMoneyRecievedMQMsg = new Gson().fromJson(new String(message.getBody()), + OrderMoneyRecievedMQMsg.class); + // 鍒嗕韩璁㈠崟濂栧姳 + if (orderMoneyRecievedMQMsg.getType() == OrderMoneyRecievedMQMsg.TYPE_SHARE) { +// try { +// redPackWinInviteService.orderArriveReward(orderMoneyRecievedMQMsg.getUid(), +// orderMoneyRecievedMQMsg.getSourceType(), orderMoneyRecievedMQMsg.getOrderId()); +// } catch (Exception e) { +// e.printStackTrace(); +// } + } } else if (tag.equalsIgnoreCase(OrderTopicTagEnum.orderStatistic.name())) {// 璁㈠崟缁熻 - + OrderMQMsg orderMQMsg = new Gson().fromJson(new String(message.getBody()), OrderMQMsg.class); + if (orderMQMsg.isValid()) { + try {// 閭�璇峰鍔� + redPackWinInviteService.inviteSucceedReward(orderMQMsg.getUid()); + } catch (Exception e) { + e.printStackTrace(); + } + } } + } else if (MQTopicName.TOPIC_USER.name().equalsIgnoreCase(message.getTopic())) { + boolean inviteSucceedReward = false; + Long uid = null; if (tag.equalsIgnoreCase(UserTopicTagEnum.userAccountBinding.name())) {// 璐﹀彿缁戝畾 UserAccountBindingMQMsg userAccountBindingMQMsg = new Gson().fromJson(new String(message.getBody()), UserAccountBindingMQMsg.class); - + Integer type = userAccountBindingMQMsg.getType(); + if (type == UserAccountBindingMQMsg.TYPE_PHONE || type == UserAccountBindingMQMsg.TYPE_TAOBAO) { + inviteSucceedReward = true; + uid = userAccountBindingMQMsg.getUid(); + } } else if (tag.equalsIgnoreCase(UserTopicTagEnum.inviteSuccess.name())) {// 閭�璇锋垚鍔� UserInviteMQMsg userInviteMQMsg = new Gson().fromJson(new String(message.getBody()), UserInviteMQMsg.class); - + inviteSucceedReward = true; + uid = userInviteMQMsg.getWorkerId(); } else if (tag.equalsIgnoreCase(UserTopicTagEnum.integralTaskFinish.name())) {// 閲戝竵浠诲姟瀹屾垚 IntegralTaskMQMsg integralTaskMQMsg = new Gson().fromJson(new String(message.getBody()), IntegralTaskMQMsg.class); + inviteSucceedReward = true; + uid = integralTaskMQMsg.getUid(); + } else if (tag.equalsIgnoreCase(UserTopicTagEnum.redPackGiftDrawback.name())) {// 绾㈠寘璧犻�� + UserRedPackGiftMQMsg userRedPackGiftMQMsg = new Gson().fromJson(new String(message.getBody()), + UserRedPackGiftMQMsg.class); + // 绾㈠寘璧犻�佸埌鏈熸湭棰嗗彇 + try { + redPackGiveRecordService.overdueByPrimaryKey(userRedPackGiftMQMsg.getId()); + } catch (Exception e) { + e.printStackTrace(); + } + return Action.CommitMessage; } + + if (inviteSucceedReward) { + try {// 閭�璇峰鍔� + if(uid==6269748) + { + System.out.println(uid); + } +// redPackWinInviteService.inviteSucceedReward(uid); + } catch (Exception e) { + e.printStackTrace(); + } + } + } return Action.CommitMessage; } -- Gitblit v1.8.0