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

sttp.client.asynchttpclient.zio.package.scala Maven / Gradle / Ivy

The newest version!
package sttp.client.asynchttpclient

import sttp.client._
import _root_.zio._
import sttp.capabilities.zio.ZioStreams
import sttp.capabilities.{Effect, WebSockets}
import sttp.client.impl.zio.{ExtendEnv, SttpClientStubbingBase}

package object zio {

  /**
    * ZIO-environment service definition, which is an SttpBackend.
    */
  type SttpClient = Has[SttpClient.Service]
  type SttpClientStubbing = Has[SttpClientStubbing.Service]

  object SttpClient {
    type Service = SttpBackend[Task, ZioStreams with WebSockets]
  }

  /**
    * Sends the request. Only requests for which the method & URI are specified can be sent.
    *
    * @return An effect resulting in a [[Response]], containing the body, deserialized as specified by the request
    *         (see [[RequestT.response]]), if the request was successful (1xx, 2xx, 3xx response codes), or if there
    *         was a protocol-level failure (4xx, 5xx response codes).
    *
    *         A failed effect, if an exception occurred when connecting to the target host, writing the request or
    *         reading the response.
    *
    *         Known exceptions are converted to one of [[SttpClientException]]. Other exceptions are kept unchanged.
    */
  def send[T](
      request: Request[T, Effect[Task] with ZioStreams with WebSockets]
  ): ZIO[SttpClient, Throwable, Response[T]] =
    ZIO.accessM(env => env.get[SttpClient.Service].send(request))

  /**
    * A variant of [[send]] which allows the effects that are part of the response handling specification (when
    * using websockets or resource-safe streaming) to use an `R` environment.
    */
  def sendR[T, R](
      request: Request[T, Effect[RIO[R, *]] with ZioStreams with WebSockets]
  ): ZIO[SttpClient with R, Throwable, Response[T]] =
    ZIO.accessM(env => env.get[SttpClient.Service].extendEnv[R].send(request))

  object SttpClientStubbing extends SttpClientStubbingBase[Any, ZioStreams with WebSockets] {
    override private[sttp] def serviceTag: Tag[SttpClientStubbing.Service] = implicitly
    override private[sttp] def sttpBackendTag: Tag[SttpClient.Service] = implicitly
  }

  object stubbing {
    import SttpClientStubbing.StubbingWhenRequest

    def whenRequestMatches(p: Request[_, _] => Boolean): StubbingWhenRequest =
      StubbingWhenRequest(p)

    val whenAnyRequest: StubbingWhenRequest =
      StubbingWhenRequest(_ => true)

    def whenRequestMatchesPartial(
        partial: PartialFunction[Request[_, _], Response[_]]
    ): URIO[SttpClientStubbing, Unit] =
      ZIO.accessM(_.get.whenRequestMatchesPartial(partial))
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy