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

org.apache.pekko.kafka.CommitterSettings.scala Maven / Gradle / Ivy

Go to download

Apache Pekko Kafka Connector is a Reactive Enterprise Integration library for Java and Scala, based on Reactive Streams and Apache Pekko.

The newest version!
/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * license agreements; and to You under the Apache License, version 2.0:
 *
 *   https://www.apache.org/licenses/LICENSE-2.0
 *
 * This file is part of the Apache Pekko project, which was derived from Akka.
 */

/*
 * Copyright (C) 2014 - 2016 Softwaremill 
 * Copyright (C) 2016 - 2020 Lightbend Inc. 
 */

package org.apache.pekko.kafka
import java.util.concurrent.TimeUnit

import org.apache.pekko
import pekko.annotation.ApiMayChange
import pekko.util.JavaDurationConverters._
import com.typesafe.config.Config

import scala.concurrent.duration._

@ApiMayChange(issue = "https://github.com/akka/alpakka-kafka/issues/882")
sealed trait CommitDelivery

/**
 * Selects how the stream delivers commits to the internal actor.
 */
@ApiMayChange(issue = "https://github.com/akka/alpakka-kafka/issues/882")
object CommitDelivery {

  /**
   * Expect replies for commits, and backpressure the stream if replies do not
   * arrive.
   */
  @ApiMayChange(issue = "https://github.com/akka/alpakka-kafka/issues/882")
  case object WaitForAck extends CommitDelivery

  /**
   * Send off commits to the internal actor without expecting replies,
   * and don't create backpressure in the stream.
   */
  @ApiMayChange(issue = "https://github.com/akka/alpakka-kafka/issues/882")
  case object SendAndForget extends CommitDelivery

  /**
   * Java API.
   */
  @ApiMayChange(issue = "https://github.com/akka/alpakka-kafka/issues/882")
  val waitForAck: CommitDelivery = WaitForAck

  /**
   * Java API.
   */
  @ApiMayChange(issue = "https://github.com/akka/alpakka-kafka/issues/882")
  val sendAndForget: CommitDelivery = SendAndForget

  def valueOf(s: String): CommitDelivery = s match {
    case "WaitForAck"    => WaitForAck
    case "SendAndForget" => SendAndForget
    case other           => throw new IllegalArgumentException(s"allowed values are: WaitForAck, SendAndForget. Received: $other")
  }
}

@ApiMayChange(issue = "https://github.com/akka/alpakka-kafka/issues/1092")
sealed trait CommitWhen

/**
 * Selects when the stream will commit an offset.
 */
@ApiMayChange(issue = "https://github.com/akka/alpakka-kafka/issues/1092")
object CommitWhen {

  /**
   * Commit as soon as a [[Committable]] offset is observed.
   */
  @ApiMayChange(issue = "https://github.com/akka/alpakka-kafka/issues/1092")
  case object OffsetFirstObserved extends CommitWhen

  /**
   * Commit once the next [[Committable]] offset is observed
   */
  @ApiMayChange(issue = "https://github.com/akka/alpakka-kafka/issues/1092")
  case object NextOffsetObserved extends CommitWhen

  /**
   * Java API.
   */
  @ApiMayChange(issue = "https://github.com/akka/alpakka-kafka/issues/1092")
  val offsetFirstObserved: CommitWhen = OffsetFirstObserved

  /**
   * Java API.
   */
  @ApiMayChange(issue = "https://github.com/akka/alpakka-kafka/issues/1092")
  val nextOffsetObserved: CommitWhen = NextOffsetObserved

  def valueOf(s: String): CommitWhen = s match {
    case "OffsetFirstObserved" => OffsetFirstObserved
    case "NextOffsetObserved"  => NextOffsetObserved
    case other =>
      throw new IllegalArgumentException(
        s"allowed values are: OffsetFirstObserved, NextOffsetObserved. Received: $other")
  }
}

object CommitterSettings {

  val configPath = "pekko.kafka.committer"

  /**
   * Create settings from the default configuration
   * `pekko.kafka.committer`.
   */
  def apply(actorSystem: pekko.actor.ActorSystem): CommitterSettings =
    apply(actorSystem.settings.config.getConfig(configPath))

  /**
   * Create settings from the default configuration
   * `pekko.kafka.committer`.
   *
   * For use with the `org.apache.pekko.actor.typed` API.
   */
  def apply(actorSystem: pekko.actor.ClassicActorSystemProvider): CommitterSettings =
    apply(actorSystem.classicSystem.settings.config.getConfig(configPath))

  /**
   * Create settings from a configuration with the same layout as
   * the default configuration `pekko.kafka.committer`.
   */
  def apply(config: Config): CommitterSettings = {
    val maxBatch = config.getLong("max-batch")
    val maxInterval = config.getDuration("max-interval", TimeUnit.MILLISECONDS).millis
    val parallelism = config.getInt("parallelism")
    val delivery = CommitDelivery.valueOf(config.getString("delivery"))
    val when = CommitWhen.valueOf(config.getString("when"))
    new CommitterSettings(maxBatch, maxInterval, parallelism, delivery, when)
  }

  /**
   * Java API: Create settings from the default configuration
   * `pekko.kafka.committer`.
   */
  def create(actorSystem: pekko.actor.ActorSystem): CommitterSettings =
    apply(actorSystem)

  /**
   * Java API: Create settings from the default configuration
   * `pekko.kafka.committer`.
   *
   * For use with the `org.apache.pekko.actor.typed` API.
   */
  def create(actorSystem: pekko.actor.ClassicActorSystemProvider): CommitterSettings =
    apply(actorSystem)

  /**
   * Java API: Create settings from a configuration with the same layout as
   * the default configuration `pekko.kafka.committer`.
   */
  def create(config: Config): CommitterSettings =
    apply(config)

}

/**
 * Settings for committer. See `pekko.kafka.committer` section in
 * reference.conf. Note that the [[pekko.kafka.CommitterSettings companion]] object provides
 * `apply` and `create` functions for convenient construction of the settings, together with
 * the `with` methods.
 */
class CommitterSettings private (
    val maxBatch: Long,
    val maxInterval: FiniteDuration,
    val parallelism: Int,
    val delivery: CommitDelivery,
    val when: CommitWhen) {

  def withMaxBatch(maxBatch: Long): CommitterSettings =
    copy(maxBatch = maxBatch)

  def withMaxInterval(maxInterval: FiniteDuration): CommitterSettings =
    copy(maxInterval = maxInterval)

  def withMaxInterval(maxInterval: java.time.Duration): CommitterSettings =
    copy(maxInterval = maxInterval.asScala)

  def withParallelism(parallelism: Int): CommitterSettings =
    copy(parallelism = parallelism)

  @ApiMayChange(issue = "https://github.com/akka/alpakka-kafka/issues/882")
  def withDelivery(value: CommitDelivery): CommitterSettings =
    copy(delivery = value)

  @ApiMayChange(issue = "https://github.com/akka/alpakka-kafka/issues/1092")
  def withCommitWhen(value: CommitWhen): CommitterSettings =
    copy(when = value)

  private def copy(maxBatch: Long = maxBatch,
      maxInterval: FiniteDuration = maxInterval,
      parallelism: Int = parallelism,
      delivery: CommitDelivery = delivery,
      when: CommitWhen = when): CommitterSettings =
    new CommitterSettings(maxBatch, maxInterval, parallelism, delivery, when)

  override def toString: String =
    "org.apache.pekko.kafka.CommitterSettings(" +
    s"maxBatch=$maxBatch," +
    s"maxInterval=${maxInterval.toCoarsest}," +
    s"parallelism=$parallelism," +
    s"delivery=$delivery," +
    s"when=$when)"
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy