-
Notifications
You must be signed in to change notification settings - Fork 121
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add PKCS7-internal BIO_f_md #1886
Conversation
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## main #1886 +/- ##
==========================================
+ Coverage 78.71% 78.75% +0.04%
==========================================
Files 587 590 +3
Lines 101218 101404 +186
Branches 14361 14380 +19
==========================================
+ Hits 79669 79856 +187
+ Misses 20913 20911 -2
- Partials 636 637 +1 ☔ View full report in Codecov by Sentry. |
36c0ed7
to
9b7deca
Compare
80f21e6
to
df434b2
Compare
bc6f15f
to
1b1e2f6
Compare
crypto/pkcs7/bio/md.c
Outdated
#include "../crypto/bio/internal.h" | ||
#include "../internal.h" | ||
|
||
// BIO_put and BIO_get both add to the digest, BIO_gets returns the digest |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Was this a leaked note? It doesn't seem like BIO_f_md
has a puts method or am I overlooking something
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
hm, should be "md_write and md_read both contribute to the digest, md_gets returns digest contents"
1b1e2f6
to
8828fbd
Compare
crypto/pkcs7/bio/md.c
Outdated
static const BIO_METHOD methods_md = { | ||
BIO_TYPE_MD, "message digest", md_write, md_read, /*puts*/ NULL, | ||
md_gets, md_ctrl, md_new, md_free, /*callback_ctrl*/ NULL, | ||
}; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
NP: This would be easier to read if each field was on a separate line.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I agree, but this was clang-format
's doing. I've been using it for formatting stuff in the pkcs7/
module. If there's some set of flags/options that we prefer to use I'm happy to specify them.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
NP: In other places, we have a comment next to each value indicating the field name it corresponds to:
static const BIO_METHOD methods_md = {
BIO_TYPE_MD, // type
"message digest", // name
md_write, // bwrite
md_read, // bread
NULL, // bputs
md_gets, // bgets
md_ctrl, // ctrl
md_new, // create
md_free, // destroy
NULL, // callback_ctrl
};
crypto/pkcs7/bio/md.c
Outdated
ret = BIO_read(next, out, outl); | ||
if (BIO_get_init(b)) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This seems to support the use-case of leaving this BIO
uninitialized while still reading data from next
. In this case, data is returned that has not been digested. Is this use-case tested as well?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
hm, good point. this use-case does appear to be supported as far back as OpenSSL 1.1.1. I didn't consider this, I can add a test case.
I do wonder -- should we support this? For compatibility, I'm leaning towards "yes" but it seems like a sharp edge that could cause subtle issues with digest calculation (see also response below)...
OpenSSL's own documentation indicates that the caller should re-initialize after DigestFinal (although it doesn't say anything about initial initialization):
After the digest has been retrieved from a digest BIO it must be reinitialized by calling BIO_reset(), or BIO_set_md() before any more data is passed through it.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Per discussion here, we now require the BIO to be initialized before it can do any IO.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
hm, at any rate, it looks like IO on uninitialized BIO's is prevented higher in the call stack in bio.c.
BIO_clear_retry_flags(b); | ||
BIO_copy_next_retry(b); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If b
was not initialized, should we still be calling BIO_clear_retry_flags
and BIO_copy_next_retry
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think the answer to this is "yes". It would be needed to support its use prior to (or without) initialization.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this is addressed by requiring b
to be initialized before it can do any IO.
crypto/pkcs7/bio/md.c
Outdated
if (EVP_DigestUpdate(ctx, (unsigned char *)out, ret) <= 0) { | ||
return -1; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If this ever returns an error, should we somehow mark this BIO
and being not OK for subsequent use? In this case, next
has provided new data that can not be reprocessed on any subsequent call.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
OpenSSL doesn't do this, but i agree philosophically that we should fail loudly and not silently corrupt the digest.
EVP_DigestUpdate
's documentation stipulates an interface contract of "It returns one". Looking at the implementation, the only case where it can break that contract is if an update
function pointer isn't configured on ctx
. I believe we can trust that to always be populated as long as ctx
has been initialized by EVP_DigestInit_ex
.
So, in other words, it looks like EVP_DigestUpdate
can only fail if ctx
hasn't been initialized. This makes me consider... should we fail b
's reads/writes before next
's IO if b
hasn't been initialized? this would address your concern here and make it harder to misuse the BIO_f_md
.
8828fbd
to
7a3f7bc
Compare
crypto/pkcs7/bio/md.c
Outdated
static const BIO_METHOD methods_md = { | ||
BIO_TYPE_MD, "message digest", md_write, md_read, /*puts*/ NULL, | ||
md_gets, md_ctrl, md_new, md_free, /*callback_ctrl*/ NULL, | ||
}; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
NP: In other places, we have a comment next to each value indicating the field name it corresponds to:
static const BIO_METHOD methods_md = {
BIO_TYPE_MD, // type
"message digest", // name
md_write, // bwrite
md_read, // bread
NULL, // bputs
md_gets, // bgets
md_ctrl, // ctrl
md_new, // create
md_free, // destroy
NULL, // callback_ctrl
};
crypto/pkcs7/bio/md.c
Outdated
if (!EVP_DigestUpdate(ctx, (const unsigned char *)in, ret)) { | ||
BIO_clear_retry_flags(b); | ||
return 0; | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
NP: Since this is a non-recoverable error, shouldn't the return value be negative? The BIO_write
documentation seems to say that.
// returns the value from calling the |callback_ex|, otherwise |BIO_write|
// returns the number of bytes written, or a negative number on error.
I see OpenSSL returns 0 for this, so compatibility might dictate we do the same. (I'm also bothered that the we're unable to inform the caller about the actual number of bytes written to next
b/c we can't return a value indicating success. But that's just the nature of this API.)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
As discussed elswhere, EVP_DigestUpdate can only fail if ctx
is uninitialized here, but greed that we should return -1 and be consistent with md_read
above.
81637c1
to
9910dc5
Compare
a1f145e
## What's Changed * 800-131Ar1: length of the key-derivation key shall be at least 112 bits. by @skmcgrail in #1924 * Marshalling/Unmarshalling DH public keys by @justsmth in #1916 * Also prune SSM documents from ec2-test-framework by @samuel40791765 in #1925 * Use illegal_parameter instead of decode_error for invalid key shares by @justsmth in #1923 * Add null check in dh testing by @torben-hansen in #1937 * DH paramgen callback by @justsmth in #1928 * Upstream merge 2024 10 17 by @torben-hansen in #1934 * Remove old Intel CPU types by @justsmth in #1942 * Remove retries on PCT failure in EC and RSA key generation. by @nebeid in #1938 * Add p4p, bump up time by @justsmth in #1943 * PQ README by @jakemas in #1932 * bump mysql CI to 9.1.0 by @justsmth in #1939 * HKDF, HKDF_expand, and PBKDF Truncated SHA2-512 by @skmcgrail in #1946 * Missing functionality + Adding Nmap to our CI by @smittals2 in #1915 * Fix FIPS.md typo by @justsmth in #1950 * Support encode or decode ∞ like OpenSSL by @samuel40791765 in #1930 * Expand support for EVP_PKEY_HMAC by @justsmth in #1933 * Add PKCS7-internal BIO_f_cipher by @WillChilds-Klein in #1836 * Add PKCS7-internal BIO_f_md by @WillChilds-Klein in #1886 * Ruby Support - DSA custom md by @justsmth in #1953 * Add support for POINT_CONVERSION_HYBRID by @samuel40791765 in #1936 * Fixes for Coverity Alerts by @smittals2 in #1960 * Also test w/ gcc 4.8 by @justsmth in #1962 * Actually add support for SSL_get_server/peer_tmp_key by @samuel40791765 in #1945 * Coverity Fix Null Check by @smittals2 in #1965 * ML-KEM keygen Pairwise Consistency Test by @dkostic in #1964 * EDDSA PCT by @torben-hansen in #1968 * Expose AES_cfb1_encrypt and AES_cfb8_encrypt by @skmcgrail in #1967 **Full Changelog**: v1.37.0...v1.38.0 By submitting this pull request, I confirm that my contribution is made under the terms of the Apache 2.0 license and the ISC license.
Issues:
Addresses CryptoAlg-2494
Description of changes:
This change introduces a new filter BIO,
BIO_f_md
for use in PR 1816.Call-outs:
Testing:
By submitting this pull request, I confirm that my contribution is made under the terms of the Apache 2.0 license and the ISC license.