X-Git-Url: https://tinc-vpn.org/git/browse?a=blobdiff_plain;f=src%2Fprotocol_auth.c;h=be90d92bfe5a619ddcb01a915bfc72101cf0d55f;hb=660a2c7d1bf7f5fba905b525bc7c3b9a5ac2ec99;hp=ac486ea6f0ba0b34b12eacc75b66990d45f7391f;hpb=53036a58790168e18f524bd923f9a7d34691ba2d;p=tinc diff --git a/src/protocol_auth.c b/src/protocol_auth.c index ac486ea6..be90d92b 100644 --- a/src/protocol_auth.c +++ b/src/protocol_auth.c @@ -379,8 +379,8 @@ bool id_h(connection_t *c, const char *request) { } if(experimental) - if(!read_ecdsa_public_key(c)) - return false; + read_ecdsa_public_key(c); + /* Ignore failures if no key known yet */ } else { if(c->protocol_minor && !ecdsa_active(c->ecdsa)) c->protocol_minor = 1; @@ -730,6 +730,12 @@ static bool upgrade_h(connection_t *c, const char *request) { return false; } + c->ecdsa = ecdsa_set_base64_public_key(pubkey); + if(!c->ecdsa) { + logger(DEBUG_ALWAYS, LOG_INFO, "Got bad Ed25519 public key from %s (%s), not upgrading.", c->name, c->hostname); + return false; + } + logger(DEBUG_ALWAYS, LOG_INFO, "Got Ed25519 public key from %s (%s), upgrading!", c->name, c->hostname); append_config_file(c->name, "Ed25519PublicKey", pubkey); c->allow_request = TERMREQ;