aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/xyz/driver/pdsuidomain/formats/json/trial.scala
diff options
context:
space:
mode:
authorKseniya Tomskikh <ktomskih@datamonsters.co>2017-10-20 16:25:04 +0700
committerKseniya Tomskikh <ktomskih@datamonsters.co>2017-10-20 16:25:04 +0700
commit54b15dae509212f6661dc1f1bc4ca248cb487443 (patch)
tree85b1ceafd9a56da511513797bd263977f52b556c /src/main/scala/xyz/driver/pdsuidomain/formats/json/trial.scala
parent6d6e732368e97e319653f00e498189afceeb4671 (diff)
downloadrest-query-54b15dae509212f6661dc1f1bc4ca248cb487443.tar.gz
rest-query-54b15dae509212f6661dc1f1bc4ca248cb487443.tar.bz2
rest-query-54b15dae509212f6661dc1f1bc4ca248cb487443.zip
PDSUI-2336 Deleted api classes of play format, userhistory and message services
Diffstat (limited to 'src/main/scala/xyz/driver/pdsuidomain/formats/json/trial.scala')
-rw-r--r--src/main/scala/xyz/driver/pdsuidomain/formats/json/trial.scala85
1 files changed, 85 insertions, 0 deletions
diff --git a/src/main/scala/xyz/driver/pdsuidomain/formats/json/trial.scala b/src/main/scala/xyz/driver/pdsuidomain/formats/json/trial.scala
new file mode 100644
index 0000000..6cc2560
--- /dev/null
+++ b/src/main/scala/xyz/driver/pdsuidomain/formats/json/trial.scala
@@ -0,0 +1,85 @@
+package xyz.driver.pdsuidomain.formats.json
+
+import java.time.{ZoneId, ZonedDateTime}
+
+import spray.json._
+import xyz.driver.core.json.EnumJsonFormat
+import xyz.driver.pdsuicommon.domain.{LongId, UuidId}
+import xyz.driver.pdsuidomain.entities._
+
+object trial {
+ import DefaultJsonProtocol._
+ import Trial._
+ import common._
+
+ implicit val trialStatusFormat = new EnumJsonFormat[Status](
+ "New" -> Status.New,
+ "ReviewSummary" -> Status.ReviewSummary,
+ "Summarized" -> Status.Summarized,
+ "PendingUpdate" -> Status.PendingUpdate,
+ "Update" -> Status.Update,
+ "ReviewCriteria" -> Status.ReviewCriteria,
+ "Done" -> Status.Done,
+ "Flagged" -> Status.Flagged,
+ "Archived" -> Status.Archived
+ )
+
+ implicit val trialFormat: RootJsonFormat[Trial] = new RootJsonFormat[Trial] {
+ override def write(obj: Trial) =
+ JsObject(
+ "id" -> obj.id.toJson,
+ "externalid" -> obj.externalId.toJson,
+ "lastUpdate" -> ZonedDateTime.of(obj.lastUpdate, ZoneId.of("Z")).toJson,
+ "status" -> obj.status.toJson,
+ "assignee" -> obj.assignee.toJson,
+ "previousStatus" -> obj.previousStatus.toJson,
+ "previousAssignee" -> obj.previousAssignee.toJson,
+ "lastActiveUser" -> obj.lastActiveUserId.toJson,
+ "phase" -> obj.phase.toJson,
+ "hypothesisId" -> obj.hypothesisId.toJson,
+ "studyDesignId" -> obj.studyDesignId.toJson,
+ "originalStudyDesignId" -> obj.originalStudyDesign.toJson,
+ "isPartner" -> obj.isPartner.toJson,
+ "overview" -> obj.overview.toJson,
+ "overviewTemplate" -> obj.overviewTemplate.toJson,
+ "isUpdated" -> obj.isUpdated.toJson,
+ "title" -> obj.title.toJson,
+ "originalTitle" -> obj.originalTitle.toJson
+ )
+
+ override def read(json: JsValue): Trial = jsonReader[Trial].read(json)
+ }
+
+ def applyUpdateToTrial(json: JsValue, orig: Trial): Trial = json match {
+ case JsObject(fields) =>
+ val hypothesisId = fields
+ .get("hypothesisId")
+ .map(_.convertTo[Option[UuidId[Hypothesis]]])
+ .getOrElse(orig.hypothesisId)
+
+ val studyDesignId = fields
+ .get("studyDesignId")
+ .map(_.convertTo[Option[LongId[StudyDesign]]])
+ .getOrElse(orig.studyDesignId)
+
+ val overview = fields
+ .get("overview")
+ .map(_.convertTo[Option[String]])
+ .getOrElse(orig.overview)
+
+ val title = fields
+ .get("title")
+ .map(_.convertTo[Option[String]].getOrElse(""))
+ .getOrElse(orig.title)
+
+ orig.copy(
+ hypothesisId = hypothesisId,
+ studyDesignId = studyDesignId,
+ overview = overview,
+ title = title
+ )
+
+ case _ => deserializationError(s"Expected Json Object as Trial, but got $json")
+ }
+
+}