Skip to content

Commit

Permalink
Make cookie extractor enrichment case insensitive (close #877)
Browse files Browse the repository at this point in the history
Previously, cookie extractor enrichment was only looking for `Cookie`
header ignoring when the header has been supplied as a lower case
`cookie`. This caused issues with Collector 3 that follows a
case-insensitive header names.
Now, both `cookie` and `Cookie` headers are matched as containing
user-agent's cookie.

1 - https://www.rfc-editor.org/rfc/rfc7230#section-3.2
  • Loading branch information
peel committed Feb 20, 2024
1 parent ac87750 commit 6634a3a
Show file tree
Hide file tree
Showing 2 changed files with 4 additions and 3 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@ final case class CookieExtractorEnrichment(cookieNames: List[String]) extends En
// rfc6265 - sections 4.2.1 and 4.2.2
val cookies = headers.flatMap { header =>
header.split(":", 2) match {
case Array("Cookie", value) =>
case Array(cookieStr, value) if cookieStr.toLowerCase == "cookie" =>
val nameValuePairs =
BasicHeaderValueParser.parseParameters(value, BasicHeaderValueParser.INSTANCE)

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,8 @@ class CookieExtractorEnrichmentSpec extends Specification {
}

def e3 = {
val cookies = List("ck1", "=cv2", "ck3=", "ck4=cv4", "ck5=\"cv5\"")
val cookies = List("ck1", "=cv2", "ck3=")
val cookies2 = List("ck4=cv4", "ck5=\"cv5\"")
val cookieKeys = List("ck1", "", "ck3", "ck4", "ck5")

val expected =
Expand Down Expand Up @@ -63,7 +64,7 @@ class CookieExtractorEnrichmentSpec extends Specification {
)

val actual = CookieExtractorEnrichment(cookieKeys)
.extract(List("Cookie: " + cookies.mkString(";")))
.extract(List("cookie: " + cookies.mkString(";"), "Cookie:" + cookies2.mkString(";")))

actual must beLike {
case cookies @ _ :: _ :: _ :: _ :: _ :: Nil => cookies must_== expected
Expand Down

0 comments on commit 6634a3a

Please sign in to comment.