CVE-2019-16786

Source
https://nvd.nist.gov/vuln/detail/CVE-2019-16786
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2019-16786.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2019-16786
Aliases
Downstream
Related
Published
2019-12-20T23:15:11Z
Modified
2025-10-15T10:28:57.635674Z
Severity
  • 7.5 (High) CVSS_V3 - CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:H/A:N CVSS Calculator
Summary
[none]
Details

Waitress through version 1.3.1 would parse the Transfer-Encoding header and only look for a single string value, if that value was not chunked it would fall through and use the Content-Length header instead. According to the HTTP standard Transfer-Encoding should be a comma separated list, with the inner-most encoding first, followed by any further transfer codings, ending with chunked. Requests sent with: "Transfer-Encoding: gzip, chunked" would incorrectly get ignored, and the request would use a Content-Length header instead to determine the body size of the HTTP message. This could allow for Waitress to treat a single request as multiple requests in the case of HTTP pipelining. This issue is fixed in Waitress 1.4.0.

References

Affected packages

Git / github.com/pylons/waitress

Affected ranges

Type
GIT
Repo
https://github.com/pylons/waitress
Events
Introduced
0 Unknown introduced commit / All previous commits are affected
Fixed

Affected versions

0.*

0.1
0.2
0.3
0.4
0.5
0.6
0.6.1
0.7
0.8
0.8.1
0.8.10
0.8.11b0
0.8.2
0.8.3
0.8.4
0.8.5
0.8.6
0.8.7
0.8.8
0.8.9
0.9.0b0

v0.*

v0.9.0
v0.9.0b1

v1.*

v1.0.0
v1.0.1
v1.0.2
v1.0a1
v1.0a2
v1.1.0
v1.2.0
v1.2.0b1
v1.2.0b2
v1.2.0b3
v1.2.1
v1.3.0
v1.3.0b0
v1.3.1