Description
http4s is an open source scala interface for HTTP. In affected versions http4s is vulnerable to response-splitting or request-splitting attacks when untrusted user input is used to create any of the following fields: Header names (`Header.name`å), Header values (`Header.value`), Status reason phrases (`Status.reason`), URI paths (`Uri.Path`), URI authority registered names (`URI.RegName`) (through 0.21). This issue has been resolved in versions 0.21.30, 0.22.5, 0.23.4, and 1.0.0-M27 perform the following. As a matter of practice http4s services and client applications should sanitize any user input in the aforementioned fields before returning a request or response to the backend. The carriage return, newline, and null characters are the most threatening.
Remediation
References
https://github.com/http4s/http4s/commit/d02007db1da4f8f3df2dbf11f1db9ac7afc3f9d8
https://github.com/http4s/http4s/security/advisories/GHSA-5vcm-3xc3-w7x3
https://httpwg.org/http-core/draft-ietf-httpbis-semantics-latest.html#fields.values
https://owasp.org/www-community/attacks/HTTP_Response_Splitting
Related Vulnerabilities
CVE-2020-11987 Vulnerability in maven package org.apache.xmlgraphics:batik-svgbrowser
CVE-2021-23341 Vulnerability in npm package prismjs
CVE-2023-40313 Vulnerability in maven package org.opennms:opennms-base-assembly
CVE-2023-38493 Vulnerability in maven package com.linecorp.armeria:armeria
CVE-2020-2245 Vulnerability in maven package org.jenkins-ci.plugins:valgrind