-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathKafkaProducer.java
More file actions
42 lines (36 loc) · 1.67 KB
/
KafkaProducer.java
File metadata and controls
42 lines (36 loc) · 1.67 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
41
42
package com.io.example.producer;
import com.io.example.util.ConstantsUtil;
import com.io.example.dto.KafkaDto;
import io.github.springwolf.bindings.kafka.annotations.KafkaAsyncOperationBinding;
import io.github.springwolf.core.asyncapi.annotations.AsyncOperation;
import io.github.springwolf.core.asyncapi.annotations.AsyncPublisher;
import lombok.RequiredArgsConstructor;
import org.springframework.cloud.stream.function.StreamBridge;
import org.springframework.stereotype.Component;
import static org.springframework.kafka.support.mapping.AbstractJavaTypeMapper.DEFAULT_CLASSID_FIELD_NAME;
@Component
@RequiredArgsConstructor
public class KafkaProducer {
private final StreamBridge bridge;
@AsyncPublisher(
operation = @AsyncOperation(
servers = {"kafka"},
channelName = ConstantsUtil.KAFKA_TOPIC,
description = "Example topic for sending messages",
payloadType = KafkaDto.class,
headers = @AsyncOperation.Headers(
schemaName = "SpringKafkaDefaultHeaders-KafkaDto",
values = {
@AsyncOperation.Headers.Header(
name = DEFAULT_CLASSID_FIELD_NAME,
value = "com.io.example.dto.KafkaDto",
description = "Type ID")
})
)
)
@KafkaAsyncOperationBinding(bindingVersion = "1.0.0")
public void send(String text) {
KafkaDto message = new KafkaDto(text);
bridge.send("kafkaV2Producer-out-0", message);
}
}