diff --git a/trunk/gosa-core/plugins/admin/ogroups/tabs_ogroups.inc b/trunk/gosa-core/plugins/admin/ogroups/tabs_ogroups.inc
index 0ea570e81608d78216e78fe2241602e5355877a6..f5b777db6ac7378446dce4fd4a27ec85133fda1d 100644 (file)
{
var $base= "";
var $acl_category;
-
+ var $to_remove=array();
+
+ /*! \brief Stage an object for removal */
+ function remove($object) {
+ if (!isset($this->to_remove[$object])) {
+ $this->to_remove[$object] = $this->by_object[$object];
+ unset($this->by_object[$object]);
+ }
+ }
+
+ /*! \brief Unstage an object from removal */
+ function add($object) {
+ if (isset($this->to_remove[$object])) {
+ unset($this->to_remove[$object]);
+ }
+ }
+
function reload($dd)
{
$objects = preg_replace('/[\[\]]/', '', $dd);
}
if((!$usePhoneTab && isset($this->by_object['phonequeue']))||
(!preg_match("/U/",$objects) && isset($this->by_object['phonequeue']))){
- $this->by_object['phonequeue']->remove_from_parent();
+ $this->remove('phonequeue');
unset($this->by_object['phonequeue']);
unset($this->by_name['phonequeue']);
}
*/
if(class_available("mailogroup")){
if(!preg_match("/U/",$objects) && isset($this->by_object['mailogroup'])){
- $this->by_object['mailogroup']->remove_from_parent();
+ $this->remove('mailogroup');
unset($this->by_object['mailogroup']);
unset($this->by_name['mailogroup']);
}
if(class_available("termgroup")){
if(($mixed_type && isset($this->by_object['termgroup'])) ||
!preg_match("/T/",$objects) && !preg_match("/W/",$objects) && isset($this->by_object['termgroup'])){
- $this->by_object['termgroup']->remove_from_parent();
+ $this->remove('termgroup');
unset($this->by_object['termgroup']);
unset($this->by_name['termgroup']);
}
if(class_available("termservice")){
if(($mixed_type && isset($this->by_object['termservice'])) ||
!preg_match("/T/",$objects) &&(isset($this->by_object['termservice']))){
- $this->by_object['termservice']->remove_from_parent();
+ $this->remove('termservice');
unset($this->by_object['termservice']);
unset($this->by_name['termservice']);
}
if(class_available("termstartup")){
if(($mixed_type && isset($this->by_object['termstartup'])) ||
!preg_match("/T/",$objects)&&(isset($this->by_object['termstartup']))){
- $this->by_object['termstartup']->remove_from_parent();
+ $this->remove('termstartup');
unset($this->by_object['termstartup']);
unset($this->by_name['termstartup']);
}
if(class_available("workservice")){
if(($mixed_type && isset($this->by_object['workservice'])) ||
(!preg_match("/W/",$objects))&&(isset($this->by_object['workservice']))){
- $this->by_object['workservice']->remove_from_parent();
+ $this->remove('workservice');
unset($this->by_object['workservice']);
unset($this->by_name['workservice']);
}
if(class_available("workstartup")){
if(($mixed_type && isset($this->by_object['workstartup'])) ||
(!preg_match("/S/",$objects) && !preg_match("/W/",$objects))&&(isset($this->by_object['workstartup']))){
- $this->by_object['workstartup']->remove_from_parent();
+ $this->remove('workstartup');
unset($this->by_object['workstartup']);
unset($this->by_name['workstartup']);
if (isset($this->by_object['faiSummary'])){
- $this->by_object['faiSummary']->remove_from_parent();
unset($this->by_object['faiSummary']);
unset($this->by_name['faiSummary']);
}
$this->by_name['phonequeue']= _("Phone queue");
$this->by_object['phonequeue']= new phonequeue($this->config, $this->dn);
$this->by_object['phonequeue']->parent= &$this;
+ $this->add('phonequeue');
break;
}
}
$this->by_name['mailogroup']= _("Mail");
$this->by_object['mailogroup']= new mailogroup($this->config, $this->dn);
$this->by_object['mailogroup']->parent= &$this;
+ $this->add('mailogroup');
}
}
}
$this->by_object['termgroup']= new termgroup($this->config, $this->dn);
$this->by_object['termgroup']->inheritTimeServer = false;
$this->by_object['termgroup']->parent= &$this;
+ $this->add('termgroup');
}
}
}
if(!isset($this->by_object['termstartup'])){
$this->by_name['termstartup']= _("Startup");
$this->by_object['termstartup']= new termstartup($this->config, $this->dn,$this->by_object['ogroup']);
- $this->by_object['termstartup']->parent= &$this;
- $this->by_object['termstartup']->acl = "#all#";
+ $this->by_object['termstartup']->parent= &$this;
+ $this->by_object['termstartup']->acl = "#all#";
+ $this->add('termstartup');
}
}
}
if(!isset($this->by_object['termservice'])){
$this->by_name['termservice']= _("Devices");
$this->by_object['termservice']= new termservice($this->config, $this->dn,$this->by_object['ogroup']);
- $this->by_object['termservice']->parent= &$this;
- $this->by_object['termservice']->acl = "#all#";
+ $this->by_object['termservice']->parent= &$this;
+ $this->by_object['termservice']->acl = "#all#";
+ $this->add('termservice');
}
}
}
$this->by_object['workstartup']= new workstartup($this->config, $this->dn);
$this->by_object['workstartup']->parent= &$this;
$this->by_object['workstartup']->acl = "#all#";
+ $this->add("workstartup");
}
}
if(!$mixed_type &&
$this->by_object['workservice']->inheritTimeServer = false;
$this->by_object['workservice']->parent= &$this;
$this->by_object['workservice']->acl = "#all#";
+ $this->add("workservice");
}
}
if(class_available("faiSummary")){
$this->by_name['faiSummary']= _("FAI summary");
$this->by_object['faiSummary']= new faiSummaryTab($this->config, $this->dn);
$this->by_object['faiSummary']->parent= &$this;
+ $this->add("faiSummary");
}
}
$this->by_object['environment']= new environment($this->config, $this->dn);
$this->by_object['environment']->acl = "#all#";
$this->by_object['environment']->parent= &$this;
+ $this->add("environment");
}
}
/* Remove environment tab if not required any longer */
if(class_available("environment")){
if(!preg_match("/G/",$objects) && !preg_match("/U/",$objects) && isset($this->by_name['environment'])){
- $this->by_object['environment']->remove_from_parent();
+ $this->remove("environment");
unset($this->by_name['environment']);
unset($this->by_object['environment']);
}
$this->by_object['appgroup']= new appgroup($this->config, $this->dn);
$this->by_object['appgroup']->acl = "#all#";
$this->by_object['appgroup']->parent= &$this;
+ $this->add('appgroup');
}
}
/* Remove application tab if not required any longer */
if(class_available("appgroup")){
if(!preg_match("/G/",$objects) && !preg_match("/U/",$objects) && isset($this->by_name['appgroup'])){
- $this->by_object['appgroup']->remove_from_parent();
+ $this->remove('appgroup');
unset($this->by_name['appgroup']);
unset($this->by_object['appgroup']);
}
$new_dn= 'cn='.$baseobject->cn.','.get_ou('ogroupRDN').$baseobject->base;
/* Move group? */
- if ($this->dn != $new_dn){
+ if (LDAP::fix($this->dn) != LDAP::fix($new_dn)){
/* Write entry on new 'dn' */
if ($this->dn != "new"){
$this->dn= 'cn='.$baseobject->cn.','.get_ou('ogroupRDN').$baseobject->base;
}
+ foreach(array_keys($this->to_remove) as $object) {
+ $this->to_remove[$object]->remove_from_parent();
+ }
tabs::save();
}