Skip to content

aiohttp's ClientSession is vulnerable to CRLF injection via version

High severity GitHub Reviewed Published Nov 26, 2023 in aio-libs/aiohttp • Updated Jan 29, 2024

Package

pip aiohttp (pip)

Affected versions

< 3.9.0

Patched versions

3.9.0

Description

Summary

Improper validation make it possible for an attacker to modify the HTTP request (e.g. to insert a new header) or even create a new HTTP request if the attacker controls the HTTP version.

Details

The vulnerability only occurs if the attacker can control the HTTP version of the request (including its type).
For example if an unvalidated JSON value is used as a version and the attacker is then able to pass an array as the version parameter.
Furthermore, the vulnerability only occurs when the Connection header is passed to the headers parameter.

At this point, the library will use the parsed value to create the request. If a list is passed, then it bypasses validation and it is possible to perform CRLF injection.

PoC

The POC below shows an example of providing an unvalidated array as a version:
https://gist.github.com/jnovikov/184afb593d9c2114d77f508e0ccd508e

Impact

CRLF injection leading to Request Smuggling.

Workaround

If these specific conditions are met and you are unable to upgrade, then validate the user input to the version parameter to ensure it is a str.

Patch: https://github.com/aio-libs/aiohttp/pull/7835/files

References

@Dreamsorcerer Dreamsorcerer published to aio-libs/aiohttp Nov 26, 2023
Published to the GitHub Advisory Database Nov 27, 2023
Reviewed Nov 27, 2023
Published by the National Vulnerability Database Nov 30, 2023
Last updated Jan 29, 2024

Severity

High
7.2
/ 10

CVSS base metrics

Attack vector
Network
Attack complexity
Low
Privileges required
None
User interaction
None
Scope
Changed
Confidentiality
Low
Integrity
Low
Availability
None
CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:L/I:L/A:N

Weaknesses

CVE ID

CVE-2023-49081

GHSA ID

GHSA-q3qx-c6g2-7pw2

Source code

Credits

Checking history
See something to contribute? Suggest improvements for this vulnerability.