blob: 07757e3ab085d60dcb7b6c359ffd68439bc347e0 (
plain) (
tree)
|
|
package xyz.driver.pdsuidomain.services.rest
import akka.http.scaladsl.model.Uri
import akka.stream.Materializer
import spray.json.DefaultJsonProtocol
import xyz.driver.core.Id
import xyz.driver.core.rest.{RestService, ServiceRequestContext, ServiceTransport}
import xyz.driver.entities.patient
import xyz.driver.pdsuidomain.entities.eligibility.{MatchedPatient, MismatchRankedLabels}
import xyz.driver.pdsuidomain.entities.{Arm, Patient, eligibility}
import xyz.driver.pdsuidomain.services.EligibilityVerificationService
import scala.concurrent.{ExecutionContext, Future}
import scalaz.ListT
import scalaz.Scalaz.futureInstance
class RestEligibilityVerificationService(transport: ServiceTransport, baseUri: Uri)(
implicit protected val materializer: Materializer,
protected val exec: ExecutionContext
) extends EligibilityVerificationService with RestService {
import DefaultJsonProtocol._
import akka.http.scaladsl.marshallers.sprayjson.SprayJsonSupport._
import xyz.driver.pdsuidomain.formats.json.sprayformats.eligibility._
override def getMatchedPatients()(implicit ctx: ServiceRequestContext): ListT[Future, eligibility.MatchedPatient] = {
val request = get(baseUri, s"/v1/patients")
listResponse[MatchedPatient](transport.sendRequest(ctx)(request))
}
override def getMismatchRankedLabels(patientId: Id[Patient],
cancerType: patient.CancerType,
excludedArms: Seq[Id[Arm]])(
implicit ctx: ServiceRequestContext): Future[eligibility.MismatchRankedLabels] = {
val query =
Seq("disease" -> cancerType.toString.toUpperCase, "ineligible_arms" -> excludedArms.map(_.value).mkString(","))
val request = get(baseUri, s"/v1/patients/$patientId/labels", query)
optionalResponse[MismatchRankedLabels](transport.sendRequest(ctx)(request))
.getOrElse(throw new Exception(s"The data of patient $patientId is not ready yet"))
}
}
|