aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/xyz/driver/pdsuidomain/services
diff options
context:
space:
mode:
Diffstat (limited to 'src/main/scala/xyz/driver/pdsuidomain/services')
-rw-r--r--src/main/scala/xyz/driver/pdsuidomain/services/DocumentIssueService.scala93
-rw-r--r--src/main/scala/xyz/driver/pdsuidomain/services/MedicalRecordIssueService.scala93
-rw-r--r--src/main/scala/xyz/driver/pdsuidomain/services/PatientIssueService.scala93
3 files changed, 279 insertions, 0 deletions
diff --git a/src/main/scala/xyz/driver/pdsuidomain/services/DocumentIssueService.scala b/src/main/scala/xyz/driver/pdsuidomain/services/DocumentIssueService.scala
new file mode 100644
index 0000000..4315352
--- /dev/null
+++ b/src/main/scala/xyz/driver/pdsuidomain/services/DocumentIssueService.scala
@@ -0,0 +1,93 @@
+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, DocumentIssue}
+
+import scala.concurrent.Future
+
+object DocumentIssueService {
+
+ trait DefaultNotFoundError {
+ def userMessage: String = "DocumentIssue not found"
+ }
+
+ trait DefaultAccessDeniedError {
+ def userMessage: String = "Access denied"
+ }
+
+ sealed trait CreateReply
+ object CreateReply {
+ type Error = CreateReply with DomainError
+ final case class Created(x: DocumentIssue) extends CreateReply
+ case object AuthorizationError
+ extends CreateReply with DomainError.AuthorizationError with DefaultAccessDeniedError
+ final case class CommonError(userMessage: String) extends CreateReply with DomainError
+ }
+
+ sealed trait GetByIdReply
+ object GetByIdReply {
+ type Error = GetByIdReply with DomainError
+ final case class Entity(x: DocumentIssue) extends GetByIdReply
+ case object NotFoundError extends GetByIdReply with DomainError.NotFoundError with DefaultNotFoundError
+ final case class CommonError(userMessage: String) extends GetByIdReply with DomainError
+ case object AuthorizationError
+ extends GetByIdReply with DomainError.AuthorizationError with DefaultAccessDeniedError
+ }
+
+ sealed trait GetListByDocumentIdReply
+ object GetListByDocumentIdReply {
+ type Error = GetListByDocumentIdReply with DomainError
+ final case class EntityList(xs: Seq[DocumentIssue], totalFound: Int, lastUpdate: Option[LocalDateTime])
+ extends GetListByDocumentIdReply
+ case object NotFoundError extends GetListByDocumentIdReply with DomainError.NotFoundError with DefaultNotFoundError
+ case object AuthorizationError
+ extends GetListByDocumentIdReply with DomainError.AuthorizationError with DefaultAccessDeniedError
+ }
+
+ sealed trait UpdateReply
+ object UpdateReply {
+ type Error = UpdateReply with DomainError
+ final case class Updated(updated: DocumentIssue) extends UpdateReply
+ case object AuthorizationError
+ extends UpdateReply with DomainError.AuthorizationError with DefaultAccessDeniedError
+ final case class CommonError(userMessage: String) extends UpdateReply with DomainError
+ }
+
+ sealed trait DeleteReply
+ object DeleteReply {
+ type Error = DeleteReply with DomainError
+ case object Deleted extends DeleteReply
+ case object AuthorizationError
+ extends DeleteReply with DomainError.AuthorizationError with DefaultAccessDeniedError
+ case object NotFoundError extends DeleteReply with DomainError.NotFoundError with DefaultNotFoundError
+ final case class CommonError(userMessage: String) extends DeleteReply with DomainError
+ }
+}
+
+trait DocumentIssueService {
+
+ import DocumentIssueService._
+
+ def create(draft: DocumentIssue)(implicit requestContext: AuthenticatedRequestContext): Future[CreateReply]
+
+ def getById(documentId: LongId[Document], id: LongId[DocumentIssue])(
+ implicit requestContext: AuthenticatedRequestContext): Future[GetByIdReply]
+
+ def getListByDocumentId(documentId: LongId[Document],
+ filter: SearchFilterExpr = SearchFilterExpr.Empty,
+ sorting: Option[Sorting] = None,
+ pagination: Option[Pagination] = None)(
+ implicit requestContext: AuthenticatedRequestContext): Future[GetListByDocumentIdReply]
+
+ def update(orig: DocumentIssue, draft: DocumentIssue)(
+ implicit requestContext: AuthenticatedRequestContext): Future[UpdateReply]
+
+ def delete(documentId: LongId[Document], id: LongId[DocumentIssue])(
+ implicit requestContext: AuthenticatedRequestContext): Future[DeleteReply]
+
+}
diff --git a/src/main/scala/xyz/driver/pdsuidomain/services/MedicalRecordIssueService.scala b/src/main/scala/xyz/driver/pdsuidomain/services/MedicalRecordIssueService.scala
new file mode 100644
index 0000000..723bdfa
--- /dev/null
+++ b/src/main/scala/xyz/driver/pdsuidomain/services/MedicalRecordIssueService.scala
@@ -0,0 +1,93 @@
+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, MedicalRecordIssue}
+
+import scala.concurrent.Future
+
+object MedicalRecordIssueService {
+
+ trait DefaultNotFoundError {
+ def userMessage: String = "MedicalRecordIssue not found"
+ }
+
+ trait DefaultAccessDeniedError {
+ def userMessage: String = "Access denied"
+ }
+
+ sealed trait CreateReply
+ object CreateReply {
+ type Error = CreateReply with DomainError
+ final case class Created(x: MedicalRecordIssue) extends CreateReply
+ case object AuthorizationError
+ extends CreateReply with DomainError.AuthorizationError with DefaultAccessDeniedError
+ final case class CommonError(userMessage: String) extends CreateReply with DomainError
+ }
+
+ sealed trait GetByIdReply
+ object GetByIdReply {
+ type Error = GetByIdReply with DomainError
+ final case class Entity(x: MedicalRecordIssue) extends GetByIdReply
+ case object NotFoundError extends GetByIdReply with DomainError.NotFoundError with DefaultNotFoundError
+ final case class CommonError(userMessage: String) extends GetByIdReply with DomainError
+ case object AuthorizationError
+ extends GetByIdReply with DomainError.AuthorizationError with DefaultAccessDeniedError
+ }
+
+ sealed trait GetListByRecordIdReply
+ object GetListByRecordIdReply {
+ type Error = GetListByRecordIdReply with DomainError
+ final case class EntityList(xs: Seq[MedicalRecordIssue], totalFound: Int, lastUpdate: Option[LocalDateTime])
+ extends GetListByRecordIdReply
+ case object NotFoundError extends GetListByRecordIdReply with DomainError.NotFoundError with DefaultNotFoundError
+ case object AuthorizationError
+ extends GetListByRecordIdReply with DomainError.AuthorizationError with DefaultAccessDeniedError
+ }
+
+ sealed trait UpdateReply
+ object UpdateReply {
+ type Error = UpdateReply with DomainError
+ final case class Updated(updated: MedicalRecordIssue) extends UpdateReply
+ case object AuthorizationError
+ extends UpdateReply with DomainError.AuthorizationError with DefaultAccessDeniedError
+ final case class CommonError(userMessage: String) extends UpdateReply with DomainError
+ }
+
+ sealed trait DeleteReply
+ object DeleteReply {
+ type Error = DeleteReply with DomainError
+ case object Deleted extends DeleteReply
+ case object AuthorizationError
+ extends DeleteReply with DomainError.AuthorizationError with DefaultAccessDeniedError
+ case object NotFoundError extends DeleteReply with DomainError.NotFoundError with DefaultNotFoundError
+ final case class CommonError(userMessage: String) extends DeleteReply with DomainError
+ }
+}
+
+trait MedicalRecordIssueService {
+
+ import MedicalRecordIssueService._
+
+ def create(draft: MedicalRecordIssue)(implicit requestContext: AuthenticatedRequestContext): Future[CreateReply]
+
+ def getById(recordId: LongId[MedicalRecord], id: LongId[MedicalRecordIssue])(
+ implicit requestContext: AuthenticatedRequestContext): Future[GetByIdReply]
+
+ def getListByRecordId(recordId: LongId[MedicalRecord],
+ filter: SearchFilterExpr = SearchFilterExpr.Empty,
+ sorting: Option[Sorting] = None,
+ pagination: Option[Pagination] = None)(
+ implicit requestContext: AuthenticatedRequestContext): Future[GetListByRecordIdReply]
+
+ def update(orig: MedicalRecordIssue, draft: MedicalRecordIssue)(
+ implicit requestContext: AuthenticatedRequestContext): Future[UpdateReply]
+
+ def delete(recordId: LongId[MedicalRecord], id: LongId[MedicalRecordIssue])(
+ implicit requestContext: AuthenticatedRequestContext): Future[DeleteReply]
+
+}
diff --git a/src/main/scala/xyz/driver/pdsuidomain/services/PatientIssueService.scala b/src/main/scala/xyz/driver/pdsuidomain/services/PatientIssueService.scala
new file mode 100644
index 0000000..b53301d
--- /dev/null
+++ b/src/main/scala/xyz/driver/pdsuidomain/services/PatientIssueService.scala
@@ -0,0 +1,93 @@
+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, UuidId}
+import xyz.driver.pdsuicommon.error.DomainError
+import xyz.driver.pdsuidomain.entities.{Patient, PatientIssue}
+
+import scala.concurrent.Future
+
+object PatientIssueService {
+
+ trait DefaultNotFoundError {
+ def userMessage: String = "PatientIssue not found"
+ }
+
+ trait DefaultAccessDeniedError {
+ def userMessage: String = "Access denied"
+ }
+
+ sealed trait CreateReply
+ object CreateReply {
+ type Error = CreateReply with DomainError
+ final case class Created(x: PatientIssue) extends CreateReply
+ case object AuthorizationError
+ extends CreateReply with DomainError.AuthorizationError with DefaultAccessDeniedError
+ final case class CommonError(userMessage: String) extends CreateReply with DomainError
+ }
+
+ sealed trait GetByIdReply
+ object GetByIdReply {
+ type Error = GetByIdReply with DomainError
+ final case class Entity(x: PatientIssue) extends GetByIdReply
+ case object NotFoundError extends GetByIdReply with DomainError.NotFoundError with DefaultNotFoundError
+ final case class CommonError(userMessage: String) extends GetByIdReply with DomainError
+ case object AuthorizationError
+ extends GetByIdReply with DomainError.AuthorizationError with DefaultAccessDeniedError
+ }
+
+ sealed trait GetListByPatientIdReply
+ object GetListByPatientIdReply {
+ type Error = GetListByPatientIdReply with DomainError
+ final case class EntityList(xs: Seq[PatientIssue], totalFound: Int, lastUpdate: Option[LocalDateTime])
+ extends GetListByPatientIdReply
+ case object NotFoundError extends GetListByPatientIdReply with DomainError.NotFoundError with DefaultNotFoundError
+ case object AuthorizationError
+ extends GetListByPatientIdReply with DomainError.AuthorizationError with DefaultAccessDeniedError
+ }
+
+ sealed trait UpdateReply
+ object UpdateReply {
+ type Error = UpdateReply with DomainError
+ final case class Updated(updated: PatientIssue) extends UpdateReply
+ case object AuthorizationError
+ extends UpdateReply with DomainError.AuthorizationError with DefaultAccessDeniedError
+ final case class CommonError(userMessage: String) extends UpdateReply with DomainError
+ }
+
+ sealed trait DeleteReply
+ object DeleteReply {
+ type Error = DeleteReply with DomainError
+ case object Deleted extends DeleteReply
+ case object AuthorizationError
+ extends DeleteReply with DomainError.AuthorizationError with DefaultAccessDeniedError
+ case object NotFoundError extends DeleteReply with DomainError.NotFoundError with DefaultNotFoundError
+ final case class CommonError(userMessage: String) extends DeleteReply with DomainError
+ }
+}
+
+trait PatientIssueService {
+
+ import PatientIssueService._
+
+ def create(draft: PatientIssue)(implicit requestContext: AuthenticatedRequestContext): Future[CreateReply]
+
+ def getById(patientId: UuidId[Patient], id: LongId[PatientIssue])(
+ implicit requestContext: AuthenticatedRequestContext): Future[GetByIdReply]
+
+ def getListByPatientId(patientId: UuidId[Patient],
+ filter: SearchFilterExpr = SearchFilterExpr.Empty,
+ sorting: Option[Sorting] = None,
+ pagination: Option[Pagination] = None)(
+ implicit requestContext: AuthenticatedRequestContext): Future[GetListByPatientIdReply]
+
+ def update(orig: PatientIssue, draft: PatientIssue)(
+ implicit requestContext: AuthenticatedRequestContext): Future[UpdateReply]
+
+ def delete(patientId: UuidId[Patient], id: LongId[PatientIssue])(
+ implicit requestContext: AuthenticatedRequestContext): Future[DeleteReply]
+
+}