diff --git a/plugins/admin/systems/class_goMailServer.inc b/plugins/admin/systems/class_goMailServer.inc
index d6ae1a90327e62e2f04e4aebae6bbd890a217556..95fe64bd990561767d71dc2805a2bf23793e3fc7 100644 (file)
var $objectclasses = array("goMailServer");
/* This class can't be assigned twice so it conflicts with itsself */
- var $conflicts = array("goMailServer");
-
var $DisplayName = "";
var $dn = NULL;
var $StatusFlag = "goMailServerStatus";
var $RestrictionFilters = array();
var $TransportProtocols = array();
var $Actions = array();
-
+ var $cn = "";
+ var $conflicts = array("goMailServer","kolab");
function goMailServer($config,$dn)
{
plugin::plugin($config,$dn);
- $this->DisplayName = _("Postfix service");
+ $this->DisplayName = _("Mail service (SMTP)");
$this->Actions = array( SERVICE_STOPPED=>SERVICE_STOPPED,
SERVICE_STARTED => SERVICE_STARTED,
- SERVICE_RESETTED=>SERVICE_RESETTED,
- "mailqueue"=>"mailqueue");
+ SERVICE_RESTARTED=>SERVICE_RESTARTED);
/* Fill RestrictionFilters TransportProtocols from external hooks */
$str = $this->config->data['TABS']['SERVERSERVICE'];
$this->TransportProtocols =array("smtp"=>"SMTP");
$this->RestrictionFilters = array("FILTER"=>"FILTER");
foreach(array("ADDITIONALRESTRICTIONFILTERS"=>"RestrictionFilters",
- "ADDITIONALPROTOCOLLS" =>"TransportProtocols") as $file => $var){
- $file = $this->config->data['MAIN'][$file];
- if((isset($file)) && is_readable($file)){
- $tmp = file_get_contents($file);
- $tmp2= split("\n",$tmp);
- foreach($tmp2 as $entry){
- if(empty($entry)) continue;
- if(preg_match("/:/",$entry)){
- $tmp3 = split(":",$entry);
- $r = $this->$var;
- $r[$tmp3[0]]=$tmp3[1];
- $this->$var = $r;
- }else{
- $r = $this->$var;
- $r[$entry] =$entry;
- $this->$var = $r;
+ "ADDITIONALPROTOCOLLS" =>"TransportProtocols") as $file => $var){
+ if(isset($this->config->data['MAIN'][$file])){
+ $file = $this->config->data['MAIN'][$file];
+ if((isset($file)) && is_readable($file)){
+ $tmp = file_get_contents($file);
+ $tmp2= split("\n",$tmp);
+ foreach($tmp2 as $entry){
+ if(empty($entry)) continue;
+ if(preg_match("/:/",$entry)){
+ $tmp3 = split(":",$entry);
+ $r = $this->$var;
+ $r[$tmp3[0]]=$tmp3[1];
+ $this->$var = $r;
+ }else{
+ $r = $this->$var;
+ $r[$entry] =$entry;
+ $this->$var = $r;
+ }
}
}
}
/* Get postfix my networks */
$this->postfixMyNetworks = array();
+ $tmp = array();
if(isset($this->attrs['postfixMyNetworks'][0])){
$tmp = split(",",$this->attrs['postfixMyNetworks'][0]);
foreach($tmp as $str){
/* Get transport tables */
+ $tmp = array();
$this->postfixTransportTable = array();
if(isset($this->attrs['postfixTransportTable'])){
$tmp = array();
/* Get sender restrictions */
+ $tmp = array();
$this->postfixSenderRestrictions = array();
if(isset($this->attrs['postfixSenderRestrictions'])){
unset($this->attrs['postfixSenderRestrictions']['count']);
/* Get sender restrictions */
+ $tmp = array();
$this->postfixRecipientRestrictions = array();
if(isset($this->attrs['postfixRecipientRestrictions'])){
unset($this->attrs['postfixRecipientRestrictions']['count']);
$this->postfixMyNetworks[base64_encode($str)] = $str;
}
- if((isset($_POST['DelpostfixMyNetworks'])) && (count($_POST['Select_postfixMyNetworks']))){
+ if((isset($_POST['DelpostfixMyNetworks'])) && isset($_POST['Select_postfixMyNetworks']) &&(count($_POST['Select_postfixMyNetworks']))){
foreach($_POST['Select_postfixMyNetworks'] as $str ){
unset($this->postfixMyNetworks[$str]);
}
$this->postfixMyDestinations[base64_encode($str)] = $str;
}
- if((isset($_POST['DelpostfixMyDestinations'])) && (count($_POST['Select_postfixMyDestinations']))){
+ if((isset($_POST['DelpostfixMyDestinations'])) && isset($_POST['Select_postfixMyDestinations']) &&(count($_POST['Select_postfixMyDestinations']))){
foreach($_POST['Select_postfixMyDestinations'] as $str ){
unset($this->postfixMyDestinations[$str]);
}
/* Create divList for translation tables */
$divTranslation = new divSelectBox("TransportProtocols");
- $divTranslation->SetHeight(110);
+ $divTranslation->SetHeight(90);
foreach($this->postfixTransportTable as $key => $entry){
$img = "";
/* Create divList for sender restrictions */
$DivSenderRestrict = new divSelectBox("postfixSenderRestrictions");
- $DivSenderRestrict->SetHeight(110);
+ $DivSenderRestrict->SetHeight(90);
foreach($this->postfixSenderRestrictions as $key => $entry){
$img ="";
/* Create divList for translation tables */
$DivRecipientRestrict = new divSelectBox("postfixRecipientRestrictions");
- $DivRecipientRestrict->SetHeight(110);
+ $DivRecipientRestrict->SetHeight(90);
+
foreach($this->postfixRecipientRestrictions as $key => $entry){
$img = "";
if($key != 0){
$smarty->assign("is_new", $this->dn);
+ $smarty->assign("is_acc", $this->initially_was_account);
$smarty->assign("TransportProtocols", $this->TransportProtocols);
$smarty->assign("Actions", $this->Actions);
$smarty->assign("RestrictionFilters", $this->RestrictionFilters);
{
$flag = $this->StatusFlag;
$fields['Status'] = $this->$flag;
- $fields['Message'] = _("Postfix"). " - ".$this->postfixMyhostname;
+ $fields['Message'] = _("Postfix")." ["._("configured for")." ".$this->postfixMyhostname."] ";
$fields['AllowStart'] = true;
$fields['AllowStop'] = true;
- $fields['AllowReset'] = true;
+ $fields['AllowRestart'] = true;
$fields['AllowRemove']= true;
$fields['AllowEdit'] = true;
return($fields);
$ldap->add($this->attrs);
}
show_ldap_error($ldap->get_error());
+ $this->handle_post_events("remove");
}
function save()
{
+ $this->postfixMyDomain = preg_replace("/^[^\.]+\./","",$this->postfixMyhostname);
+ $this->postfixMyhostname = preg_replace("/\..*$/","",$this->postfixMyhostname);
+
plugin::save();
/* Fix transport table*/
foreach($this->postfixMyNetworks as $entry){
$this->attrs['postfixMyNetworks'] .=$entry.",";
}
+ $this->attrs['postfixMyNetworks'] = preg_replace("/,$/","",$this->attrs['postfixMyNetworks']);
}else{
$this->attrs['postfixMyNetworks'] = array();
}
- $this->attrs['postfixMyNetworks'] = preg_replace("/,$/","",$this->attrs['postfixMyNetworks']);
-
- $this->attrs['postfixMyhostname'] = preg_replace("/\..*$/","",$this->postfixMyhostname);
- $this->attrs['postfixMyDomain'] = preg_replace("/^[^\.]+\./","",$this->postfixMyhostname);
/* Check if this is a new entry ... add/modify */
$ldap = $this->config->get_ldap_link();
$ldap->add($this->attrs);
}
show_ldap_error($ldap->get_error());
+ if($this->initially_was_account){
+ $this->handle_post_events("modify");
+ }else{
+ $this->handle_post_events("add");
+ }
+
}
/* Directly save new status flag */
function setStatus($value)
{
+ if($value == "none") return;
+ if(!$this->initially_was_account) return;
$ldap = $this->config->get_ldap_link();
$ldap->cd($this->dn);
$ldap->cat($this->dn,array("objectClass"));
-
if($ldap->count()){
- $attrs =array();
$tmp = $ldap->fetch();
for($i = 0; $i < $tmp['objectClass']['count']; $i ++){
$attrs['objectClass'][] = $tmp['objectClass'][$i];
}
- if(!in_array("goMailServer",$attrs['objectClass'])){
- $attrs['objectClass'][] = "goMailServer";
- }
-
$flag = $this->StatusFlag;
$attrs[$flag] = $value;
$this->$flag = $value;
$ldap->modify($attrs);
show_ldap_error($ldap->get_error());
+ $this->action_hook();
}
}
function check()
{
$message =plugin::check();
-
+
if(!is_numeric($this->postfixHeaderSizeLimit)){
$message[] = _("Please specify a numeric value for header size limit.");
}
return($ret);
}
+
+ function action_hook($add_attrs= array())
+ {
+ /* Find postcreate entries for this class */
+ $command= search_config($this->config->data['MENU'], get_class($this), "ACTION_HOOK");
+ if ($command == "" && isset($this->config->data['TABS'])){
+ $command= search_config($this->config->data['TABS'], get_class($this), "ACTION_HOOK");
+ }
+ if ($command != ""){
+ /* Walk through attribute list */
+ foreach ($this->attributes as $attr){
+ if (!is_array($this->$attr)){
+ $command= preg_replace("/%$attr/", $this->$attr, $command);
+ }
+ }
+ $command= preg_replace("/%dn/", $this->dn, $command);
+ /* Additional attributes */
+ foreach ($add_attrs as $name => $value){
+ $command= preg_replace("/%$name/", $value, $command);
+ }
+
+ /* If there are still some %.. in our command, try to fill these with some other class vars */
+ if(preg_match("/%/",$command)){
+ $attrs = get_object_vars($this);
+ foreach($attrs as $name => $value){
+ if(!is_string($value)) continue;
+ $command= preg_replace("/%$name/", $value, $command);
+ }
+ }
+
+ if (check_command($command)){
+ @DEBUG (DEBUG_SHELL, __LINE__, __FUNCTION__, __FILE__,
+ $command, "Execute");
+
+ exec($command);
+ } else {
+ $message= sprintf(_("Command '%s', specified as ACTION_HOOK for plugin '%s' doesn't seem to exist."), $command, get_class($this));
+ print_red ($message);
+ }
+ }
+ }
function save_object()
{