X-Git-Url: http://git.meshlink.io/?a=blobdiff_plain;f=src%2Fprotocol_auth.c;h=416066ff0ed0a6eb6654bab6a0e70bc2b709e8e6;hb=2224a56ea44bffdafbe29ba7b74d1a0adb0cbd95;hp=6517d9ceef8765bcb5493d03b75daecd98c9865a;hpb=da64ed8d36196524ec78ad4b3b350bed35f4535c;p=meshlink diff --git a/src/protocol_auth.c b/src/protocol_auth.c index 6517d9ce..416066ff 100644 --- a/src/protocol_auth.c +++ b/src/protocol_auth.c @@ -21,6 +21,7 @@ #include "conf.h" #include "connection.h" +#include "devtools.h" #include "ecdsa.h" #include "edge.h" #include "graph.h" @@ -152,12 +153,7 @@ bool send_id(meshlink_handle_t *mesh, connection_t *c) { return send_request(mesh, c, NULL, "%d %s %d.%d %s", ID, mesh->self->name, PROT_MAJOR, PROT_MINOR, mesh->appname); } -static bool finalize_invitation(meshlink_handle_t *mesh, connection_t *c, const void *data, uint16_t len) { - if(len != 32) { - logger(mesh, MESHLINK_ERROR, "Received invalid key from invited node %s!\n", c->name); - return false; - } - +static bool commit_invitation(meshlink_handle_t *mesh, connection_t *c, const void *data) { // Create a new node node_t *n = new_node(); n->name = xstrdup(c->name); @@ -186,22 +182,7 @@ static bool finalize_invitation(meshlink_handle_t *mesh, connection_t *c, const return true; } -static bool receive_invitation_sptps(void *handle, uint8_t type, const void *data, uint16_t len) { - connection_t *c = handle; - meshlink_handle_t *mesh = c->mesh; - - if(type == 128) { - return true; - } - - if(type == 1 && c->status.invitation_used) { - return finalize_invitation(mesh, c, data, len); - } - - if(type != 0 || len != 18 || c->status.invitation_used) { - return false; - } - +static bool process_invitation(meshlink_handle_t *mesh, connection_t *c, const void *data) { // Recover the filename from the cookie and the key char *fingerprint = ecdsa_get_base64_public_key(mesh->invitation_key); char hash[64]; @@ -248,6 +229,14 @@ static bool receive_invitation_sptps(void *handle, uint8_t type, const void *dat } } + if(mesh->inviter_commits_first && !commit_invitation(mesh, c, (const char *)data + 18)) { + return false; + } + + if(mesh->inviter_commits_first) { + devtool_set_inviter_commits_first(true); + } + // Send the node the contents of the invitation file sptps_send_record(&c->sptps, 0, config.buf, config.len); @@ -259,6 +248,30 @@ static bool receive_invitation_sptps(void *handle, uint8_t type, const void *dat return true; } +static bool receive_invitation_sptps(void *handle, uint8_t type, const void *data, uint16_t len) { + connection_t *c = handle; + meshlink_handle_t *mesh = c->mesh; + + if(type == SPTPS_HANDSHAKE) { + // The peer should send its cookie first. + return true; + } + + if(mesh->inviter_commits_first) { + if(type == 2 && len == 18 + 32 && !c->status.invitation_used) { + return process_invitation(mesh, c, data); + } + } else { + if(type == 0 && len == 18 && !c->status.invitation_used) { + return process_invitation(mesh, c, data); + } else if(type == 1 && len == 32 && c->status.invitation_used) { + return commit_invitation(mesh, c, data); + } + } + + return false; +} + bool id_h(meshlink_handle_t *mesh, connection_t *c, const char *request) { assert(request); assert(*request);