X-Git-Url: https://juplo.de/gitweb/?a=blobdiff_plain;f=transfer%2Fsrc%2Fmain%2Fjava%2Fde%2Fjuplo%2Fkafka%2Fpayment%2Ftransfer%2FTransferServiceApplication.java;h=80f1d4e13363c14f678181dac16025a66e17f4ec;hb=5bffe60126c5fa74bff59c91dfbd722d291b1c93;hp=4a55c85b0f321d26fcf85ae98d3280d61c094f10;hpb=178ce6ffc044415eb00f250aed2f9b1999bd47d1;p=demos%2Fkafka%2Fdemos-kafka-payment-system-transfer diff --git a/transfer/src/main/java/de/juplo/kafka/payment/transfer/TransferServiceApplication.java b/transfer/src/main/java/de/juplo/kafka/payment/transfer/TransferServiceApplication.java index 4a55c85..80f1d4e 100644 --- a/transfer/src/main/java/de/juplo/kafka/payment/transfer/TransferServiceApplication.java +++ b/transfer/src/main/java/de/juplo/kafka/payment/transfer/TransferServiceApplication.java @@ -1,39 +1,48 @@ package de.juplo.kafka.payment.transfer; -import de.trion.microservices.avro.Order; -import io.confluent.kafka.streams.serdes.avro.SpecificAvroSerializer; -import java.util.Properties; -import java.util.UUID; +import com.fasterxml.jackson.databind.ObjectMapper; +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.StringSerializer; import org.apache.kafka.common.serialization.UUIDSerializer; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; 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) +@Slf4j public class TransferServiceApplication { - private final static Logger LOG = LoggerFactory.getLogger(TransferServiceApplication.class); - - @Bean(destroyMethod = "close") - KafkaProducer producer(TransferServiceProperties properties) + KafkaProducer producer(TransferServiceProperties properties) { Properties props = new Properties(); - props.put("bootstrap.servers", 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.BOOTSTRAP_SERVERS_CONFIG, properties.bootstrapServers); + props.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, UUIDSerializer.class); + props.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, StringSerializer.class); return new KafkaProducer<>(props); } + @Bean + TransferService transferService( + KafkaProducer producer, + ObjectMapper mapper, + TransferServiceProperties properties) + { + return new TransferService(producer, mapper, properties.topic); + } + + public static void main(String[] args) { SpringApplication.run(TransferServiceApplication.class, args);