]> git.meshlink.io Git - meshlink/commitdiff
Don't load config files partially.
authorGuus Sliepen <guus@meshlink.io>
Thu, 10 Oct 2019 19:23:58 +0000 (21:23 +0200)
committerGuus Sliepen <guus@meshlink.io>
Thu, 10 Oct 2019 19:23:58 +0000 (21:23 +0200)
There are various points where we update node information and store a new
host config file to disk. However, at startup we read only part of the host
config files. This allowed a corner case where we never read the full host
config file, but did write it to disk, losing information in the process.

src/conf.c
src/net_setup.c

index 0363cde5fcc34c9ccd901ec644c78393a208af50..65ff2272ef68e50e293ad23cda5d4045315b3d7e 100644 (file)
@@ -645,7 +645,7 @@ bool config_scan_all(meshlink_handle_t *mesh, const char *conf_subdir, const cha
        assert(conf_type);
 
        if(!mesh->confbase) {
-               return false;
+               return true;
        }
 
        DIR *dir;
index 667d15a381723869df9abdf650adbeb3cdfdce23..1a123cf5415665e9ead4390fde87742dc9d8ff80 100644 (file)
@@ -46,6 +46,7 @@ static bool node_get_config(meshlink_handle_t *mesh, node_t *n, config_t *config
        uint32_t version = packmsg_get_uint32(in);
 
        if(version != MESHLINK_CONFIG_VERSION) {
+               logger(mesh, MESHLINK_ERROR, "Invalid config file for node %s", n->name);
                config_free(config);
                return false;
        }
@@ -54,6 +55,7 @@ static bool node_get_config(meshlink_handle_t *mesh, node_t *n, config_t *config
        uint32_t len = packmsg_get_str_raw(in, &name);
 
        if(len != strlen(n->name) || !name || strncmp(name, n->name, len)) {
+               logger(mesh, MESHLINK_ERROR, "Invalid config file for node %s", n->name);
                config_free(config);
                return false;
        }
@@ -61,43 +63,6 @@ static bool node_get_config(meshlink_handle_t *mesh, node_t *n, config_t *config
        return true;
 }
 
-/// Read device class, blacklist status and submesh from a host config file. Used at startup when reading all host config files.
-bool node_read_partial(meshlink_handle_t *mesh, node_t *n) {
-       config_t config;
-       packmsg_input_t in;
-
-       if(!node_get_config(mesh, n, &config, &in)) {
-               return false;
-       }
-
-       char *submesh_name = packmsg_get_str_dup(&in);
-
-       if(!strcmp(submesh_name, CORE_MESH)) {
-               free(submesh_name);
-               n->submesh = NULL;
-       } else {
-               n->submesh = lookup_or_create_submesh(mesh, submesh_name);
-               free(submesh_name);
-
-               if(!n->submesh) {
-                       config_free(&config);
-                       return false;
-               }
-       }
-
-       dev_class_t devclass = packmsg_get_int32(&in);
-       bool blacklisted = packmsg_get_bool(&in);
-       config_free(&config);
-
-       if(!packmsg_input_ok(&in) || devclass < 0 || devclass >= DEV_CLASS_COUNT) {
-               return false;
-       }
-
-       n->devclass = devclass;
-       n->status.blacklisted = blacklisted;
-       return true;
-}
-
 /// Read the public key from a host config file. Used whenever we need to start an SPTPS session.
 bool node_read_public_key(meshlink_handle_t *mesh, node_t *n) {
        if(ecdsa_active(n->ecdsa)) {
@@ -295,11 +260,23 @@ static bool load_node(meshlink_handle_t *mesh, const char *name, void *priv) {
        n = new_node();
        n->name = xstrdup(name);
 
-       if(!node_read_partial(mesh, n)) {
+       config_t config;
+       packmsg_input_t in;
+
+       if(!node_get_config(mesh, n, &config, &in)) {
+               free_node(n);
+               return false;
+       }
+
+       if(!node_read_from_config(mesh, n, &config)) {
+               logger(mesh, MESHLINK_ERROR, "Invalid config file for node %s", n->name);
+               config_free(&config);
                free_node(n);
-               return true;
+               return false;
        }
 
+       config_free(&config);
+
        node_add(mesh, n);
 
        return true;
@@ -423,7 +400,10 @@ bool setup_myself(meshlink_handle_t *mesh) {
 
        graph(mesh);
 
-       config_scan_all(mesh, "current", "hosts", load_node, NULL);
+       if(!config_scan_all(mesh, "current", "hosts", load_node, NULL)) {
+               meshlink_errno = MESHLINK_ESTORAGE;
+               return false;
+       }
 
        /* Open sockets */