From cdf136baf98654b415a28d66d92abff338996545 Mon Sep 17 00:00:00 2001 From: Robin Date: Tue, 7 Nov 2023 12:07:31 +0100 Subject: [PATCH] Vanilla kafka producer --- kafka/README.md | 2 ++ kafka/build.gradle.kts | 3 ++ kafka/main/no/nav/aap/kafka/KafkaFactory.kt | 39 +++++++++++++++++++++ settings.gradle.kts | 1 + 4 files changed, 45 insertions(+) create mode 100644 kafka/README.md create mode 100644 kafka/build.gradle.kts create mode 100644 kafka/main/no/nav/aap/kafka/KafkaFactory.kt diff --git a/kafka/README.md b/kafka/README.md new file mode 100644 index 00000000..5df58e7c --- /dev/null +++ b/kafka/README.md @@ -0,0 +1,2 @@ +## Kafka +Library for setting up kafka producers and consumers diff --git a/kafka/build.gradle.kts b/kafka/build.gradle.kts new file mode 100644 index 00000000..c3280c67 --- /dev/null +++ b/kafka/build.gradle.kts @@ -0,0 +1,3 @@ +dependencies { + implementation("org.apache.kafka:kafka-clients:3.5.1") +} diff --git a/kafka/main/no/nav/aap/kafka/KafkaFactory.kt b/kafka/main/no/nav/aap/kafka/KafkaFactory.kt new file mode 100644 index 00000000..65a2bad9 --- /dev/null +++ b/kafka/main/no/nav/aap/kafka/KafkaFactory.kt @@ -0,0 +1,39 @@ +package no.nav.aap.kafka + +import org.apache.kafka.clients.CommonClientConfigs +import org.apache.kafka.clients.producer.KafkaProducer +import org.apache.kafka.clients.producer.ProducerConfig +import org.apache.kafka.common.config.SslConfigs +import org.apache.kafka.common.serialization.Serdes +import java.util.* + +class KafkaConfig( + val brokers: String, + val truststorePath: String, + val keystorePath: String, + val credstorePsw: String, +) + +class KafkaFactory private constructor() { + companion object { + fun createProducer(clientId: String, config: KafkaConfig): KafkaProducer { + fun properties(): Properties = Properties().apply { + this[CommonClientConfigs.CLIENT_ID_CONFIG] = clientId + this[CommonClientConfigs.BOOTSTRAP_SERVERS_CONFIG] = config.brokers + this[ProducerConfig.ACKS_CONFIG] = "all" + this[ProducerConfig.MAX_IN_FLIGHT_REQUESTS_PER_CONNECTION] = "5" + this[CommonClientConfigs.SECURITY_PROTOCOL_CONFIG] = "SSL" + this[SslConfigs.SSL_TRUSTSTORE_TYPE_CONFIG] = "JKS" + this[SslConfigs.SSL_TRUSTSTORE_LOCATION_CONFIG] = config.truststorePath + this[SslConfigs.SSL_TRUSTSTORE_PASSWORD_CONFIG] = config.credstorePsw + this[SslConfigs.SSL_KEYSTORE_TYPE_CONFIG] = "PKCS12" + this[SslConfigs.SSL_KEYSTORE_LOCATION_CONFIG] = config.keystorePath + this[SslConfigs.SSL_KEYSTORE_PASSWORD_CONFIG] = config.credstorePsw + this[SslConfigs.SSL_KEY_PASSWORD_CONFIG] = config.credstorePsw + this[SslConfigs.SSL_ENDPOINT_IDENTIFICATION_ALGORITHM_CONFIG] = "" + } + + return KafkaProducer(properties(), Serdes.StringSerde().serializer(), Serdes.StringSerde().serializer()) + } + } +} diff --git a/settings.gradle.kts b/settings.gradle.kts index 2467a9ae..a5be23bc 100644 --- a/settings.gradle.kts +++ b/settings.gradle.kts @@ -2,6 +2,7 @@ rootProject.name = "aap-libs" include( "cache", + "kafka", "kafka-2", "kafka-interfaces", "kafka-avroserde",