git: f29684158232 - main - security/openssl30: Update to 3.0.10

From: Bernard Spil <brnrd_at_FreeBSD.org>
Date: Wed, 02 Aug 2023 19:40:05 UTC
The branch main has been updated by brnrd:

URL: https://cgit.FreeBSD.org/ports/commit/?id=f296841582324e0a466445726701f41390fa35df

commit f296841582324e0a466445726701f41390fa35df
Author:     Bernard Spil <brnrd@FreeBSD.org>
AuthorDate: 2023-08-02 19:38:52 +0000
Commit:     Bernard Spil <brnrd@FreeBSD.org>
CommitDate: 2023-08-02 19:38:52 +0000

    security/openssl30: Update to 3.0.10
    
     * MFH this version as this is a roll-up of multiple vulnerability fixes
    
    MFH:            2023Q3
---
 security/openssl30/Makefile                  |  3 +-
 security/openssl30/distinfo                  |  6 +--
 security/openssl30/files/patch-CVE-2023-2975 | 54 --------------------------
 security/openssl30/files/patch-CVE-2023-3817 | 58 ----------------------------
 4 files changed, 4 insertions(+), 117 deletions(-)

diff --git a/security/openssl30/Makefile b/security/openssl30/Makefile
index 2627d0fc46a1..263d6e6ed0b7 100644
--- a/security/openssl30/Makefile
+++ b/security/openssl30/Makefile
@@ -1,6 +1,5 @@
 PORTNAME=	openssl
-PORTVERSION=	3.0.9
-PORTREVISION=	2
+PORTVERSION=	3.0.10
 CATEGORIES=	security devel
 MASTER_SITES=	https://www.openssl.org/source/ \
 		ftp://ftp.cert.dfn.de/pub/tools/net/openssl/source/
diff --git a/security/openssl30/distinfo b/security/openssl30/distinfo
index fcd53eed537a..2d411570ab05 100644
--- a/security/openssl30/distinfo
+++ b/security/openssl30/distinfo
@@ -1,3 +1,3 @@
-TIMESTAMP = 1685529949
-SHA256 (openssl-3.0.9.tar.gz) = eb1ab04781474360f77c318ab89d8c5a03abc38e63d65a603cabbf1b00a1dc90
-SIZE (openssl-3.0.9.tar.gz) = 15181285
+TIMESTAMP = 1691004174
+SHA256 (openssl-3.0.10.tar.gz) = 1761d4f5b13a1028b9b6f3d4b8e17feb0cedc9370f6afe61d7193d2cdce83323
+SIZE (openssl-3.0.10.tar.gz) = 15194904
diff --git a/security/openssl30/files/patch-CVE-2023-2975 b/security/openssl30/files/patch-CVE-2023-2975
deleted file mode 100644
index 397b46deb430..000000000000
--- a/security/openssl30/files/patch-CVE-2023-2975
+++ /dev/null
@@ -1,54 +0,0 @@
-From 00e2f5eea29994d19293ec4e8c8775ba73678598 Mon Sep 17 00:00:00 2001
-From: Tomas Mraz <tomas@openssl.org>
-Date: Tue, 4 Jul 2023 17:30:35 +0200
-Subject: [PATCH] Do not ignore empty associated data with AES-SIV mode
-
-The AES-SIV mode allows for multiple associated data items
-authenticated separately with any of these being 0 length.
-
-The provided implementation ignores such empty associated data
-which is incorrect in regards to the RFC 5297 and is also
-a security issue because such empty associated data then become
-unauthenticated if an application expects to authenticate them.
-
-Fixes CVE-2023-2975
-
-Reviewed-by: Matt Caswell <matt@openssl.org>
-Reviewed-by: Paul Dale <pauli@openssl.org>
-(Merged from https://github.com/openssl/openssl/pull/21384)
-
-(cherry picked from commit c426c281cfc23ab182f7d7d7a35229e7db1494d9)
----
- .../implementations/ciphers/cipher_aes_siv.c   | 18 +++++++++++-------
- 1 file changed, 11 insertions(+), 7 deletions(-)
-
-diff --git a/providers/implementations/ciphers/cipher_aes_siv.c b/providers/implementations/ciphers/cipher_aes_siv.c
-index 45010b90db2a..b396c8651a32 100644
---- providers/implementations/ciphers/cipher_aes_siv.c.orig
-+++ providers/implementations/ciphers/cipher_aes_siv.c
-@@ -120,14 +120,18 @@ static int siv_cipher(void *vctx, unsigned char *out, size_t *outl,
-     if (!ossl_prov_is_running())
-         return 0;
- 
--    if (inl == 0) {
--        *outl = 0;
--        return 1;
--    }
-+    /* Ignore just empty encryption/decryption call and not AAD. */
-+    if (out != NULL) {
-+        if (inl == 0) {
-+            if (outl != NULL)
-+                *outl = 0;
-+            return 1;
-+        }
- 
--    if (outsize < inl) {
--        ERR_raise(ERR_LIB_PROV, PROV_R_OUTPUT_BUFFER_TOO_SMALL);
--        return 0;
-+        if (outsize < inl) {
-+            ERR_raise(ERR_LIB_PROV, PROV_R_OUTPUT_BUFFER_TOO_SMALL);
-+            return 0;
-+        }
-     }
- 
-     if (ctx->hw->cipher(ctx, out, in, inl) <= 0)
diff --git a/security/openssl30/files/patch-CVE-2023-3817 b/security/openssl30/files/patch-CVE-2023-3817
deleted file mode 100644
index d90c0a11fb9d..000000000000
--- a/security/openssl30/files/patch-CVE-2023-3817
+++ /dev/null
@@ -1,58 +0,0 @@
-From 9002fd07327a91f35ba6c1307e71fa6fd4409b7f Mon Sep 17 00:00:00 2001
-From: Tomas Mraz <tomas@openssl.org>
-Date: Tue, 25 Jul 2023 15:22:48 +0200
-Subject: [PATCH] DH_check(): Do not try checking q properties if it is
- obviously invalid
-
-If  |q| >= |p| then the q value is obviously wrong as q
-is supposed to be a prime divisor of p-1.
-
-We check if p is overly large so this added test implies that
-q is not large either when performing subsequent tests using that
-q value.
-
-Otherwise if it is too large these additional checks of the q value
-such as the primality test can then trigger DoS by doing overly long
-computations.
-
-Fixes CVE-2023-3817
-
-Reviewed-by: Matt Caswell <matt@openssl.org>
-Reviewed-by: Paul Dale <pauli@openssl.org>
-Reviewed-by: Tom Cosgrove <tom.cosgrove@arm.com>
-Reviewed-by: Todd Short <todd.short@me.com>
-(Merged from https://github.com/openssl/openssl/pull/21550)
-
-(cherry picked from commit 1c16253f3c3a8d1e25918c3f404aae6a5b0893de)
-(cherry picked from commit 6a1eb62c29db6cb5eec707f9338aee00f44e26f5)
----
- crypto/dh/dh_check.c | 9 ++++++++-
- 1 file changed, 8 insertions(+), 1 deletion(-)
-
-diff --git a/crypto/dh/dh_check.c b/crypto/dh/dh_check.c
-index aef6f9b1b77d..fbe279756954 100644
---- crypto/dh/dh_check.c.orig
-+++ crypto/dh/dh_check.c
-@@ -143,7 +143,7 @@ int DH_check(const DH *dh, int *ret)
- #ifdef FIPS_MODULE
-     return DH_check_params(dh, ret);
- #else
--    int ok = 0, r;
-+    int ok = 0, r, q_good = 0;
-     BN_CTX *ctx = NULL;
-     BIGNUM *t1 = NULL, *t2 = NULL;
-     int nid = DH_get_nid((DH *)dh);
-@@ -172,6 +172,13 @@ int DH_check(const DH *dh, int *ret)
-         goto err;
- 
-     if (dh->params.q != NULL) {
-+        if (BN_ucmp(dh->params.p, dh->params.q) > 0)
-+            q_good = 1;
-+        else
-+            *ret |= DH_CHECK_INVALID_Q_VALUE;
-+    }
-+
-+    if (q_good) {
-         if (BN_cmp(dh->params.g, BN_value_one()) <= 0)
-             *ret |= DH_NOT_SUITABLE_GENERATOR;
-         else if (BN_cmp(dh->params.g, dh->params.p) >= 0)