From d61ed25db4d71ac182f09ce7bc02439470f3a998 Mon Sep 17 00:00:00 2001 From: zachdriver Date: Fri, 25 May 2018 12:44:15 -0700 Subject: Add service exception json formatters and pass through exceptions in HttpRestServiceTransport (#168) --- src/main/scala/xyz/driver/core/core.scala | 11 +++++++++++ 1 file changed, 11 insertions(+) (limited to 'src/main/scala/xyz/driver/core/core.scala') diff --git a/src/main/scala/xyz/driver/core/core.scala b/src/main/scala/xyz/driver/core/core.scala index 14e1b10..72237b9 100644 --- a/src/main/scala/xyz/driver/core/core.scala +++ b/src/main/scala/xyz/driver/core/core.scala @@ -3,6 +3,9 @@ package xyz.driver import scalaz.{Equal, Monad, OptionT} import eu.timepit.refined.api.{Refined, Validate} import eu.timepit.refined.collection.NonEmpty +import xyz.driver.core.rest.errors.ExternalServiceException + +import scala.concurrent.{ExecutionContext, Future} package object core { @@ -54,6 +57,14 @@ package object core { def toUnitOptionT: OptionT[H, Unit] = OptionT.optionT[H](monadT(monadicValue)(_ => Option(()))) } + + implicit class FutureExtensions[T](future: Future[T]) { + def passThroughExternalServiceException(implicit executionContext: ExecutionContext): Future[T] = + future.transform(identity, { + case ExternalServiceException(_, _, Some(e)) => e + case t: Throwable => t + }) + } } package core { -- cgit v1.2.3