All Downloads are FREE. Search and download functionalities are using the official Maven repository.
Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
sttp.client3.okhttp.OkHttpAsyncBackend.scala Maven / Gradle / Ivy
package sttp.client3.okhttp
import java.io.IOException
import java.util.concurrent.atomic.AtomicBoolean
import okhttp3.{Call, Callback, OkHttpClient, Response => OkHttpResponse, WebSocket => OkHttpWebSocket}
import sttp.capabilities.Streams
import sttp.client3.internal.ws.{SimpleQueue, WebSocketEvent}
import sttp.monad.syntax._
import sttp.client3.okhttp.OkHttpBackend.EncodingHandler
import sttp.client3.{Request, Response, ignore}
import sttp.monad.{Canceler, MonadAsyncError}
abstract class OkHttpAsyncBackend[F[_], S <: Streams[S], P](
client: OkHttpClient,
monad: MonadAsyncError[F],
closeClient: Boolean,
customEncodingHandler: EncodingHandler
) extends OkHttpBackend[F, S, P](client, closeClient, customEncodingHandler) {
override protected def sendRegular[T, R >: PE](request: Request[T, R]): F[Response[T]] = {
val nativeRequest = convertRequest(request)
monad.flatten(monad.async[F[Response[T]]] { cb =>
def success(r: F[Response[T]]): Unit = cb(Right(r))
def error(t: Throwable): Unit = cb(Left(t))
val call = OkHttpBackend
.updateClientIfCustomReadTimeout(request, client)
.newCall(nativeRequest)
call.enqueue(new Callback {
override def onFailure(call: Call, e: IOException): Unit =
error(e)
override def onResponse(call: Call, response: OkHttpResponse): Unit =
try success(readResponse(response, request))
catch {
case e: Exception =>
response.close()
error(e)
}
})
Canceler(() => call.cancel())
})
}
override protected def sendWebSocket[T, R >: PE](
request: Request[T, R]
): F[Response[T]] = {
val nativeRequest = convertRequest(request)
monad.flatten(
createSimpleQueue[WebSocketEvent]
.flatMap { queue =>
monad.async[F[Response[T]]] { cb =>
val listener = createListener(queue, cb, request)
val ws = OkHttpBackend
.updateClientIfCustomReadTimeout(request, client)
.newWebSocket(nativeRequest, listener)
Canceler(() => ws.cancel())
}
}
)
}
private def createListener[R >: PE, T](
queue: SimpleQueue[F, WebSocketEvent],
cb: Either[Throwable, F[Response[T]]] => Unit,
request: Request[T, R]
): DelegatingWebSocketListener = {
val isOpen = new AtomicBoolean(false)
val addToQueue = new AddToQueueListener(queue, isOpen)
def onOpen(nativeWs: OkHttpWebSocket, response: OkHttpResponse) = {
val webSocket = new WebSocketImpl(nativeWs, queue, isOpen, response.headers())
val wsResponse = readResponse(response, request.response(ignore))
.flatMap { baseResponse =>
bodyFromOkHttp(
response.body().byteStream(),
request.response,
baseResponse,
Some(webSocket)
).map(b => baseResponse.copy(body = b))
}
cb(Right(wsResponse))
}
def onError(e: Throwable) = cb(Left(e))
new DelegatingWebSocketListener(
addToQueue,
onOpen,
onError
)
}
override implicit val responseMonad: MonadAsyncError[F] = monad
}