diff options
author | vlad <vlad@driver.xyz> | 2017-06-13 16:12:20 -0700 |
---|---|---|
committer | vlad <vlad@driver.xyz> | 2017-06-13 16:12:20 -0700 |
commit | cd1b635b2ae90d9ac2d8b1779183a1fbd8c5fd5c (patch) | |
tree | 062e8dad1a1513e26b0fd08b1742d6ff2ee874f7 /src/main/scala/xyz/driver/pdsuicommon/error | |
parent | 0000a65ab4479a2a40e2d6468036438e9705b4aa (diff) | |
download | rest-query-cd1b635b2ae90d9ac2d8b1779183a1fbd8c5fd5c.tar.gz rest-query-cd1b635b2ae90d9ac2d8b1779183a1fbd8c5fd5c.tar.bz2 rest-query-cd1b635b2ae90d9ac2d8b1779183a1fbd8c5fd5c.zip |
Adding domain entitiesv0.1.0
Diffstat (limited to 'src/main/scala/xyz/driver/pdsuicommon/error')
4 files changed, 56 insertions, 0 deletions
diff --git a/src/main/scala/xyz/driver/pdsuicommon/error/DomainError.scala b/src/main/scala/xyz/driver/pdsuicommon/error/DomainError.scala new file mode 100644 index 0000000..4bf90d1 --- /dev/null +++ b/src/main/scala/xyz/driver/pdsuicommon/error/DomainError.scala @@ -0,0 +1,30 @@ +package xyz.driver.pdsuicommon.error + +import xyz.driver.pdsuicommon.logging.{PhiString, Unsafe} +import xyz.driver.pdsuicommon.utils.Utils + +trait DomainError { + + protected def userMessage: String + + def getMessage: String = userMessage + +} + +object DomainError { + + // 404 error + trait NotFoundError extends DomainError + + // 401 error + trait AuthenticationError extends DomainError + + // 403 error + trait AuthorizationError extends DomainError + + implicit def toPhiString(x: DomainError): PhiString = { + // userMessage possibly can contain a personal information, + // so we should prevent it to be printed in logs. + Unsafe(Utils.getClassSimpleName(x.getClass)) + } +} diff --git a/src/main/scala/xyz/driver/pdsuicommon/error/ExceptionFormatter.scala b/src/main/scala/xyz/driver/pdsuicommon/error/ExceptionFormatter.scala new file mode 100644 index 0000000..1e3e4c4 --- /dev/null +++ b/src/main/scala/xyz/driver/pdsuicommon/error/ExceptionFormatter.scala @@ -0,0 +1,18 @@ +package xyz.driver.pdsuicommon.error + +import java.io.{ByteArrayOutputStream, PrintStream} + +object ExceptionFormatter { + + def format(e: Throwable): String = s"$e\n${printStackTrace(e)}" + + def printStackTrace(e: Throwable): String = { + val baos = new ByteArrayOutputStream() + val ps = new PrintStream(baos) + + e.printStackTrace(ps) + + ps.close() + baos.toString() + } +} diff --git a/src/main/scala/xyz/driver/pdsuicommon/error/FailedValidationException.scala b/src/main/scala/xyz/driver/pdsuicommon/error/FailedValidationException.scala new file mode 100644 index 0000000..7137255 --- /dev/null +++ b/src/main/scala/xyz/driver/pdsuicommon/error/FailedValidationException.scala @@ -0,0 +1,5 @@ +package xyz.driver.pdsuicommon.error + +import xyz.driver.pdsuicommon.validation.ValidationError + +class FailedValidationException(val error: ValidationError) extends RuntimeException("The validation is failed") diff --git a/src/main/scala/xyz/driver/pdsuicommon/error/IncorrectIdException.scala b/src/main/scala/xyz/driver/pdsuicommon/error/IncorrectIdException.scala new file mode 100644 index 0000000..5705229 --- /dev/null +++ b/src/main/scala/xyz/driver/pdsuicommon/error/IncorrectIdException.scala @@ -0,0 +1,3 @@ +package xyz.driver.pdsuicommon.error + +final case class IncorrectIdException(message: String) extends Exception(message) |