package com.yeshi.fanli.util.mq.rabbit.consumer;
|
|
import com.rabbitmq.client.Channel;
|
import com.yeshi.fanli.entity.pdd.PDDOrder;
|
import com.yeshi.fanli.log.LogHelper;
|
import com.yeshi.fanli.service.inter.order.OrderProcessService;
|
import com.yeshi.fanli.service.inter.order.pdd.PDDOrderService;
|
import com.yeshi.fanli.util.StringUtil;
|
import com.yeshi.fanli.util.mq.rabbit.RabbitmqMsgConsumeUtil;
|
import org.springframework.amqp.core.Message;
|
import org.springframework.amqp.rabbit.annotation.RabbitListener;
|
import org.springframework.amqp.rabbit.core.RabbitTemplate;
|
import org.springframework.stereotype.Component;
|
|
import javax.annotation.Resource;
|
import java.nio.charset.StandardCharsets;
|
import java.util.List;
|
|
/**
|
* @author hxh
|
* @title: QueueHelloWorldListener
|
* @description:
|
* @date 2024/9/26 13:47
|
*/
|
@Component
|
public class OrderPDDListener {
|
@Resource
|
private RabbitTemplate rabbitTemplate;
|
|
@Resource
|
private PDDOrderService pddOrderService;
|
|
@Resource
|
private OrderProcessService orderProcessService;
|
|
@RabbitListener(queues = "order-pdd-fanli", ackMode = "MANUAL")
|
public void onMessage(Message message, Channel channel) throws Exception {
|
RabbitmqMsgConsumeUtil.processMessage(message, channel, rabbitTemplate, () -> {
|
String orderId = new String(message.getBody(), StandardCharsets.UTF_8);
|
try {
|
if (!StringUtil.isNullOrEmpty(orderId)) {
|
List<PDDOrder> orderList = pddOrderService.selectByOrderSn(orderId);
|
if (orderList != null)
|
for (PDDOrder order : orderList)
|
orderProcessService.processPDDOrder(order);
|
}
|
LogHelper.test("拼多多订单处理成功:" + orderId);
|
} catch (Exception e) {
|
LogHelper.test("拼多多订单处理失败:" + orderId);
|
LogHelper.errorDetailInfo(e);
|
throw e;
|
}
|
|
});
|
}
|
}
|