Initial support for host certificates.
Now we offer the OpenSSH certificate key types in our KEXINIT host key
algorithm list, so that if the server has a certificate, they can send
it to us.
There's a new storage.h abstraction for representing a list of trusted
host CAs, and which ones are trusted to certify hosts for what
domains. This is stored outside the normal saved session data, because
the whole point of host certificates is to avoid per-host faffing.
Configuring this set of trusted CAs is done via a new GUI dialog box,
separate from the main PuTTY config box (because it modifies a single
set of settings across all saved sessions), which you can launch by
clicking a button in the 'Host keys' pane. The GUI is pretty crude for
the moment, and very much at a 'just about usable' stage right now. It
will want some polishing.
If we have no CA configured that matches the hostname, we don't offer
to receive certified host keys in the first place. So for existing
users who haven't set any of this up yet, nothing will immediately
change.
Currently, if we do offer to receive certified host keys and the
server presents one signed by a CA we don't trust, PuTTY will bomb out
unconditionally with an error, instead of offering a confirmation box.
That's an unfinished part which I plan to fix before this goes into a
release.
2022-04-22 11:07:24 +00:00
|
|
|
#include "defs.h"
|
|
|
|
#include "misc.h"
|
|
|
|
#include "storage.h"
|
|
|
|
|
2022-05-02 06:40:52 +00:00
|
|
|
host_ca *host_ca_new(void)
|
|
|
|
{
|
|
|
|
host_ca *hca = snew(host_ca);
|
|
|
|
memset(hca, 0, sizeof(*hca));
|
2022-05-02 09:18:16 +00:00
|
|
|
hca->opts.permit_rsa_sha1 = false;
|
|
|
|
hca->opts.permit_rsa_sha256 = true;
|
|
|
|
hca->opts.permit_rsa_sha512 = true;
|
2022-05-02 06:40:52 +00:00
|
|
|
return hca;
|
|
|
|
}
|
|
|
|
|
Initial support for host certificates.
Now we offer the OpenSSH certificate key types in our KEXINIT host key
algorithm list, so that if the server has a certificate, they can send
it to us.
There's a new storage.h abstraction for representing a list of trusted
host CAs, and which ones are trusted to certify hosts for what
domains. This is stored outside the normal saved session data, because
the whole point of host certificates is to avoid per-host faffing.
Configuring this set of trusted CAs is done via a new GUI dialog box,
separate from the main PuTTY config box (because it modifies a single
set of settings across all saved sessions), which you can launch by
clicking a button in the 'Host keys' pane. The GUI is pretty crude for
the moment, and very much at a 'just about usable' stage right now. It
will want some polishing.
If we have no CA configured that matches the hostname, we don't offer
to receive certified host keys in the first place. So for existing
users who haven't set any of this up yet, nothing will immediately
change.
Currently, if we do offer to receive certified host keys and the
server presents one signed by a CA we don't trust, PuTTY will bomb out
unconditionally with an error, instead of offering a confirmation box.
That's an unfinished part which I plan to fix before this goes into a
release.
2022-04-22 11:07:24 +00:00
|
|
|
void host_ca_free(host_ca *hca)
|
|
|
|
{
|
|
|
|
sfree(hca->name);
|
|
|
|
if (hca->ca_public_key)
|
|
|
|
strbuf_free(hca->ca_public_key);
|
|
|
|
for (size_t i = 0; i < hca->n_hostname_wildcards; i++)
|
|
|
|
sfree(hca->hostname_wildcards[i]);
|
|
|
|
sfree(hca->hostname_wildcards);
|
|
|
|
sfree(hca);
|
|
|
|
}
|