]> git.meshlink.io Git - meshlink/commitdiff
Only let mesh->self be reachable when the mesh is started.
authorGuus Sliepen <guus@meshlink.io>
Mon, 27 Jan 2020 14:07:35 +0000 (15:07 +0100)
committerGuus Sliepen <guus@meshlink.io>
Mon, 27 Jan 2020 14:07:35 +0000 (15:07 +0100)
This ensures meshlink_node_get_reachability(mesh->self) returns true only
if the mesh has been started. It also handles reachability of self in
graph.c just like any other node. This means there will now also be a
node status callback generated when the mesh is started and stopped.

src/graph.c
src/meshlink.c
src/net_setup.c
test/basic.c

index d70279c2e85b99f6a9f28a6ef7ed142dbfe68f7a..e6212116528a64d17bb0b03d5e209ace106158fe 100644 (file)
@@ -72,7 +72,7 @@ static void sssp_bfs(meshlink_handle_t *mesh) {
 
        /* Begin with mesh->self */
 
-       mesh->self->status.visited = true;
+       mesh->self->status.visited = mesh->threadstarted;
        mesh->self->nexthop = mesh->self;
        mesh->self->prevedge = NULL;
        mesh->self->distance = 0;
index 2d4c2e1f2beb1c218eebd5343be2f6aa75cb8644..2309d77521865147a0f584701df518bd635c12a4 100644 (file)
@@ -37,6 +37,7 @@
 #include "ed25519/sha512.h"
 #include "discovery.h"
 #include "devtools.h"
+#include "graph.h"
 
 #ifndef MSG_NOSIGNAL
 #define MSG_NOSIGNAL 0
@@ -1527,8 +1528,9 @@ bool meshlink_start(meshlink_handle_t *mesh) {
 
        pthread_cond_wait(&mesh->cond, &mesh->mutex);
        mesh->threadstarted = true;
-       mesh->self->last_reachable = time(NULL);
-       mesh->self->status.dirty = true;
+
+       // Ensure we are considered reachable
+       graph(mesh);
 
        pthread_mutex_unlock(&mesh->mutex);
        return true;
@@ -1543,11 +1545,6 @@ void meshlink_stop(meshlink_handle_t *mesh) {
        pthread_mutex_lock(&mesh->mutex);
        logger(mesh, MESHLINK_DEBUG, "meshlink_stop called\n");
 
-       if(mesh->self) {
-               mesh->self->last_unreachable = time(NULL);
-               mesh->self->status.dirty = true;
-       }
-
        // Shut down the main thread
        event_loop_stop(&mesh->loop);
 
@@ -1587,6 +1584,11 @@ void meshlink_stop(meshlink_handle_t *mesh) {
 
        exit_outgoings(mesh);
 
+       // Ensure we are considered unreachable
+       if(mesh->nodes) {
+               graph(mesh);
+       }
+
        // Try to write out any changed node config files, ignore errors at this point.
        if(mesh->nodes) {
                for splay_each(node_t, n, mesh->nodes) {
index 8baff8b87c9f9f9e623470e6f03b72dd6480f37c..1b091db04034bd1a343390f508752d89de571b6a 100644 (file)
@@ -412,12 +412,9 @@ bool setup_myself(meshlink_handle_t *mesh) {
        /* Done */
 
        mesh->self->nexthop = mesh->self;
-       mesh->self->status.reachable = true;
 
        node_add(mesh, mesh->self);
 
-       graph(mesh);
-
        if(!config_scan_all(mesh, "current", "hosts", load_node, NULL)) {
                logger(mesh, MESHLINK_WARNING, "Could not scan all host config files");
        }
index 46f86960cab377bb97f7517191560ec9c3258eb6..bf8ff772af73db120cadbc2d54403fb36b512d26 100644 (file)
@@ -37,18 +37,31 @@ int main() {
        assert(self);
        assert(!strcmp(self->name, "foo"));
 
-       // Check that we are reachable.
+       // Check that we are not reachable.
 
-       assert(meshlink_get_node_reachability(mesh, self, NULL, NULL));
+       time_t last_reachable;
+       time_t last_unreachable;
+       assert(!meshlink_get_node_reachability(mesh, self, &last_reachable, &last_unreachable));
+       assert(!last_reachable);
+       assert(!last_unreachable);
 
        // Start and stop the mesh.
 
        assert(meshlink_start(mesh));
+
+       // Check that we are now reachable
+
+       assert(meshlink_get_node_reachability(mesh, self, &last_reachable, &last_unreachable));
+       assert(last_reachable);
+       assert(!last_unreachable);
+
        meshlink_stop(mesh);
 
-       // Check that we are still reachable.
+       // Check that we are no longer reachable.
 
-       assert(meshlink_get_node_reachability(mesh, self, NULL, NULL));
+       assert(!meshlink_get_node_reachability(mesh, self, &last_reachable, &last_unreachable));
+       assert(last_reachable);
+       assert(last_unreachable);
 
        // Make sure we can start and stop the mesh again.
 
@@ -63,6 +76,15 @@ int main() {
        mesh = meshlink_open("basic_conf", "bar", "basic", DEV_CLASS_BACKBONE);
        assert(mesh);
 
+       self = meshlink_get_self(mesh);
+       assert(self);
+
+       // Check that we remembered we were reachable
+
+       assert(!meshlink_get_node_reachability(mesh, self, &last_reachable, &last_unreachable));
+       assert(last_reachable);
+       assert(last_unreachable);
+
        // Check that the name is ignored now, and that we still are "foo".
 
        assert(!meshlink_get_node(mesh, "bar"));