CVE-2013-2174
URL decode buffer boundary flaw
Project curl Security Advisory, June 22 2013 Permalink
VULNERABILITY
libcurl is vulnerable to a case of bad checking of the input data which may lead to heap corruption.
The function curl_easy_unescape() decodes URL encoded strings to raw binary data. URL encoded octets are represented with %HH combinations where HH is a two-digit hexadecimal number. The decoded string is written to an allocated memory area that the function returns to the caller.
The function takes a source string and a length parameter, and if the length provided is 0 the function instead uses strlen() to figure out how much data to parse.
The "%HH" parser wrongly only considered the case where a zero byte would terminate the input. If a length-limited buffer was passed in which ended with a '%' character which was followed by two hexadecimal digits outside of the buffer libcurl was allowed to parse alas without a terminating zero, libcurl would still parse that sequence as well. The counter for remaining data to handle would then be decreased too much and wrap to become a very large integer and the copying would go on too long and the destination buffer that is allocated on the heap would get overwritten.
We consider it unlikely that programs allow user-provided strings unfiltered into this function. Also, only the not zero-terminated input string use case is affected by this flaw. Exploiting this flaw for gain is probably possible for specific circumstances but we consider the general risk for this to be low.
The curl command line tool is not affected by this problem as it does not use this function.
INFO
The Common Vulnerabilities and Exposures (CVE) project has assigned the name CVE-2013-2174 to this issue.
CWE-126: Buffer Over-read
Severity: High
AFFECTED VERSIONS
Not affected versions: libcurl < 7.7 and >= 7.31.0
libcurl is used by many applications, but not always advertised as such!
SOLUTION
libcurl 7.31.0 implements a proper check that the following hexadecimal digits are within the provided input length.
RECOMMENDATIONS
We suggest you take one of the following actions immediately, in order of preference:
A - Upgrade to curl and libcurl 7.31.0
B - Apply patch and rebuild libcurl
C - Double-check your curl_easy_unescape()
usage (for
example use it with the 'length' argument set to 0), or avoid using that
function
TIMELINE
It was reported to the curl project on May 19th 20. We contacted linux-distros on June 12.
curl 7.31.0 was released on June 22 2013, coordinated with the publication of this advisory.
CREDITS
- Reported-by: Timo Sirainen
- Patched-by: Daniel Stenberg
Thanks a lot!