WIP:TaskExecutor-NEU
[demos/kafka/training] / src / main / java / de / juplo / kafka / ApplicationConfiguration.java
1 package de.juplo.kafka;
2
3 import org.apache.kafka.clients.consumer.Consumer;
4 import org.springframework.boot.autoconfigure.kafka.KafkaProperties;
5 import org.springframework.boot.context.properties.EnableConfigurationProperties;
6 import org.springframework.context.annotation.Bean;
7 import org.springframework.context.annotation.Configuration;
8
9 import org.springframework.kafka.core.ConsumerFactory;
10
11 import java.util.concurrent.ExecutorService;
12 import java.util.concurrent.Executors;
13
14
15 @Configuration
16 @EnableConfigurationProperties({ KafkaProperties.class, ApplicationProperties.class })
17 public class ApplicationConfiguration
18 {
19   @Bean
20   public SimpleConsumer endlessConsumer(
21       Consumer<String, String> kafkaConsumer,
22       KafkaProperties kafkaProperties,
23       ApplicationProperties applicationProperties)
24   {
25     return
26         new SimpleConsumer(
27             kafkaProperties.getClientId(),
28             applicationProperties.getTopic(),
29             kafkaConsumer);
30   }
31
32   @Bean(destroyMethod = "close")
33   public Consumer<?, ?> kafkaConsumer(ConsumerFactory<?, ?> factory)
34   {
35     return factory.createConsumer();
36   }
37 }