/** * Generated by API Builder - https://www.apibuilder.io * Service version: 0.0.6-dev * User agent: apibuilder app.apibuilder.io/danitest/competition-api/0.0.6-dev/http4s_0_15 */ package namespace.server import org.http4s.dsl._ import namespace.models.json._ private[server] object Matchers { implicit lazy val queryParamDecodeBigDecimal: org.http4s.QueryParamDecoder[BigDecimal] = org.http4s.QueryParamDecoder.fromUnsafeCast[BigDecimal](p => BigDecimal(p.value))("BigDecimal") implicit lazy val queryParamDecodeInstant: org.http4s.QueryParamDecoder[_root_.java.time.Instant] = org.http4s.QueryParamDecoder.fromUnsafeCast[_root_.java.time.Instant](p => _root_.java.time.OffsetDateTime.parse(p.value).toInstant)("_root_.java.time.Instant") implicit lazy val queryParamDecodeLocalDate: org.http4s.QueryParamDecoder[_root_.java.time.LocalDate] = org.http4s.QueryParamDecoder.fromUnsafeCast[_root_.java.time.LocalDate](p => _root_.java.time.LocalDate.parse(p.value))("_root_.java.time.LocalDate") implicit lazy val queryParamDecodeUUID: org.http4s.QueryParamDecoder[_root_.java.util.UUID] = org.http4s.QueryParamDecoder.fromUnsafeCast[_root_.java.util.UUID](p => _root_.java.util.UUID.fromString(p.value))("_root_.java.util.UUID") object ApiVersion { val ApiVersionMajor = { "X-Apidoc-Version-Major".ci } def apply(req: org.http4s.Message): Boolean = req.headers.get(ApiVersionMajor) match { case Some(v) if v.value == "0" => true case _ => false } } } trait CompetitionRoutes { import Matchers._ implicit def circeJsonDecoder[A](implicit decoder: _root_.io.circe.Decoder[A]) = org.http4s.circe.jsonOf[A] implicit def circeJsonEncoder[A](implicit encoder: _root_.io.circe.Encoder[A]) = org.http4s.circe.jsonEncoderOf[A] sealed trait PostResponse object PostResponse { case class HTTP201(value: namespace.models.Competition, headers: Seq[org.http4s.Header] = Nil) extends PostResponse case class UndocumentedResponse(response: scalaz.concurrent.Task[org.http4s.Response]) extends PostResponse } def post( _req: org.http4s.Request, body: => org.http4s.DecodeResult[namespace.models.Competition] ): scalaz.concurrent.Task[PostResponse] sealed trait GetByIdResponse object GetByIdResponse { case class HTTP200(value: namespace.models.Competition, headers: Seq[org.http4s.Header] = Nil) extends GetByIdResponse case class UndocumentedResponse(response: scalaz.concurrent.Task[org.http4s.Response]) extends GetByIdResponse } def getById( _req: org.http4s.Request, id: String ): scalaz.concurrent.Task[GetByIdResponse] def apiVersionMatch(req: org.http4s.Message): Boolean = ApiVersion(req) def service() = org.http4s.HttpService { case _req @ POST -> Root / "competitions" if apiVersionMatch(_req) => post(_req, _req.attemptAs[namespace.models.Competition]).flatMap { case PostResponse.HTTP201(value, headers) => Created(value).putHeaders(headers: _*) case PostResponse.UndocumentedResponse(response) => response } case _req @ POST -> Root / "competitions" if !_req.headers.get(ApiVersion.ApiVersionMajor).isDefined => BadRequest(s"Missing required request header: ${ApiVersion.ApiVersionMajor}.") case _req @ GET -> Root / "competitions" / id if apiVersionMatch(_req) => getById(_req, id).flatMap { case GetByIdResponse.HTTP200(value, headers) => Ok(value).putHeaders(headers: _*) case GetByIdResponse.UndocumentedResponse(response) => response } case _req @ GET -> Root / "competitions" / id if !_req.headers.get(ApiVersion.ApiVersionMajor).isDefined => BadRequest(s"Missing required request header: ${ApiVersion.ApiVersionMajor}.") } } trait CompetitorRoutes { import Matchers._ implicit def circeJsonDecoder[A](implicit decoder: _root_.io.circe.Decoder[A]) = org.http4s.circe.jsonOf[A] implicit def circeJsonEncoder[A](implicit encoder: _root_.io.circe.Encoder[A]) = org.http4s.circe.jsonEncoderOf[A] sealed trait PostResponse object PostResponse { case class HTTP201(value: namespace.models.Competitor, headers: Seq[org.http4s.Header] = Nil) extends PostResponse case class UndocumentedResponse(response: scalaz.concurrent.Task[org.http4s.Response]) extends PostResponse } def post( _req: org.http4s.Request, body: => org.http4s.DecodeResult[namespace.models.Competitor] ): scalaz.concurrent.Task[PostResponse] sealed trait GetByIdResponse object GetByIdResponse { case class HTTP200(value: namespace.models.Competitor, headers: Seq[org.http4s.Header] = Nil) extends GetByIdResponse case class UndocumentedResponse(response: scalaz.concurrent.Task[org.http4s.Response]) extends GetByIdResponse } def getById( _req: org.http4s.Request, id: String ): scalaz.concurrent.Task[GetByIdResponse] def apiVersionMatch(req: org.http4s.Message): Boolean = ApiVersion(req) def service() = org.http4s.HttpService { case _req @ POST -> Root / "competitors" if apiVersionMatch(_req) => post(_req, _req.attemptAs[namespace.models.Competitor]).flatMap { case PostResponse.HTTP201(value, headers) => Created(value).putHeaders(headers: _*) case PostResponse.UndocumentedResponse(response) => response } case _req @ POST -> Root / "competitors" if !_req.headers.get(ApiVersion.ApiVersionMajor).isDefined => BadRequest(s"Missing required request header: ${ApiVersion.ApiVersionMajor}.") case _req @ GET -> Root / "competitors" / id if apiVersionMatch(_req) => getById(_req, id).flatMap { case GetByIdResponse.HTTP200(value, headers) => Ok(value).putHeaders(headers: _*) case GetByIdResponse.UndocumentedResponse(response) => response } case _req @ GET -> Root / "competitors" / id if !_req.headers.get(ApiVersion.ApiVersionMajor).isDefined => BadRequest(s"Missing required request header: ${ApiVersion.ApiVersionMajor}.") } }