All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.github.embeddedkafka.connect.EmbeddedConnectConfig.scala Maven / Gradle / Ivy

There is a newer version: 3.9.0
Show newest version
package io.github.embeddedkafka.connect

import java.nio.file.Path

import io.github.embeddedkafka.EmbeddedKafkaConfig

import org.apache.kafka.connect.runtime.rest.RestServerConfig
import org.apache.kafka.connect.runtime.standalone.StandaloneConfig
import org.apache.kafka.connect.runtime.WorkerConfig

/**
  * Kafka Connect config generator.
  *
  * @tparam C
  *   an [[EmbeddedKafkaConfig]]
  */
private[embeddedkafka] trait EmbeddedConnectConfig[C <: EmbeddedKafkaConfig] {
  protected[embeddedkafka] def baseConnectConfig(
      connectPort: Int,
      offsets: Path
  )(
      implicit kafkaConfig: C
  ): Map[String, String] =
    Map(
      RestServerConfig.LISTENERS_CONFIG -> s"http://localhost:$connectPort",
      WorkerConfig.BOOTSTRAP_SERVERS_CONFIG -> s"localhost:${kafkaConfig.kafkaPort}",
      WorkerConfig.KEY_CONVERTER_CLASS_CONFIG -> "org.apache.kafka.connect.json.JsonConverter",
      WorkerConfig.VALUE_CONVERTER_CLASS_CONFIG -> "org.apache.kafka.connect.json.JsonConverter",
      WorkerConfig.OFFSET_COMMIT_INTERVAL_MS_CONFIG -> "10000",
      StandaloneConfig.OFFSET_STORAGE_FILE_FILENAME_CONFIG -> offsets.toAbsolutePath.toString
    )

  /**
    * @param connectPort
    *   the Kafka Connect port for the REST API to listen on.
    * @param offsets
    *   the file to store offset data in.
    * @param extraConfig
    *   any additional configuration. If the keys are already defined in the
    *   default they will be overwritten with this.
    * @param kafkaConfig
    *   the Kafka test configuration.
    * @return
    *   a map of config parameters for running the Kafka Connect server.
    */
  def config(connectPort: Int, offsets: Path, extraConfig: Map[String, String])(
      implicit kafkaConfig: C
  ): Map[String, String] =
    baseConnectConfig(connectPort, offsets) ++ extraConfig
}

final class EmbeddedConnectConfigImpl
    extends EmbeddedConnectConfig[EmbeddedKafkaConfig]




© 2015 - 2025 Weber Informatics LLC | Privacy Policy