main: drop privileges right after reading the config
This is the second part of fixing bug #74. I lets tinyproxy create its log and pid files as the user as which it is running, so that later on at SIGHUP, the log file can successfully be reopened. Michael
This commit is contained in:
		
							parent
							
								
									6d5709de38
								
							
						
					
					
						commit
						965664798c
					
				
							
								
								
									
										15
									
								
								src/main.c
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								src/main.c
									
									
									
									
									
								
							@ -374,6 +374,14 @@ main (int argc, char **argv)
 | 
			
		||||
                exit (EX_SOFTWARE);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        /* Switch to a different user if we're running as root */
 | 
			
		||||
        if (geteuid () == 0) {
 | 
			
		||||
                change_user (argv[0]);
 | 
			
		||||
        } else {
 | 
			
		||||
                log_message (LOG_WARNING,
 | 
			
		||||
                             "Not running as root, so not changing UID/GID.");
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        ret = setup_logging ();
 | 
			
		||||
        if (ret != 0) {
 | 
			
		||||
                exit (EX_SOFTWARE);
 | 
			
		||||
@ -419,13 +427,6 @@ main (int argc, char **argv)
 | 
			
		||||
                exit (EX_OSERR);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        /* Switch to a different user if we're running as root */
 | 
			
		||||
        if (geteuid () == 0)
 | 
			
		||||
                change_user (argv[0]);
 | 
			
		||||
        else
 | 
			
		||||
                log_message (LOG_WARNING,
 | 
			
		||||
                             "Not running as root, so not changing UID/GID.");
 | 
			
		||||
 | 
			
		||||
        if (child_pool_create () < 0) {
 | 
			
		||||
                fprintf (stderr,
 | 
			
		||||
                         "%s: Could not create the pool of children.\n",
 | 
			
		||||
 | 
			
		||||
		Loading…
	
		Reference in New Issue
	
	Block a user