Author: msergeant
Date: Sat May 26 16:38:09 2007
New Revision: 745

Modified:
   trunk/qpsmtpd-async

Log:
Fix dropping privileges code to be same as forkserver


Modified: trunk/qpsmtpd-async
==============================================================================
--- trunk/qpsmtpd-async (original)
+++ trunk/qpsmtpd-async Sat May 26 16:38:09 2007
@@ -36,7 +36,8 @@
 my $PORT        = 2525;
 my $LOCALADDR   = '0.0.0.0';
 my $PROCS       = 1;
-my $USER        = '';      # user to suid to
+my $USER        = (getpwuid $>)[0];         # user to suid to
+   $USER        = "smtpd" if $USER eq "root";
 my $PAUSED      = 0;
 my $NUMACCEPT   = 20;
 my $ACCEPT_RSET = Danga::Socket->AddTimer(30, \&reset_num_accept);
@@ -76,7 +77,7 @@
 # detaint the commandline
 if ($PORT =~ /^(\d+)$/) { $PORT = $1 } else { &help }
 if ($LOCALADDR =~ /^([\d\w\-.]+)$/) { $LOCALADDR = $1 } else { &help }
-if ($USER =~ /^([\w\-]+)$/) { $USER = $1 }
+if ($USER =~ /^([\w\-]+)$/) { $USER = $1 } else { &help }
 if ($PROCS =~ /^(\d+)$/) { $PROCS = $1 } else { &help }
 
 sub force_poll {
@@ -192,17 +193,15 @@
     IO::Handle::blocking($CONFIG_SERVER, 0);
     binmode($CONFIG_SERVER, ':raw');
 
-    if ($USER) {
-        # Drop priviledges
-        my (undef, undef, $quid, $qgid) = getpwnam $USER or
-              die "unable to determine uid/gid for $USER\n";
-        $) = "";
-        POSIX::setgid($qgid) or
-              die "unable to change gid: $!\n";
-        POSIX::setuid($quid) or
-              die "unable to change uid: $!\n";
-        $> = $quid;
-    }
+    # Drop priviledges
+    my (undef, undef, $quid, $qgid) = getpwnam $USER or
+          die "unable to determine uid/gid for $USER\n";
+    $) = "";
+    POSIX::setgid($qgid) or
+          die "unable to change gid: $!\n";
+    POSIX::setuid($quid) or
+          die "unable to change uid: $!\n";
+    $> = $quid;
     
     # Load plugins here
     my $plugin_loader = Qpsmtpd::SMTP->new();

Reply via email to