From b6b8d9afb98050138036055e9c673ccf7140c889 Mon Sep 17 00:00:00 2001 From: Andrea Bisacchi Date: Tue, 12 Mar 2024 10:43:47 +0100 Subject: [PATCH] Fix headers in ApiGatewayProxyHandler --- .../feral/lambda/http4s/ApiGatewayProxyHandler.scala | 2 +- .../lambda/http4s/ApiGatewayProxyHandlerSuite.scala | 4 +++- .../lambda/events/ApiGatewayProxyEventSuite.scala | 12 +++++++++--- 3 files changed, 13 insertions(+), 5 deletions(-) diff --git a/lambda-http4s/src/main/scala/feral/lambda/http4s/ApiGatewayProxyHandler.scala b/lambda-http4s/src/main/scala/feral/lambda/http4s/ApiGatewayProxyHandler.scala index 152303a5..0d2a8edb 100644 --- a/lambda-http4s/src/main/scala/feral/lambda/http4s/ApiGatewayProxyHandler.scala +++ b/lambda-http4s/src/main/scala/feral/lambda/http4s/ApiGatewayProxyHandler.scala @@ -63,6 +63,7 @@ object ApiGatewayProxyHandler { event: ApiGatewayProxyEvent): F[Request[F]] = { val queryString: String = getMultiValueQueryStringParameters( event.multiValueQueryStringParameters) + val uriString: String = event.path + (if (queryString.nonEmpty) s"?$queryString" else "") for { @@ -70,7 +71,6 @@ object ApiGatewayProxyHandler { uri <- Uri.fromString(uriString).liftTo[F] headers = { val builder = List.newBuilder[Header.Raw] - event.headers.foreach { h => h.foreachEntry(builder += Header.Raw(_, _)) } event.multiValueHeaders.foreach { hMap => hMap.foreach { case (key, values) => diff --git a/lambda-http4s/src/test/scala/feral/lambda/http4s/ApiGatewayProxyHandlerSuite.scala b/lambda-http4s/src/test/scala/feral/lambda/http4s/ApiGatewayProxyHandlerSuite.scala index 7d31505c..72602062 100644 --- a/lambda-http4s/src/test/scala/feral/lambda/http4s/ApiGatewayProxyHandlerSuite.scala +++ b/lambda-http4s/src/test/scala/feral/lambda/http4s/ApiGatewayProxyHandlerSuite.scala @@ -37,6 +37,8 @@ class ApiGatewayProxyHandlerSuite extends CatsEffectSuite { "X-Amz-Cf-Id" -> "cDehVQoZnx43VYQb9j2-nvCh-9z396Uhbp027Y2JvkCPNLmGJHqlaA==", "Host" -> "1234567890.execute-api.us-east-1.amazonaws.com", "Accept-Encoding" -> "gzip, deflate, sdch", + "X-MultiHeader" -> "foo", + "X-MultiHeader" -> "bar", "X-Forwarded-Port" -> "443", "Cache-Control" -> "max-age=0", "CloudFront-Viewer-Country" -> "US", @@ -57,7 +59,7 @@ class ApiGatewayProxyHandlerSuite extends CatsEffectSuite { event <- event.as[ApiGatewayProxyEvent].liftTo[IO] request <- ApiGatewayProxyHandler.decodeEvent[IO](event) _ <- IO(assertEquals(request.method, Method.POST)) - _ <- IO(assertEquals(request.uri, uri"/path/to/resource?foo=bar")) + _ <- IO(assertEquals(request.uri, uri"/path/to/resource?foo=bar&foo=baz")) _ <- IO(assertEquals(request.headers, expectedHeaders)) responseBody <- request.bodyText.compile.string _ <- IO(assertEquals(responseBody, expectedBody)) diff --git a/lambda/shared/src/test/scala/feral/lambda/events/ApiGatewayProxyEventSuite.scala b/lambda/shared/src/test/scala/feral/lambda/events/ApiGatewayProxyEventSuite.scala index 1ff531f7..167d5671 100644 --- a/lambda/shared/src/test/scala/feral/lambda/events/ApiGatewayProxyEventSuite.scala +++ b/lambda/shared/src/test/scala/feral/lambda/events/ApiGatewayProxyEventSuite.scala @@ -43,7 +43,8 @@ object ApiGatewayProxyEventSuite { }, "multiValueQueryStringParameters": { "foo": [ - "bar" + "bar", + "baz" ] }, "pathParameters": { @@ -70,7 +71,8 @@ object ApiGatewayProxyEventSuite { "X-Amz-Cf-Id": "cDehVQoZnx43VYQb9j2-nvCh-9z396Uhbp027Y2JvkCPNLmGJHqlaA==", "X-Forwarded-For": "127.0.0.1, 127.0.0.2", "X-Forwarded-Port": "443", - "X-Forwarded-Proto": "https" + "X-Forwarded-Proto": "https", + "X-MultiHeader": "foo" }, "multiValueHeaders": { "Accept": [ @@ -104,7 +106,7 @@ object ApiGatewayProxyEventSuite { "US" ], "Host": [ - "0123456789.execute-api.us-east-1.amazonaws.com" + "1234567890.execute-api.us-east-1.amazonaws.com" ], "Upgrade-Insecure-Requests": [ "1" @@ -126,6 +128,10 @@ object ApiGatewayProxyEventSuite { ], "X-Forwarded-Proto": [ "https" + ], + "X-MultiHeader": [ + "foo", + "bar" ] }, "requestContext": {