summaryrefslogtreecommitdiff
path: root/src/lib/libcrypto/ts/ts_rsp_verify.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/lib/libcrypto/ts/ts_rsp_verify.c')
-rw-r--r--src/lib/libcrypto/ts/ts_rsp_verify.c11
1 files changed, 7 insertions, 4 deletions
diff --git a/src/lib/libcrypto/ts/ts_rsp_verify.c b/src/lib/libcrypto/ts/ts_rsp_verify.c
index 2e72ff47ae..07578945cb 100644
--- a/src/lib/libcrypto/ts/ts_rsp_verify.c
+++ b/src/lib/libcrypto/ts/ts_rsp_verify.c
@@ -1,4 +1,4 @@
1/* $OpenBSD: ts_rsp_verify.c,v 1.22 2021/11/01 20:53:08 tb Exp $ */ 1/* $OpenBSD: ts_rsp_verify.c,v 1.23 2021/11/04 23:52:34 beck Exp $ */
2/* Written by Zoltan Glozik (zglozik@stones.com) for the OpenSSL 2/* Written by Zoltan Glozik (zglozik@stones.com) for the OpenSSL
3 * project 2002. 3 * project 2002.
4 */ 4 */
@@ -325,10 +325,14 @@ static int
325TS_find_cert(STACK_OF(ESS_CERT_ID) *cert_ids, X509 *cert) 325TS_find_cert(STACK_OF(ESS_CERT_ID) *cert_ids, X509 *cert)
326{ 326{
327 int i; 327 int i;
328 unsigned char cert_hash[TS_HASH_LEN];
328 329
329 if (!cert_ids || !cert) 330 if (!cert_ids || !cert)
330 return -1; 331 return -1;
331 332
333 if (!X509_digest(cert, TS_HASH_EVP, cert_hash, NULL))
334 return -1;
335
332 /* Recompute SHA1 hash of certificate if necessary (side effect). */ 336 /* Recompute SHA1 hash of certificate if necessary (side effect). */
333 X509_check_purpose(cert, -1, 0); 337 X509_check_purpose(cert, -1, 0);
334 338
@@ -337,9 +341,8 @@ TS_find_cert(STACK_OF(ESS_CERT_ID) *cert_ids, X509 *cert)
337 ESS_CERT_ID *cid = sk_ESS_CERT_ID_value(cert_ids, i); 341 ESS_CERT_ID *cid = sk_ESS_CERT_ID_value(cert_ids, i);
338 342
339 /* Check the SHA-1 hash first. */ 343 /* Check the SHA-1 hash first. */
340 if (cid->hash->length == sizeof(cert->sha1_hash) && 344 if (cid->hash->length == TS_HASH_LEN && !memcmp(cid->hash->data,
341 !memcmp(cid->hash->data, cert->sha1_hash, 345 cert_hash, TS_HASH_LEN)) {
342 sizeof(cert->sha1_hash))) {
343 /* Check the issuer/serial as well if specified. */ 346 /* Check the issuer/serial as well if specified. */
344 ESS_ISSUER_SERIAL *is = cid->issuer_serial; 347 ESS_ISSUER_SERIAL *is = cid->issuer_serial;
345 if (!is || !TS_issuer_serial_cmp(is, cert->cert_info)) 348 if (!is || !TS_issuer_serial_cmp(is, cert->cert_info))