diff --git a/plugins/admin/systems/class_goImapServer.inc b/plugins/admin/systems/class_goImapServer.inc
index 301a2dd8721b49258e180e4344cafde733554c1a..c1571e64fd349168ba9929d1ac93474f31066fe4 100644 (file)
var $objectclasses = array("goImapServer");
/* This class can't be assigned twice so it conflicts with itsself */
- var $conflicts = array("goImapServer");
var $DisplayName = "";
var $dn = NULL;
"goImapSieveServer","goImapSievePort",
"cyrusImap","cyrusImapSSL","cyrusPop3","cyrusPop3SSL");
- var $cn;
+ var $cn = "";
var $goImapName = "";
var $goImapConnect = "";
var $acl;
- var $Actions = array();
+ var $Actions = array();
+ var $conflicts = array("goImapServer","kolab");
function goImapServer($config,$dn)
{
}
$smarty->assign("Actions",$this->Actions);
$smarty->assign("is_new",$this->dn);
+ $smarty->assign("is_acc",$this->initially_was_account);
return($smarty->fetch(get_template_path("goImapServer.tpl",TRUE,dirname(__FILE__))));
}
$ldap->add($this->attrs);
}
show_ldap_error($ldap->get_error());
+ $this->handle_post_events("remove");
}
function save()
$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");
+ }
+
}
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","goImapName","goImapConnect","goImapAdmin","goImapPassword"));
-
+ $ldap->cat($this->dn,array("objectClass"));
if($ldap->count()){
- $attrs =array();
- foreach(array("goImapName","goImapConnect","goImapAdmin","goImapPassword") as $required){
- if(!isset($attrs[$required])){
- if(empty($this->$required)){
- print_red(_("Can't set new status while there are blank option within generic configuration part."));
- return;
- }else{
- $attrs[$required] = $this->$required;
- }
- }else{
- $attrs[$required] = $attrs[$required][0];
- }
- }
-
$tmp = $ldap->fetch();
for($i = 0; $i < $tmp['objectClass']['count']; $i ++){
$attrs['objectClass'][] = $tmp['objectClass'][$i];
}
- if(!in_array("goImapServer",$attrs['objectClass'])){
- $attrs['objectClass'][] = "goImapServer";
- }
$flag = $this->StatusFlag;
$attrs[$flag] = $value;
$this->$flag = $value;
$ldap->modify($attrs);
show_ldap_error($ldap->get_error());
+ $this->action_hook();
}
}
}
}
}
+
+ 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);
+ }
+ }
+ }
+
}
// vim:tabstop=2:expandtab:shiftwidth=2:filetype=php:syntax:ruler:
?>