EEF-CVE-2026-49756

Source
https://cna.erlef.org/osv/EEF-CVE-2026-49756.html
Import Source
https://cna.erlef.org/osv/EEF-CVE-2026-49756.json
JSON Data
https://api.osv.dev/v1/vulns/EEF-CVE-2026-49756
Aliases
  • CVE-2026-49756
  • GHSA-px9f-whj3-246m
Published
2026-06-08T15:20:24.035Z
Modified
2026-06-08T16:34:58.505Z
Severity
  • 2.1 (Low) CVSS_V4 - CVSS:4.0/AV:L/AC:L/AT:P/PR:N/UI:N/VC:N/VI:L/VA:N/SC:L/SI:L/SA:N CVSS Calculator
Summary
Multipart form-data header injection in Req via unescaped name/filename/content_type
Details

Summary

Improper Neutralization of CRLF Sequences ('CRLF Injection') vulnerability in wojtekmach Req allows multipart parameter smuggling via attacker-influenced part metadata.

Req.Utils.encodeformpart/2 in lib/req/utils.ex builds the per-part headers by interpolating the caller-supplied name, filename, and content_type values directly into the content-disposition and content-type lines with no escaping or CRLF stripping. A value containing ", \r, or \n closes the surrounding quoted value and starts a new header line; an additional \r\n--<boundary> terminates the current part and prepends a smuggled part of the attacker's choosing.

This is reachable through every supported way of supplying a part. It is particularly easy when value is a %File.Stream{}, because filename then defaults to Path.basename(stream.path) and POSIX filenames may legitimately contain \r and \n. Any application that forwards user-controlled filenames (or field names / MIME types) through Req.post/2 with form_multipart: lets an attacker inject arbitrary headers into the outgoing multipart body or smuggle additional fields and parts into the request the victim service sends downstream.

This issue affects req: from 0.5.3 before 0.6.0.

Workaround

Sanitize attacker-influenced name, filename, and contenttype values before passing them to Req.post/2 with formmultipart:. At minimum, reject (or strip) any value containing \r, \n, or ". When forwarding uploads, derive filename from a normalised string rather than Path.basename/1 on a user-controlled path.

Database specific
{
    "cpe_ids": [
        "cpe:2.3:a:wojtekmach:req:*:*:*:*:*:*:*:*"
    ],
    "capec_ids": [
        "CAPEC-33",
        "CAPEC-105"
    ],
    "cwe_ids": [
        "CWE-93"
    ]
}
References
Credits
    • Peter Ullrich - FINDER
    • Wojtek Mach - REMEDIATION_DEVELOPER
    • Jonatan Männchen / EEF - ANALYST

Affected packages

Hex / req

Package

Name
req
Purl
pkg:hex/req

Affected ranges

Type
SEMVER
Events
Introduced
0.5.3
Fixed
0.6.0

Affected versions

0.*
0.5.3
0.5.4
0.5.5
0.5.6
0.5.7
0.5.8
0.5.9
0.5.10
0.5.11
0.5.12
0.5.13
0.5.14
0.5.15
0.5.16
0.5.17
0.5.18

Database specific

source
"https://cna.erlef.org/osv/EEF-CVE-2026-49756.json"

Git / github.com/wojtekmach/req.git

Affected ranges

Type
GIT
Repo
https://github.com/wojtekmach/req.git
Events

Affected versions

v0.*
v0.5.10
v0.5.11
v0.5.12
v0.5.13
v0.5.14
v0.5.16
v0.5.17
v0.5.3
v0.5.4
v0.5.5
v0.5.6
v0.5.7
v0.5.8
v0.5.9

Database specific

source
"https://cna.erlef.org/osv/EEF-CVE-2026-49756.json"