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