/** * Generated by API Builder - https://www.apibuilder.io * Service version: 0.0.1 * apibuilder 0.15.11 app.apibuilder.io/edsancha/survey-models/0.0.1/play_2_2_client */ package com.edsancha.survey.models.v0.models { sealed trait Component extends _root_.scala.Product with _root_.scala.Serializable object Component { case object Label extends Component { override def toString = "label" } case object Image extends Component { override def toString = "image" } case object Nps extends Component { override def toString = "nps" } case object TextArea extends Component { override def toString = "textArea" } case object TextInput extends Component { override def toString = "textInput" } case object Radio extends Component { override def toString = "radio" } case object Checkbox extends Component { override def toString = "checkbox" } case object Grading extends Component { override def toString = "grading" } case object Grading0to10 extends Component { override def toString = "grading0to10" } case object Grading1to10 extends Component { override def toString = "grading1to10" } /** * 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 Component /** * 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[Component] = scala.List(Label, Image, Nps, TextArea, TextInput, Radio, Checkbox, Grading, Grading0to10, Grading1to10) private[this] val byName: Map[String, Component] = all.map(x => x.toString.toLowerCase -> x).toMap def apply(value: String): Component = fromString(value).getOrElse(UNDEFINED(value)) def fromString(value: String): _root_.scala.Option[Component] = byName.get(value.toLowerCase) } } package com.edsancha.survey.models.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.edsancha.survey.models.v0.models.json._ private[v0] implicit val jsonReadsUUID = __.read[String].map { str => _root_.java.util.UUID.fromString(str) } private[v0] implicit val jsonWritesUUID = new Writes[_root_.java.util.UUID] { def writes(x: _root_.java.util.UUID) = JsString(x.toString) } private[v0] implicit val jsonReadsJodaDateTime = __.read[String].map { str => _root_.org.joda.time.format.ISODateTimeFormat.dateTimeParser.parseDateTime(str) } private[v0] implicit val jsonWritesJodaDateTime = new Writes[_root_.org.joda.time.DateTime] { def writes(x: _root_.org.joda.time.DateTime) = { JsString(_root_.org.joda.time.format.ISODateTimeFormat.dateTime.print(x)) } } private[v0] implicit val jsonReadsJodaLocalDate = __.read[String].map { str => _root_.org.joda.time.format.ISODateTimeFormat.dateTimeParser.parseLocalDate(str) } private[v0] implicit val jsonWritesJodaLocalDate = new Writes[_root_.org.joda.time.LocalDate] { def writes(x: _root_.org.joda.time.LocalDate) = { JsString(_root_.org.joda.time.format.ISODateTimeFormat.date.print(x)) } } implicit val jsonReadsSurveyModelsComponent = new play.api.libs.json.Reads[com.edsancha.survey.models.v0.models.Component] { def reads(js: play.api.libs.json.JsValue): play.api.libs.json.JsResult[com.edsancha.survey.models.v0.models.Component] = { js match { case v: play.api.libs.json.JsString => play.api.libs.json.JsSuccess(com.edsancha.survey.models.v0.models.Component(v.value)) case _ => { (js \ "value").validate[String] match { case play.api.libs.json.JsSuccess(v, _) => play.api.libs.json.JsSuccess(com.edsancha.survey.models.v0.models.Component(v)) case err: play.api.libs.json.JsError => (js \ "component").validate[String] match { case play.api.libs.json.JsSuccess(v, _) => play.api.libs.json.JsSuccess(com.edsancha.survey.models.v0.models.Component(v)) case err: play.api.libs.json.JsError => err } } } } } } def jsonWritesSurveyModelsComponent(obj: com.edsancha.survey.models.v0.models.Component) = { play.api.libs.json.JsString(obj.toString) } def jsObjectComponent(obj: com.edsancha.survey.models.v0.models.Component) = { play.api.libs.json.Json.obj("value" -> play.api.libs.json.JsString(obj.toString)) } implicit def jsonWritesSurveyModelsComponent: play.api.libs.json.Writes[Component] = { new play.api.libs.json.Writes[com.edsancha.survey.models.v0.models.Component] { def writes(obj: com.edsancha.survey.models.v0.models.Component) = { jsonWritesSurveyModelsComponent(obj) } } } } } package com.edsancha.survey.models.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.edsancha.survey.models.v0.models._ val componentConverter: ApibuilderTypeConverter[com.edsancha.survey.models.v0.models.Component] = new ApibuilderTypeConverter[com.edsancha.survey.models.v0.models.Component] { override def convert(value: String): com.edsancha.survey.models.v0.models.Component = com.edsancha.survey.models.v0.models.Component(value) override def convert(value: com.edsancha.survey.models.v0.models.Component): String = value.toString override def example: com.edsancha.survey.models.v0.models.Component = com.edsancha.survey.models.v0.models.Component.Label override def validValues: Seq[com.edsancha.survey.models.v0.models.Component] = com.edsancha.survey.models.v0.models.Component.all } implicit def pathBindableComponent(implicit stringBinder: QueryStringBindable[String]): PathBindable[com.edsancha.survey.models.v0.models.Component] = ApibuilderPathBindable(componentConverter) implicit def queryStringBindableComponent(implicit stringBinder: QueryStringBindable[String]): QueryStringBindable[com.edsancha.survey.models.v0.models.Component] = ApibuilderQueryStringBindable(componentConverter) } 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.edsancha.survey.models.v0 { object Constants { val BaseUrl = "https://api-us.kampyle.com/api/v1" val Namespace = "com.edsancha.survey.models.v0" val UserAgent = "apibuilder 0.15.11 app.apibuilder.io/edsancha/survey-models/0.0.1/play_2_2_client" val Version = "0.0.1" val VersionMajor = 0 } class Client( val baseUrl: String = "https://api-us.kampyle.com/api/v1", auth: scala.Option[com.edsancha.survey.models.v0.Authorization] = None, defaultHeaders: Seq[(String, String)] = Nil ) extends interfaces.Client { import com.edsancha.survey.models.v0.models.json._ private[this] val logger = play.api.Logger("com.edsancha.survey.models.v0.Client") logger.info(s"Initializing com.edsancha.survey.models.v0.Client for url $baseUrl") def _requestHolder(path: String): play.api.libs.ws.WS.WSRequestHolder = { import play.api.Play.current val holder = play.api.libs.ws.WS.url(baseUrl + path).withHeaders( "User-Agent" -> Constants.UserAgent, "X-Apidoc-Version" -> Constants.Version, "X-Apidoc-Version-Major" -> Constants.VersionMajor.toString ).withHeaders(defaultHeaders : _*) auth.fold(holder) { case Authorization.Basic(username, password) => { holder.withAuth(username, password.getOrElse(""), com.ning.http.client.Realm.AuthScheme.BASIC) } case a => sys.error("Invalid authorization scheme[" + a.getClass + "]") } } def _logRequest(method: String, req: play.api.libs.ws.WS.WSRequestHolder): play.api.libs.ws.WS.WSRequestHolder = { 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.Response] = { method.toUpperCase match { case "GET" => { _logRequest("GET", _requestHolder(path).withHeaders(requestHeaders:_*).withQueryString(queryParameters:_*)).get() } case "POST" => { _logRequest("POST", _requestHolder(path).withHeaders(_withJsonContentType(requestHeaders):_*).withQueryString(queryParameters:_*)).post(body.getOrElse(play.api.libs.json.Json.obj())) } case "PUT" => { _logRequest("PUT", _requestHolder(path).withHeaders(_withJsonContentType(requestHeaders):_*).withQueryString(queryParameters:_*)).put(body.getOrElse(play.api.libs.json.Json.obj())) } case "PATCH" => { sys.error("PATCH method is not supported in Play Framework Version 2.2.x") } case "DELETE" => { _logRequest("DELETE", _requestHolder(path).withHeaders(requestHeaders:_*).withQueryString(queryParameters:_*)).delete() } case "HEAD" => { _logRequest("HEAD", _requestHolder(path).withHeaders(requestHeaders:_*).withQueryString(queryParameters:_*)).head() } case "OPTIONS" => { _logRequest("OPTIONS", _requestHolder(path).withHeaders(requestHeaders:_*).withQueryString(queryParameters:_*)).options() } case _ => { _logRequest(method, _requestHolder(path).withHeaders(requestHeaders:_*).withQueryString(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.Response, 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.edsancha.survey.models.v0.errors.FailedRequest(r.status, s"Invalid json for class[" + className + "]: " + errors.mkString(" "), requestUri = Some(r.ahcResponse.getUri)) } } } } 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 } } 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") } }