WIP
[demos/kafka/demos-kafka-payment-system-transfer] / transfer / src / main / java / de / juplo / kafka / payment / transfer / TransferServiceApplication.java
index 26b14d6..320b841 100644 (file)
@@ -1,19 +1,21 @@
 package de.juplo.kafka.payment.transfer;
 
 
-import java.util.Properties;
-import java.util.UUID;
-
-import io.confluent.kafka.streams.serdes.avro.SpecificAvroSerializer;
+import com.fasterxml.jackson.databind.ObjectMapper;
+import de.juplo.kafka.payment.transfer.domain.TransferRepository;
+import de.juplo.kafka.payment.transfer.domain.TransferService;
 import lombok.extern.slf4j.Slf4j;
 import org.apache.kafka.clients.producer.KafkaProducer;
 import org.apache.kafka.clients.producer.ProducerConfig;
-import org.apache.kafka.common.serialization.UUIDSerializer;
+import org.apache.kafka.common.serialization.StringSerializer;
 import org.springframework.boot.SpringApplication;
 import org.springframework.boot.autoconfigure.SpringBootApplication;
 import org.springframework.boot.context.properties.EnableConfigurationProperties;
 import org.springframework.context.annotation.Bean;
 
+import java.util.Properties;
+import java.util.UUID;
+
 
 @SpringBootApplication
 @EnableConfigurationProperties(TransferServiceProperties.class)
@@ -21,17 +23,27 @@ import org.springframework.context.annotation.Bean;
 public class TransferServiceApplication
 {
   @Bean(destroyMethod = "close")
-  KafkaProducer<UUID, TransferBean> producer(TransferServiceProperties properties)
+  KafkaProducer<String, String> producer(TransferServiceProperties properties)
   {
     Properties props = new Properties();
     props.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG, properties.bootstrapServers);
-    props.put("schema.registry.url", properties.schemaRegistryUrl);
-    props.put("key.serializer", UUIDSerializer.class.getName());
-    props.put("value.serializer", SpecificAvroSerializer.class.getName());
+    props.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, StringSerializer.class);
+    props.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, StringSerializer.class);
 
     return new KafkaProducer<>(props);
   }
 
+  @Bean
+  TransferService transferService(
+      TransferRepository repository,
+      KafkaProducer<String, String> producer,
+      ObjectMapper mapper,
+      TransferServiceProperties properties)
+  {
+    return new TransferService(repository, producer, mapper, properties.topic);
+  }
+
+
   public static void main(String[] args)
   {
     SpringApplication.run(TransferServiceApplication.class, args);