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

com.evolutiongaming.kafka.journal.KafkaProducer.scala Maven / Gradle / Ivy

The newest version!
package com.evolutiongaming.kafka.journal

import cats.FlatMap
import cats.syntax.all._
import com.evolutiongaming.skafka
import com.evolutiongaming.skafka.producer
import com.evolutiongaming.skafka.producer._

trait KafkaProducer[F[_]] {

  def send[K, V](
    record: ProducerRecord[K, V])(implicit
    toBytesK: skafka.ToBytes[F, K],
    toBytesV: skafka.ToBytes[F, V]
  ): F[producer.RecordMetadata]
}

object KafkaProducer {

  def apply[F[_]](implicit F: KafkaProducer[F]): KafkaProducer[F] = F

  def apply[F[_] : FlatMap](producer: Producer[F]): KafkaProducer[F] = {
    new KafkaProducer[F] {

      def send[K, V](
        record: ProducerRecord[K, V])(implicit
        toBytesK: skafka.ToBytes[F, K],
        toBytesV: skafka.ToBytes[F, V]
      ) = {
        producer.send(record).flatten
      }
    }
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy