/** * Generated by API Builder - https://www.apibuilder.io * Service version: 0.0.1 * User agent: apibuilder app.apibuilder.io/faberoh/order-api/0.0.1/play_2_x_json */ package com.faberoh.order.api.v0.models { /** * An address * * @param firstName The first name. * @param lastName The last name. * @param line1 The first line of the address. * @param line2 The second line of the address. * @param zip The zip code. * @param city The city name. * @param state The state name. * @param countryCode The country ISO code. */ final case class Address( firstName: String, lastName: String, line1: String, line2: _root_.scala.Option[String] = None, zip: String, city: String, state: String, countryCode: String ) /** * A credit card. * * @param number The credit card number. * @param expirationMonth The credit card expiration month. * @param expirationYear The credit card expiration year. * @param securityCode The credit card security code. * @param brand The credit card brand. * @param holderName The credit card holder name. */ final case class CreditCard( number: String, expirationMonth: Int, expirationYear: Int, securityCode: String, brand: com.faberoh.order.api.v0.models.CreditCardBrand, holderName: String ) /** * An item of the order. * * @param upc The UPC code for the product. * @param quantity The quantity of this item in the order. */ final case class Item( upc: String, quantity: Int ) /** * A customer order * * @param id The order unique identifier. * @param user The customer info. * @param status The current status of the order. * @param items The items of the order. * @param billingAddress The billing address of the order. * @param shippingAddress The shipping address of the order. * @param creditCard The payment method used. * @param summary the order summary amounts */ final case class Order( id: _root_.java.util.UUID, user: com.faberoh.order.api.v0.models.User, status: com.faberoh.order.api.v0.models.OrderStatus, items: Seq[com.faberoh.order.api.v0.models.Item], billingAddress: com.faberoh.order.api.v0.models.Address, shippingAddress: com.faberoh.order.api.v0.models.Address, creditCard: com.faberoh.order.api.v0.models.CreditCard, summary: com.faberoh.order.api.v0.models.OrderSummary ) /** * An item of the order. * * @param itemsTotal The total cost of the items in the order. * @param shippingCharge The charge for shipping the order. * @param taxes The taxes amount. * @param total The total amount. */ final case class OrderSummary( itemsTotal: Int, shippingCharge: Int, taxes: Int, total: Int ) /** * Customer info. * * @param id The unique ID for the user. * @param email The customer's email address. */ final case class User( id: _root_.java.util.UUID, email: String ) /** * The credit card brands supported. */ sealed trait CreditCardBrand extends _root_.scala.Product with _root_.scala.Serializable object CreditCardBrand { case object Visa extends CreditCardBrand { override def toString = "visa" } case object Mastercard extends CreditCardBrand { override def toString = "mastercard" } case object Amex extends CreditCardBrand { override def toString = "amex" } /** * UNDEFINED captures values that are sent either in error or * that were added by the server after this library was * generated. We want to make it easy and obvious for users of * this library to handle this case gracefully. * * We use all CAPS for the variable name to avoid collisions * with the camel cased values above. */ final case class UNDEFINED(override val toString: String) extends CreditCardBrand /** * all returns a list of all the valid, known values. We use * lower case to avoid collisions with the camel cased values * above. */ val all: scala.List[CreditCardBrand] = scala.List(Visa, Mastercard, Amex) private val byName: Map[String, CreditCardBrand] = all.map(x => x.toString.toLowerCase -> x).toMap def apply(value: String): CreditCardBrand = fromString(value).getOrElse(UNDEFINED(value)) def fromString(value: String): _root_.scala.Option[CreditCardBrand] = byName.get(value.toLowerCase) } /** * The processing status of an order. */ sealed trait OrderStatus extends _root_.scala.Product with _root_.scala.Serializable object OrderStatus { case object Open extends OrderStatus { override def toString = "open" } case object Submitted extends OrderStatus { override def toString = "submitted" } case object Processed extends OrderStatus { override def toString = "processed" } case object Shipped extends OrderStatus { override def toString = "shipped" } case object Cancelled extends OrderStatus { override def toString = "cancelled" } case object Returned extends OrderStatus { override def toString = "returned" } /** * UNDEFINED captures values that are sent either in error or * that were added by the server after this library was * generated. We want to make it easy and obvious for users of * this library to handle this case gracefully. * * We use all CAPS for the variable name to avoid collisions * with the camel cased values above. */ final case class UNDEFINED(override val toString: String) extends OrderStatus /** * all returns a list of all the valid, known values. We use * lower case to avoid collisions with the camel cased values * above. */ val all: scala.List[OrderStatus] = scala.List(Open, Submitted, Processed, Shipped, Cancelled, Returned) private val byName: Map[String, OrderStatus] = all.map(x => x.toString.toLowerCase -> x).toMap def apply(value: String): OrderStatus = fromString(value).getOrElse(UNDEFINED(value)) def fromString(value: String): _root_.scala.Option[OrderStatus] = byName.get(value.toLowerCase) } } package com.faberoh.order.api.v0.models { package object json { import play.api.libs.json.__ import play.api.libs.json.JsString import play.api.libs.json.Writes import play.api.libs.functional.syntax._ import com.faberoh.order.api.v0.models.json._ private[v0] implicit val jsonReadsUUID: play.api.libs.json.Reads[_root_.java.util.UUID] = __.read[String].map { str => _root_.java.util.UUID.fromString(str) } private[v0] implicit val jsonWritesUUID: play.api.libs.json.Writes[_root_.java.util.UUID] = (x: _root_.java.util.UUID) => play.api.libs.json.JsString(x.toString) private[v0] implicit val jsonReadsJodaDateTime: play.api.libs.json.Reads[_root_.org.joda.time.DateTime] = __.read[String].map { str => _root_.org.joda.time.format.ISODateTimeFormat.dateTimeParser.parseDateTime(str) } private[v0] implicit val jsonWritesJodaDateTime: play.api.libs.json.Writes[_root_.org.joda.time.DateTime] = (x: _root_.org.joda.time.DateTime) => { play.api.libs.json.JsString(_root_.org.joda.time.format.ISODateTimeFormat.dateTime.print(x)) } private[v0] implicit val jsonReadsJodaLocalDate: play.api.libs.json.Reads[_root_.org.joda.time.LocalDate] = __.read[String].map { str => _root_.org.joda.time.format.ISODateTimeFormat.dateTimeParser.parseLocalDate(str) } private[v0] implicit val jsonWritesJodaLocalDate: play.api.libs.json.Writes[_root_.org.joda.time.LocalDate] = (x: _root_.org.joda.time.LocalDate) => { play.api.libs.json.JsString(_root_.org.joda.time.format.ISODateTimeFormat.date.print(x)) } implicit val jsonReadsOrderApiCreditCardBrand: play.api.libs.json.Reads[com.faberoh.order.api.v0.models.CreditCardBrand] = new play.api.libs.json.Reads[com.faberoh.order.api.v0.models.CreditCardBrand] { def reads(js: play.api.libs.json.JsValue): play.api.libs.json.JsResult[com.faberoh.order.api.v0.models.CreditCardBrand] = { js match { case v: play.api.libs.json.JsString => play.api.libs.json.JsSuccess(com.faberoh.order.api.v0.models.CreditCardBrand(v.value)) case _ => { (js \ "value").validate[String] match { case play.api.libs.json.JsSuccess(v, _) => play.api.libs.json.JsSuccess(com.faberoh.order.api.v0.models.CreditCardBrand(v)) case err: play.api.libs.json.JsError => (js \ "credit_card_brand").validate[String] match { case play.api.libs.json.JsSuccess(v, _) => play.api.libs.json.JsSuccess(com.faberoh.order.api.v0.models.CreditCardBrand(v)) case err: play.api.libs.json.JsError => err } } } } } } def jsonWritesOrderApiCreditCardBrand(obj: com.faberoh.order.api.v0.models.CreditCardBrand) = { play.api.libs.json.JsString(obj.toString) } def jsObjectCreditCardBrand(obj: com.faberoh.order.api.v0.models.CreditCardBrand) = { play.api.libs.json.Json.obj("value" -> play.api.libs.json.JsString(obj.toString)) } implicit def jsonWritesOrderApiCreditCardBrand: play.api.libs.json.Writes[CreditCardBrand] = { (obj: com.faberoh.order.api.v0.models.CreditCardBrand) => { com.faberoh.order.api.v0.models.json.jsonWritesOrderApiCreditCardBrand(obj) } } implicit val jsonReadsOrderApiOrderStatus: play.api.libs.json.Reads[com.faberoh.order.api.v0.models.OrderStatus] = new play.api.libs.json.Reads[com.faberoh.order.api.v0.models.OrderStatus] { def reads(js: play.api.libs.json.JsValue): play.api.libs.json.JsResult[com.faberoh.order.api.v0.models.OrderStatus] = { js match { case v: play.api.libs.json.JsString => play.api.libs.json.JsSuccess(com.faberoh.order.api.v0.models.OrderStatus(v.value)) case _ => { (js \ "value").validate[String] match { case play.api.libs.json.JsSuccess(v, _) => play.api.libs.json.JsSuccess(com.faberoh.order.api.v0.models.OrderStatus(v)) case err: play.api.libs.json.JsError => (js \ "order_status").validate[String] match { case play.api.libs.json.JsSuccess(v, _) => play.api.libs.json.JsSuccess(com.faberoh.order.api.v0.models.OrderStatus(v)) case err: play.api.libs.json.JsError => err } } } } } } def jsonWritesOrderApiOrderStatus(obj: com.faberoh.order.api.v0.models.OrderStatus) = { play.api.libs.json.JsString(obj.toString) } def jsObjectOrderStatus(obj: com.faberoh.order.api.v0.models.OrderStatus) = { play.api.libs.json.Json.obj("value" -> play.api.libs.json.JsString(obj.toString)) } implicit def jsonWritesOrderApiOrderStatus: play.api.libs.json.Writes[OrderStatus] = { (obj: com.faberoh.order.api.v0.models.OrderStatus) => { com.faberoh.order.api.v0.models.json.jsonWritesOrderApiOrderStatus(obj) } } implicit def jsonReadsOrderApiAddress: play.api.libs.json.Reads[com.faberoh.order.api.v0.models.Address] = { for { firstName <- (__ \ "first_name").read[String] lastName <- (__ \ "last_name").read[String] line1 <- (__ \ "line1").read[String] line2 <- (__ \ "line2").readNullable[String] zip <- (__ \ "zip").read[String] city <- (__ \ "city").read[String] state <- (__ \ "state").read[String] countryCode <- (__ \ "country_code").read[String] } yield Address(firstName, lastName, line1, line2, zip, city, state, countryCode) } def jsObjectAddress(obj: com.faberoh.order.api.v0.models.Address): play.api.libs.json.JsObject = { play.api.libs.json.Json.obj( "first_name" -> play.api.libs.json.JsString(obj.firstName), "last_name" -> play.api.libs.json.JsString(obj.lastName), "line1" -> play.api.libs.json.JsString(obj.line1), "zip" -> play.api.libs.json.JsString(obj.zip), "city" -> play.api.libs.json.JsString(obj.city), "state" -> play.api.libs.json.JsString(obj.state), "country_code" -> play.api.libs.json.JsString(obj.countryCode) ) ++ (obj.line2 match { case None => play.api.libs.json.Json.obj() case Some(x) => play.api.libs.json.Json.obj("line2" -> play.api.libs.json.JsString(x)) }) } implicit def jsonWritesOrderApiAddress: play.api.libs.json.Writes[Address] = { (obj: com.faberoh.order.api.v0.models.Address) => { com.faberoh.order.api.v0.models.json.jsObjectAddress(obj) } } implicit def jsonReadsOrderApiCreditCard: play.api.libs.json.Reads[com.faberoh.order.api.v0.models.CreditCard] = { for { number <- (__ \ "number").read[String] expirationMonth <- (__ \ "expiration_month").read[Int] expirationYear <- (__ \ "expiration_year").read[Int] securityCode <- (__ \ "security_code").read[String] brand <- (__ \ "brand").read[com.faberoh.order.api.v0.models.CreditCardBrand] holderName <- (__ \ "holder_name").read[String] } yield CreditCard(number, expirationMonth, expirationYear, securityCode, brand, holderName) } def jsObjectCreditCard(obj: com.faberoh.order.api.v0.models.CreditCard): play.api.libs.json.JsObject = { play.api.libs.json.Json.obj( "number" -> play.api.libs.json.JsString(obj.number), "expiration_month" -> play.api.libs.json.JsNumber(obj.expirationMonth), "expiration_year" -> play.api.libs.json.JsNumber(obj.expirationYear), "security_code" -> play.api.libs.json.JsString(obj.securityCode), "brand" -> play.api.libs.json.JsString(obj.brand.toString), "holder_name" -> play.api.libs.json.JsString(obj.holderName) ) } implicit def jsonWritesOrderApiCreditCard: play.api.libs.json.Writes[CreditCard] = { (obj: com.faberoh.order.api.v0.models.CreditCard) => { com.faberoh.order.api.v0.models.json.jsObjectCreditCard(obj) } } implicit def jsonReadsOrderApiItem: play.api.libs.json.Reads[com.faberoh.order.api.v0.models.Item] = { for { upc <- (__ \ "upc").read[String] quantity <- (__ \ "quantity").read[Int] } yield Item(upc, quantity) } def jsObjectItem(obj: com.faberoh.order.api.v0.models.Item): play.api.libs.json.JsObject = { play.api.libs.json.Json.obj( "upc" -> play.api.libs.json.JsString(obj.upc), "quantity" -> play.api.libs.json.JsNumber(obj.quantity) ) } implicit def jsonWritesOrderApiItem: play.api.libs.json.Writes[Item] = { (obj: com.faberoh.order.api.v0.models.Item) => { com.faberoh.order.api.v0.models.json.jsObjectItem(obj) } } implicit def jsonReadsOrderApiOrder: play.api.libs.json.Reads[com.faberoh.order.api.v0.models.Order] = { for { id <- (__ \ "id").read[_root_.java.util.UUID] user <- (__ \ "user").read[com.faberoh.order.api.v0.models.User] status <- (__ \ "status").read[com.faberoh.order.api.v0.models.OrderStatus] items <- (__ \ "items").read[Seq[com.faberoh.order.api.v0.models.Item]] billingAddress <- (__ \ "billing_address").read[com.faberoh.order.api.v0.models.Address] shippingAddress <- (__ \ "shipping_address").read[com.faberoh.order.api.v0.models.Address] creditCard <- (__ \ "credit_card").read[com.faberoh.order.api.v0.models.CreditCard] summary <- (__ \ "summary").read[com.faberoh.order.api.v0.models.OrderSummary] } yield Order(id, user, status, items, billingAddress, shippingAddress, creditCard, summary) } def jsObjectOrder(obj: com.faberoh.order.api.v0.models.Order): play.api.libs.json.JsObject = { play.api.libs.json.Json.obj( "id" -> play.api.libs.json.JsString(obj.id.toString), "user" -> com.faberoh.order.api.v0.models.json.jsObjectUser(obj.user), "status" -> play.api.libs.json.JsString(obj.status.toString), "items" -> play.api.libs.json.Json.toJson(obj.items), "billing_address" -> com.faberoh.order.api.v0.models.json.jsObjectAddress(obj.billingAddress), "shipping_address" -> com.faberoh.order.api.v0.models.json.jsObjectAddress(obj.shippingAddress), "credit_card" -> com.faberoh.order.api.v0.models.json.jsObjectCreditCard(obj.creditCard), "summary" -> com.faberoh.order.api.v0.models.json.jsObjectOrderSummary(obj.summary) ) } implicit def jsonWritesOrderApiOrder: play.api.libs.json.Writes[Order] = { (obj: com.faberoh.order.api.v0.models.Order) => { com.faberoh.order.api.v0.models.json.jsObjectOrder(obj) } } implicit def jsonReadsOrderApiOrderSummary: play.api.libs.json.Reads[com.faberoh.order.api.v0.models.OrderSummary] = { for { itemsTotal <- (__ \ "items_total").read[Int] shippingCharge <- (__ \ "shipping_charge").read[Int] taxes <- (__ \ "taxes").read[Int] total <- (__ \ "total").read[Int] } yield OrderSummary(itemsTotal, shippingCharge, taxes, total) } def jsObjectOrderSummary(obj: com.faberoh.order.api.v0.models.OrderSummary): play.api.libs.json.JsObject = { play.api.libs.json.Json.obj( "items_total" -> play.api.libs.json.JsNumber(obj.itemsTotal), "shipping_charge" -> play.api.libs.json.JsNumber(obj.shippingCharge), "taxes" -> play.api.libs.json.JsNumber(obj.taxes), "total" -> play.api.libs.json.JsNumber(obj.total) ) } implicit def jsonWritesOrderApiOrderSummary: play.api.libs.json.Writes[OrderSummary] = { (obj: com.faberoh.order.api.v0.models.OrderSummary) => { com.faberoh.order.api.v0.models.json.jsObjectOrderSummary(obj) } } implicit def jsonReadsOrderApiUser: play.api.libs.json.Reads[com.faberoh.order.api.v0.models.User] = { for { id <- (__ \ "id").read[_root_.java.util.UUID] email <- (__ \ "email").read[String] } yield User(id, email) } def jsObjectUser(obj: com.faberoh.order.api.v0.models.User): play.api.libs.json.JsObject = { play.api.libs.json.Json.obj( "id" -> play.api.libs.json.JsString(obj.id.toString), "email" -> play.api.libs.json.JsString(obj.email) ) } implicit def jsonWritesOrderApiUser: play.api.libs.json.Writes[User] = { (obj: com.faberoh.order.api.v0.models.User) => { com.faberoh.order.api.v0.models.json.jsObjectUser(obj) } } } } package com.faberoh.order.api.v0 { object Bindables { import play.api.mvc.{PathBindable, QueryStringBindable} // import models directly for backwards compatibility with prior versions of the generator import Core._ import Models._ object Core { implicit def pathBindableDateTimeIso8601(implicit stringBinder: QueryStringBindable[String]): PathBindable[_root_.org.joda.time.DateTime] = ApibuilderPathBindable(ApibuilderTypes.dateTimeIso8601) implicit def queryStringBindableDateTimeIso8601(implicit stringBinder: QueryStringBindable[String]): QueryStringBindable[_root_.org.joda.time.DateTime] = ApibuilderQueryStringBindable(ApibuilderTypes.dateTimeIso8601) implicit def pathBindableDateIso8601(implicit stringBinder: QueryStringBindable[String]): PathBindable[_root_.org.joda.time.LocalDate] = ApibuilderPathBindable(ApibuilderTypes.dateIso8601) implicit def queryStringBindableDateIso8601(implicit stringBinder: QueryStringBindable[String]): QueryStringBindable[_root_.org.joda.time.LocalDate] = ApibuilderQueryStringBindable(ApibuilderTypes.dateIso8601) } object Models { import com.faberoh.order.api.v0.models._ val creditCardBrandConverter: ApibuilderTypeConverter[com.faberoh.order.api.v0.models.CreditCardBrand] = new ApibuilderTypeConverter[com.faberoh.order.api.v0.models.CreditCardBrand] { override def convert(value: String): com.faberoh.order.api.v0.models.CreditCardBrand = com.faberoh.order.api.v0.models.CreditCardBrand(value) override def convert(value: com.faberoh.order.api.v0.models.CreditCardBrand): String = value.toString override def example: com.faberoh.order.api.v0.models.CreditCardBrand = com.faberoh.order.api.v0.models.CreditCardBrand.Visa override def validValues: Seq[com.faberoh.order.api.v0.models.CreditCardBrand] = com.faberoh.order.api.v0.models.CreditCardBrand.all } implicit def pathBindableCreditCardBrand(implicit stringBinder: QueryStringBindable[String]): PathBindable[com.faberoh.order.api.v0.models.CreditCardBrand] = ApibuilderPathBindable(creditCardBrandConverter) implicit def queryStringBindableCreditCardBrand(implicit stringBinder: QueryStringBindable[String]): QueryStringBindable[com.faberoh.order.api.v0.models.CreditCardBrand] = ApibuilderQueryStringBindable(creditCardBrandConverter) val orderStatusConverter: ApibuilderTypeConverter[com.faberoh.order.api.v0.models.OrderStatus] = new ApibuilderTypeConverter[com.faberoh.order.api.v0.models.OrderStatus] { override def convert(value: String): com.faberoh.order.api.v0.models.OrderStatus = com.faberoh.order.api.v0.models.OrderStatus(value) override def convert(value: com.faberoh.order.api.v0.models.OrderStatus): String = value.toString override def example: com.faberoh.order.api.v0.models.OrderStatus = com.faberoh.order.api.v0.models.OrderStatus.Open override def validValues: Seq[com.faberoh.order.api.v0.models.OrderStatus] = com.faberoh.order.api.v0.models.OrderStatus.all } implicit def pathBindableOrderStatus(implicit stringBinder: QueryStringBindable[String]): PathBindable[com.faberoh.order.api.v0.models.OrderStatus] = ApibuilderPathBindable(orderStatusConverter) implicit def queryStringBindableOrderStatus(implicit stringBinder: QueryStringBindable[String]): QueryStringBindable[com.faberoh.order.api.v0.models.OrderStatus] = ApibuilderQueryStringBindable(orderStatusConverter) } trait ApibuilderTypeConverter[T] { def convert(value: String): T def convert(value: T): String def example: T def validValues: Seq[T] = Nil def errorMessage(key: String, value: String, ex: java.lang.Exception): String = { val base = s"Invalid value '$value' for parameter '$key'. " validValues.toList match { case Nil => base + "Ex: " + convert(example) case values => base + ". Valid values are: " + values.mkString("'", "', '", "'") } } } object ApibuilderTypes { val dateTimeIso8601: ApibuilderTypeConverter[_root_.org.joda.time.DateTime] = new ApibuilderTypeConverter[_root_.org.joda.time.DateTime] { override def convert(value: String): _root_.org.joda.time.DateTime = _root_.org.joda.time.format.ISODateTimeFormat.dateTimeParser.parseDateTime(value) override def convert(value: _root_.org.joda.time.DateTime): String = _root_.org.joda.time.format.ISODateTimeFormat.dateTime.print(value) override def example: _root_.org.joda.time.DateTime = _root_.org.joda.time.DateTime.now } val dateIso8601: ApibuilderTypeConverter[_root_.org.joda.time.LocalDate] = new ApibuilderTypeConverter[_root_.org.joda.time.LocalDate] { override def convert(value: String): _root_.org.joda.time.LocalDate = _root_.org.joda.time.format.ISODateTimeFormat.dateTimeParser.parseLocalDate(value) override def convert(value: _root_.org.joda.time.LocalDate): String = _root_.org.joda.time.format.ISODateTimeFormat.date.print(value) override def example: _root_.org.joda.time.LocalDate = _root_.org.joda.time.LocalDate.now } } final case class ApibuilderQueryStringBindable[T]( converters: ApibuilderTypeConverter[T] ) extends QueryStringBindable[T] { override def bind(key: String, params: Map[String, Seq[String]]): _root_.scala.Option[_root_.scala.Either[String, T]] = { params.getOrElse(key, Nil).headOption.map { v => try { Right( converters.convert(v) ) } catch { case ex: java.lang.Exception => Left( converters.errorMessage(key, v, ex) ) } } } override def unbind(key: String, value: T): String = { s"$key=${converters.convert(value)}" } } final case class ApibuilderPathBindable[T]( converters: ApibuilderTypeConverter[T] ) extends PathBindable[T] { override def bind(key: String, value: String): _root_.scala.Either[String, T] = { try { Right( converters.convert(value) ) } catch { case ex: java.lang.Exception => Left( converters.errorMessage(key, value, ex) ) } } override def unbind(key: String, value: T): String = { converters.convert(value) } } } }