• Please be aware: Kaspersky Anti-Virus has been deprecated
    With the upgrade to Plesk Obsidian 18.0.64, "Kaspersky Anti-Virus for Servers" will be automatically removed from the servers it is installed on. We recommend that you migrate to Sophos Anti-Virus for Servers.
  • The Horde webmail has been deprecated. Its complete removal is scheduled for April 2025. For details and recommended actions, see the Feature and Deprecation Plan.
  • We’re working on enhancing the Monitoring feature in Plesk, and we could really use your expertise! If you’re open to sharing your experiences with server and website monitoring or providing feedback, we’d love to have a one-hour online meeting with you.

Solved: Not_allowed_to_perform_deliveries_as_root

Z

zymsys

Guest
I ran into a problem today and thought I'd post the solution here in case anyone else runs into it.

I am migrating customers from my old server with no control panel, but with vchkpasswd to Plesk. I wrote a script that takes the vpasswd file and assorted .qmail files and generates a script that calls mail.sh to migrate account information. This morning it migrated an email account that had an alias which contained an underscore. The old system replaced _ with :, so it generated the following mail.sh parameter:

-aliases add:first:last

The script ran just fine, but this account wouldn't receive email. All other accounts in the domain worked, and some aliases to this account worked, but not the regular name for it.

It turns out that in /var/qmail/users/assign the : was written unchanged into the user ID field, and this caused mail deliver failures with the error "Not_allowed_to_perform_deliveries_as_root". I guess when the parser failed it gave a zero for the user's UID.

I updated my script that generates the configuration to replace : with _ and manually updated the user with the problem and now all is well.

I hope this helps someone!
 
Sure... Bear in mind that this is a work in progress. I've probably migrated 20 or so clients with it so far, and I'm still running into little things like this. Also I didn't write it with wide deployment in mind, so it may not be useful unless you're already a techie. Here it is:
Code:
#!/usr/local/bin/php
<?
$forward = array();
$box = array();
$alias = array();

$dir = "/home/vpopmail/domains/{$argv[1]}/";
$dh = opendir($dir);
if ($dh === false)
{
        echo "Can't open $dir.\n";
        exit;
}
while (($file = readdir($dh)) !== false)
{
        if (substr($file,0,7)=='.qmail-')
        {
                $local = substr($file,7);
                $dq = explode("\n",file_get_contents($dir.$file));
                foreach ($dq as $ln)
                {
                        $ln = trim($ln);
                        if ($ln == '') continue;
                        $fc = substr($ln,0,1);
                        if ($fc == '&')
                                $forward[$local] = substr($ln,1);
                        else if ($fc == '/')
                        {
                                $lp = explode('/',$ln);
                                $alias[$local] = $lp[5];
                        }
                        else if ($fc == '|')
                                $pipe[$local] = $ln;
                        else
                                $forward[$local] = $ln;
                }
        }
}
closedir($dh);

$fd = fopen("{$dir}vpasswd",'r');
while (!feof($fd))
{
        $ln = trim(fgets($fd,4096));
        $lp = explode(':',$ln);
        $box[$lp[0]] = str_replace(array("!","("),array("\!","\("),$lp[7]);
}
fclose($fd);
$allmail = array_keys(array_merge($box,$forward));
foreach ($allmail as $email)
{
        if ($email == '') continue;
        $opts = array("-c $email@{$argv[1]}");
        if (isset($box[$email]))
        {
                $opts[] = "-mailbox true";
                if ($box[$email] != '') $opts[] = "-passwd {$box[$email]}";
        }
        $myaliases = array();
        foreach ($alias as $e=>$a)
        {
                if ($a == $email) $myaliases[] = str_replace(":","_",$e);
        }
        if (count ($myaliases)>0)
        {
                $opts[] = "-aliases add:".implode(',',$myaliases);
        }
        if ($forward[$email]!='')
        {
                $opts[] = "-redirect true";
                $opts[] = "-rediraddr ".$forward[$email];
        }
        echo "/usr/local/psa/bin/mail.sh ".implode(' ',$opts)."\n";
}
?>
 
Back
Top