Skip to content
This repository has been archived by the owner on Jun 22, 2022. It is now read-only.

Latest commit

 

History

History
119 lines (105 loc) · 3.45 KB

README.md

File metadata and controls

119 lines (105 loc) · 3.45 KB

hoopla-serializer-scala

Codacy Badge Build Status Coverage Status

jsonapi

hoopla-serializer-scala is a jsonapi.org serializer, given a json4s format it will produce valid json4s output.

Structure

no.hoopla.serializer.Schema describes how to convert an object into jsonapi output, no.hoopla.serializer.Serializer contains one public function (serialize) that serializes based on a Schema and an object.

API

A schema is an abstract class with the following fields

// the name of the primary key
primaryKey: String

// the name of the type to serialize
typeName: String

// names of attributes or fields in the class to include, defaults to empty
attributes: List[String] = List()

// relationships to include, defaults to empty
relationships: List[Relationship] = List()

A relationship is a case class for describing how schemas interact, containing the following fields:

// the schema of the related resource
schema: Schema

// the field in the model that is serialized with this relationship's schema.
attribute: String

// whether to include the data in the output, defaults to false.
included: Boolean = false

Example Usage

import org.json4s._
import org.json4s.jackson.JsonMethods._
import no.hoopla.serializer._

object SerializationExample extends App {
  // the case class to serialize
  case class Person(id: Long, name: String, supervisor: Option[Person])

  // the schema
  object PersonSchema extends Schema[Person] {
    override def primaryKey = "id"
    override def typeName = "persons"
    // include name in the json output.
    override def attributes = List("name")
    // a Person may have a boss, include it in output
    override def relationships = List(Relationship(PersonSchema, "supervisor", included=true))
  }

  // the data
  val executiveErica = Person(3, "Erica the Eldricht", None)
  val middleManagementMark = Person(2, "Mark the Magniloquent", Some(executiveErica))
  val builderBob = Person(1, "Bob the Bacciferous", Some(middleManagementMark))

  // serialize!
  val jsonOutput: JValue = Serializer.serialize(PersonSchema, builderBob)

  // pretty print output
  println(pretty(render(jsonOutput)))
}

Expected output:

{
  "data" : {
    "type" : "persons",
    "id" : "1",
    "attributes" : {
      "name" : "Bob the Bacciferous"
    },
    "relationships" : {
      "supervisor" : {
        "data" : {
          "type" : "persons",
          "id" : "2"
        }
      }
    }
  },
  "included" : [ {
    "type" : "persons",
    "id" : "3",
    "attributes" : {
      "name" : "Erica the Eldricht"
    },
    "relationships" : {
      "supervisor" : {
        "data" : null
      }
    }
  }, {
    "type" : "persons",
    "id" : "2",
    "attributes" : {
      "name" : "Mark the Magniloquent"
    },
    "relationships" : {
      "supervisor" : {
        "data" : {
          "type" : "persons",
          "id" : "3"
        }
      }
    }
  } ]
}

For more usage, see the tests.