kinesis4cats.compat.retry.syntax.retry.scala Maven / Gradle / Ivy
/*
* Copyright 2023-2023 etspaceman
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package kinesis4cats.compat.retry
package syntax
import cats.{Monad, MonadError}
import kinesis4cats.compat.retry
private[kinesis4cats] trait RetrySyntax {
implicit final def retrySyntaxBase[M[_], A](
action: => M[A]
): RetryingOps[M, A] =
new RetryingOps[M, A](action)
implicit final def retrySyntaxError[M[_], A, E](
action: => M[A]
)(implicit M: MonadError[M, E]): RetryingErrorOps[M, A, E] =
new RetryingErrorOps[M, A, E](action)
}
private[kinesis4cats] final class RetryingOps[M[_], A](action: => M[A]) {
def retryingOnFailures[E](
wasSuccessful: A => M[Boolean],
policy: RetryPolicy[M],
onFailure: (A, RetryDetails) => M[Unit]
)(implicit
M: Monad[M],
S: Sleep[M]
): M[A] =
retry.retryingOnFailures(
policy = policy,
wasSuccessful = wasSuccessful,
onFailure = onFailure
)(action)
}
private[kinesis4cats] final class RetryingErrorOps[M[_], A, E](action: => M[A])(
implicit M: MonadError[M, E]
) {
def retryingOnAllErrors(
policy: RetryPolicy[M],
onError: (E, RetryDetails) => M[Unit]
)(implicit S: Sleep[M]): M[A] =
retry.retryingOnAllErrors(
policy = policy,
onError = onError
)(action)
def retryingOnSomeErrors(
isWorthRetrying: E => M[Boolean],
policy: RetryPolicy[M],
onError: (E, RetryDetails) => M[Unit]
)(implicit S: Sleep[M]): M[A] =
retry.retryingOnSomeErrors(
policy = policy,
isWorthRetrying = isWorthRetrying,
onError = onError
)(action)
def retryingOnFailuresAndAllErrors(
wasSuccessful: A => M[Boolean],
policy: RetryPolicy[M],
onFailure: (A, RetryDetails) => M[Unit],
onError: (E, RetryDetails) => M[Unit]
)(implicit S: Sleep[M]): M[A] =
retry.retryingOnFailuresAndAllErrors(
policy = policy,
wasSuccessful = wasSuccessful,
onFailure = onFailure,
onError = onError
)(action)
def retryingOnFailuresAndSomeErrors(
wasSuccessful: A => M[Boolean],
isWorthRetrying: E => M[Boolean],
policy: RetryPolicy[M],
onFailure: (A, RetryDetails) => M[Unit],
onError: (E, RetryDetails) => M[Unit]
)(implicit S: Sleep[M]): M[A] =
retry.retryingOnFailuresAndSomeErrors(
policy = policy,
wasSuccessful = wasSuccessful,
isWorthRetrying = isWorthRetrying,
onFailure = onFailure,
onError = onError
)(action)
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy