X-Git-Url: https://git.distorted.org.uk/~mdw/disorder/blobdiff_plain/36c5e137f39bc1ec10274201c9a13c04dcc86259..a4766caa48b06b06edbe100f8bc17db721bb0efa:/server/disorderd.c diff --git a/server/disorderd.c b/server/disorderd.c index 2bf6434..31b70a4 100644 --- a/server/disorderd.c +++ b/server/disorderd.c @@ -58,7 +58,7 @@ static int handle_sighup(ev_source attribute((unused)) *ev_, int attribute((unused)) sig, void attribute((unused)) *u) { info("received SIGHUP"); - reconfigure(ev, 1); + reconfigure(ev, RECONFIGURE_RELOADING); return 0; } @@ -244,7 +244,7 @@ int main(int argc, char **argv) { /* make sure we're not root, whatever the config says */ if(getuid() == 0 || geteuid() == 0) fatal(0, "do not run as root"); /* open a lockfile - we only want one copy of the server to run at once. */ - if(config->lock) { + if(1) { const char *lockfile; int lockfd; struct flock lock; @@ -262,8 +262,8 @@ int main(int argc, char **argv) { /* initialize database environment */ trackdb_init(TRACKDB_NORMAL_RECOVER|TRACKDB_MAY_CREATE); trackdb_master(ev); - /* install new config (calls trackdb_open()) */ - if(reconfigure(ev, 0)) + /* install new config; don't create socket */ + if(reconfigure(ev, RECONFIGURE_FIRST)) fatal(0, "failed to read configuration"); /* Open the database */ trackdb_open(TRACKDB_CAN_UPGRADE); @@ -276,6 +276,10 @@ int main(int argc, char **argv) { trackdb_old_users(); /* create a root login */ trackdb_create_root(); + /* create sockets */ + reset_sockets(ev); + /* check for change to database parameters */ + dbparams_check(); /* re-read config if we receive a SIGHUP */ if(ev_signal(ev, SIGHUP, handle_sighup, 0)) fatal(0, "ev_signal failed"); /* exit on SIGINT/SIGTERM */