CVE-2026-31842

Name
CVE-2026-31842
Description
Tinyproxy through 1.11.3 is vulnerable to HTTP request parsing desynchronization due to a case-sensitive comparison of the Transfer-Encoding header in src/reqs.c. The is_chunked_transfer() function uses strcmp() to compare the header value against "chunked", even though RFC 7230 specifies that transfer-coding names are case-insensitive. By sending a request with Transfer-Encoding: Chunked, an unauthenticated remote attacker can cause Tinyproxy to misinterpret the request as having no body. In this state, Tinyproxy sets content_length.client to -1, skips pull_client_data_chunked(), forwards request headers upstream, and transitions into relay_connection() raw TCP forwarding while unread body data remains buffered. This leads to inconsistent request state between Tinyproxy and backend servers. RFC-compliant backends (e.g., Node.js, Nginx) will continue waiting for chunked body data, causing connections to hang indefinitely. This behavior enables application-level denial of service through backend worker exhaustion. Additionally, in deployments where Tinyproxy is used for request-body inspection, filtering, or security enforcement, the unread body may be forwarded without proper inspection, resulting in potential security control bypass.
NVD Severity
unknown
Other trackers
Mailing lists
Exploits
Forges
GitHub (code, issues), Aports (code, issues)

References

Type URI
309f9ea4-e3e9-4c6c-b79d-e8eb01244f2c https://datatracker.ietf.org/doc/html/rfc7230
309f9ea4-e3e9-4c6c-b79d-e8eb01244f2c https://github.com/tinyproxy/tinyproxy
309f9ea4-e3e9-4c6c-b79d-e8eb01244f2c https://github.com/tinyproxy/tinyproxy/issues/604

Match rules

CPE URI Source package Min version Max version
cpe:2.3:a:tinyproxy_project:tinyproxy:*:*:*:*:*:*:*:* tinyproxy >= None <= 1.11.3

Vulnerable and fixed packages

Source package Branch Version Maintainer Status
tinyproxy edge-main 1.11.3-r0 Michael Mason <ms13sp@gmail.com> possibly vulnerable
tinyproxy edge-main 1.11.2-r0 Michael Mason <ms13sp@gmail.com> possibly vulnerable
tinyproxy edge-main 1.11.1-r3 Michael Mason <ms13sp@gmail.com> possibly vulnerable
tinyproxy edge-main 1.11.1-r2 Michael Mason <ms13sp@gmail.com> possibly vulnerable
tinyproxy 3.23-main 1.11.2-r0 Michael Mason <ms13sp@gmail.com> possibly vulnerable
tinyproxy 3.22-main 1.11.2-r0 Michael Mason <ms13sp@gmail.com> possibly vulnerable
tinyproxy 3.22-main 1.11.1-r2 None possibly vulnerable
tinyproxy 3.21-main 1.11.2-r0 Michael Mason <ms13sp@gmail.com> possibly vulnerable
tinyproxy 3.21-main 1.11.1-r2 None possibly vulnerable
tinyproxy 3.20-main 1.11.2-r0 Michael Mason <ms13sp@gmail.com> possibly vulnerable
tinyproxy 3.20-main 1.11.1-r2 None possibly vulnerable
tinyproxy 3.19-main 1.11.2-r0 Michael Mason <ms13sp@gmail.com> possibly vulnerable
tinyproxy 3.19-main 1.11.1-r3 Michael Mason <ms13sp@gmail.com> possibly vulnerable
tinyproxy 3.19-main 1.11.1-r2 None possibly vulnerable