diff options
Diffstat (limited to 'akka-http-handler')
-rw-r--r-- | akka-http-handler/src/main/scala/com/softwaremill/sttp/akkahttp/AkkaHttpSttpHandler.scala | 51 | ||||
-rw-r--r-- | akka-http-handler/src/main/scala/com/softwaremill/sttp/akkahttp/package.scala | 14 |
2 files changed, 29 insertions, 36 deletions
diff --git a/akka-http-handler/src/main/scala/com/softwaremill/sttp/akkahttp/AkkaHttpSttpHandler.scala b/akka-http-handler/src/main/scala/com/softwaremill/sttp/akkahttp/AkkaHttpSttpHandler.scala index e167dd5..60d5686 100644 --- a/akka-http-handler/src/main/scala/com/softwaremill/sttp/akkahttp/AkkaHttpSttpHandler.scala +++ b/akka-http-handler/src/main/scala/com/softwaremill/sttp/akkahttp/AkkaHttpSttpHandler.scala @@ -7,7 +7,7 @@ import akka.http.scaladsl.model._ import akka.stream.ActorMaterializer import akka.stream.scaladsl.Source import akka.util.ByteString -import com.softwaremill.sttp.{IgnoreResponseBody, Method, Request, Response, ResponseBodyReader, SttpStreamHandler} +import com.softwaremill.sttp._ import scala.concurrent.Future @@ -18,23 +18,28 @@ class AkkaHttpSttpHandler(actorSystem: ActorSystem) extends SttpStreamHandler[Fu private implicit val materializer = ActorMaterializer() import as.dispatcher - override def send[T](r: Request, responseReader: ResponseBodyReader[T]): Future[Response[T]] = { - requestToAkka(r).flatMap { ar => - Http().singleRequest(ar).flatMap { hr => - val code = hr.status.intValue() - bodyFromAkkaResponse(responseReader, hr).map(Response(code, _)) - } + override def send[T](r: Request, responseAs: ResponseAs[T]): Future[Response[T]] = { + requestToAkka(r).flatMap(Http().singleRequest(_)).flatMap { hr => + val code = hr.status.intValue() + bodyFromAkkaResponse(responseAs, hr).map(Response(code, _)) + } + } + + override def send[T](r: Request, responseAsStream: ResponseAsStream[Source[ByteString, Any]]): Future[Response[Source[ByteString, Any]]] = { + requestToAkka(r).flatMap(Http().singleRequest(_)).map { hr => + val code = hr.status.intValue() + Response(code, hr.entity.dataBytes) } } override def sendStream[T](r: Request, contentType: String, stream: Source[ByteString, Any], - responseReader: ResponseBodyReader[T]): Future[Response[T]] = { + responseAs: ResponseAs[T]): Future[Response[T]] = { for { ar <- requestToAkka(r) ct <- contentTypeToAkka(contentType) hr <- Http().singleRequest(ar.withEntity(HttpEntity(ct, stream))) - body <- bodyFromAkkaResponse(responseReader, hr) + body <- bodyFromAkkaResponse(responseAs, hr) } yield Response(hr.status.intValue(), body) } @@ -44,19 +49,22 @@ class AkkaHttpSttpHandler(actorSystem: ActorSystem) extends SttpStreamHandler[Fu case _ => HttpMethod.custom(m.m) } - private def bodyFromAkkaResponse[T](rr: ResponseBodyReader[T], hr: HttpResponse): Future[T] = rr match { - case IgnoreResponseBody => - hr.discardEntityBytes() - Future.successful(()) + private def bodyFromAkkaResponse[T](rr: ResponseAs[T], hr: HttpResponse): Future[T] = { + def asByteArray = hr.entity.dataBytes + .runFold(ByteString(""))(_ ++ _) + .map(_.toArray[Byte]) - case AkkaStreamsSourceResponseBody => - Future.successful(hr.entity.dataBytes) + rr match { + case IgnoreResponse => + hr.discardEntityBytes() + Future.successful(()) - case _ => - hr.entity.dataBytes - .runFold(ByteString(""))(_ ++ _) - .map(_.toArray[Byte]) - .map(rr.fromBytes) + case ResponseAsString(enc) => + asByteArray.map(new String(_, enc)) + + case ResponseAsByteArray => + asByteArray + } } private def requestToAkka(r: Request): Future[HttpRequest] = { @@ -85,5 +93,4 @@ class AkkaHttpSttpHandler(actorSystem: ActorSystem) extends SttpStreamHandler[Fu def close(): Future[Terminated] = { actorSystem.terminate() } -} - +}
\ No newline at end of file diff --git a/akka-http-handler/src/main/scala/com/softwaremill/sttp/akkahttp/package.scala b/akka-http-handler/src/main/scala/com/softwaremill/sttp/akkahttp/package.scala deleted file mode 100644 index 3b9a1aa..0000000 --- a/akka-http-handler/src/main/scala/com/softwaremill/sttp/akkahttp/package.scala +++ /dev/null @@ -1,14 +0,0 @@ -package com.softwaremill.sttp - -import java.io.InputStream - -import akka.stream.scaladsl.Source -import akka.util.ByteString - -package object akkahttp { - implicit object AkkaStreamsSourceResponseBody extends ResponseBodyReader[Source[ByteString, Any]] { - override def fromInputStream(is: InputStream): Source[ByteString, Any] = ??? - - override def fromBytes(bytes: Array[Byte]): Source[ByteString, Any] = ??? - } -} |