logger(mesh, MESHLINK_ERROR, "Proxy type not implemented yet");
return false;
- case PROXY_EXEC:
- return true;
-
default:
logger(mesh, MESHLINK_ERROR, "Unknown proxy type");
return false;
return false;
}
- return send_request(mesh, c, "%d %s %d.%d", ID, mesh->self->connection->name, mesh->self->connection->protocol_major, minor);
+ return send_request(mesh, c, "%d %s %d.%d %s", ID, mesh->self->connection->name, mesh->self->connection->protocol_major, minor, mesh->appname);
}
static bool finalize_invitation(meshlink_handle_t *mesh, connection_t *c, const void *data, uint16_t len) {
if(!f) {
logger(mesh, MESHLINK_ERROR, "Error trying to open invitation %s\n", cookie);
+ unlink(usedname);
+ return false;
+ }
+
+ // Check the timestamp
+ struct stat st;
+
+ if(fstat(fileno(f), &st)) {
+ logger(mesh, MESHLINK_ERROR, "Could not stat invitation file %s\n", usedname);
+ fclose(f);
+ unlink(usedname);
+ return false;
+ }
+
+ if(time(NULL) > st.st_mtime + mesh->invitation_timeout) {
+ logger(mesh, MESHLINK_ERROR, "Peer %s tried to use an outdated invitation file %s\n", c->name, usedname);
+ fclose(f);
+ unlink(usedname);
return false;
}
}
}
+ bool blacklisted = false;
+ get_config_bool(lookup_config(c->config_tree, "blacklisted"), &blacklisted);
+
+ if(blacklisted) {
+ logger(mesh, MESHLINK_EPEER, "Peer %s is blacklisted", c->name);
+ return false;
+ }
+
read_ecdsa_public_key(mesh, c);
if(!ecdsa_active(c->ecdsa)) {
for splay_each(node_t, n, mesh->nodes) {
for splay_each(edge_t, e, n->edge_tree) {
- send_add_edge(mesh, c, e);
+ send_add_edge(mesh, c, e, 0);
}
}
}
/* Notify everyone of the new edge */
- send_add_edge(mesh, mesh->everyone, c->edge);
+ send_add_edge(mesh, mesh->everyone, c->edge, 0);
/* Run MST and SSSP algorithms */