aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/xyz/driver/pdsuidomain/formats/json/sprayformats/recordissue.scala
diff options
context:
space:
mode:
authorKseniya Tomskikh <ktomskih@datamonsters.co>2017-08-04 17:57:12 +0600
committerKseniya Tomskikh <ktomskih@datamonsters.co>2017-08-11 14:41:17 +0600
commitef9517e1b8f599fbdd15c474cf7dfea61e803c2f (patch)
treec31a139d35dab0c10c70bb7afef2bca8e48f0fee /src/main/scala/xyz/driver/pdsuidomain/formats/json/sprayformats/recordissue.scala
parent5519c219e2404cb19b6116dee90b40b5e5e2a720 (diff)
downloadrest-query-ef9517e1b8f599fbdd15c474cf7dfea61e803c2f.tar.gz
rest-query-ef9517e1b8f599fbdd15c474cf7dfea61e803c2f.tar.bz2
rest-query-ef9517e1b8f599fbdd15c474cf7dfea61e803c2f.zip
PDSUI-2188 Created and fixed spray json formats for tric and rep
Diffstat (limited to 'src/main/scala/xyz/driver/pdsuidomain/formats/json/sprayformats/recordissue.scala')
-rw-r--r--src/main/scala/xyz/driver/pdsuidomain/formats/json/sprayformats/recordissue.scala85
1 files changed, 85 insertions, 0 deletions
diff --git a/src/main/scala/xyz/driver/pdsuidomain/formats/json/sprayformats/recordissue.scala b/src/main/scala/xyz/driver/pdsuidomain/formats/json/sprayformats/recordissue.scala
new file mode 100644
index 0000000..9e23b8a
--- /dev/null
+++ b/src/main/scala/xyz/driver/pdsuidomain/formats/json/sprayformats/recordissue.scala
@@ -0,0 +1,85 @@
+package xyz.driver.pdsuidomain.formats.json.sprayformats
+
+import java.time.LocalDateTime
+
+import spray.json._
+import xyz.driver.pdsuicommon.domain.{LongId, StringId, User}
+import xyz.driver.pdsuidomain.entities._
+
+object recordissue {
+ import DefaultJsonProtocol._
+ import common._
+
+ def applyUpdateToRecordIssue(json: JsValue, orig: MedicalRecordIssue): MedicalRecordIssue = json match {
+ case JsObject(fields) =>
+ val text = fields
+ .get("text")
+ .map(_.convertTo[String])
+ .getOrElse(deserializationError(s"MedicalRecordIssue json object does not contain `text` field: $json"))
+
+ val archiveRequired = fields
+ .get("archiveRequired")
+ .map(_.convertTo[Boolean])
+ .getOrElse(
+ deserializationError(s"MedicalRecordIssue json object does not contain `archiveRequired` field: $json"))
+
+ val startPage = fields.get("startPage").map(_.convertTo[Double])
+ val endPage = fields.get("endPage").map(_.convertTo[Double])
+
+ orig.copy(
+ text = text,
+ archiveRequired = archiveRequired,
+ startPage = startPage,
+ endPage = endPage
+ )
+
+ case _ => deserializationError(s"Expected Json Object as partial MedicalRecordIssue, but got $json")
+
+ }
+
+ def jsValueToRecordIssue(json: JsValue,
+ recordId: LongId[MedicalRecord],
+ userId: StringId[User]): MedicalRecordIssue = json match {
+ case JsObject(fields) =>
+ val text = fields
+ .get("text")
+ .map(_.convertTo[String])
+ .getOrElse(deserializationError(s"MedicalRecordIssue json object does not contain `text` field: $json"))
+
+ val archiveRequired = fields
+ .get("archiveRequired")
+ .map(_.convertTo[Boolean])
+ .getOrElse(
+ deserializationError(s"MedicalRecordIssue json object does not contain `archiveRequired` field: $json"))
+
+ val startPage = fields.get("startPage").map(_.convertTo[Double])
+ val endPage = fields.get("endPage").map(_.convertTo[Double])
+ MedicalRecordIssue(
+ id = LongId(0),
+ userId = userId,
+ recordId = recordId,
+ lastUpdate = LocalDateTime.MIN,
+ isDraft = true,
+ text = text,
+ archiveRequired = archiveRequired,
+ startPage = startPage,
+ endPage = endPage
+ )
+
+ case _ => deserializationError(s"Expected Json Object as MedicalRecordIssue, but got $json")
+ }
+
+ implicit val recordIssueWriter = new JsonWriter[MedicalRecordIssue] {
+ override def write(obj: MedicalRecordIssue) = JsObject(
+ "id" -> obj.id.toJson,
+ "startPage" -> obj.startPage.toJson,
+ "endPage" -> obj.endPage.toJson,
+ "text" -> obj.text.toJson,
+ "lastUpdate" -> obj.lastUpdate.toJson,
+ "userId" -> obj.userId.toJson,
+ "isDraft" -> obj.isDraft.toJson,
+ "archiveRequired" -> obj.archiveRequired.toJson
+ )
+ }
+
+}