From 433c5abadf47a785f2a2042b4be2b3ab97190685 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Fri, 26 Aug 2022 17:56:49 +0800
Subject: [PATCH] 20220822
---
src/main/java/cc/mrbird/febs/common/configure/RabbitConfigure.java | 83 +++++++++++++++++++++++++++++++++++++++--
1 files changed, 79 insertions(+), 4 deletions(-)
diff --git a/src/main/java/cc/mrbird/febs/common/configure/RabbitConfigure.java b/src/main/java/cc/mrbird/febs/common/configure/RabbitConfigure.java
index 96a523b..50797b6 100644
--- a/src/main/java/cc/mrbird/febs/common/configure/RabbitConfigure.java
+++ b/src/main/java/cc/mrbird/febs/common/configure/RabbitConfigure.java
@@ -3,10 +3,8 @@
import cc.mrbird.febs.rabbit.constants.ExchangeConstants;
import cc.mrbird.febs.rabbit.constants.QueueConstants;
import cc.mrbird.febs.rabbit.constants.RouteKeyConstants;
-import org.springframework.amqp.core.Binding;
-import org.springframework.amqp.core.BindingBuilder;
-import org.springframework.amqp.core.DirectExchange;
-import org.springframework.amqp.core.Queue;
+import cc.mrbird.febs.rabbit.enumerates.RabbitQueueEnum;
+import org.springframework.amqp.core.*;
import org.springframework.amqp.rabbit.connection.ConnectionFactory;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.beans.factory.config.ConfigurableBeanFactory;
@@ -47,4 +45,81 @@
public Binding defaultBind() {
return BindingBuilder.bind(defaultQueue()).to(defaultExchange()).with(RouteKeyConstants.ROUTE_KEY_DEFAULT);
}
+
+ @Bean
+ public DirectExchange delayTtlExchange() {
+ return new DirectExchange(RabbitQueueEnum.ORDER_CANCEL_DELAY_TTL.getExchange());
+ }
+
+ @Bean
+ public DirectExchange orderDelayExchange() {
+ return new DirectExchange(RabbitQueueEnum.ORDER_CANCEL_DELAY.getExchange());
+ }
+
+ @Bean
+ public Queue orderDelayQueue() {
+ return new Queue(RabbitQueueEnum.ORDER_CANCEL_DELAY.getQueue());
+ }
+
+ @Bean
+ public Queue orderDelayQueueTtl() {
+ return QueueBuilder.durable(RabbitQueueEnum.ORDER_CANCEL_DELAY_TTL.getQueue())
+ //到期后转发的交换机
+ .withArgument("x-dead-letter-exchange", RabbitQueueEnum.ORDER_CANCEL_DELAY.getExchange())
+ //到期后转发的路由键
+ .withArgument("x-dead-letter-routing-key", RabbitQueueEnum.ORDER_CANCEL_DELAY.getRoute())
+ .build();
+ }
+
+ @Bean
+ public Binding orderDelayBind() {
+ return BindingBuilder.bind(orderDelayQueue()).to(orderDelayExchange()).with(RabbitQueueEnum.ORDER_CANCEL_DELAY.getRoute());
+ }
+
+ @Bean
+ public Binding orderDelayBindTtl() {
+ return BindingBuilder.bind(orderDelayQueueTtl()).to(delayTtlExchange()).with(RabbitQueueEnum.ORDER_CANCEL_DELAY_TTL.getRoute());
+ }
+
+ @Bean
+ public Queue autoLevelUpAgentQueue() {
+ return new Queue(QueueConstants.AGENT_AUTO_LEVEL_UP);
+ }
+
+ @Bean
+ public Binding autoLevelUpBind() {
+ return BindingBuilder.bind(autoLevelUpAgentQueue()).to(defaultExchange()).with(RouteKeyConstants.ROUTE_KEY_DEFAULT);
+ }
+
+ @Bean
+ public DirectExchange agentReturnMoneyExchange() {
+ return new DirectExchange(RabbitQueueEnum.AGENT_REUTRN_MONEY.getExchange());
+ }
+
+ @Bean
+ public Queue agentReturnMoneyQueue() {
+ return new Queue(QueueConstants.AGENT_RETURN_MONEY);
+ }
+
+ @Bean
+ public Binding agentReturnMoneyBind() {
+ return BindingBuilder.bind(agentReturnMoneyQueue()).to(agentReturnMoneyExchange()).with(RabbitQueueEnum.AGENT_REUTRN_MONEY.getRoute());
+ }
+
+
+ @Bean
+ public DirectExchange orderReturnMoneyExchange() {
+ return new DirectExchange(RabbitQueueEnum.ORDER_RETURN_MONEY.getExchange());
+ }
+
+ @Bean
+ public Queue orderReturnMoneyQueue() {
+ return new Queue(QueueConstants.ORDER_RETURN_MONEY);
+ }
+
+ @Bean
+ public Binding orderReturnMoneyBind() {
+ return BindingBuilder.bind(orderReturnMoneyQueue()).to(orderReturnMoneyExchange()).with(RabbitQueueEnum.ORDER_RETURN_MONEY.getRoute());
+ }
+
}
--
Gitblit v1.9.1