X-Git-Url: https://tinc-vpn.org/git/browse?a=blobdiff_plain;f=src%2Fnet_setup.c;h=d53aad004f28dc2d461b02714c0f1c89ad9abdd2;hb=edc08b73a9e353bde6db4c73866a6a730a1a7cb4;hp=95ff5c3e962e08c82149a3bdb1816782d99ad2b1;hpb=40ed0c07dd3d4667054b0f5952b89ee39686493b;p=tinc diff --git a/src/net_setup.c b/src/net_setup.c index 95ff5c3e..d53aad00 100644 --- a/src/net_setup.c +++ b/src/net_setup.c @@ -50,6 +50,7 @@ char *proxyport; char *proxyuser; char *proxypass; proxytype_t proxytype; +int autoconnect; char *scriptinterpreter; char *scriptextension; @@ -284,7 +285,7 @@ void regenerate_key(void) { timeout_set(&keyexpire_event, keyexpire_handler, NULL); } - event_add(&keyexpire_event, &(struct timeval){keylifetime, 0}); + event_add(&keyexpire_event, &(struct timeval){keylifetime, rand() % 100000}); } /* @@ -347,6 +348,36 @@ void load_all_subnets(void) { closedir(dir); } +void load_all_nodes(void) { + DIR *dir; + struct dirent *ent; + char *dname; + + xasprintf(&dname, "%s" SLASH "hosts", confbase); + dir = opendir(dname); + if(!dir) { + logger(DEBUG_ALWAYS, LOG_ERR, "Could not open %s: %s", dname, strerror(errno)); + free(dname); + return; + } + + while((ent = readdir(dir))) { + if(!check_id(ent->d_name)) + continue; + + node_t *n = lookup_node(ent->d_name); + if(n) + continue; + + n = new_node(); + n->name = xstrdup(ent->d_name); + node_add(n); + } + + closedir(dir); +} + + char *get_name(void) { char *name = NULL; @@ -570,6 +601,8 @@ bool setup_myself_reloadable(void) { if(!get_config_int(lookup_config(config_tree, "KeyExpire"), &keylifetime)) keylifetime = 3600; + get_config_int(lookup_config(config_tree, "AutoConnect"), &autoconnect); + return true; } @@ -730,6 +763,8 @@ static bool setup_myself(void) { if(strictsubnets) load_all_subnets(); + else if(autoconnect) + load_all_nodes(); /* Open device */