WIP
[demos/kafka/demos-kafka-payment-system-transfer] / transfer / src / main / java / de / juplo / kafka / payment / transfer / TransferServiceApplication.java
1 package de.juplo.kafka.payment.transfer;
2
3
4 import com.fasterxml.jackson.databind.ObjectMapper;
5 import de.juplo.kafka.payment.transfer.domain.TransferRepository;
6 import de.juplo.kafka.payment.transfer.domain.TransferService;
7 import lombok.extern.slf4j.Slf4j;
8 import org.apache.kafka.clients.producer.KafkaProducer;
9 import org.apache.kafka.clients.producer.ProducerConfig;
10 import org.apache.kafka.common.serialization.StringSerializer;
11 import org.springframework.boot.SpringApplication;
12 import org.springframework.boot.autoconfigure.SpringBootApplication;
13 import org.springframework.boot.context.properties.EnableConfigurationProperties;
14 import org.springframework.context.annotation.Bean;
15
16 import java.util.Properties;
17 import java.util.UUID;
18
19
20 @SpringBootApplication
21 @EnableConfigurationProperties(TransferServiceProperties.class)
22 @Slf4j
23 public class TransferServiceApplication
24 {
25   @Bean(destroyMethod = "close")
26   KafkaProducer<String, String> producer(TransferServiceProperties properties)
27   {
28     Properties props = new Properties();
29     props.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG, properties.bootstrapServers);
30     props.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, StringSerializer.class);
31     props.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, StringSerializer.class);
32
33     return new KafkaProducer<>(props);
34   }
35
36   @Bean
37   TransferService transferService(
38       TransferRepository repository,
39       KafkaProducer<String, String> producer,
40       ObjectMapper mapper,
41       TransferServiceProperties properties)
42   {
43     return new TransferService(repository, producer, mapper, properties.topic);
44   }
45
46
47   public static void main(String[] args)
48   {
49     SpringApplication.run(TransferServiceApplication.class, args);
50   }
51 }