diff options
author | Andre Heinecke <[email protected]> | 2018-10-23 10:46:38 +0000 |
---|---|---|
committer | Andre Heinecke <[email protected]> | 2018-10-23 13:59:54 +0000 |
commit | 6b36c16f77722d17f4f317c788701cbc1e9552b2 (patch) | |
tree | 678e03fa7e7f8d04a0a73091ba2507ed30866b48 | |
parent | dirmngr: Prepare for updated WKD specs with ?l= param (diff) | |
download | gnupg-6b36c16f77722d17f4f317c788701cbc1e9552b2.tar.gz gnupg-6b36c16f77722d17f4f317c788701cbc1e9552b2.zip |
sm: Fix dirmngr loadcrl for intermediate certs
* sm/call-dirmngr.c (run_command_inq_cb): Support ISTRUSTED.
(inq_certificate): Distinguish unsupported inquiry error.
--
When loading a CRL through "gpgsm --call-dirmngr loadcrl foo"
dirmngr can ask gpgsm back if a certificate used ISTRUSTED, which
previously resulted in an error.
Diffstat (limited to '')
-rw-r--r-- | sm/call-dirmngr.c | 28 |
1 files changed, 26 insertions, 2 deletions
diff --git a/sm/call-dirmngr.c b/sm/call-dirmngr.c index 3a38bca50..fb05413a6 100644 --- a/sm/call-dirmngr.c +++ b/sm/call-dirmngr.c @@ -390,7 +390,7 @@ inq_certificate (void *opaque, const char *line) } else { - log_error ("unsupported inquiry '%s'\n", line); + log_error ("unsupported certificate inquiry '%s'\n", line); return gpg_error (GPG_ERR_ASS_UNKNOWN_INQUIRE); } @@ -950,9 +950,33 @@ run_command_inq_cb (void *opaque, const char *line) line = s; log_info ("dirmngr: %s\n", line); } + else if ((s = has_leading_keyword (line, "ISTRUSTED"))) + { + /* The server is asking us whether the certificate is a trusted + root certificate. */ + char fpr[41]; + struct rootca_flags_s rootca_flags; + int n; + + line = s; + + for (s=line,n=0; hexdigitp (s); s++, n++) + ; + if (*s || n != 40) + return gpg_error (GPG_ERR_ASS_PARAMETER); + for (s=line, n=0; n < 40; s++, n++) + fpr[n] = (*s >= 'a')? (*s & 0xdf): *s; + fpr[n] = 0; + + if (!gpgsm_agent_istrusted (parm->ctrl, NULL, fpr, &rootca_flags)) + rc = assuan_send_data (parm->ctx, "1", 1); + else + rc = 0; + return rc; + } else { - log_error ("unsupported inquiry '%s'\n", line); + log_error ("unsupported command inquiry '%s'\n", line); rc = gpg_error (GPG_ERR_ASS_UNKNOWN_INQUIRE); } |