diff options
author | Vyatcheslav Suharnikov <arz.freezy@gmail.com> | 2017-07-25 10:48:08 +0300 |
---|---|---|
committer | Vyatcheslav Suharnikov <arz.freezy@gmail.com> | 2017-07-25 11:20:48 +0300 |
commit | 4c7b4102dede53b9707fe3758a4a9ff9ccf87bf8 (patch) | |
tree | e692c278f343fc3d0ce5945c1fab5e7d10459ec7 /src/main/scala/xyz/driver/pdsuidomain/services | |
parent | a835eef22830ab86a9f65194a6645f4f474ae0cc (diff) | |
download | rest-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')
-rw-r--r-- | src/main/scala/xyz/driver/pdsuidomain/services/DocumentHistoryService.scala | 44 | ||||
-rw-r--r-- | src/main/scala/xyz/driver/pdsuidomain/services/MedicalRecordHistoryService.scala | 44 |
2 files changed, 88 insertions, 0 deletions
diff --git a/src/main/scala/xyz/driver/pdsuidomain/services/DocumentHistoryService.scala b/src/main/scala/xyz/driver/pdsuidomain/services/DocumentHistoryService.scala new file mode 100644 index 0000000..2d9679d --- /dev/null +++ b/src/main/scala/xyz/driver/pdsuidomain/services/DocumentHistoryService.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.{Document, DocumentHistory} + +import scala.concurrent.Future + +object DocumentHistoryService { + + trait DefaultNotFoundError { + def userMessage: String = "Document history not found" + } + + trait DefaultAccessDeniedError { + def userMessage: String = "Access denied" + } + + sealed trait GetListReply + object GetListReply { + final case class EntityList(xs: Seq[DocumentHistory], totalFound: Int, lastUpdate: Option[LocalDateTime]) + extends GetListReply + + final case object AuthorizationError + extends GetListReply with DomainError.AuthorizationError with DefaultAccessDeniedError + } + +} + +trait DocumentHistoryService { + + import DocumentHistoryService._ + + def getListByDocumentId(id: LongId[Document], + filter: SearchFilterExpr = SearchFilterExpr.Empty, + sorting: Option[Sorting] = None, + pagination: Option[Pagination] = None)( + implicit requestContext: AuthenticatedRequestContext): Future[GetListReply] + +} 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] + +} |