auth->check_module_permissions('mail'); // Loading classes $app->uses('tpl,tform,tform_actions'); $app->load('tform_actions'); class page_action extends tform_actions { function onShowNew() { global $app, $conf; // we will check only users, not admins if($_SESSION["s"]["user"]["typ"] == 'user') { if(!$app->tform->checkClientLimit('limit_mailrouting')) { $app->error($app->tform->wordbook["limit_mailrouting_txt"]); } if(!$app->tform->checkResellerLimit('limit_mailrouting')) { $app->error('Reseller: '.$app->tform->wordbook["limit_mailrouting_txt"]); } } parent::onShowNew(); } function onShowEnd() { global $app, $conf; $tmp_parts = explode(":", $this->dataRecord["transport"]); if(!empty($this->id) && !stristr($this->dataRecord["transport"], ':')) { $rec["type"] = 'custom'; } else { if(empty($this->id) && empty($tmp_parts[0])) { $rec["type"] = 'smtp'; } else { $rec["type"] = $tmp_parts[0]; } } if(!empty($tmp_parts[2])) { $dest = @$tmp_parts[1].':'.@$tmp_parts[2]; } elseif(!empty($tmp_parts[1]) || $this->dataRecord["transport"] == ":") { $dest = $tmp_parts[1]; } else { $dest = $this->dataRecord["transport"]; } if(@substr($dest, 0, 1) == '[') { $rec["mx"] = 'checked="CHECKED"'; $rec["destination"] = @str_replace(']', '', @str_replace('[', '', $dest)); } else { $rec["mx"] = ''; $rec["destination"] = @$dest; } $types = array('smtp' => 'smtp', 'uucp' => 'uucp', 'slow' => 'slow', 'error' => 'error', 'custom' => 'custom', '' => 'null'); $type_select = ''; if(is_array($types)) { foreach( $types as $key => $val) { $selected = ($key == $rec["type"])?'SELECTED':''; $type_select .= "\r\n"; } } $rec["type"] = $type_select; $app->tpl->setVar($rec); unset($type); unset($types); 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; // Check the client limits, if user is not the admin if($_SESSION["s"]["user"]["typ"] != 'admin') { // if user is not admin // Get the limits of the client $client_group_id = $app->functions->intval($_SESSION["s"]["user"]["default_group"]); $client = $app->db->queryOneRecord("SELECT limit_mailrouting FROM sys_group, client WHERE sys_group.client_id = client.client_id and sys_group.groupid = $client_group_id"); // Check if the user may add another transport. if($this->id == 0 && $client["limit_mailrouting"] >= 0) { $tmp = $app->db->queryOneRecord("SELECT count(transport_id) as number FROM mail_transport WHERE sys_groupid = $client_group_id"); if($tmp["number"] >= $client["limit_mailrouting"]) { $app->tform->errorMessage .= $app->tform->wordbook["limit_mailrouting_txt"]."
"; } unset($tmp); } } // end if user is not admin //* Compose transport field if($this->dataRecord["mx"] == 'y') { 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"]; } if($this->dataRecord["type"] == 'custom') { $this->dataRecord["transport"] = $transport; } else { $this->dataRecord["transport"] = $this->dataRecord["type"].':'.$transport; } unset($this->dataRecord["type"]); unset($this->dataRecord["mx"]); unset($this->dataRecord["destination"]); parent::onSubmit(); } } $page = new page_action; $page->onLoad(); ?>