-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathKafkaConsumer.java
More file actions
40 lines (34 loc) · 1.56 KB
/
KafkaConsumer.java
File metadata and controls
40 lines (34 loc) · 1.56 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
package com.io.example.consumer;
import com.io.example.dto.KafkaDto;
import com.io.example.util.ConstantsUtil;
import io.github.springwolf.bindings.kafka.annotations.KafkaAsyncOperationBinding;
import io.github.springwolf.core.asyncapi.annotations.AsyncListener;
import io.github.springwolf.core.asyncapi.annotations.AsyncOperation;
import lombok.extern.slf4j.Slf4j;
import org.springframework.messaging.Message;
import org.springframework.stereotype.Component;
import java.util.function.Consumer;
import static org.springframework.kafka.support.mapping.AbstractJavaTypeMapper.DEFAULT_CLASSID_FIELD_NAME;
@Slf4j
@Component("kafkaConsumer")
public class KafkaConsumer implements Consumer<Message<KafkaDto>> {
@KafkaAsyncOperationBinding(bindingVersion = "1.0.0")
@AsyncListener(operation = @AsyncOperation(
channelName = ConstantsUtil.KAFKA_TOPIC,
description = " Topic that receives sample data from Kafka",
servers = {"kafka"},
headers = @AsyncOperation.Headers(
schemaName = "SpringKafkaDefaultHeaders-KafkaDto",
values = {
@AsyncOperation.Headers.Header(
name = DEFAULT_CLASSID_FIELD_NAME,
value = "com.io.example.dto.KafkaDto",
description = "Type ID")
})
))
@Override
public void accept(Message<KafkaDto> message) {
var kafkaDto = message.getPayload();
log.info("receive: {}", kafkaDto.message());
}
}