aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/xyz/driver/pdsuidomain/services/LinkedPatientService.scala
diff options
context:
space:
mode:
authorvlad <vlad@driver.xyz>2017-06-30 19:38:37 -0700
committervlad <vlad@driver.xyz>2017-06-30 19:38:37 -0700
commit96d81a36286e41035ff4068859a3b0f9da924fbc (patch)
tree8d9f0014140d1f07ca449b56adaba8ccb3d2fc59 /src/main/scala/xyz/driver/pdsuidomain/services/LinkedPatientService.scala
parenta997aa6539d1f0af4ab4fc395ff2033335da312a (diff)
downloadrest-query-96d81a36286e41035ff4068859a3b0f9da924fbc.tar.gz
rest-query-96d81a36286e41035ff4068859a3b0f9da924fbc.tar.bz2
rest-query-96d81a36286e41035ff4068859a3b0f9da924fbc.zip
Latest PDS UI utils including all the domain stuffv0.1.12
Diffstat (limited to 'src/main/scala/xyz/driver/pdsuidomain/services/LinkedPatientService.scala')
-rw-r--r--src/main/scala/xyz/driver/pdsuidomain/services/LinkedPatientService.scala62
1 files changed, 62 insertions, 0 deletions
diff --git a/src/main/scala/xyz/driver/pdsuidomain/services/LinkedPatientService.scala b/src/main/scala/xyz/driver/pdsuidomain/services/LinkedPatientService.scala
new file mode 100644
index 0000000..8fc1662
--- /dev/null
+++ b/src/main/scala/xyz/driver/pdsuidomain/services/LinkedPatientService.scala
@@ -0,0 +1,62 @@
+package xyz.driver.pdsuidomain.services
+
+import xyz.driver.pdsuicommon.domain._
+import xyz.driver.pdsuicommon.error.DomainError
+import xyz.driver.pdsuicommon.logging._
+import xyz.driver.pdsuidomain.entities.{LinkedPatient, Patient, Trial}
+
+import scala.concurrent.Future
+
+object LinkedPatientService {
+
+ trait DefaultTrialNotFoundError {
+ def userMessage: String = "Trial not found"
+ }
+
+ trait DefaultPatientNotFoundError {
+ def userMessage: String = "Patient not found"
+ }
+
+ final case class RichLinkedPatient(email: Email,
+ name: String,
+ patientId: UuidId[Patient],
+ trialId: StringId[Trial]) {
+ def toLinkedPatient(user: User) = LinkedPatient(
+ userId = user.id,
+ patientId = patientId,
+ trialId = trialId
+ )
+ }
+
+ object RichLinkedPatient {
+ implicit def toPhiString(x: RichLinkedPatient): PhiString = {
+ import x._
+ phi"RichLinkedPatient(email=${Unsafe(email)}, patientId=$patientId, trialId=$trialId)"
+ }
+ }
+
+ sealed trait CreateReply
+ object CreateReply {
+ type Error = CreateReply with DomainError
+
+ /**
+ * @param createdUser None if a user was created before
+ */
+ final case class Created(x: RichLinkedPatient, createdUser: Option[User]) extends CreateReply
+
+ case object PatientNotFoundError
+ extends CreateReply with DefaultPatientNotFoundError with DomainError.NotFoundError
+
+ case object TrialNotFoundError
+ extends CreateReply with DefaultPatientNotFoundError with DomainError.NotFoundError
+
+ final case class CommonError(userMessage: String) extends CreateReply with DomainError
+ }
+}
+
+trait LinkedPatientService {
+
+ import LinkedPatientService._
+
+ def create(entity: RichLinkedPatient): Future[CreateReply]
+}