From: Dr. Stephen Henson Date: Thu, 17 May 2007 12:55:03 +0000 (+0000) Subject: Use default md if none specified in dgst utility. X-Git-Tag: OpenSSL_0_9_8k^2~834 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=f03620ea15c4553de375258bc40bbf7a4092da90;p=oweals%2Fopenssl.git Use default md if none specified in dgst utility. --- diff --git a/apps/dgst.c b/apps/dgst.c index 147c4f9e61..deb829ae19 100644 --- a/apps/dgst.c +++ b/apps/dgst.c @@ -231,8 +231,6 @@ int MAIN(int argc, char **argv) argv++; } - if (md == NULL) - md=EVP_md5(); if(do_verify && !sigfile) { BIO_printf(bio_err, "No signature to verify: use the -signature option\n"); @@ -447,11 +445,16 @@ int MAIN(int argc, char **argv) } } /* we use md as a filter, reading from 'in' */ - else if (!BIO_set_md(bmd,md)) + else { - BIO_printf(bio_err, "Error setting digest %s\n", pname); - ERR_print_errors(bio_err); - goto end; + if (md == NULL) + md = EVP_md5(); + if (!BIO_set_md(bmd,md)) + { + BIO_printf(bio_err, "Error setting digest %s\n", pname); + ERR_print_errors(bio_err); + goto end; + } } if(sigfile && sigkey) { @@ -476,6 +479,13 @@ int MAIN(int argc, char **argv) } inp=BIO_push(bmd,in); + if (md == NULL) + { + EVP_MD_CTX *tctx; + BIO_get_md_ctx(bmd, &tctx); + md = EVP_MD_CTX_md(tctx); + } + if (argc == 0) { BIO_set_fp(in,stdin,BIO_NOCLOSE);