Dominik
2015-04-25 f339ebf3a37fc23aac843ce1c7008d4a77d87fa8
server/plugins-available/postfix_server_plugin.inc.php
@@ -115,6 +115,7 @@
            $rbl_hosts = explode(",", $rbl_hosts);
         }
         $options = explode(", ", exec("postconf -h smtpd_recipient_restrictions"));
         $new_options = array();
         foreach ($options as $key => $value) {
            if (!preg_match('/reject_rbl_client/', $value)) {
               $new_options[] = $value;
@@ -138,6 +139,24 @@
         exec("postconf -e 'smtpd_recipient_restrictions = ".implode(", ", $new_options)."'");
      }
      
      if($mail_config['reject_sender_login_mismatch'] != $old_ini_data['mail']['reject_sender_login_mismatch']) {
         $options = explode(", ", exec("postconf -h smtpd_sender_restrictions"));
         $new_options = array();
         foreach ($options as $key => $value) {
            if (!preg_match('/reject_authenticated_sender_login_mismatch/', $value)) {
               $new_options[] = $value;
            }
         }
         if ($mail_config['reject_sender_login_mismatch'] == 'y') {
            reset($new_options); $i = 0;
            // insert after check_sender_access but before permit_...
            while (isset($new_options[$i]) && substr($new_options[$i], 0, 19) == 'check_sender_access') ++$i;
            array_splice($new_options, $i, 0, array('reject_authenticated_sender_login_mismatch'));
         }
         exec("postconf -e 'smtpd_sender_restrictions = ".implode(", ", $new_options)."'");
      }
      if ($mail_config["mailbox_virtual_uidgid_maps"] == 'y') {
         // If dovecot switch to lmtp
         if($app->system->is_installed('dovecot')) {