/** * Generated by API Builder - https://www.apibuilder.io * Service version: 1.0.1 * User agent: apibuilder app.apibuilder.io/gilt/gilt-public-api/1.0.1/play_2_9_scala_3_client */ package com.gilt.public.api.models { /** * @param name Product name * @param product URL to product object * @param id Unique identifier for product * @param brand Brand name * @param url Link to product detail page where item can be purchased * @param categories A list of categories to which this product belongs. * @param imageUrls A map of key/value pairs with the key being the image resolution WIDTHxHEIGHT * and the value being an array of image objects. * @param skus List of Skus */ final case class Product( name: String, product: String, id: Long, brand: String, url: String, content: com.gilt.public.api.models.ProductContent, categories: Seq[String], imageUrls: _root_.play.api.libs.json.JsObject, skus: Seq[com.gilt.public.api.models.Sku] ) /** * @param categories A list of categories to which this product belongs. */ final case class ProductCategories( categories: Seq[String] ) /** * @param description Product description. * @param fitNotes Sizing information. * @param material Materials list. * @param careInstructions Additional care information. * @param origin Place of manufacture. */ final case class ProductContent( description: _root_.scala.Option[String] = None, fitNotes: _root_.scala.Option[String] = None, material: _root_.scala.Option[String] = None, careInstructions: _root_.scala.Option[String] = None, origin: _root_.scala.Option[String] = None ) /** * @param name Sale name * @param sale URL to single sale object * @param saleKey unique identifier for sale * @param store Store key * @param description A description of the sale's theme or brand * @param saleUrl Permalink to sale website * @param begins ISO8601-formatted time for beginning of sale * @param ends ISO-8601-formatted time for end of sale * @param imageUrls A map of key/value pairs with the key being the image resolution WIDTHxHEIGHT * and the value being an array of image objects. * @param products List of URLs to individual product objects (not available if sale is upcoming or * sold out) */ final case class SaleDetail( name: String, sale: String, saleKey: String, store: com.gilt.public.api.models.Store, description: _root_.scala.Option[String] = None, saleUrl: String, begins: _root_.org.joda.time.DateTime, ends: _root_.scala.Option[_root_.org.joda.time.DateTime] = None, imageUrls: _root_.play.api.libs.json.JsObject, products: _root_.scala.Option[Seq[String]] = None ) /** * @param sales List of sales. */ final case class SaleList( sales: Seq[com.gilt.public.api.models.SaleDetail] ) /** * @param id The SKU unique identifier * @param inventoryStatus Describes product availability. One of: sold out, for sale or reserved. * @param msrpPrice MSRP price of SKU in US Dollars. * @param salePrice Sale price of SKU in US Dollars. * @param shippingSurcharge If absent, standard Gilt.com shipping policy and any resulting charges apply. If * present, standard shipping charge is overridden by amount listed here in US * Dollars. * @param attributes SKU attributes like color and size. */ final case class Sku( id: Long, inventoryStatus: String, msrpPrice: BigDecimal, salePrice: BigDecimal, shippingSurcharge: _root_.scala.Option[BigDecimal] = None, attributes: Seq[_root_.play.api.libs.json.JsObject] ) /** * Gilt.com is divided into stores. Currently there are four stores exposed by the * API: Women, Men, Baby & Kids and Home. */ sealed trait Store extends _root_.scala.Product with _root_.scala.Serializable object Store { case object Women extends Store { override def toString = "women" } case object Men extends Store { override def toString = "men" } case object Kids extends Store { override def toString = "kids" } case object Home extends Store { override def toString = "home" } /** * 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 to 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 Store /** * 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[Store] = scala.List(Women, Men, Kids, Home) private val byName: Map[String, Store] = all.map(x => x.toString.toLowerCase -> x).toMap def apply(value: String): Store = fromString(value).getOrElse(UNDEFINED(value)) def fromString(value: String): _root_.scala.Option[Store] = byName.get(value.toLowerCase) } } package com.gilt.public.api.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.gilt.public.api.models.json._ private[api] implicit val jsonReadsUUID: play.api.libs.json.Reads[_root_.java.util.UUID] = __.read[String].map { str => _root_.java.util.UUID.fromString(str) } private[api] 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[api] 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[api] 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[api] 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[api] 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 jsonReadsGiltPublicApiStore: play.api.libs.json.Reads[com.gilt.public.api.models.Store] = new play.api.libs.json.Reads[com.gilt.public.api.models.Store] { def reads(js: play.api.libs.json.JsValue): play.api.libs.json.JsResult[com.gilt.public.api.models.Store] = { js match { case v: play.api.libs.json.JsString => play.api.libs.json.JsSuccess(com.gilt.public.api.models.Store(v.value)) case _ => { (js \ "value").validate[String] match { case play.api.libs.json.JsSuccess(v, _) => play.api.libs.json.JsSuccess(com.gilt.public.api.models.Store(v)) case _: play.api.libs.json.JsError => (js \ "store").validate[String] match { case play.api.libs.json.JsSuccess(v, _) => play.api.libs.json.JsSuccess(com.gilt.public.api.models.Store(v)) case err: play.api.libs.json.JsError => err } } } } } } def jsonWritesGiltPublicApiStore(obj: com.gilt.public.api.models.Store) = { play.api.libs.json.JsString(obj.toString) } def jsObjectStore(obj: com.gilt.public.api.models.Store) = { play.api.libs.json.Json.obj("value" -> play.api.libs.json.JsString(obj.toString)) } implicit def jsonWritesGiltPublicApiStore: play.api.libs.json.Writes[Store] = { (obj: com.gilt.public.api.models.Store) => { com.gilt.public.api.models.json.jsonWritesGiltPublicApiStore(obj) } } implicit def jsonReadsGiltPublicApiProduct: play.api.libs.json.Reads[com.gilt.public.api.models.Product] = { for { name <- (__ \ "name").read[String] product <- (__ \ "product").read[String] id <- (__ \ "id").read[Long] brand <- (__ \ "brand").read[String] url <- (__ \ "url").read[String] content <- (__ \ "content").read[com.gilt.public.api.models.ProductContent] categories <- (__ \ "categories").read[Seq[String]] imageUrls <- (__ \ "image_urls").read[_root_.play.api.libs.json.JsObject] skus <- (__ \ "skus").read[Seq[com.gilt.public.api.models.Sku]] } yield Product(name, product, id, brand, url, content, categories, imageUrls, skus) } def jsObjectProduct(obj: com.gilt.public.api.models.Product): play.api.libs.json.JsObject = { play.api.libs.json.Json.obj( "name" -> play.api.libs.json.JsString(obj.name), "product" -> play.api.libs.json.JsString(obj.product), "id" -> play.api.libs.json.JsNumber(obj.id), "brand" -> play.api.libs.json.JsString(obj.brand), "url" -> play.api.libs.json.JsString(obj.url), "content" -> com.gilt.public.api.models.json.jsObjectProductContent(obj.content), "categories" -> play.api.libs.json.Json.toJson(obj.categories), "image_urls" -> obj.imageUrls, "skus" -> play.api.libs.json.Json.toJson(obj.skus) ) } implicit def jsonWritesGiltPublicApiProduct: play.api.libs.json.Writes[Product] = { (obj: com.gilt.public.api.models.Product) => { com.gilt.public.api.models.json.jsObjectProduct(obj) } } implicit def jsonReadsGiltPublicApiProductCategories: play.api.libs.json.Reads[com.gilt.public.api.models.ProductCategories] = { (__ \ "categories").read[Seq[String]].map { x => ProductCategories(categories = x) } } def jsObjectProductCategories(obj: com.gilt.public.api.models.ProductCategories): play.api.libs.json.JsObject = { play.api.libs.json.Json.obj( "categories" -> play.api.libs.json.Json.toJson(obj.categories) ) } implicit def jsonWritesGiltPublicApiProductCategories: play.api.libs.json.Writes[ProductCategories] = { (obj: com.gilt.public.api.models.ProductCategories) => { com.gilt.public.api.models.json.jsObjectProductCategories(obj) } } implicit def jsonReadsGiltPublicApiProductContent: play.api.libs.json.Reads[com.gilt.public.api.models.ProductContent] = { for { description <- (__ \ "description").readNullable[String] fitNotes <- (__ \ "fit_notes").readNullable[String] material <- (__ \ "material").readNullable[String] careInstructions <- (__ \ "care_instructions").readNullable[String] origin <- (__ \ "origin").readNullable[String] } yield ProductContent(description, fitNotes, material, careInstructions, origin) } def jsObjectProductContent(obj: com.gilt.public.api.models.ProductContent): play.api.libs.json.JsObject = { (obj.description match { case None => play.api.libs.json.Json.obj() case Some(x) => play.api.libs.json.Json.obj("description" -> play.api.libs.json.JsString(x)) }) ++ (obj.fitNotes match { case None => play.api.libs.json.Json.obj() case Some(x) => play.api.libs.json.Json.obj("fit_notes" -> play.api.libs.json.JsString(x)) }) ++ (obj.material match { case None => play.api.libs.json.Json.obj() case Some(x) => play.api.libs.json.Json.obj("material" -> play.api.libs.json.JsString(x)) }) ++ (obj.careInstructions match { case None => play.api.libs.json.Json.obj() case Some(x) => play.api.libs.json.Json.obj("care_instructions" -> play.api.libs.json.JsString(x)) }) ++ (obj.origin match { case None => play.api.libs.json.Json.obj() case Some(x) => play.api.libs.json.Json.obj("origin" -> play.api.libs.json.JsString(x)) }) } implicit def jsonWritesGiltPublicApiProductContent: play.api.libs.json.Writes[ProductContent] = { (obj: com.gilt.public.api.models.ProductContent) => { com.gilt.public.api.models.json.jsObjectProductContent(obj) } } implicit def jsonReadsGiltPublicApiSaleDetail: play.api.libs.json.Reads[com.gilt.public.api.models.SaleDetail] = { for { name <- (__ \ "name").read[String] sale <- (__ \ "sale").read[String] saleKey <- (__ \ "sale_key").read[String] store <- (__ \ "store").read[com.gilt.public.api.models.Store] description <- (__ \ "description").readNullable[String] saleUrl <- (__ \ "sale_url").read[String] begins <- (__ \ "begins").read[_root_.org.joda.time.DateTime] ends <- (__ \ "ends").readNullable[_root_.org.joda.time.DateTime] imageUrls <- (__ \ "image_urls").read[_root_.play.api.libs.json.JsObject] products <- (__ \ "products").readNullable[Seq[String]] } yield SaleDetail(name, sale, saleKey, store, description, saleUrl, begins, ends, imageUrls, products) } def jsObjectSaleDetail(obj: com.gilt.public.api.models.SaleDetail): play.api.libs.json.JsObject = { play.api.libs.json.Json.obj( "name" -> play.api.libs.json.JsString(obj.name), "sale" -> play.api.libs.json.JsString(obj.sale), "sale_key" -> play.api.libs.json.JsString(obj.saleKey), "store" -> play.api.libs.json.JsString(obj.store.toString), "sale_url" -> play.api.libs.json.JsString(obj.saleUrl), "begins" -> play.api.libs.json.JsString(_root_.org.joda.time.format.ISODateTimeFormat.dateTime.print(obj.begins)), "image_urls" -> obj.imageUrls ) ++ (obj.description match { case None => play.api.libs.json.Json.obj() case Some(x) => play.api.libs.json.Json.obj("description" -> play.api.libs.json.JsString(x)) }) ++ (obj.ends match { case None => play.api.libs.json.Json.obj() case Some(x) => play.api.libs.json.Json.obj("ends" -> play.api.libs.json.JsString(_root_.org.joda.time.format.ISODateTimeFormat.dateTime.print(x))) }) ++ (obj.products match { case None => play.api.libs.json.Json.obj() case Some(x) => play.api.libs.json.Json.obj("products" -> play.api.libs.json.Json.toJson(x)) }) } implicit def jsonWritesGiltPublicApiSaleDetail: play.api.libs.json.Writes[SaleDetail] = { (obj: com.gilt.public.api.models.SaleDetail) => { com.gilt.public.api.models.json.jsObjectSaleDetail(obj) } } implicit def jsonReadsGiltPublicApiSaleList: play.api.libs.json.Reads[com.gilt.public.api.models.SaleList] = { (__ \ "sales").read[Seq[com.gilt.public.api.models.SaleDetail]].map { x => SaleList(sales = x) } } def jsObjectSaleList(obj: com.gilt.public.api.models.SaleList): play.api.libs.json.JsObject = { play.api.libs.json.Json.obj( "sales" -> play.api.libs.json.Json.toJson(obj.sales) ) } implicit def jsonWritesGiltPublicApiSaleList: play.api.libs.json.Writes[SaleList] = { (obj: com.gilt.public.api.models.SaleList) => { com.gilt.public.api.models.json.jsObjectSaleList(obj) } } implicit def jsonReadsGiltPublicApiSku: play.api.libs.json.Reads[com.gilt.public.api.models.Sku] = { for { id <- (__ \ "id").read[Long] inventoryStatus <- (__ \ "inventory_status").read[String] msrpPrice <- (__ \ "msrp_price").read[BigDecimal] salePrice <- (__ \ "sale_price").read[BigDecimal] shippingSurcharge <- (__ \ "shipping_surcharge").readNullable[BigDecimal] attributes <- (__ \ "attributes").read[Seq[_root_.play.api.libs.json.JsObject]] } yield Sku(id, inventoryStatus, msrpPrice, salePrice, shippingSurcharge, attributes) } def jsObjectSku(obj: com.gilt.public.api.models.Sku): play.api.libs.json.JsObject = { play.api.libs.json.Json.obj( "id" -> play.api.libs.json.JsNumber(obj.id), "inventory_status" -> play.api.libs.json.JsString(obj.inventoryStatus), "msrp_price" -> play.api.libs.json.JsNumber(obj.msrpPrice), "sale_price" -> play.api.libs.json.JsNumber(obj.salePrice), "attributes" -> play.api.libs.json.Json.toJson(obj.attributes) ) ++ (obj.shippingSurcharge match { case None => play.api.libs.json.Json.obj() case Some(x) => play.api.libs.json.Json.obj("shipping_surcharge" -> play.api.libs.json.JsNumber(x)) }) } implicit def jsonWritesGiltPublicApiSku: play.api.libs.json.Writes[Sku] = { (obj: com.gilt.public.api.models.Sku) => { com.gilt.public.api.models.json.jsObjectSku(obj) } } } } package com.gilt.public.api { 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.gilt.public.api.models._ val storeConverter: ApibuilderTypeConverter[com.gilt.public.api.models.Store] = new ApibuilderTypeConverter[com.gilt.public.api.models.Store] { override def convert(value: String): com.gilt.public.api.models.Store = com.gilt.public.api.models.Store(value) override def convert(value: com.gilt.public.api.models.Store): String = value.toString override def example: com.gilt.public.api.models.Store = com.gilt.public.api.models.Store.Women override def validValues: Seq[com.gilt.public.api.models.Store] = com.gilt.public.api.models.Store.all } implicit def pathBindableStore(implicit stringBinder: QueryStringBindable[String]): PathBindable[com.gilt.public.api.models.Store] = ApibuilderPathBindable(storeConverter) implicit def queryStringBindableStore(implicit stringBinder: QueryStringBindable[String]): QueryStringBindable[com.gilt.public.api.models.Store] = ApibuilderQueryStringBindable(storeConverter) } 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) } } } } package com.gilt.public.api { object Constants { val BaseUrl = "https://api.gilt.com/v1" val Namespace = "com.gilt.public.api" val UserAgent = "apibuilder app.apibuilder.io/gilt/gilt-public-api/1.0.1/play_2_9_scala_3_client" val Version = "1.0.1" val VersionMajor = 1 } class Client( ws: play.api.libs.ws.WSClient, val baseUrl: String = "https://api.gilt.com/v1", auth: scala.Option[com.gilt.public.api.Authorization] = None, defaultHeaders: Seq[(String, String)] = Nil ) extends interfaces.Client { import com.gilt.public.api.models.json._ private val logger = play.api.Logger("com.gilt.public.api.Client") logger.info(s"Initializing com.gilt.public.api.Client for url $baseUrl") def products: Products = Products def saleDetails: SaleDetails = SaleDetails def saleList: SaleList = SaleList object Products extends Products { override def getDetailJsonByProductId( productId: String, apikey: String, requestHeaders: Seq[(String, String)] = Nil )(implicit ec: scala.concurrent.ExecutionContext): scala.concurrent.Future[com.gilt.public.api.models.Product] = { val queryParameters = Seq( Some("apikey" -> apikey) ).flatten _executeRequest("GET", s"/products/${play.utils.UriEncoding.encodePathSegment(productId, "UTF-8")}/detail.json", queryParameters = queryParameters, requestHeaders = requestHeaders).map { case r if r.status == 200 => _root_.com.gilt.public.api.Client.parseJson("com.gilt.public.api.models.Product", r, _.validate[com.gilt.public.api.models.Product]) case r => throw com.gilt.public.api.errors.FailedRequest(r.status, s"Unsupported response code[${r.status}]. Expected: 200") } } override def getCategoriesJson( apikey: String, requestHeaders: Seq[(String, String)] = Nil )(implicit ec: scala.concurrent.ExecutionContext): scala.concurrent.Future[com.gilt.public.api.models.ProductCategories] = { val queryParameters = Seq( Some("apikey" -> apikey) ).flatten _executeRequest("GET", s"/products/categories.json", queryParameters = queryParameters, requestHeaders = requestHeaders).map { case r if r.status == 200 => _root_.com.gilt.public.api.Client.parseJson("com.gilt.public.api.models.ProductCategories", r, _.validate[com.gilt.public.api.models.ProductCategories]) case r => throw com.gilt.public.api.errors.FailedRequest(r.status, s"Unsupported response code[${r.status}]. Expected: 200") } } } object SaleDetails extends SaleDetails { override def getDetailJson( store: com.gilt.public.api.models.Store, sale: String, apikey: String, requestHeaders: Seq[(String, String)] = Nil )(implicit ec: scala.concurrent.ExecutionContext): scala.concurrent.Future[com.gilt.public.api.models.SaleDetail] = { val queryParameters = Seq( Some("apikey" -> apikey) ).flatten _executeRequest("GET", s"/sales/${play.utils.UriEncoding.encodePathSegment(store.toString, "UTF-8")}/${play.utils.UriEncoding.encodePathSegment(sale, "UTF-8")}detail.json", queryParameters = queryParameters, requestHeaders = requestHeaders).map { case r if r.status == 200 => _root_.com.gilt.public.api.Client.parseJson("com.gilt.public.api.models.SaleDetail", r, _.validate[com.gilt.public.api.models.SaleDetail]) case r => throw com.gilt.public.api.errors.FailedRequest(r.status, s"Unsupported response code[${r.status}]. Expected: 200") } } } object SaleList extends SaleList { override def getActiveJson( apikey: String, requestHeaders: Seq[(String, String)] = Nil )(implicit ec: scala.concurrent.ExecutionContext): scala.concurrent.Future[com.gilt.public.api.models.SaleList] = { val queryParameters = Seq( Some("apikey" -> apikey) ).flatten _executeRequest("GET", s"/sales/active.json", queryParameters = queryParameters, requestHeaders = requestHeaders).map { case r if r.status == 200 => _root_.com.gilt.public.api.Client.parseJson("com.gilt.public.api.models.SaleList", r, _.validate[com.gilt.public.api.models.SaleList]) case r => throw com.gilt.public.api.errors.FailedRequest(r.status, s"Unsupported response code[${r.status}]. Expected: 200") } } override def getActiveJsonByStore( store: String, apikey: String, requestHeaders: Seq[(String, String)] = Nil )(implicit ec: scala.concurrent.ExecutionContext): scala.concurrent.Future[com.gilt.public.api.models.SaleList] = { val queryParameters = Seq( Some("apikey" -> apikey) ).flatten _executeRequest("GET", s"/sales/${play.utils.UriEncoding.encodePathSegment(store, "UTF-8")}/active.json", queryParameters = queryParameters, requestHeaders = requestHeaders).map { case r if r.status == 200 => _root_.com.gilt.public.api.Client.parseJson("com.gilt.public.api.models.SaleList", r, _.validate[com.gilt.public.api.models.SaleList]) case r => throw com.gilt.public.api.errors.FailedRequest(r.status, s"Unsupported response code[${r.status}]. Expected: 200") } } override def getUpcomingJson( apikey: String, requestHeaders: Seq[(String, String)] = Nil )(implicit ec: scala.concurrent.ExecutionContext): scala.concurrent.Future[com.gilt.public.api.models.SaleList] = { val queryParameters = Seq( Some("apikey" -> apikey) ).flatten _executeRequest("GET", s"/sales/upcoming.json", queryParameters = queryParameters, requestHeaders = requestHeaders).map { case r if r.status == 200 => _root_.com.gilt.public.api.Client.parseJson("com.gilt.public.api.models.SaleList", r, _.validate[com.gilt.public.api.models.SaleList]) case r => throw com.gilt.public.api.errors.FailedRequest(r.status, s"Unsupported response code[${r.status}]. Expected: 200") } } override def getUpcomingJsonByStore( store: String, apikey: String, requestHeaders: Seq[(String, String)] = Nil )(implicit ec: scala.concurrent.ExecutionContext): scala.concurrent.Future[com.gilt.public.api.models.SaleList] = { val queryParameters = Seq( Some("apikey" -> apikey) ).flatten _executeRequest("GET", s"/sales/${play.utils.UriEncoding.encodePathSegment(store, "UTF-8")}/upcoming.json", queryParameters = queryParameters, requestHeaders = requestHeaders).map { case r if r.status == 200 => _root_.com.gilt.public.api.Client.parseJson("com.gilt.public.api.models.SaleList", r, _.validate[com.gilt.public.api.models.SaleList]) case r => throw com.gilt.public.api.errors.FailedRequest(r.status, s"Unsupported response code[${r.status}]. Expected: 200") } } } def _requestHolder(path: String): play.api.libs.ws.WSRequest = { val holder = ws.url(baseUrl + path).addHttpHeaders( "User-Agent" -> Constants.UserAgent, "X-Apidoc-Version" -> Constants.Version, "X-Apidoc-Version-Major" -> Constants.VersionMajor.toString ).addHttpHeaders(defaultHeaders*) auth.fold(holder) { case Authorization.Basic(username, password) => { holder.withAuth(username, password.getOrElse(""), play.api.libs.ws.WSAuthScheme.BASIC) } } } def _logRequest(method: String, req: play.api.libs.ws.WSRequest): play.api.libs.ws.WSRequest = { val queryComponents = for { (name, values) <- req.queryString value <- values } yield s"$name=$value" val url = s"${req.url}${queryComponents.mkString("?", "&", "")}" auth.fold(logger.info(s"curl -X $method '$url'")) { _ => logger.info(s"curl -X $method -u '[REDACTED]:' '$url'") } req } def _executeRequest( method: String, path: String, queryParameters: Seq[(String, String)] = Nil, requestHeaders: Seq[(String, String)] = Nil, body: Option[play.api.libs.json.JsValue] = None ): scala.concurrent.Future[play.api.libs.ws.WSResponse] = { import play.api.libs.ws.WSBodyWritables.writeableOf_JsValue method.toUpperCase match { case "GET" => { _logRequest("GET", _requestHolder(path).addHttpHeaders(requestHeaders*).addQueryStringParameters(queryParameters*)).get() } case "POST" => { _logRequest("POST", _requestHolder(path).addHttpHeaders(_withJsonContentType(requestHeaders)*).addQueryStringParameters(queryParameters*)).post(body.getOrElse(play.api.libs.json.Json.obj())) } case "PUT" => { _logRequest("PUT", _requestHolder(path).addHttpHeaders(_withJsonContentType(requestHeaders)*).addQueryStringParameters(queryParameters*)).put(body.getOrElse(play.api.libs.json.Json.obj())) } case "PATCH" => { _logRequest("PATCH", _requestHolder(path).addHttpHeaders(requestHeaders*).addQueryStringParameters(queryParameters*)).patch(body.getOrElse(play.api.libs.json.Json.obj())) } case "DELETE" => { _logRequest("DELETE", _requestHolder(path).addHttpHeaders(requestHeaders*).addQueryStringParameters(queryParameters*)).delete() } case "HEAD" => { _logRequest("HEAD", _requestHolder(path).addHttpHeaders(requestHeaders*).addQueryStringParameters(queryParameters*)).head() } case "OPTIONS" => { _logRequest("OPTIONS", _requestHolder(path).addHttpHeaders(requestHeaders*).addQueryStringParameters(queryParameters*)).options() } case _ => { _logRequest(method, _requestHolder(path).addHttpHeaders(requestHeaders*).addQueryStringParameters(queryParameters*)) sys.error("Unsupported method[%s]".format(method)) } } } /** * Adds a Content-Type: application/json header unless the specified requestHeaders * already contain a Content-Type header */ def _withJsonContentType(headers: Seq[(String, String)]): Seq[(String, String)] = { headers.find { _._1.toUpperCase == "CONTENT-TYPE" } match { case None => headers ++ Seq("Content-Type" -> "application/json; charset=UTF-8") case Some(_) => headers } } } object Client { def parseJson[T]( className: String, r: play.api.libs.ws.WSResponse, f: (play.api.libs.json.JsValue => play.api.libs.json.JsResult[T]) ): T = { f(play.api.libs.json.Json.parse(r.body)) match { case play.api.libs.json.JsSuccess(x, _) => x case play.api.libs.json.JsError(errors) => { throw com.gilt.public.api.errors.FailedRequest(r.status, s"Invalid json for class[" + className + "]: " + errors.mkString(" ")) } } } } sealed trait Authorization extends _root_.scala.Product with _root_.scala.Serializable object Authorization { final case class Basic(username: String, password: Option[String] = None) extends Authorization } package interfaces { trait Client { def baseUrl: String def products: com.gilt.public.api.Products def saleDetails: com.gilt.public.api.SaleDetails def saleList: com.gilt.public.api.SaleList } } trait Products { def getDetailJsonByProductId( productId: String, apikey: String, requestHeaders: Seq[(String, String)] = Nil )(implicit ec: scala.concurrent.ExecutionContext): scala.concurrent.Future[com.gilt.public.api.models.Product] def getCategoriesJson( apikey: String, requestHeaders: Seq[(String, String)] = Nil )(implicit ec: scala.concurrent.ExecutionContext): scala.concurrent.Future[com.gilt.public.api.models.ProductCategories] } trait SaleDetails { def getDetailJson( store: com.gilt.public.api.models.Store, sale: String, apikey: String, requestHeaders: Seq[(String, String)] = Nil )(implicit ec: scala.concurrent.ExecutionContext): scala.concurrent.Future[com.gilt.public.api.models.SaleDetail] } trait SaleList { def getActiveJson( apikey: String, requestHeaders: Seq[(String, String)] = Nil )(implicit ec: scala.concurrent.ExecutionContext): scala.concurrent.Future[com.gilt.public.api.models.SaleList] def getActiveJsonByStore( store: String, apikey: String, requestHeaders: Seq[(String, String)] = Nil )(implicit ec: scala.concurrent.ExecutionContext): scala.concurrent.Future[com.gilt.public.api.models.SaleList] def getUpcomingJson( apikey: String, requestHeaders: Seq[(String, String)] = Nil )(implicit ec: scala.concurrent.ExecutionContext): scala.concurrent.Future[com.gilt.public.api.models.SaleList] def getUpcomingJsonByStore( store: String, apikey: String, requestHeaders: Seq[(String, String)] = Nil )(implicit ec: scala.concurrent.ExecutionContext): scala.concurrent.Future[com.gilt.public.api.models.SaleList] } package errors { final case class FailedRequest(responseCode: Int, message: String, requestUri: Option[_root_.java.net.URI] = None) extends _root_.java.lang.Exception(s"HTTP $responseCode: $message") } }