Security
Headlines
HeadlinesLatestCVEs

Headline

CVE-2023-3247: Missing error check and insufficient random bytes in HTTP Digest authentication for SOAP

In PHP versions 8.0.* before 8.0.29, 8.1.* before 8.1.20, 8.2.* before 8.2.7 when using SOAP HTTP Digest Authentication, random value generator was not checked for failure, and was using narrower range of values than it should have. In case of random generator failure, it could lead to a disclosure of 31 bits of uninitialized memory from the client to the server, and it also made easier to a malicious server to guess the client’s nonce.

CVE
#git#php#auth

This report was co-authored by @TimWolla

Summary

The random byte generation function used in the SOAP HTTP Digest authentication code is not checked for failure. This can result in a stack information leak. Furthermore, there’s an insufficient number of random bytes used.

Details

Context:

php_random_bytes_throw(&nonce, sizeof(nonce));

nonce &= 0x7fffffff;

PHP_MD5Init(&md5ctx);

snprintf(cnonce, sizeof(cnonce), ZEND_LONG_FMT, nonce);

PHP_MD5Update(&md5ctx, (unsigned char*)cnonce, strlen(cnonce));

PHP_MD5Final(hash, &md5ctx);

make_digest(cnonce, hash);

If php_random_bytes_throw fails, the nonce will be uninitialized, but
still sent to the server. The client nonce is intended to protect
against a malicious server. See section 5.10 and 5.12 of RFC 7616,
and bullet point 2 below.

Tim pointed out that even though it’s the MD5 of the nonce that gets sent,
enumerating 31 bits is trivial. So we have still a stack information leak
of 31 bits.

Furthermore, Tim found the following issues:

  • The small size of cnonce might cause the server to erroneously reject
    a request due to a repeated (cnonce, nc) pair. As per the birthday
    problem 31 bits of randomness will return a duplication with 50%
    chance after less than 55000 requests and nc always starts counting at 1.

  • The cnonce is intended to protect the client and password against a
    malicious server that returns a constant server nonce where the server
    precomputed a rainbow table between passwords and correct client response.
    As storage is fairly cheap, a server could precompute the client responses
    for (a subset of) client nonces and still have a chance of reversing the
    client response with the same probability as the cnonce duplication.

    Precomputing the rainbow table for all 2^31 cnonces increases the rainbow
    table size by factor 2 billion, which is infeasible. But precomputing it
    for 2^14 cnonces only increases the table size by factor 16k and the server
    would still have a 10% chance of successfully reversing a password with a
    single client request.

PoC

We do not have a proof-of-concept.

Impact

The weak randomness affects applications that use SOAP with HTTP Digest authentication against a possibly malicious server over HTTP. The stack information leak applies to both HTTP and HTTPS, but is only a few bytes.

Proposed patch

This patch fixes the issues by increasing the nonce size, and checking
the return value of php_random_bytes_throw(). In the process we also get
rid of the MD5 hashing of the nonce.

From f26fcd3a152a5c6b2d140cb35a5040671696f6e1 Mon Sep 17 00:00:00 2001 From: Niels Dossche [email protected] Date: Sun, 16 Apr 2023 15:05:03 +0200 Subject: [PATCH] Fix missing randomness check and insufficient random bytes for SOAP HTTP Digest MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit

If php_random_bytes_throw fails, the nonce will be uninitialized, but still sent to the server. The client nonce is intended to protect against a malicious server. See section 5.10 and 5.12 of RFC 7616 [1], and bullet point 2 below.

Tim pointed out that even though it’s the MD5 of the nonce that gets sent, enumerating 31 bits is trivial. So we have still a stack information leak of 31 bits.

Furthermore, Tim found the following issues: * The small size of cnonce might cause the server to erroneously reject a request due to a repeated (cnonce, nc) pair. As per the birthday problem 31 bits of randomness will return a duplication with 50% chance after less than 55000 requests and nc always starts counting at 1. * The cnonce is intended to protect the client and password against a malicious server that returns a constant server nonce where the server precomputed a rainbow table between passwords and correct client response. As storage is fairly cheap, a server could precompute the client responses for (a subset of) client nonces and still have a chance of reversing the client response with the same probability as the cnonce duplication.

Precomputing the rainbow table for all 2^31 cnonces increases the rainbow table size by factor 2 billion, which is infeasible. But precomputing it for 2^14 cnonces only increases the table size by factor 16k and the server would still have a 10% chance of successfully reversing a password with a single client request.

This patch fixes the issues by increasing the nonce size, and checking the return value of php_random_bytes_throw(). In the process we also get rid of the MD5 hashing of the nonce.

[1] RFC 7616: https://www.rfc-editor.org/rfc/rfc7616

Co-authored-by: Tim Düsterhus [email protected] — ext/soap/php_http.c | 21 ++++++++++++±------- 1 file changed, 13 insertions(+), 8 deletions(-)

diff --git a/ext/soap/php_http.c b/ext/soap/php_http.c index db3c97b647…a619949c69 100644 — a/ext/soap/php_http.c +++ b/ext/soap/php_http.c @@ -657,18 +657,23 @@ try_again: has_authorization = 1; if (Z_TYPE_P(digest) == IS_ARRAY) { char HA1[33], HA2[33], response[33], cnonce[33], nc[9]; - zend_long nonce;

  •           unsigned char nonce\[16\];
              PHP\_MD5\_CTX   md5ctx;
              unsigned char hash\[16\];
    

- php_random_bytes_throw(&nonce, sizeof(nonce)); - nonce &= 0x7fffffff;

  •           if (UNEXPECTED(php\_random\_bytes\_throw(&nonce, sizeof(nonce)) != SUCCESS)) {
    
  •               ZEND\_ASSERT(EG(exception));
    
  •               php\_stream\_close(stream);
    
  •               convert\_to\_null(Z\_CLIENT\_HTTPURL\_P(this\_ptr));
    
  •               convert\_to\_null(Z\_CLIENT\_HTTPSOCKET\_P(this\_ptr));
    
  •               convert\_to\_null(Z\_CLIENT\_USE\_PROXY\_P(this\_ptr));
    
  •               smart\_str\_free(&soap\_headers\_z);
    
  •               smart\_str\_free(&soap\_headers);
    
  •               return FALSE;
    
  •           }
    

- PHP_MD5Init(&md5ctx); - snprintf(cnonce, sizeof(cnonce), ZEND_LONG_FMT, nonce); - PHP_MD5Update(&md5ctx, (unsigned char*)cnonce, strlen(cnonce)); - PHP_MD5Final(hash, &md5ctx); - make_digest(cnonce, hash);

  •           php\_hash\_bin2hex(cnonce, nonce, sizeof(nonce));
    
  •           cnonce\[32\] = 0;
    
              if ((tmp = zend\_hash\_str\_find(Z\_ARRVAL\_P(digest), "nc", sizeof("nc")-1)) != NULL &&
                  Z\_TYPE\_P(tmp) == IS\_LONG) {
    

– 2.40.0

Related news

Red Hat Security Advisory 2024-0387-03

Red Hat Security Advisory 2024-0387-03 - An update for the php:8.1 module is now available for Red Hat Enterprise Linux 9. Issues addressed include a denial of service vulnerability.

Ubuntu Security Notice USN-6199-2

Ubuntu Security Notice 6199-2 - USN-6199-1 fixed a vulnerability in PHP. This update provides the corresponding update for Ubuntu 16.04 LTS and Ubuntu 18.04 LTS. It was discovered that PHP incorrectly handled certain Digest authentication for SOAP. An attacker could possibly use this issue to expose sensitive information.

CVE-2023-22130: Oracle Critical Patch Update Advisory - October 2023

Vulnerability in the Sun ZFS Storage Appliance product of Oracle Systems (component: Core). The supported version that is affected is 8.8.60. Difficult to exploit vulnerability allows unauthenticated attacker with network access via HTTP to compromise Sun ZFS Storage Appliance. Successful attacks of this vulnerability can result in unauthorized ability to cause a hang or frequently repeatable crash (complete DOS) of Sun ZFS Storage Appliance. CVSS 3.1 Base Score 5.9 (Availability impacts). CVSS Vector: (CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:N/I:N/A:H).

Ubuntu Security Notice USN-6199-1

Ubuntu Security Notice 6199-1 - It was discovered that PHP incorrectly handled certain Digest authentication for SOAP. An attacker could possibly use this issue to expose sensitive information.

CVE: Latest News

CVE-2023-50976: Transactions API Authorization by oleiman · Pull Request #14969 · redpanda-data/redpanda