fantu
2009-01-06 c1c3664a30eefde593a35e87c1359af7ea9d7f21
interface/web/mail/mail_transport_edit.php
@@ -41,11 +41,8 @@
require_once('../../lib/config.inc.php');
require_once('../../lib/app.inc.php');
// Checking module permissions
if(!stristr($_SESSION["s"]["user"]["modules"],'mail')) {
   header("Location: ../index.php");
   exit;
}
//* Check permissions for module
$app->auth->check_module_permissions('mail');
// Loading classes
@@ -85,12 +82,17 @@
      } else {
         $rec["type"] = $tmp_parts[0];
      }
      if(@substr($tmp_parts[1],0,1) == '[') {
      if(@$tmp_parts[2] != '') {
         $dest = @$tmp_parts[1].':'.@$tmp_parts[2];
      } else {
         $dest = $tmp_parts[1];
      }
      if(@substr($dest,0,1) == '[') {
         $rec["mx"] = 'checked="CHECKED"';
         $rec["destination"] = @substr($tmp_parts[1],1,-1);
         $rec["destination"] = @str_replace(']','',@str_replace('[','',$dest));
      } else {
         $rec["mx"] = '';
         $rec["destination"] = @$tmp_parts[1];
         $rec["destination"] = @$dest;
      }
      
      $types = array('smtp' => 'smtp','uucp' => 'uucp','slow' => 'slow', 'error' => 'error', '' => 'null');
@@ -108,7 +110,23 @@
      
      parent::onShowEnd();
   }
   function onBeforeUpdate() {
      global $app, $conf;
      //* Check if the server has been changed
      // We do this only for the admin or reseller users, as normal clients can not change the server ID anyway
      if($_SESSION["s"]["user"]["typ"] == 'admin' || $app->auth->has_clients($_SESSION['s']['user']['userid'])) {
         $rec = $app->db->queryOneRecord("SELECT server_id from mail_transport WHERE transport_id = ".$this->id);
         if($rec['server_id'] != $this->dataRecord["server_id"]) {
            //* Add a error message and switch back to old server
            $app->tform->errorMessage .= $app->lng('The Server can not be changed.');
            $this->dataRecord["server_id"] = $rec['server_id'];
         }
         unset($rec);
      }
   }
   function onSubmit() {
      global $app, $conf;
            
@@ -130,7 +148,12 @@
      
      //* Compose transport field
      if($this->dataRecord["mx"] == 'y') {
         $transport = '['.$this->dataRecord["destination"].']';
         if(stristr($this->dataRecord["destination"],':')) {
            $tmp_parts = explode(":",$this->dataRecord["destination"]);
            $transport = '['.$tmp_parts[0].']:'.$tmp_parts[1];
         } else {
            $transport = '['.$this->dataRecord["destination"].']';
         }
      } else {
         $transport = $this->dataRecord["destination"];
      }