diff options
author | ktomskikh <ktomskih@datamonsters.co> | 2017-08-03 18:04:00 +0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-08-03 18:04:00 +0700 |
commit | 40ee33a7c176895a19ee0f9066849d34c38c75fd (patch) | |
tree | 21b9d9b308f91af1eefaa5f68b4fef0e011c9e98 /src/main/scala/xyz/driver/pdsuidomain/services | |
parent | a0c4fdf5f4280aa05518b925ed7bdc319758145a (diff) | |
parent | fc7c7063cafd7df8efe2c6c0dbc28e5ff0de06f6 (diff) | |
download | rest-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.scala | 44 |
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] + +} |