if(outgoing) {
do_outgoing_connection(mesh, outgoing);
}
-
-#ifndef HAVE_MINGW
- /* Clean up dead proxy processes */
-
- while(waitpid(-1, NULL, WNOHANG) > 0);
-
-#endif
}
/*
}
}
+ if(c->status.active && c->last_key_renewal + 3600 < mesh->loop.now.tv_sec) {
+ if(!sptps_force_kex(&c->sptps)) {
+ logger(mesh, MESHLINK_ERROR, "SPTPS key renewal for connection with %s failed", c->name);
+ terminate_connection(mesh, c, true);
+ continue;
+ } else {
+ c->last_key_renewal = mesh->loop.now.tv_sec;
+ }
+ }
+
if(c->last_ping_time + pingtimeout <= mesh->loop.now.tv_sec) {
if(c->status.active) {
if(c->status.pinged) {
for splay_each(node_t, n, mesh->nodes) {
if(n->status.dirty) {
- if(node_write_config(mesh, n)) {
+ if(!node_write_config(mesh, n)) {
logger(mesh, MESHLINK_DEBUG, "Could not update %s", n->name);
}
sptps_stop(&n->sptps);
n->status.waitingforkey = false;
n->last_req_key = 0;
+ } else {
+ n->last_req_key = mesh->loop.now.tv_sec;
}
}
}