org.enodeframework.kafka.message.KafkaSendReplyService.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of enode-kafka Show documentation
Show all versions of enode-kafka Show documentation
enodeframework message queue kafka adapter
The newest version!
package org.enodeframework.kafka.message
import org.enodeframework.commanding.CommandOptions
import org.enodeframework.common.serializing.SerializeService
import org.enodeframework.messaging.ReplyMessage
import org.enodeframework.queue.MessageTypeCode
import org.enodeframework.queue.QueueMessage
import org.enodeframework.queue.SendMessageResult
import org.enodeframework.queue.SendReplyService
import java.util.concurrent.CompletableFuture
/**
* @author [email protected]
*/
class KafkaSendReplyService(
private val kafkaProducerHolder: KafkaProducerHolder,
private val commandOptions: CommandOptions,
private val serializeService: SerializeService
) : SendReplyService {
override fun send(message: ReplyMessage): CompletableFuture {
return kafkaProducerHolder.send(buildQueueMessage(message))
}
private fun buildQueueMessage(replyMessage: ReplyMessage): QueueMessage {
val message = replyMessage.asGenericReplyMessage()
val queueMessage = replyMessage.asPartQueueMessage()
queueMessage.topic = commandOptions.replyWith(replyMessage.address)
queueMessage.tag = replyMessage.address
queueMessage.body = serializeService.serializeBytes(message)
queueMessage.type = MessageTypeCode.ReplyMessage.value
return queueMessage
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy