Improved error reporting for timestamping errors (patch from Carlo Teubner)

This commit is contained in:
Per Allansson 2015-03-10 20:29:32 +01:00
parent afd5c5177d
commit 59a42c66b6
2 changed files with 39 additions and 10 deletions

View File

@ -2,6 +2,8 @@
- add support for pkcs11-based hardware tokens - add support for pkcs11-based hardware tokens
(Patch from Leif Johansson) (Patch from Leif Johansson)
- improved error reporting of timestamping errors
(Patch from Carlo Teubner)
=== 1.7.1 (2014-07-11) === 1.7.1 (2014-07-11)

View File

@ -489,6 +489,8 @@ static int add_unauthenticated_blob(PKCS7 *sig)
} }
static int g_verbose = 0;
#ifdef ENABLE_CURL #ifdef ENABLE_CURL
static int blob_has_nl = 0; static int blob_has_nl = 0;
@ -501,6 +503,19 @@ static size_t curl_write( void *ptr, size_t sz, size_t nmemb, void *stream)
return BIO_write((BIO*)stream, ptr, sz*nmemb); return BIO_write((BIO*)stream, ptr, sz*nmemb);
} }
static void print_timestamp_error(const char *url, long http_code)
{
if (http_code != -1) {
fprintf(stderr, "Failed to convert timestamp reply from %s; "
"HTTP status %ld\n", url, http_code);
} else {
fprintf(stderr, "Failed to convert timestamp reply from %s; "
"no HTTP status available", url);
}
ERR_print_errors_fp(stderr);
}
/* /*
A timestamp request looks like this: A timestamp request looks like this:
@ -640,16 +655,25 @@ static int add_timestamp(PKCS7 *sig, char *url, char *proxy, int rfc3161, const
} else { } else {
(void)BIO_flush(bin); (void)BIO_flush(bin);
long http_code = -1;
curl_easy_getinfo(curl, CURLINFO_RESPONSE_CODE, &http_code);
/*
* At this point we could also look at the response body (and perhaps
* log it if we fail to decode the response):
*
* char *resp_body = NULL;
* long resp_body_len = BIO_get_mem_data(bin, &resp_body);
*/
if (rfc3161) { if (rfc3161) {
TimeStampResp *reply; TimeStampResp *reply;
(void)BIO_flush(bin); (void)BIO_flush(bin);
reply = ASN1_item_d2i_bio(ASN1_ITEM_rptr(TimeStampResp), bin, NULL); reply = ASN1_item_d2i_bio(ASN1_ITEM_rptr(TimeStampResp), bin, NULL);
BIO_free_all(bin); BIO_free_all(bin);
if (!reply) { if (!reply) {
if (verbose) { if (verbose)
fprintf(stderr, "Failed to convert timestamp reply\n"); print_timestamp_error(url, http_code);
ERR_print_errors_fp(stderr);
}
return -1; return -1;
} }
if (ASN1_INTEGER_get(reply->status->status) != 0) { if (ASN1_INTEGER_get(reply->status->status) != 0) {
@ -691,10 +715,8 @@ static int add_timestamp(PKCS7 *sig, char *url, char *proxy, int rfc3161, const
p7 = d2i_PKCS7_bio(b64_bin, NULL); p7 = d2i_PKCS7_bio(b64_bin, NULL);
if (p7 == NULL) { if (p7 == NULL) {
BIO_free_all(b64_bin); BIO_free_all(b64_bin);
if (verbose) { if (verbose)
fprintf(stderr, "Failed to convert timestamp reply\n"); print_timestamp_error(url, http_code);
ERR_print_errors_fp(stderr);
}
return -1; return -1;
} }
BIO_free_all(b64_bin); BIO_free_all(b64_bin);
@ -735,7 +757,7 @@ static int add_timestamp_authenticode(PKCS7 *sig, char **url, int nurls, char *p
{ {
int i; int i;
for (i=0; i<nurls; i++) { for (i=0; i<nurls; i++) {
int res = add_timestamp(sig, url[i], proxy, 0, NULL, nurls == 1); int res = add_timestamp(sig, url[i], proxy, 0, NULL, g_verbose || nurls == 1);
if (!res) return 0; if (!res) return 0;
} }
return -1; return -1;
@ -745,7 +767,7 @@ static int add_timestamp_rfc3161(PKCS7 *sig, char **url, int nurls, char *proxy,
{ {
int i; int i;
for (i=0; i<nurls; i++) { for (i=0; i<nurls; i++) {
int res = add_timestamp(sig, url[i], proxy, 1, md, nurls == 1); int res = add_timestamp(sig, url[i], proxy, 1, md, g_verbose || nurls == 1);
if (!res) return 0; if (!res) return 0;
} }
return -1; return -1;
@ -798,6 +820,7 @@ static void usage(const char *argv0)
#endif #endif
"\t\t[ -addUnauthenticatedBlob ]\n\n" "\t\t[ -addUnauthenticatedBlob ]\n\n"
"\t\t[ -nest ]\n\n" "\t\t[ -nest ]\n\n"
"\t\t[ -verbose ]\n\n"
"\t\tMSI specific:\n" "\t\tMSI specific:\n"
"\t\t[ -add-msi-dse ]\n\n" "\t\t[ -add-msi-dse ]\n\n"
"\t\t[ -in ] <infile> [-out ] <outfile>\n\n" "\t\t[ -in ] <infile> [-out ] <outfile>\n\n"
@ -2504,6 +2527,8 @@ int main(int argc, char **argv)
addBlob = 1; addBlob = 1;
} else if ((cmd == CMD_SIGN) && !strcmp(*argv, "-nest")) { } else if ((cmd == CMD_SIGN) && !strcmp(*argv, "-nest")) {
nest = 1; nest = 1;
} else if ((cmd == CMD_SIGN) && !strcmp(*argv, "-verbose")) {
g_verbose = 1;
} else if ((cmd == CMD_SIGN) && !strcmp(*argv, "-add-msi-dse")) { } else if ((cmd == CMD_SIGN) && !strcmp(*argv, "-add-msi-dse")) {
add_msi_dse = 1; add_msi_dse = 1;
} else if ((cmd == CMD_VERIFY) && !strcmp(*argv, "-require-leaf-hash")) { } else if ((cmd == CMD_VERIFY) && !strcmp(*argv, "-require-leaf-hash")) {
@ -3289,4 +3314,6 @@ Local Variables:
tab-width: 4 tab-width: 4
indent-tabs-mode: t indent-tabs-mode: t
End: End:
vim: set ts=4 :
*/ */