/** * 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/http4s_0_18 */ package com.faberoh.order.api.v0.models { package object json { import io.circe.Decoder._ import io.circe.Encoder._ import scala.language.implicitConversions // See below - Make Scala 2.11 Either monadic import scala.util.Try import io.circe.{Json, JsonObject, Encoder, Decoder, DecodingFailure} import io.circe.syntax._ import com.faberoh.order.api.v0.models.json._ // Make Scala 2.11 Either monadic private[v0] implicit def eitherOps[A,B](e: Either[A,B]) = cats.implicits.catsSyntaxEither(e) private[v0] implicit val decodeUUID: Decoder[_root_.java.util.UUID] = Decoder.decodeString.emapTry(str => Try(_root_.java.util.UUID.fromString(str))) private[v0] implicit val encodeUUID: Encoder[_root_.java.util.UUID] = Encoder.encodeString.contramap[_root_.java.util.UUID](uuid => uuid.toString) private[v0] implicit val decodeInstant: Decoder[_root_.java.time.Instant] = Decoder.decodeString.emapTry(str => Try(_root_.java.time.OffsetDateTime.parse(str).toInstant)) private[v0] implicit val encodeInstant: Encoder[_root_.java.time.Instant] = Encoder.encodeString.contramap[_root_.java.time.Instant](_.toString) private[v0] implicit val decodeLocalDate: Decoder[_root_.java.time.LocalDate] = Decoder.decodeString.emapTry(str => Try(_root_.java.time.LocalDate.parse(str))) private[v0] implicit val encodeLocalDate: Encoder[_root_.java.time.LocalDate] = Encoder.encodeString.contramap[_root_.java.time.LocalDate](_.toString) implicit val jsonDecoderOrderApiCreditCardBrand: Decoder[com.faberoh.order.api.v0.models.CreditCardBrand] = Decoder.decodeString.map(com.faberoh.order.api.v0.models.CreditCardBrand(_)) implicit val jsonEncoderOrderApiCreditCardBrand: Encoder[com.faberoh.order.api.v0.models.CreditCardBrand] = Encoder.encodeString.contramap[com.faberoh.order.api.v0.models.CreditCardBrand](_.toString) implicit val jsonDecoderOrderApiOrderStatus: Decoder[com.faberoh.order.api.v0.models.OrderStatus] = Decoder.decodeString.map(com.faberoh.order.api.v0.models.OrderStatus(_)) implicit val jsonEncoderOrderApiOrderStatus: Encoder[com.faberoh.order.api.v0.models.OrderStatus] = Encoder.encodeString.contramap[com.faberoh.order.api.v0.models.OrderStatus](_.toString) implicit def decodeOrderApiAddress: Decoder[Address] = Decoder.instance { c => for { firstName <- c.downField("first_name").as[String] lastName <- c.downField("last_name").as[String] line1 <- c.downField("line1").as[String] line2 <- c.downField("line2").as[Option[String]] zip <- c.downField("zip").as[String] city <- c.downField("city").as[String] state <- c.downField("state").as[String] countryCode <- c.downField("country_code").as[String] } yield { Address( firstName = firstName, lastName = lastName, line1 = line1, line2 = line2, zip = zip, city = city, state = state, countryCode = countryCode ) } } implicit def encodeOrderApiAddress: Encoder[Address] = Encoder.instance { t => Json.fromFields(Seq( Some("first_name" -> t.firstName.asJson), Some("last_name" -> t.lastName.asJson), Some("line1" -> t.line1.asJson), t.line2.map(t => "line2" -> t.asJson), Some("zip" -> t.zip.asJson), Some("city" -> t.city.asJson), Some("state" -> t.state.asJson), Some("country_code" -> t.countryCode.asJson) ).flatten) } implicit def decodeOrderApiCreditCard: Decoder[CreditCard] = Decoder.instance { c => for { number <- c.downField("number").as[String] expirationMonth <- c.downField("expiration_month").as[Int] expirationYear <- c.downField("expiration_year").as[Int] securityCode <- c.downField("security_code").as[String] brand <- c.downField("brand").as[com.faberoh.order.api.v0.models.CreditCardBrand] holderName <- c.downField("holder_name").as[String] } yield { CreditCard( number = number, expirationMonth = expirationMonth, expirationYear = expirationYear, securityCode = securityCode, brand = brand, holderName = holderName ) } } implicit def encodeOrderApiCreditCard: Encoder[CreditCard] = Encoder.instance { t => Json.fromFields(Seq( Some("number" -> t.number.asJson), Some("expiration_month" -> t.expirationMonth.asJson), Some("expiration_year" -> t.expirationYear.asJson), Some("security_code" -> t.securityCode.asJson), Some("brand" -> t.brand.asJson), Some("holder_name" -> t.holderName.asJson) ).flatten) } implicit def decodeOrderApiItem: Decoder[Item] = Decoder.instance { c => for { upc <- c.downField("upc").as[String] quantity <- c.downField("quantity").as[Int] } yield { Item( upc = upc, quantity = quantity ) } } implicit def encodeOrderApiItem: Encoder[Item] = Encoder.instance { t => Json.fromFields(Seq( Some("upc" -> t.upc.asJson), Some("quantity" -> t.quantity.asJson) ).flatten) } implicit def decodeOrderApiOrder: Decoder[Order] = Decoder.instance { c => for { id <- c.downField("id").as[_root_.java.util.UUID] user <- c.downField("user").as[com.faberoh.order.api.v0.models.User] status <- c.downField("status").as[com.faberoh.order.api.v0.models.OrderStatus] items <- c.downField("items").as[Seq[com.faberoh.order.api.v0.models.Item]] billingAddress <- c.downField("billing_address").as[com.faberoh.order.api.v0.models.Address] shippingAddress <- c.downField("shipping_address").as[com.faberoh.order.api.v0.models.Address] creditCard <- c.downField("credit_card").as[com.faberoh.order.api.v0.models.CreditCard] summary <- c.downField("summary").as[com.faberoh.order.api.v0.models.OrderSummary] } yield { Order( id = id, user = user, status = status, items = items, billingAddress = billingAddress, shippingAddress = shippingAddress, creditCard = creditCard, summary = summary ) } } implicit def encodeOrderApiOrder: Encoder[Order] = Encoder.instance { t => Json.fromFields(Seq( Some("id" -> t.id.asJson), Some("user" -> t.user.asJson), Some("status" -> t.status.asJson), Some("items" -> t.items.asJson), Some("billing_address" -> t.billingAddress.asJson), Some("shipping_address" -> t.shippingAddress.asJson), Some("credit_card" -> t.creditCard.asJson), Some("summary" -> t.summary.asJson) ).flatten) } implicit def decodeOrderApiOrderSummary: Decoder[OrderSummary] = Decoder.instance { c => for { itemsTotal <- c.downField("items_total").as[Int] shippingCharge <- c.downField("shipping_charge").as[Int] taxes <- c.downField("taxes").as[Int] total <- c.downField("total").as[Int] } yield { OrderSummary( itemsTotal = itemsTotal, shippingCharge = shippingCharge, taxes = taxes, total = total ) } } implicit def encodeOrderApiOrderSummary: Encoder[OrderSummary] = Encoder.instance { t => Json.fromFields(Seq( Some("items_total" -> t.itemsTotal.asJson), Some("shipping_charge" -> t.shippingCharge.asJson), Some("taxes" -> t.taxes.asJson), Some("total" -> t.total.asJson) ).flatten) } implicit def decodeOrderApiUser: Decoder[User] = Decoder.instance { c => for { id <- c.downField("id").as[_root_.java.util.UUID] email <- c.downField("email").as[String] } yield { User( id = id, email = email ) } } implicit def encodeOrderApiUser: Encoder[User] = Encoder.instance { t => Json.fromFields(Seq( Some("id" -> t.id.asJson), Some("email" -> t.email.asJson) ).flatten) } } }