com.twitter.finatra.http.internal.exceptions.FailureExceptionMapper.scala Maven / Gradle / Ivy
The newest version!
package com.twitter.finatra.http.internal.exceptions
import com.twitter.finagle.Failure
import com.twitter.finagle.http.{Request, Response}
import com.twitter.finatra.http.internal.exceptions.ThrowableExceptionMapper._
import com.twitter.finatra.http.response.ResponseBuilder
import com.twitter.inject.Logging
import com.twitter.{logging => ctl}
import javax.inject.{Inject, Singleton}
@Singleton
private[http] class FailureExceptionMapper @Inject() (response: ResponseBuilder)
extends AbstractFrameworkExceptionMapper[Failure](response)
with Logging {
private val MaxDepth = 5
override protected def handle(
request: Request,
response: ResponseBuilder,
exception: Failure
): Response =
unwrapFailure(exception, MaxDepth) match {
case _: Failure =>
logFailure(exception)
unhandledExceptionResponse(request, response, exception)
case cause: Throwable =>
// Re-raise the cause so that it can get mapped correctly
throw cause
}
/* Private */
private def unwrapFailure(failure: Failure, depth: Int): Throwable = {
if (depth == 0) {
failure
} else {
failure.cause match {
case Some(inner: Failure) => unwrapFailure(inner, depth - 1)
case Some(cause) => cause
case None => failure
}
}
}
private[this] def logFailure(failure: Failure): Unit = {
val message = "Unhandled Failure"
failure.logLevel match {
case ctl.Level.ALL | ctl.Level.TRACE =>
trace(message, failure)
case ctl.Level.INFO =>
info(message, failure)
case ctl.Level.WARNING =>
warn(message, failure)
case ctl.Level.ERROR | ctl.Level.CRITICAL | ctl.Level.FATAL =>
error(message, failure)
case ctl.Level.DEBUG =>
debug(message, failure)
case _ =>
// do nothing
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy