diff --git a/plugins/admin/systems/class_goKrbServer.inc b/plugins/admin/systems/class_goKrbServer.inc
index e5beef1250719eacbd6e3f06888602a497b57cce..edc0895365f2351510e1a25c7c6076926df8b9f7 100644 (file)
/* This plugin only writes its objectClass */
var $objectclasses = array("goKrbServer");
- var $attributes = array("goKrbServerStatus","goKrbRealm", "goKrbAdmin","goKrbPassword");
+ var $attributes = array("goKrbRealm", "goKrbAdmin","goKrbPassword");
var $StatusFlag = "goKrbServerStatus";
/* This class can't be assigned twice so it conflicts with itsself */
var $dn = NULL;
var $goKrbServerStatus= "";
var $acl;
-
+ var $cn ="";
var $goKrbRealm = "";
var $goKrbAdmin = "";
var $goKrbPassword ="";
$ldap->add($this->attrs);
}
show_ldap_error($ldap->get_error());
+ $this->handle_post_events("remove");
}
$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");
+ }
}
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");