Browse Source

put switch_id and start_daemon earlier

svn:r1188
Roger Dingledine 21 years ago
parent
commit
2c341cd032
1 changed files with 11 additions and 10 deletions
  1. 11 10
      src/or/main.c

+ 11 - 10
src/or/main.c

@@ -430,6 +430,17 @@ static int init_from_config(int argc, char **argv) {
     return -1;
   }
   close_logs(); /* we'll close, then open with correct loglevel if necessary */
+
+  if(options.User || options.Group) {
+    if(switch_id(options.User, options.Group) != 0) {
+      return -1;
+    }
+  }
+
+  if (options.RunAsDaemon) {
+    start_daemon(options.DataDirectory);
+  }
+
   if(!options.LogFile && !options.RunAsDaemon)
     add_stream_log(options.loglevel, "<stdout>", stdout);
   if(options.LogFile) {
@@ -450,12 +461,6 @@ static int init_from_config(int argc, char **argv) {
   global_read_bucket = options.BandwidthBurst; /* start it at max traffic */
   stats_prev_global_read_bucket = global_read_bucket;
 
-  if(options.User || options.Group) {
-    if(switch_id(options.User, options.Group) != 0) {
-      return -1;
-    }
-  }
-
   if(options.RunAsDaemon) {
     /* XXXX Can we delay this any more? */
     finish_daemon();
@@ -680,10 +685,6 @@ int tor_main(int argc, char *argv[]) {
     log_fn(LOG_WARN,"You are running Tor as root. You don't need to, and you probably shouldn't.");
 #endif
 
-  if (options.RunAsDaemon) {
-    start_daemon(options.DataDirectory);
-  }
-
   if(options.ORPort) { /* only spawn dns handlers if we're a router */
     dns_init(); /* initialize the dns resolve tree, and spawn workers */
   }