From 2980de938597212b4f900cb3806ab06f442ffc36 Mon Sep 17 00:00:00 2001 From: Mathieu Ancelin Date: Tue, 31 Oct 2023 14:42:23 +0100 Subject: [PATCH] fix #1751 --- otoroshi/app/netty/h1h2client.scala | 40 ++++++++++------------------- otoroshi/app/netty/h3client.scala | 20 ++++++++------- otoroshi/app/utils/httpclient.scala | 20 ++++++++------- 3 files changed, 36 insertions(+), 44 deletions(-) diff --git a/otoroshi/app/netty/h1h2client.scala b/otoroshi/app/netty/h1h2client.scala index 78f2ac56fb..3ed90bf2eb 100644 --- a/otoroshi/app/netty/h1h2client.scala +++ b/otoroshi/app/netty/h1h2client.scala @@ -1,12 +1,12 @@ package otoroshi.netty import akka.http.scaladsl.model.HttpHeader.ParsingResult -import akka.http.scaladsl.model.headers.{`Content-Length`, `Content-Type`, `User-Agent`, RawHeader} +import akka.http.scaladsl.model.headers.{RawHeader, `Content-Length`, `Content-Type`, `User-Agent`} import akka.http.scaladsl.model.{ContentType, HttpHeader, Uri} import akka.stream.scaladsl.{Sink, Source} import akka.util.ByteString import com.google.common.base.Charsets -import io.netty.buffer.Unpooled +import io.netty.buffer.{ByteBuf, Unpooled} import io.netty.channel.ChannelOption import io.netty.handler.codec.http.HttpMethod import io.netty.handler.logging.LogLevel @@ -20,21 +20,7 @@ import otoroshi.utils.reactive.ReactiveStreamUtils import otoroshi.utils.syntax.implicits._ import play.api.Logger import play.api.libs.json.{JsValue, Json} -import play.api.libs.ws.{ - BodyWritable, - DefaultWSCookie, - EmptyBody, - InMemoryBody, - SourceBody, - WSAuthScheme, - WSBody, - WSCookie, - WSProxyServer, - WSRequest, - WSRequestFilter, - WSResponse, - WSSignatureCalculator -} +import play.api.libs.ws.{BodyWritable, DefaultWSCookie, EmptyBody, InMemoryBody, SourceBody, WSAuthScheme, WSBody, WSCookie, WSProxyServer, WSRequest, WSRequestFilter, WSResponse, WSSignatureCalculator} import play.api.mvc.MultipartFormData import reactor.core.publisher.{Flux, Mono} import reactor.netty.ByteBufFlux @@ -208,15 +194,17 @@ case class NettyWsClientRequest( .addHttpHeaders("Content-Type" -> "application/octet-stream") .execute() override def withCookies(cookies: WSCookie*): WSRequest = { - val oldCookies = headers.get("Cookie").getOrElse(Seq.empty[String]) - val newCookies = oldCookies :+ cookies.toList - .map { c => - s"${c.name}=${c.value}" - } - .mkString(";") - copy( - headers = headers + ("Cookie" -> newCookies) - ) + if (cookies.nonEmpty) { + val oldCookies = headers.get("Cookie").getOrElse(Seq.empty[String]) + val newCookies = oldCookies :+ cookies.toList + .map { c => + s"${c.name}=${c.value}" + } + .mkString(";") + copy( + headers = headers + ("Cookie" -> newCookies) + ) + } else this } override def withHeaders(headers: (String, String)*): WSRequest = withHttpHeaders(headers: _*) override def withHttpHeaders(headers: (String, String)*): WSRequest = { diff --git a/otoroshi/app/netty/h3client.scala b/otoroshi/app/netty/h3client.scala index e5db400c36..76fbf5e657 100644 --- a/otoroshi/app/netty/h3client.scala +++ b/otoroshi/app/netty/h3client.scala @@ -508,15 +508,17 @@ case class NettyHttp3ClientWsRequest( .addHttpHeaders("Content-Type" -> "application/octet-stream") .execute() override def withCookies(cookies: WSCookie*): WSRequest = { - val oldCookies = headers.get("Cookie").getOrElse(Seq.empty[String]) - val newCookies = oldCookies :+ cookies.toList - .map { c => - s"${c.name}=${c.value}" - } - .mkString(";") - copy( - headers = headers + ("Cookie" -> newCookies) - ) + if (cookies.nonEmpty) { + val oldCookies = headers.get("Cookie").getOrElse(Seq.empty[String]) + val newCookies = oldCookies :+ cookies.toList + .map { c => + s"${c.name}=${c.value}" + } + .mkString(";") + copy( + headers = headers + ("Cookie" -> newCookies) + ) + } else this } override def withHeaders(headers: (String, String)*): WSRequest = withHttpHeaders(headers: _*) override def withHttpHeaders(headers: (String, String)*): WSRequest = { diff --git a/otoroshi/app/utils/httpclient.scala b/otoroshi/app/utils/httpclient.scala index 0fcf9db20f..d3e14247e7 100644 --- a/otoroshi/app/utils/httpclient.scala +++ b/otoroshi/app/utils/httpclient.scala @@ -1482,15 +1482,17 @@ case class AkkaWsClientRequest( /////////// override def withCookies(cookies: WSCookie*): WSRequest = { - val oldCookies = headers.get("Cookie").getOrElse(Seq.empty[String]) - val newCookies = oldCookies :+ cookies.toList - .map { c => - s"${c.name}=${c.value}" - } - .mkString(";") - copy( - headers = headers + ("Cookie" -> newCookies) - ) + if (cookies.nonEmpty) { + val oldCookies = headers.get("Cookie").getOrElse(Seq.empty[String]) + val newCookies = oldCookies :+ cookies.toList + .map { c => + s"${c.name}=${c.value}" + } + .mkString(";") + copy( + headers = headers + ("Cookie" -> newCookies) + ) + } else this } override lazy val followRedirects: Option[Boolean] = Some(false)