]> git.meshlink.io Git - meshlink/commitdiff
Ignore REQ_KEY only if we very recently sent one ourselves.
authorGuus Sliepen <guus@meshlink.io>
Sun, 18 Aug 2019 14:58:29 +0000 (16:58 +0200)
committerGuus Sliepen <guus@meshlink.io>
Sun, 18 Aug 2019 14:58:29 +0000 (16:58 +0200)
In case the SPTPS state between two nodes becomes desynchronized, we must
allow a new SPTPS connection to be set up eventually.

src/protocol_key.c

index 179252984e1c3856947ba2569a86ba6e6d2b324c..2fbbe126e7d22dbc43396889366d1d9fcf1b1239 100644 (file)
@@ -156,7 +156,7 @@ static bool req_key_ext_h(meshlink_handle_t *mesh, connection_t *c, const char *
                if(from->sptps.label) {
                        logger(mesh, MESHLINK_DEBUG, "Got REQ_KEY from %s while we already started a SPTPS session!", from->name);
 
-                       if(strcmp(mesh->self->name, from->name) < 0) {
+                       if(mesh->loop.now.tv_sec < from->last_req_key + mesh->pingtimeout / 2 && strcmp(mesh->self->name, from->name) < 0) {
                                logger(mesh, MESHLINK_DEBUG, "Ignoring REQ_KEY from %s.", from->name);
                                return true;
                        }