This flaw allows an attacker to intentionally inject cookies into a running program using libcurl, if the specific series of conditions are met.
libcurl performs transfers. In its API, an application creates "easy handles" that are the individual handles for single transfers.
libcurl provides a function call that duplicates an easy handle called curleasyduphandle.
If a transfer has cookies enabled when the handle is duplicated, the
cookie-enable state is also cloned - but without cloning the actual
cookies. If the source handle did not read any cookies from a specific file on
disk, the cloned version of the handle would instead store the filename as
none
(using the four ASCII letters, no quotes).
Subsequent use of the cloned handle that does not explicitly set a source to
load cookies from would then inadvertently load cookies from a file named
none
- if such a file exists and is readable in the current directory of the
program using libcurl, when using the correct file format of course.
{ "CWE": { "id": "CWE-73", "desc": "External Control of filename or Path" }, "award": { "amount": "540", "currency": "USD" }, "URL": "https://curl.se/docs/CVE-2023-38546.json", "package": "curl", "severity": "Low", "issue": "https://hackerone.com/reports/2148242", "www": "https://curl.se/docs/CVE-2023-38546.html", "last_affected": "8.3.0" }