aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/xyz/driver/pdsuidomain/services
diff options
context:
space:
mode:
authorktomskikh <ktomskih@datamonsters.co>2017-08-03 18:04:00 +0700
committerGitHub <noreply@github.com>2017-08-03 18:04:00 +0700
commit40ee33a7c176895a19ee0f9066849d34c38c75fd (patch)
tree21b9d9b308f91af1eefaa5f68b4fef0e011c9e98 /src/main/scala/xyz/driver/pdsuidomain/services
parenta0c4fdf5f4280aa05518b925ed7bdc319758145a (diff)
parentfc7c7063cafd7df8efe2c6c0dbc28e5ff0de06f6 (diff)
downloadrest-query-40ee33a7c176895a19ee0f9066849d34c38c75fd.tar.gz
rest-query-40ee33a7c176895a19ee0f9066849d34c38c75fd.tar.bz2
rest-query-40ee33a7c176895a19ee0f9066849d34c38c75fd.zip
Merge pull request #15 from drivergroup/PDSUI-2181v0.2.13
PDSUI-2181 Created entities for patient history
Diffstat (limited to 'src/main/scala/xyz/driver/pdsuidomain/services')
-rw-r--r--src/main/scala/xyz/driver/pdsuidomain/services/PatientHistoryService.scala44
1 files changed, 44 insertions, 0 deletions
diff --git a/src/main/scala/xyz/driver/pdsuidomain/services/PatientHistoryService.scala b/src/main/scala/xyz/driver/pdsuidomain/services/PatientHistoryService.scala
new file mode 100644
index 0000000..855eddc
--- /dev/null
+++ b/src/main/scala/xyz/driver/pdsuidomain/services/PatientHistoryService.scala
@@ -0,0 +1,44 @@
+package xyz.driver.pdsuidomain.services
+
+import java.time.LocalDateTime
+
+import xyz.driver.pdsuicommon.auth.AuthenticatedRequestContext
+import xyz.driver.pdsuicommon.db.{Pagination, SearchFilterExpr, Sorting}
+import xyz.driver.pdsuicommon.domain.UuidId
+import xyz.driver.pdsuicommon.error.DomainError
+import xyz.driver.pdsuidomain.entities.{Patient, PatientHistory}
+
+import scala.concurrent.Future
+
+object PatientHistoryService {
+
+ trait DefaultNotFoundError {
+ def userMessage: String = "Patient history not found"
+ }
+
+ trait DefaultAccessDeniedError {
+ def userMessage: String = "Access denied"
+ }
+
+ sealed trait GetListReply
+ object GetListReply {
+ final case class EntityList(xs: Seq[PatientHistory], totalFound: Int, lastUpdate: Option[LocalDateTime])
+ extends GetListReply
+
+ final case object AuthorizationError
+ extends GetListReply with DomainError.AuthorizationError with DefaultAccessDeniedError
+ }
+
+}
+
+trait PatientHistoryService {
+
+ import PatientHistoryService._
+
+ def getListByPatientId(id: UuidId[Patient],
+ filter: SearchFilterExpr = SearchFilterExpr.Empty,
+ sorting: Option[Sorting] = None,
+ pagination: Option[Pagination] = None)(
+ implicit requestContext: AuthenticatedRequestContext): Future[GetListReply]
+
+}