aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/xyz/driver/pdsuidomain/services/MedicalRecordHistoryService.scala
diff options
context:
space:
mode:
authorVyatcheslav Suharnikov <arz.freezy@gmail.com>2017-07-25 10:48:08 +0300
committerVyatcheslav Suharnikov <arz.freezy@gmail.com>2017-07-25 11:20:48 +0300
commit4c7b4102dede53b9707fe3758a4a9ff9ccf87bf8 (patch)
treee692c278f343fc3d0ce5945c1fab5e7d10459ec7 /src/main/scala/xyz/driver/pdsuidomain/services/MedicalRecordHistoryService.scala
parenta835eef22830ab86a9f65194a6645f4f474ae0cc (diff)
downloadrest-query-4c7b4102dede53b9707fe3758a4a9ff9ccf87bf8.tar.gz
rest-query-4c7b4102dede53b9707fe3758a4a9ff9ccf87bf8.tar.bz2
rest-query-4c7b4102dede53b9707fe3758a4a9ff9ccf87bf8.zip
PDSUI-2145 Create own user history for Documents and Medical Records
Diffstat (limited to 'src/main/scala/xyz/driver/pdsuidomain/services/MedicalRecordHistoryService.scala')
-rw-r--r--src/main/scala/xyz/driver/pdsuidomain/services/MedicalRecordHistoryService.scala44
1 files changed, 44 insertions, 0 deletions
diff --git a/src/main/scala/xyz/driver/pdsuidomain/services/MedicalRecordHistoryService.scala b/src/main/scala/xyz/driver/pdsuidomain/services/MedicalRecordHistoryService.scala
new file mode 100644
index 0000000..f8fe3be
--- /dev/null
+++ b/src/main/scala/xyz/driver/pdsuidomain/services/MedicalRecordHistoryService.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.LongId
+import xyz.driver.pdsuicommon.error.DomainError
+import xyz.driver.pdsuidomain.entities.{MedicalRecord, MedicalRecordHistory}
+
+import scala.concurrent.Future
+
+object MedicalRecordHistoryService {
+
+ trait DefaultNotFoundError {
+ def userMessage: String = "Medical record history not found"
+ }
+
+ trait DefaultAccessDeniedError {
+ def userMessage: String = "Access denied"
+ }
+
+ sealed trait GetListReply
+ object GetListReply {
+ final case class EntityList(xs: Seq[MedicalRecordHistory], totalFound: Int, lastUpdate: Option[LocalDateTime])
+ extends GetListReply
+
+ final case object AuthorizationError
+ extends GetListReply with DomainError.AuthorizationError with DefaultAccessDeniedError
+ }
+
+}
+
+trait MedicalRecordHistoryService {
+
+ import MedicalRecordHistoryService._
+
+ def getListByRecordId(id: LongId[MedicalRecord],
+ filter: SearchFilterExpr = SearchFilterExpr.Empty,
+ sorting: Option[Sorting] = None,
+ pagination: Option[Pagination] = None)(
+ implicit requestContext: AuthenticatedRequestContext): Future[GetListReply]
+
+}