All Downloads are FREE. Search and download functionalities are using the official Maven repository.

quasar.api.QHttpService.scala Maven / Gradle / Ivy

There is a newer version: 28.1.6
Show newest version
/*
 * Copyright 2014–2017 SlamData Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package quasar.api

import slamdata.Predef.PartialFunction
import quasar.fp._
import quasar.fp.free
import quasar.fp.ski._
import org.http4s.{Request, Response, Status, HttpService}
import scalaz._
import scalaz.concurrent.Task

final case class QHttpService[S[_]] private (val f: PartialFunction[Request, Free[S, QResponse[S]]]) {
  def apply(req: Request): Free[S, QResponse[S]] =
    f.applyOrElse(req, κ(Free.pure(QResponse.empty[S].withStatus(Status.NotFound))))

  def flatMapS[T[_]](g: S ~> Free[T, ?]): QHttpService[T] =
    new QHttpService(f.andThen(_.map(_.flatMapS(g)).flatMapSuspension(g)))

  def mapS[T[_]](g: S ~> T): QHttpService[T] =
    new QHttpService(f.andThen(_.map(_.mapS(g)).mapSuspension(g)))

  def translate[T[_]](g: Free[S, ?] ~> Free[T, ?]): QHttpService[T] =
    new QHttpService(f.andThen(resp => g(resp).map(_.translate(g))))

  def orElse(other: QHttpService[S]): QHttpService[S] =
    new QHttpService(f orElse other.f)

  def toHttpService(i: S ~> ResponseOr): HttpService =
    toHttpServiceF(free.foldMapNT(i))

  def toHttpServiceF(i: Free[S, ?] ~> ResponseOr): HttpService = {
    def mkResponse(prg: Free[S, QResponse[S]]): Task[Response] =
      i(prg).map(_.toHttpResponseF(i)).merge

    HttpService(f andThen mkResponse)
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy