Security
Headlines
HeadlinesLatestCVEs

Headline

CVE-2023-40012: src: bump OpenSSL, EKU check (#78) · trailofbits/uthenticode@caeb1eb

uthenticode is a small cross-platform library for partially verifying Authenticode digital signatures. Versions of uthenticode prior to the 2.x series did not check Extended Key Usages in certificates, in violation of the Authenticode X.509 certificate profile. As a result, a malicious user could produce a “signed” PE file that uthenticode would verify and consider valid using an X.509 certificate that isn’t entitled to produce code signatures (e.g., a SSL certificate). By design, uthenticode does not perform full-chain validation. However, the absence of EKU validation was an unintended oversight. The 2.0.0 release series includes EKU checks. There are no workarounds to this vulnerability.

CVE
#vulnerability#git#auth#ssl

Expand Up @@ -3,6 +3,7 @@ #include <openssl/crypto.h> #include <openssl/err.h> #include <openssl/x509.h> #include <openssl/x509v3.h>
#include <algorithm> #include <array> Expand Down Expand Up @@ -209,6 +210,32 @@ bool SignedData::verify_signature() const { return false; }
auto *signers_stack_ptr = PKCS7_get0_signers(p7_, nullptr, 0); if (signers_stack_ptr == nullptr) { return false; } auto signers_stack = impl::STACK_OF_X509_ptr(signers_stack_ptr, impl::SK_X509_free);
/* NOTE(ww): Authenticode specification, page 13: the signer must have the * codeSigning EKU, **or** no member of the signer’s chain may have it. * * The check below is more strict than that: **every** signer must have * the codeSigning EKU, and we don’t check the embedded chain (since * we can’t do full chain verification anyways). */ for (auto i = 0; i < sk_X509_num(signers_stack.get()); ++i) { auto *signer = sk_X509_value(signers_stack.get(), i);
/* NOTE(ww): Ths should really be X509_check_purpose with * X509_PURPOSE_CODE_SIGN, but this is inexplicably not present * in even the latest releases of OpenSSL as of 2023-05. */ auto xku_flags = X509_get_extended_key_usage(signer); if (!(xku_flags & XKU_CODE_SIGN)) { return false; } }
/* NOTE(ww): What happens below is a bit dumb: we convert our SpcIndirectDataContent back * into DER form so that we can unwrap its ASN.1 sequence and pass the underlying data * to PKCS7_verify for verification. This displays our intent a little more clearly than Expand Down

CVE: Latest News

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