Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 6 additions & 0 deletions email-service/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,12 @@
<artifactId>spring-rabbit-test</artifactId>
<scope>test</scope>
</dependency>

<dependency>
<groupId>net.adiletkdev</groupId>
<artifactId>order-service</artifactId>
<version>0.0.1-SNAPSHOT</version>
</dependency>
</dependencies>

<build>
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
package net.adiletkdev.emailservice.config;

import org.springframework.amqp.core.AmqpTemplate;
import org.springframework.amqp.rabbit.connection.ConnectionFactory;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.amqp.support.converter.Jackson2JsonMessageConverter;
import org.springframework.amqp.support.converter.MessageConverter;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class RabbitMQConfig {

// message converter
@Bean
public MessageConverter converter() {
return new Jackson2JsonMessageConverter();
}

// configure RabbitTemplate
public AmqpTemplate amqpTemplate(ConnectionFactory connectionFactory) {
RabbitTemplate rabbitTemplate = new RabbitTemplate(connectionFactory);
rabbitTemplate.setMessageConverter(converter());

return rabbitTemplate;
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
package net.adiletkdev.emailservice.consumer;

import net.adiletkdev.orderservice.dto.OrderEvent;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.stereotype.Service;

@Service
public class OrderConsumer {

private Logger LOGGER = LoggerFactory.getLogger(OrderConsumer.class);

@RabbitListener(queues = {"${rabbitmq.queue.email.name}"})
public void consume(OrderEvent event) {
LOGGER.info(String.format("Order event received int email service -> %s", event.toString()));

// email service needs to email customer
}
}
4 changes: 3 additions & 1 deletion email-service/src/main/resources/application.properties
Original file line number Diff line number Diff line change
@@ -1 +1,3 @@
server.port=8082
server.port=8082

rabbitmq.queue.email.name=email_queue