aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/xyz/driver/pdsuidomain/services/HypothesisService.scala
diff options
context:
space:
mode:
authorAleksandr <ognelisar@gmail.com>2017-10-18 14:15:45 +0700
committerAleksandr <ognelisar@gmail.com>2017-10-18 14:15:45 +0700
commit68537891ca8f1b06301bbe7b996e5eb4ed680e39 (patch)
tree646dd2efc4a2971646d6df1dc032f7f2c529bd9c /src/main/scala/xyz/driver/pdsuidomain/services/HypothesisService.scala
parent0c8a7c3f1920e38a0606de91be5793c4f2a1d40a (diff)
downloadrest-query-68537891ca8f1b06301bbe7b996e5eb4ed680e39.tar.gz
rest-query-68537891ca8f1b06301bbe7b996e5eb4ed680e39.tar.bz2
rest-query-68537891ca8f1b06301bbe7b996e5eb4ed680e39.zip
Added REST API methods to HypothesisService
Diffstat (limited to 'src/main/scala/xyz/driver/pdsuidomain/services/HypothesisService.scala')
-rw-r--r--src/main/scala/xyz/driver/pdsuidomain/services/HypothesisService.scala39
1 files changed, 39 insertions, 0 deletions
diff --git a/src/main/scala/xyz/driver/pdsuidomain/services/HypothesisService.scala b/src/main/scala/xyz/driver/pdsuidomain/services/HypothesisService.scala
index 52cd6c8..9dc8d33 100644
--- a/src/main/scala/xyz/driver/pdsuidomain/services/HypothesisService.scala
+++ b/src/main/scala/xyz/driver/pdsuidomain/services/HypothesisService.scala
@@ -2,12 +2,21 @@ package xyz.driver.pdsuidomain.services
import xyz.driver.pdsuicommon.auth.AuthenticatedRequestContext
import xyz.driver.pdsuicommon.db.Sorting
+import xyz.driver.pdsuicommon.domain.UuidId
import xyz.driver.pdsuicommon.error.DomainError
import xyz.driver.pdsuidomain.entities.Hypothesis
import scala.concurrent.Future
object HypothesisService {
+ trait DefaultNotFoundError {
+ def userMessage: String = "Intervention not found"
+ }
+
+ trait DefaultAccessDeniedError {
+ def userMessage: String = "Access denied"
+ }
+
sealed trait GetListReply
object GetListReply {
final case class EntityList(xs: Seq[Hypothesis], totalFound: Int) extends GetListReply
@@ -16,6 +25,32 @@ object HypothesisService {
def userMessage: String = "Access denied"
}
}
+
+ sealed trait CreateReply
+ object CreateReply {
+ final case class Created(x: Hypothesis) extends CreateReply
+
+ type Error = CreateReply with DomainError
+
+ case object AuthorizationError
+ extends CreateReply with DefaultAccessDeniedError with DomainError.AuthorizationError
+
+ final case class CommonError(userMessage: String) extends CreateReply with DomainError
+ }
+
+ sealed trait DeleteReply
+ object DeleteReply {
+ case object Deleted extends DeleteReply
+
+ type Error = DeleteReply with DomainError
+
+ case object NotFoundError extends DeleteReply with DefaultNotFoundError with DomainError.NotFoundError
+
+ case object AuthorizationError
+ extends DeleteReply with DefaultAccessDeniedError with DomainError.AuthorizationError
+
+ final case class CommonError(userMessage: String) extends DeleteReply with DomainError
+ }
}
trait HypothesisService {
@@ -24,4 +59,8 @@ trait HypothesisService {
def getAll(sorting: Option[Sorting] = None)(
implicit requestContext: AuthenticatedRequestContext): Future[GetListReply]
+
+ def create(draftHypothesis: Hypothesis)(implicit requestContext: AuthenticatedRequestContext): Future[CreateReply]
+
+ def delete(id: UuidId[Hypothesis])(implicit requestContext: AuthenticatedRequestContext): Future[DeleteReply]
}