Code

Renamed class fai_func to FAI
authorhickert <hickert@594d385d-05f5-0310-b6e9-bd551577e9d8>
Tue, 15 Jan 2008 14:04:53 +0000 (14:04 +0000)
committerhickert <hickert@594d385d-05f5-0310-b6e9-bd551577e9d8>
Tue, 15 Jan 2008 14:04:53 +0000 (14:04 +0000)
git-svn-id: https://oss.gonicus.de/repositories/gosa/trunk@8365 594d385d-05f5-0310-b6e9-bd551577e9d8

14 files changed:
gosa-core/include/class_location.inc
gosa-core/plugins/admin/fai/class_FAI.inc [new file with mode: 0644]
gosa-core/plugins/admin/fai/class_faiHook.inc
gosa-core/plugins/admin/fai/class_faiManagement.inc
gosa-core/plugins/admin/fai/class_faiPackage.inc
gosa-core/plugins/admin/fai/class_faiPartitionTable.inc
gosa-core/plugins/admin/fai/class_faiProfile.inc
gosa-core/plugins/admin/fai/class_faiProfileEntry.inc
gosa-core/plugins/admin/fai/class_faiScript.inc
gosa-core/plugins/admin/fai/class_faiSummaryTab.inc
gosa-core/plugins/admin/fai/class_faiTemplate.inc
gosa-core/plugins/admin/fai/class_faiVariable.inc
gosa-core/plugins/admin/fai/class_fai_func.inc [deleted file]
gosa-core/plugins/admin/systems/class_workstationStartup.inc

index 3b928246009de1db146f514df196edae388b0843..f60535dee8d3fdaf698ba6187a50e01d17e13d3b 100644 (file)
@@ -92,7 +92,7 @@ $class_mapping= array(
                 "askClassName" => "plugins/admin/fai/class_askClassName.inc",
                 "faiTemplateEntry" => "plugins/admin/fai/class_faiTemplateEntry.inc",
                 "debconf" => "plugins/admin/fai/class_debconfTemplate.inc",
-                "fai_func" => "plugins/admin/fai/class_fai_func.inc",
+                "FAI" => "plugins/admin/fai/class_FAI.inc",
                 "groupManagement" => "plugins/admin/groups/class_groupManagement.inc",
                 "group" => "plugins/admin/groups/class_groupGeneric.inc",
                 "divListGroup" => "plugins/admin/groups/class_divListGroup.inc",
diff --git a/gosa-core/plugins/admin/fai/class_FAI.inc b/gosa-core/plugins/admin/fai/class_FAI.inc
new file mode 100644 (file)
index 0000000..daaf5f5
--- /dev/null
@@ -0,0 +1,742 @@
+<?php
+
+define("DEBUG_FAI_FUNC",FALSE);
+
+
+class FAI
+{
+
+  /* TEST PHASE .... */
+
+  /* Returns all object for the given release.
+     This function resolves the releases  
+     from base up to the given dn.
+   */
+  static function get_all_objects_for_given_base($Current_DN,$filter,$detailed = false)
+  {
+    global $config;
+    $ldap = $config->get_ldap_link();
+    $ldap->cd($config->current['BASE']);
+    $res = array();
+    $tmp = array();
+
+    if(!FAI::is_release_department($Current_DN)) {
+      return($res);
+    }
+
+    /* Collect some basic informations and initialize some variables */ 
+    $base_release       = FAI::get_release_dn($Current_DN);
+    $previous_releases  = array_reverse(FAI::             get_previous_releases_of_this_release($base_release,true));
+
+    /* We must also include the given release dn */
+    $previous_releases[] = $base_release;
+
+    /* Walk through all releases */
+    foreach($previous_releases as $release){
+
+      /* Get fai departments */
+      $deps_to_search = FAI::get_FAI_departments($release); 
+
+      /* For every single department  (ou=hoos,ou ..) */
+      foreach($deps_to_search as $fai_base){
+
+        /* Ldap search for fai classes specified in this release */
+        $attributes  = array("dn","objectClass","FAIstate","cn");
+        $res_tmp = get_list($filter,"fai",$fai_base,$attributes,GL_SUBSEARCH | GL_SIZELIMIT);
+
+        /* check the returned objects, and add/replace them in our return variable */
+        foreach($res_tmp as $attr){
+
+          $buffer = array();
+          $name = preg_replace("/".normalizePreg($release)."/i","",$attr['dn']);
+
+          if(isset($attr['FAIstate'][0])){
+            if(preg_match("/removed$/",$attr['FAIstate'][0])){
+              if(isset($res[$name])){
+                unset($res[$name]);
+              }
+              continue;
+            }
+          }
+
+          /* In detailed mode are some additonal informations visible */
+          if($detailed){
+
+            /* Create list of parents */
+            if(isset($res[$name])){
+              $buffer = $res[$name];
+              $buffer['parents'][] = $res[$name]['dn'];
+            }else{
+              $buffer['parents'] = array();
+            }
+
+            /* Append objectClass to resulsts */
+            foreach($attributes as $val){
+              if(isset($attr[$val])){
+                $buffer[$val] = $attr[$val];
+              }
+            }
+            unset($buffer['objectClass']['count']);
+          }
+
+          /* Add this object to our list */
+          $buffer['dn']           = $attr['dn'];
+          $res[$name] = $buffer;
+        }
+      }
+    }
+    return($res);
+  }
+
+
+  /* Return all relevant FAI departments */
+  static function get_FAI_departments($suffix = "")
+  {
+    $arr = array("hooks","scripts","disk","packages","profiles","templates","variables");
+    $tmp = array();
+    if(preg_match("/^,/",$suffix)){
+      $suffix = preg_replace("/^,/","",$suffix);
+    }
+    foreach($arr as $name){
+      if(empty($suffix)){
+        $tmp[$name] = "ou=".$name;
+      }else{
+        $tmp[$name] = "ou=".$name.",".$suffix;
+      }
+    }
+    return($tmp);
+  }
+
+
+  /* Return all releases within the given base */
+  static function get_all_releases_from_base($dn,$appendedName=false)
+  {
+    global $config;
+
+    if(!preg_match("/".normalizePreg(get_ou('faiou'))."/",$dn)){
+      $base = get_ou('faiou').$dn;
+    }else{
+      $base = $dn;
+    }
+    $res = array();  
+
+    $ldap = $config->get_ldap_link();
+    $ldap->cd($base);
+    $ldap->search("(objectClass=FAIbranch)",array("ou","dn"));
+    while($attrs = $ldap->fetch()){
+      if($appendedName){
+        $res[$attrs['dn']] = convert_department_dn(preg_replace("/,".normalizePreg(get_ou('faiou')).".*$/","",$attrs['dn']));
+      }else{
+        $res[$attrs['dn']] = $attrs['ou'][0];
+      }
+    }
+    return($res);
+  }
+
+
+  /* Add this object to list of objects, that must be checked for release saving */
+  static function prepare_to_save_FAI_object($Current_DN,$objectAttrs,$removed = false)
+  {
+    /* Get ldap object */  
+    global $config;
+    $addObj['Current_DN'] = $Current_DN;
+    $addObj['objectAttrs']= $objectAttrs;
+    $addObj['removed']    = $removed;
+    $addObj['diff']       = TRUE;
+
+    if(!$removed){
+      $ldap = $config->get_ldap_link();
+      $ldap->cd($config->current['BASE']);
+
+      /* Get some basic informations */
+      $parent_obj   = FAI::get_parent_release_object($Current_DN);
+      if(!empty($parent_obj)){
+        $ldap->cat($parent_obj,array("*"));
+        $attrs = FAI::                           prepare_ldap_fetch_to_be_saved($ldap->fetch());
+
+        if(!FAI::array_diff_FAI( $attrs,$objectAttrs)){
+          $addObj['diff'] = FALSE;
+        }
+      } 
+    }
+    $FAI_objects_to_save = session::get('FAI_objects_to_save') ;
+    $FAI_objects_to_save[$Current_DN] =  $addObj;
+    session::set('FAI_objects_to_save',$FAI_objects_to_save);
+  }
+
+
+  /* Detect differences in attribute arrays  */
+  static function array_diff_FAI($ar1,$ar2)
+  {
+
+    if((!isset($ar1['description'])) || (isset($ar1['description']) && (count($ar1['description']) == 0))){
+      $ar1['description'] = "";
+    }
+    if((!isset($ar2['description'])) || (isset($ar2['description']) && (count($ar2['description']) == 0))){
+      $ar2['description'] = "";
+    }
+
+    if(count($ar1) != count($ar2)) {
+      return (true);
+    }
+
+    foreach($ar1 as $key1 => $val1){
+
+      if((is_array($val1)) && (count($val1)==1)){
+        $ar1[$key1] = $val1[0];
+      }
+
+      if((is_array($ar2[$key1])) && (count($ar2[$key1])==1)){
+        $val1 = $val1[0];
+        $ar2[$key1] = $ar2[$key1][0];
+      }
+    }
+    ksort($ar1);
+    ksort($ar2);
+    if(count( array_diff($ar1,$ar2)) || FAI::arr_diff($ar1,$ar2)){
+      return(true);
+    }else{
+      return(false);
+    }
+  }
+
+
+  static function arr_diff($ar1,$ar2)
+  {
+    foreach($ar1 as $ak1 => $av1){
+      if(!isset($ar2[$ak1]) || (!($av1 === $ar2[$ak1]))){
+        return(true);
+      }elseif(is_array($av1)){
+        return(FAI::arr_diff($av1,$ar2[$ak1]));
+      }
+    }
+    return(FALSE);
+  }
+
+
+
+
+  /* check which objects must be saved, and save them */
+  static function save_release_changes_now()
+  {
+    /* Variable init*/
+    $to_save = array();
+
+    /* check which objects must be saved */
+    $FAI_objects_to_save = session::get('FAI_objects_to_save');
+    foreach($FAI_objects_to_save as $Current_DN => $object){
+      if($object['diff']){
+        $sub_name = $Current_DN;
+        while(isset($FAI_objects_to_save[$sub_name])){
+          $to_save[strlen($sub_name)][$sub_name] = $FAI_objects_to_save[$sub_name]; 
+          unset($FAI_objects_to_save[$sub_name]);
+          $sub_name = preg_replace('/^[^,]+,/', '', $sub_name);
+        }
+      }
+    }
+    session::set('FAI_objects_to_save',$FAI_objects_to_save);
+
+    /* Sort list of objects that must be saved, and ensure that 
+       container   objects are safed, before their childs are saved */
+    ksort($to_save);
+    $tmp = array();
+    foreach($to_save as $SubObjects){
+      foreach($SubObjects as $object){
+        $tmp[] = $object;
+      }
+    }
+    $to_save = $tmp;
+
+    /* Save objects and manage the correct release behavior*/
+    foreach($to_save as $save){
+
+      $Current_DN = $save['Current_DN'];
+      $removed    = $save['removed'];
+      $objectAttrs= $save['objectAttrs'];
+
+      /* Get ldap object */ 
+      global $config;
+      $ldap = $config->get_ldap_link();
+      $ldap->cd($config->current['BASE']);
+
+      /* Get some basic informations */
+      $base_release       = FAI::get_release_dn($Current_DN);
+      $sub_releases       = FAI::                       get_sub_releases_of_this_release($base_release,true);
+      $parent_obj         = FAI::get_parent_release_object($Current_DN);
+      $following_releases = FAI::                       get_sub_releases_of_this_release($base_release,true);
+
+      /* Check if given dn exists or if is a new entry */
+      $ldap->cat($Current_DN);
+      if(!$ldap->count()){
+        $is_new = true;
+      }else{
+        $is_new = false;
+      }
+
+      /* if parameter removed is true, we have to add FAIstate to the current attrs 
+         FAIstate should end with ...|removed after this operation */  
+      if($removed ){
+        $ldap->cat($Current_DN);
+
+        /* Get current object, because we must add the FAIstate ...|removed */
+        if((!$ldap->count()) && !empty($parent_obj)){
+          $ldap->cat($parent_obj);
+        }
+
+        /* Check if we have found a suiteable object */ 
+        if(!$ldap->count()){
+          echo "Error can't remove this object ".$Current_DN;
+          return;
+        }else{
+
+          /* Set FAIstate to current objectAttrs */
+          $objectAttrs = FAI::                           prepare_ldap_fetch_to_be_saved($ldap->fetch());
+          if(isset($objectAttrs['FAIstate'][0])){
+            if(!preg_match("/removed$/",$objectAttrs['FAIstate'][0])){
+              $objectAttrs['FAIstate'][0] .= "|removed";
+            }
+          }else{
+            $objectAttrs['FAIstate'][0] = "|removed";
+          }
+        }
+      }
+
+      /* Check if this a leaf release or not */ 
+      if(count($following_releases) == 0 ){
+
+        /* This is a leaf object. It isn't inherited by any other object */    
+        if(DEBUG_FAI_FUNC) { 
+          echo "<b>Saving directly, is a leaf object</b><br> ".$Current_DN;
+          print_a($objectAttrs);
+        }
+        FAI::save_FAI_object($Current_DN,$objectAttrs);
+      }else{
+
+        /* This object is inherited by some sub releases */  
+
+        /* Get all releases, that inherit this object */ 
+        $r = get_following_releases_that_inherit_this_object($Current_DN);
+
+        /* Get parent object */
+        $ldap->cat($parent_obj);
+        $parent_attrs = FAI::                           prepare_ldap_fetch_to_be_saved($ldap->fetch());
+
+        /* New objects require special handling */
+        if($is_new){
+
+          /* check if there is already an entry named like this,
+             in one of our parent releases */
+          if(!empty($parent_obj)){
+            if(DEBUG_FAI_FUNC) { 
+              echo "There is already an entry named like this.</b><br>";
+
+              echo "<b>Saving main object</b>".$Current_DN;
+              print_a($objectAttrs);
+            }    
+            FAI::save_FAI_object($Current_DN,$objectAttrs);
+
+            foreach($r as $key){
+              if(DEBUG_FAI_FUNC) { 
+                echo "<b>Saving parent to following release</b> ".$key;
+                print_a($parent_attrs);
+              }
+              FAI::save_FAI_object($key,$parent_attrs);
+            }
+          }else{
+
+            if(DEBUG_FAI_FUNC) { 
+              echo "<b>Saving main object</b>".$Current_DN;
+              print_a($objectAttrs);
+            }
+            FAI::save_FAI_object($Current_DN,$objectAttrs);
+
+            if(isset($objectAttrs['FAIstate'])){
+              $objectAttrs['FAIstate'] .= "|removed"; 
+            }else{
+              $objectAttrs['FAIstate'] = "|removed";
+            }
+
+            foreach($r as $key ){
+              if(DEBUG_FAI_FUNC) { 
+                echo "<b>Create an empty placeholder in follwing release</b> ".$key; 
+                print_a($objectAttrs);
+              }
+              FAI::save_FAI_object($key,$objectAttrs);
+            }
+          }
+        }else{
+
+          /* check if we must patch the follwing release */
+          if(!empty($r)){
+            foreach($r as $key ){
+              if(DEBUG_FAI_FUNC) { 
+                echo "<b>Copy current objects original attributes to next release</b> ".$key;
+                print_a($parent_attrs);
+              }
+              FAI::save_FAI_object($key,$parent_attrs);
+            }
+          }
+
+          if(DEBUG_FAI_FUNC) { 
+            echo "<b>Saving current object</b>".$parent_obj;
+            print_a($objectAttrs);
+          }
+          FAI::save_FAI_object($parent_obj,$objectAttrs);
+
+          if(($parent_obj != $Current_DN)){
+            msg_dialog::display(_("Error"), sprintf(_("Error, following objects should be equal '%s' and '%s'"),$parent_obj,$Current_DN), ERROR_DIALOG);
+          }
+        }
+      }
+    } 
+    session::set('FAI_objects_to_save',array());
+  }
+
+
+  /* this function will remove all unused (deleted) objects,
+     that have no parent object */
+  static function clean_up_releases($Current_DN)
+  {
+    global $config;
+    $ldap = $config->get_ldap_link();
+    $ldap->cd($config->current['BASE']);
+
+    /* Collect some basic informations and initialize some variables */ 
+    $base_release       = FAI::get_release_dn($Current_DN);
+    $previous_releases  = array_reverse(FAI::             get_previous_releases_of_this_release($base_release,true));
+    $Kill = array();
+    $Skip = array();
+
+    /* We must also include the given release dn */
+    $previous_releases[] = $base_release;
+
+    /* Walk through all releases */
+    foreach($previous_releases as $release){
+
+      /* Get fai departments */
+      $deps_to_search = FAI::get_FAI_departments($release); 
+
+      /* For every single department  (ou=hoos,ou ..) */
+      foreach($deps_to_search as $fai_base){
+
+        /* Ldap search for fai classes specified in this release */
+        $ldap->cd($fai_base);
+        $ldap->search("(objectClass=FAIclass)",array("dn","objectClass","FAIstate"));
+
+        /* check the returned objects, and add/replace them in our return variable */
+        while($attr = $ldap->fetch()){
+
+          $buffer = array();
+#        $name = str_ireplace($release,"",$attr['dn']);
+          $name = preg_replace("/".normalizePreg($release)."/i","",$attr['dn']);
+
+          if(isset($attr['FAIstate'][0])&&(preg_match("/removed$/",$attr['FAIstate'][0]))){
+
+            /* Check if this object is required somehow */    
+            if(!isset($Skip[$name])){
+              $Kill[$attr['dn']] = $attr['dn'];
+            }
+          }else{
+
+            /* This object is required (not removed), so do not 
+               delete any following sub releases of this object */
+            $Skip[$name] = $attr['dn'];
+          }
+        }
+      }
+    }
+    return($Kill);
+  }
+
+
+  /* Remove numeric index and 'count' from ldap->fetch result */
+  static function prepare_ldap_fetch_to_be_saved($attrs)
+  {
+    foreach($attrs as $key => $value){
+      if(is_numeric($key) || ($key == "count") || ($key == "dn")){
+        unset($attrs[$key]);
+      }
+      if(is_array($value) && isset($value['count'])){
+        unset($attrs[$key]['count']);
+      }
+    }
+    return($attrs);
+  }
+
+
+  /* Save given attrs to specified dn*/
+  static function save_FAI_object($dn,$attrs)
+  {
+    global $config;
+    $ldap = $config->get_ldap_link();
+    $ldap->cd($config->current['BASE']);
+    $ldap->create_missing_trees(preg_replace('/^[^,]+,/', '', $dn));
+    $ldap->cd($dn);
+
+    $ldap->cat($dn,array("dn"));
+    if($ldap->count()){
+
+      /* Remove FAIstate*/
+      if(!isset($attrs['FAIstate'])){
+        $attrs['FAIstate'] = array();
+      }
+
+      $ldap->modify($attrs);
+    }else{
+
+      /* Unset description if empty  */
+      if(empty($attrs['description'])){
+        unset($attrs['description']);
+      }    
+
+      $ldap->add($attrs);
+    }
+    show_ldap_error($ldap->get_error(),sprintf(_("Release management failed, can't save '%s'"),$dn));
+  }
+
+
+  /* Return FAIstate freeze branch or "" for specified release department */
+  static function get_release_tag($dn)
+  {
+    global $config;
+    $ldap = $config->get_ldap_link();
+    $ldap->cd($dn);
+    $ldap->cat($dn,array("FAIstate"));
+
+    if($ldap->count()){
+
+      $attr = $ldap->fetch();
+      if(isset($attr['FAIstate'][0])){
+        if(preg_match("/freeze/",$attr['FAIstate'][0])){
+          return("freeze");
+        }elseif(preg_match("/branch/",$attr['FAIstate'][0])){
+          return("branch");
+        }
+      }
+    }
+    return("");
+  }
+
+
+  static function get_following_releases_that_inherit_this_object($dn)
+  {
+    global $config;
+    $ldap = $config->get_ldap_link();
+    $ldap->cd($config->current['BASE']);
+
+    $ret = array();
+
+    /* Get base release */
+    $base_release = FAI::get_release_dn($dn);
+
+    /* Get previous release dns */
+    $sub_releases = FAI::                       get_sub_releases_of_this_release($base_release);
+
+    /* Get dn suffix. Example  "FAIvairableEntry=keksdose,FAIvariable=Keksregal," */
+#  $dn_suffix = str_ireplace($base_release,"",$dn);
+    $dn_suffix = preg_replace("/".normalizePreg($base_release)."/i","",$dn);
+
+    /* Check if given object also exists whitin one of these releases */
+    foreach($sub_releases as $p_release => $name){
+
+      $check_dn = $dn_suffix.$p_release;
+
+      $ldap->cat($check_dn,array("dn","objectClass"));
+
+      if($ldap->count()){
+        //return($ret);
+      }else{
+        $ret[$check_dn]=$check_dn;
+      }
+    }
+    return($ret);
+  }
+
+
+  /* Get previous version of the object dn */
+  static function get_parent_release_object($dn,$include_myself=true)
+  {
+    global $config;
+    $ldap = $config->get_ldap_link();
+    $ldap->cd($config->current['BASE']);
+    $previous_releases= array();
+
+    /* Get base release */
+    $base_release = FAI::get_release_dn($dn);
+    if($include_myself){
+      $previous_releases[] = $base_release;  
+    }
+
+    /* Get previous release dns */
+    $tmp = FAI::             get_previous_releases_of_this_release($base_release,true);
+    foreach($tmp as $release){
+      $previous_releases[] = $release;
+    }
+
+    /* Get dn suffix. Example  "FAIvairableEntry=keksdose,FAIvariable=Keksregal," */
+#  $dn_suffix = str_ireplace($base_release,"",$dn);
+    $dn_suffix = preg_replace("/".normalizePreg($base_release)."/i","",$dn);
+
+    /* Check if given object also exists whitin one of these releases */
+    foreach($previous_releases as $p_release){
+      $check_dn = $dn_suffix.$p_release;
+      $ldap->cat($check_dn,array("dn","objectClass"));
+
+      if($ldap->count()){
+        return($check_dn);
+      }
+    }
+    return("");
+  }
+
+
+  /* return release names of all parent releases */
+  static function get_previous_releases_of_this_release($dn,$flat)
+  {
+    global $config;
+    $ldap = $config->get_ldap_link();
+    $ldap->cd($config->current['BASE']);
+    $ret = array();
+
+    /* Explode dns into pieces, to be able to build parent dns */
+    $dns_to_check = gosa_ldap_explode_dn(preg_replace("/".normalizePreg(",".$config->current['BASE'])."/i","",$dn));
+
+    if(!is_array($dns_to_check)){
+      return;  
+    }
+
+    /* Unset first entry which represents the given dn */
+    unset($dns_to_check['count']); 
+    unset($dns_to_check[key($dns_to_check)]);
+
+    /* Create dns addresses and check if this dn is a release dn */
+    $id = 0;
+    while(count($dns_to_check)){
+
+      /* build parent dn */
+      $new_dn = "";
+      foreach($dns_to_check as $part){
+        $new_dn .= $part.",";
+      }
+      $new_dn .= $config->current['BASE'];
+
+      /* check if this dn is a release */
+      if(FAI::is_release_department($new_dn)){
+        if($flat){
+          $ret[$id] = $new_dn; 
+        }else{
+          $ret = array($new_dn=>$ret); 
+        }
+        $id ++;
+      }else{
+        return($ret);
+      }
+      reset($dns_to_check);
+      unset($dns_to_check[key($dns_to_check)]);
+    }
+    return($ret);
+  } 
+
+
+  /* This function returns all sub release names, recursivly  */
+  static function get_sub_releases_of_this_release($dn,$flat = false)
+  {
+    global $config;
+    $res  = array();
+    $ldap = $config->get_ldap_link();
+    $ldap->cd($config->current['BASE']);
+    $ldap->ls("(objectClass=FAIbranch)",$dn,array("objectClass","dn","ou"));
+    while($attr = $ldap->fetch()){
+
+      /* Append department name */
+      if($flat){
+        $res[$attr['dn']] = $attr['ou'][0];
+      }else{
+        $res[$attr['dn']] = array();
+      }
+
+      /* Get sub release departments of this department */
+      if(in_array("FAIbranch",$attr['objectClass'])) {
+        if($flat){
+          $tmp = FAI::                       get_sub_releases_of_this_release($attr['dn'],$flat);
+          foreach($tmp as $dn => $value){
+            $res[$dn]=$value;
+          }
+        }else{
+          $res[$attr['dn']] = FAI::                       get_sub_releases_of_this_release($attr['dn']);
+        }
+      }
+    }
+    return($res);
+  }
+
+
+  /* Check if the given department is a release department */
+  static function is_release_department($dn)
+  {
+    global $config;
+    $ldap = $config->get_ldap_link();
+    $ldap->cd($config->current['BASE']);
+    $ldap->cat($dn,array("objectClass","ou"));
+
+    /* Check objectClasses and name to check if this is a release department */
+    if($ldap->count()){
+      $attrs = $ldap->fetch();
+
+      $ou = "";
+      if(isset($attrs['ou'][0])){
+        $ou = $attrs['ou'][0]; 
+      }
+
+      if((in_array("FAIbranch",$attrs['objectClass'])) || ($ou == "fai")){
+        return($attrs['dn']);
+      }
+    }
+    return(false);
+  }
+
+
+  /* This function returns the dn of the object release */
+  static function get_release_dn($Current_DN)
+  {
+    global $config;
+    $ldap = $config->get_ldap_link();
+    $ldap->cd($config->current['BASE']);
+
+    /* Split dn into pices */ 
+    $dns_to_check = gosa_ldap_explode_dn(preg_replace("/".normalizePreg(",".$config->current['BASE'])."/i","",$Current_DN));
+
+    if(!is_array($dns_to_check)){
+      return;  
+    }
+
+    /* Use dn pieces, to create sub dns like 
+       ou=test,ou=1,ou=0...
+       ou=1,ou=0...
+       ou=0... 
+       To check which dn is our release container.
+     */
+    unset($dns_to_check['count']); 
+    while(count($dns_to_check)){
+
+      /* Create dn */
+      $new_dn = "";
+      foreach($dns_to_check as $part){
+        $new_dn .= $part.",";
+      }
+      $new_dn .= $config->current['BASE'];
+
+      /* Check if this dn is a release dn */
+      if(FAI::is_release_department($new_dn)){
+        return($new_dn);
+      }
+
+      /* Remove first element of dn pieces */
+      reset($dns_to_check);
+      unset($dns_to_check[key($dns_to_check)]);
+    }
+    return("");
+  }
+}
+// vim:tabstop=2:expandtab:shiftwidth=2:filetype=php:syntax:ruler:
+?>
index 22da2e5a2f09d8d15e95cdf70df77d5b419a504d..f65d06d1c1d1bafe4427f7430c39000061d0784c 100644 (file)
@@ -404,21 +404,21 @@ class faiHook extends plugin
     $ldap->cd ($this->dn);
 
     $faifilter = session::get('faifilter');
-    $use_dn = preg_replace("/".normalizePreg(fai_func::get_release_dn($this->dn))."/i", $faifilter['branch'], $this->dn);
+    $use_dn = preg_replace("/".normalizePreg(FAI::get_release_dn($this->dn))."/i", $faifilter['branch'], $this->dn);
     if($faifilter['branch'] == "main"){
       $use_dn = $this->dn;
     }
 
-    fai_func::prepare_to_save_FAI_object($use_dn,array(),true);
+    FAI::prepare_to_save_FAI_object($use_dn,array(),true);
 
     new log("remove","fai/".get_class($this),$use_dn,$this->attributes);
 
     foreach($this->SubObjects as $name => $obj){
-      $use_dn = preg_replace("/".normalizePreg(fai_func::get_release_dn($this->dn))."/i", $faifilter['branch'], $obj['dn']);
+      $use_dn = preg_replace("/".normalizePreg(FAI::get_release_dn($this->dn))."/i", $faifilter['branch'], $obj['dn']);
       if($faifilter['branch'] == "main"){
         $use_dn = $obj['dn'];
       }
-      fai_func::prepare_to_save_FAI_object($use_dn,array(),true);
+      FAI::prepare_to_save_FAI_object($use_dn,array(),true);
     }
     $this->handle_post_events("remove");    
   }
@@ -456,7 +456,7 @@ class faiHook extends plugin
 
     $ldap = $this->config->get_ldap_link();
 
-    fai_func::prepare_to_save_FAI_object($this->dn,$this->attrs);
+    FAI::prepare_to_save_FAI_object($this->dn,$this->attrs);
     show_ldap_error($ldap->get_error(), sprintf(_("Saving of FAI/hook with dn '%s' failed."),$this->dn));
 
     if($this->initially_was_account){
@@ -537,13 +537,13 @@ class faiHook extends plugin
       }
 
       if($obj['status'] == "delete"){
-        fai_func::prepare_to_save_FAI_object($sub_dn,array(),true);
+        FAI::prepare_to_save_FAI_object($sub_dn,array(),true);
         $this->handle_post_events("remove");
       }elseif($obj['status'] == "edited"){
-        fai_func::prepare_to_save_FAI_object($sub_dn,$tmp);
+        FAI::prepare_to_save_FAI_object($sub_dn,$tmp);
         $this->handle_post_events("modify");
       }elseif($obj['status']=="new"){
-        fai_func::prepare_to_save_FAI_object($sub_dn,$tmp);
+        FAI::prepare_to_save_FAI_object($sub_dn,$tmp);
         $this->handle_post_events("add");
       }
       $this->handle_object_tagging($sub_dn, $this->gosaUnitTag);
index 542d9e7146035ac098df8748bce8aa89438b0e54..6b9c08ddee1e856c0deaca7e2f2b6e04cf294d22 100644 (file)
@@ -284,8 +284,8 @@ class faiManagement extends plugin
           $this->dialog->by_object[$type[1]]->remove_from_parent ();
           unset ($this->dialog);
           $this->dialog= FALSE;
-          $to_del = fai_func::clean_up_releases($dn);
-          fai_func::save_release_changes_now();
+          $to_del = FAI::clean_up_releases($dn);
+          FAI::save_release_changes_now();
 
           foreach($to_del as $dn){
             $ldap->rmdir_recursive($dn);
@@ -355,8 +355,8 @@ class faiManagement extends plugin
           $this->dialog->by_object[$type[1]]->remove_from_parent ();
           unset ($this->dialog);
           $this->dialog= FALSE;
-          $to_del = fai_func::clean_up_releases($this->dn);
-          fai_func::save_release_changes_now();
+          $to_del = FAI::clean_up_releases($this->dn);
+          FAI::save_release_changes_now();
 
           foreach($to_del as $dn){
             $ldap->rmdir_recursive($dn);
@@ -786,7 +786,7 @@ class faiManagement extends plugin
                                }
                        }else{
                                $this->dialog->save();
-        fai_func::save_release_changes_now();
+        FAI::save_release_changes_now();
         if (!isset($_POST['edit_apply'])){
           del_lock ($this->dn);
           unset($this->dialog);
@@ -888,7 +888,7 @@ class faiManagement extends plugin
     if(!$base){
       $base = session::get('CurrentMainBase');
     }
-    $tmp = fai_func::get_all_releases_from_base($base,true);
+    $tmp = FAI::get_all_releases_from_base($base,true);
     foreach($tmp as $dn => $name){
       $ret[$name]=$dn;
     }
@@ -933,7 +933,7 @@ class faiManagement extends plugin
     $this->base = $base;
     $this->set_acl_base($this->base);
 
-    $this->lock_type = fai_func::get_release_tag(fai_func::get_release_dn($base));
+    $this->lock_type = FAI::get_release_tag(FAI::get_release_dn($base));
 
     /* Create a new list of FAI object 
      * Generate List of Partitions,Hooks,Scripts,Templates,Profiles ... 
@@ -956,7 +956,7 @@ class faiManagement extends plugin
     $filter = "(&(|".$filter.")(cn=$Regex))";
     
     /* Get resolved release dependencies */
-    $tmp = fai_func::get_all_objects_for_given_base($base,$filter);
+    $tmp = FAI::get_all_objects_for_given_base($base,$filter);
 
     /* Ge listed ldap objects */
     $ldap = $this->config->get_ldap_link();
@@ -1128,7 +1128,7 @@ class faiManagement extends plugin
       /* Get dialog */
       $data = $this->CopyPasteHandler->execute();
 
-      fai_func::save_release_changes_now();
+      FAI::save_release_changes_now();
 
       /* Return dialog data */
       if(!empty($data)){
index 2e62249bbb10ca9cad5b4e631b5af3681b8cf9b3..9938e2142db0430c9f470ef403e23f32cf49e4fb 100644 (file)
@@ -336,23 +336,23 @@ class faiPackage extends plugin
     $ldap = $this->config->get_ldap_link();
     $ldap->cd ($this->dn);
 
-    $use_dn = preg_replace("/".normalizePreg(fai_func::get_release_dn($this->dn))."/i", $faifilter['branch'], $this->dn);
+    $use_dn = preg_replace("/".normalizePreg(FAI::get_release_dn($this->dn))."/i", $faifilter['branch'], $this->dn);
     if($faifilter['branch'] == "main"){
       $use_dn = $this->dn;
     }
 
-    fai_func::prepare_to_save_FAI_object($use_dn,array(),true);
+    FAI::prepare_to_save_FAI_object($use_dn,array(),true);
 
     new log("remove","fai/".get_class($this),$use_dn,$this->attributes);
 
     foreach($this->ConfiguredPackages as $pkgname => $attrs){
       foreach($attrs as $name => $attr){
         $pkgdn =  "FAIvariable=".$name.",".$this->dn;
-        $use_dn = preg_replace("/".normalizePreg(fai_func::get_release_dn($this->dn))."/i", $faifilter['branch'], $pkgdn);
+        $use_dn = preg_replace("/".normalizePreg(FAI::get_release_dn($this->dn))."/i", $faifilter['branch'], $pkgdn);
         if($faifilter['branch'] == "main"){
           $use_dn = $obj['dn'];
         }
-        fai_func::prepare_to_save_FAI_object($use_dn,array(),true);
+        FAI::prepare_to_save_FAI_object($use_dn,array(),true);
       }
     }
     $this->handle_post_events("remove");
@@ -492,7 +492,7 @@ class faiPackage extends plugin
       $this->attrs['FAIdebianSection'][] = $sec;
     }
 
-    fai_func::prepare_to_save_FAI_object($this->dn,$this->attrs);
+    FAI::prepare_to_save_FAI_object($this->dn,$this->attrs);
     show_ldap_error($ldap->get_error(), sprintf(_("Saving of FAI/package list with dn '%s' failed."),$this->dn));
     
     if($this->initially_was_account){
@@ -534,7 +534,7 @@ class faiPackage extends plugin
         }
 
         if(in_array($pkgattrs['FAIvariableType'],array("boolean","multiselect","password","select","string","text"))){
-          fai_func::prepare_to_save_FAI_object($pkgdn,$pkgattrs);
+          FAI::prepare_to_save_FAI_object($pkgdn,$pkgattrs);
         }
   
         /* Handle tagging */
index 55827a6a42c287d06a530bac5ff3d93dbcaf0a89..1b4931ca76ea13961c0fb5649036d50b4c1dc873 100644 (file)
@@ -346,32 +346,32 @@ class faiPartitionTable extends plugin
     $ldap->cd ($this->dn);
 
     $faifilter = session::get('faifilter');
-    $use_dn = preg_replace("/".normalizePreg(fai_func::get_release_dn($this->dn))."/i", $faifilter['branch'], $this->dn);
+    $use_dn = preg_replace("/".normalizePreg(FAI::get_release_dn($this->dn))."/i", $faifilter['branch'], $this->dn);
     if($faifilter['branch'] == "main"){
       $use_dn = $this->dn;
     }
 
-    fai_func::prepare_to_save_FAI_object($use_dn,array(),true);
+    FAI::prepare_to_save_FAI_object($use_dn,array(),true);
 
     new log("remove","fai/".get_class($this),$use_dn,$this->attributes);   
  
     foreach($this->disks as $disk){
 
       $disk_dn = "cn=".$disk['cn'].",".$this->dn;
-      $use_dn = preg_replace("/".normalizePreg(fai_func::get_release_dn($this->dn))."/i", $faifilter['branch'], $disk_dn);
+      $use_dn = preg_replace("/".normalizePreg(FAI::get_release_dn($this->dn))."/i", $faifilter['branch'], $disk_dn);
       if($faifilter['branch'] == "main"){
         $use_dn = $disk_dn;
       }
-      fai_func::prepare_to_save_FAI_object($use_dn,array(),true);
+      FAI::prepare_to_save_FAI_object($use_dn,array(),true);
 
       foreach($disk['partitions'] as $key => $partition){    
      
         $partition_dn= "FAIpartitionNr=".$partition['FAIpartitionNr'].",".$disk_dn;      
-        $use_dn = preg_replace("/".normalizePreg(fai_func::get_release_dn($this->dn))."/i", $faifilter['branch'], $partition_dn);
+        $use_dn = preg_replace("/".normalizePreg(FAI::get_release_dn($this->dn))."/i", $faifilter['branch'], $partition_dn);
         if($faifilter['branch'] == "main"){
           $use_dn = $disk_dn;
         }
-        fai_func::prepare_to_save_FAI_object($use_dn,array(),true);
+        FAI::prepare_to_save_FAI_object($use_dn,array(),true);
       }
     }
   }
@@ -414,7 +414,7 @@ class faiPartitionTable extends plugin
 
     $ldap = $this->config->get_ldap_link();
 
-    fai_func::prepare_to_save_FAI_object($this->dn,$this->attrs);
+    FAI::prepare_to_save_FAI_object($this->dn,$this->attrs);
     show_ldap_error($ldap->get_error(), sprintf(_("Saving of FAI/partition table with dn '%s' failed."),$this->dn));
 
     if($this->initially_was_account){
@@ -461,13 +461,13 @@ class faiPartitionTable extends plugin
       }
 
       if($disk['status'] == "delete"){
-        fai_func::prepare_to_save_FAI_object($disk_dn,array(),true);
+        FAI::prepare_to_save_FAI_object($disk_dn,array(),true);
         $this->handle_post_events("remove");
       }elseif($disk['status'] == "edited"){
-        fai_func::prepare_to_save_FAI_object($disk_dn,$disk_attrs);
+        FAI::prepare_to_save_FAI_object($disk_dn,$disk_attrs);
         $this->handle_post_events("modify");
       }elseif($disk['status']=="new"){
-        fai_func::prepare_to_save_FAI_object($disk_dn,$disk_attrs);
+        FAI::prepare_to_save_FAI_object($disk_dn,$disk_attrs);
         $this->handle_post_events("add");
       }
 
@@ -512,13 +512,13 @@ class faiPartitionTable extends plugin
         }
 
         if($partition['status'] == "delete"){
-          fai_func::prepare_to_save_FAI_object($partition_dn,array(),true);
+          FAI::prepare_to_save_FAI_object($partition_dn,array(),true);
           $this->handle_post_events("remove");
         }elseif($partition['status'] == "edited"){
-          fai_func::prepare_to_save_FAI_object($partition_dn,$partition_attrs);
+          FAI::prepare_to_save_FAI_object($partition_dn,$partition_attrs);
           $this->handle_post_events("modify");
         }elseif($partition['status']=="new"){
-          fai_func::prepare_to_save_FAI_object($partition_dn,$partition_attrs);
+          FAI::prepare_to_save_FAI_object($partition_dn,$partition_attrs);
           $this->handle_post_events("add");
         }
 
index 382f09bafd4af84dea1af5f74ddbfc4882bc31c1..cd325b47524bafa0cd4856729930e61b44b9aa6a 100644 (file)
@@ -370,13 +370,13 @@ class faiProfile extends plugin
     $ldap->cd ($this->dn);
 
     $faifilter = session::get('faifilter');
-    $use_dn = preg_replace("/".normalizePreg(fai_func::get_release_dn($this->dn))."/i", $faifilter['branch'], $this->dn);
+    $use_dn = preg_replace("/".normalizePreg(FAI::get_release_dn($this->dn))."/i", $faifilter['branch'], $this->dn);
     if($faifilter['branch'] == "main"){
       $use_dn = $this->dn;
     }
 
     new log("remove","fai/".get_class($this),$use_dn,$this->attributes);
-    fai_func::prepare_to_save_FAI_object($use_dn,array(),true);
+    FAI::prepare_to_save_FAI_object($use_dn,array(),true);
     $this->handle_post_events("remove");    
   }
 
@@ -440,7 +440,7 @@ class faiProfile extends plugin
 
     $this->attrs['FAIclass']=trim($this->FAIclass);
 
-    fai_func::prepare_to_save_FAI_object($this->dn,$this->attrs);
+    FAI::prepare_to_save_FAI_object($this->dn,$this->attrs);
    
     if($this->initially_was_account){
       new log("modify","fai/".get_class($this),$this->dn,$this->attributes);
index 38dc606b69eb0736ccb833f000580c01931fb8ab..8963973e3247f425b9f306e7d5f58a933dbe7ffb 100644 (file)
@@ -32,7 +32,7 @@ class faiProfileEntry extends plugin
     $filter = "(|(objectClass=FAIscript)(objectClass=FAItemplate)(objectClass=FAIhook)".
                 "(objectClass=FAIvariable)(objectClass=FAIpartitionTable)(objectClass=FAIpackageList))";
 
-    $FAI_objects = fai_func::get_all_objects_for_given_base($base,$filter,true);
+    $FAI_objects = FAI::get_all_objects_for_given_base($base,$filter,true);
 
     /* Create array with categories to be able to sort different types of objects */
     $categories = array("FAIscript"         => "faiScript",
index 3f3ba1fbdef2f9283648a3eae4b84dbc9273cc8c..68a58e0160f47b968e18814d49d4a06abe184ab9 100644 (file)
@@ -438,21 +438,21 @@ class faiScript extends plugin
       $ldap = $this->config->get_ldap_link();
       $ldap->cd ($this->dn);
       $faifilter = session::get('faifilter');
-      $use_dn = preg_replace("/".normalizePreg(fai_func::get_release_dn($this->dn))."/i", $faifilter['branch'], $this->dn);
+      $use_dn = preg_replace("/".normalizePreg(FAI::get_release_dn($this->dn))."/i", $faifilter['branch'], $this->dn);
       if($faifilter['branch'] == "main"){
         $use_dn = $this->dn;
       }
    
       new log("remove","fai/".get_class($this),$use_dn,$this->attributes);
  
-      fai_func::prepare_to_save_FAI_object($use_dn,array(),true);
+      FAI::prepare_to_save_FAI_object($use_dn,array(),true);
       
       foreach($this->SubObjects as $name => $obj){
-        $use_dn = preg_replace("/".normalizePreg(fai_func::get_release_dn($this->dn))."/i", $faifilter['branch'], $obj['dn']);
+        $use_dn = preg_replace("/".normalizePreg(FAI::get_release_dn($this->dn))."/i", $faifilter['branch'], $obj['dn']);
         if($faifilter['branch'] == "main"){
           $use_dn = $obj['dn'];
         }
-        fai_func::prepare_to_save_FAI_object($use_dn,array(),true);
+        FAI::prepare_to_save_FAI_object($use_dn,array(),true);
       }
       $this->handle_post_events("remove");
     }
@@ -503,7 +503,7 @@ class faiScript extends plugin
 
     $ldap = $this->config->get_ldap_link();
 
-    fai_func::prepare_to_save_FAI_object($this->dn,$this->attrs);
+    FAI::prepare_to_save_FAI_object($this->dn,$this->attrs);
     show_ldap_error($ldap->get_error(), sprintf(_("Creating of FAI/script with dn '%s' failed."),$this->dn));
 
     if($this->initially_was_account){
@@ -587,13 +587,13 @@ class faiScript extends plugin
       }
 
       if($obj['status'] == "delete"){
-        fai_func::prepare_to_save_FAI_object($sub_dn,array(),true);
+        FAI::prepare_to_save_FAI_object($sub_dn,array(),true);
         $this->handle_post_events("remove");
       }elseif($obj['status'] == "edited"){
-        fai_func::prepare_to_save_FAI_object($sub_dn,$tmp);
+        FAI::prepare_to_save_FAI_object($sub_dn,$tmp);
         $this->handle_post_events("modify");
       }elseif($obj['status']=="new"){
-        fai_func::prepare_to_save_FAI_object($sub_dn,$tmp);
+        FAI::prepare_to_save_FAI_object($sub_dn,$tmp);
         $this->handle_post_events("add");
       }
 
index 093378a6884f03192b8f0b3ed50a7896ea3d0f6f..f2bdd51f1ac847cc62357b5bc8f0bf2f1df6dc6b 100644 (file)
@@ -162,7 +162,7 @@ class faiSummaryTab extends plugin{
     if(!$base){
       $base = $this->base;
     }
-    return(fai_func::get_all_releases_from_base($base,true));
+    return(FAI::get_all_releases_from_base($base,true));
   }
 
 
@@ -383,7 +383,7 @@ class faiSummaryTab extends plugin{
   {
     $ldap                = $this->config->get_ldap_link();
     $dn                    = $this->Releases [$this->Release];
-    $resolvedClasses  = fai_func::get_all_objects_for_given_base($dn,"(&(objectClass=FAIclass)(cn=".$class."))");
+    $resolvedClasses  = FAI::get_all_objects_for_given_base($dn,"(&(objectClass=FAIclass)(cn=".$class."))");
 
     /* Try to fetch all types of fai objects with the given cn  */
     foreach($resolvedClasses as $obj){
index b3e24e86335a267f051dcd787c38e23645fe9071..b13104b30951edb45e5bb91a44d3a12a618d64a6 100644 (file)
@@ -388,20 +388,20 @@ class faiTemplate extends plugin
     $ldap->cd ($this->dn);
 
     $faifilter = session::get('faifilter');
-    $use_dn = preg_replace("/".normalizePreg(fai_func::get_release_dn($this->dn))."/i", $faifilter['branch'], $this->dn);
+    $use_dn = preg_replace("/".normalizePreg(FAI::get_release_dn($this->dn))."/i", $faifilter['branch'], $this->dn);
     if($faifilter['branch'] == "main"){
       $use_dn = $this->dn;
     }
 
-    fai_func::prepare_to_save_FAI_object($use_dn,array(),true);
+    FAI::prepare_to_save_FAI_object($use_dn,array(),true);
     new log("remove","fai/".get_class($this),$use_dn,$this->attributes);
 
     foreach($this->SubObjects as $name => $obj){
-      $use_dn = preg_replace("/".normalizePreg(fai_func::get_release_dn($this->dn))."/i", $faifilter['branch'], $obj['dn']);
+      $use_dn = preg_replace("/".normalizePreg(FAI::get_release_dn($this->dn))."/i", $faifilter['branch'], $obj['dn']);
       if($faifilter['branch'] == "main"){
         $use_dn = $obj['dn'];
       }
-      fai_func::prepare_to_save_FAI_object($use_dn,array(),true);
+      FAI::prepare_to_save_FAI_object($use_dn,array(),true);
     }
     $this->handle_post_events("remove");    
   }
@@ -434,7 +434,7 @@ class faiTemplate extends plugin
 
     $ldap = $this->config->get_ldap_link();
 
-    fai_func::prepare_to_save_FAI_object($this->dn,$this->attrs);
+    FAI::prepare_to_save_FAI_object($this->dn,$this->attrs);
     show_ldap_error($ldap->get_error(), sprintf(_("Saving of FAI/template with dn '%s' failed."),$this->dn));
 
     if($this->initially_was_account){
@@ -506,13 +506,13 @@ class faiTemplate extends plugin
       }
 
       if($obj['status'] == "delete"){
-        fai_func::prepare_to_save_FAI_object($sub_dn,array(),true);
+        FAI::prepare_to_save_FAI_object($sub_dn,array(),true);
         $this->handle_post_events("remove");
       }elseif($obj['status'] == "edited"){
-        fai_func::prepare_to_save_FAI_object($sub_dn,$tmp);
+        FAI::prepare_to_save_FAI_object($sub_dn,$tmp);
         $this->handle_post_events("modify");
       }elseif($obj['status']=="new"){
-        fai_func::prepare_to_save_FAI_object($sub_dn,$tmp);
+        FAI::prepare_to_save_FAI_object($sub_dn,$tmp);
         $this->handle_post_events("add");
       }
 
index 32f26c1b99733e387bf669a73d63b310616232ec..278710e72ff6ebf328f5a3e606d775a32546b554 100644 (file)
@@ -285,20 +285,20 @@ class faiVariable extends plugin
       $ldap->cd ($this->dn);
 
       $faifilter = session::get('faifilter');
-      $use_dn = preg_replace("/".normalizePreg(fai_func::get_release_dn($this->dn))."/i", $faifilter['branch'], $this->dn);
+      $use_dn = preg_replace("/".normalizePreg(FAI::get_release_dn($this->dn))."/i", $faifilter['branch'], $this->dn);
       if($faifilter['branch'] == "main"){
         $use_dn = $this->dn;
       }
   
-      fai_func::prepare_to_save_FAI_object($use_dn,array(),true);
+      FAI::prepare_to_save_FAI_object($use_dn,array(),true);
       new log("remove","fai/".get_class($this),$use_dn,$this->attributes);
 
       foreach($this->SubObjects as $name => $obj){
-        $use_dn = preg_replace("/".normalizePreg(fai_func::get_release_dn($this->dn))."/i", $faifilter['branch'], $obj['dn']);
+        $use_dn = preg_replace("/".normalizePreg(FAI::get_release_dn($this->dn))."/i", $faifilter['branch'], $obj['dn']);
         if($faifilter['branch'] == "main"){
           $use_dn = $obj['dn'];
         }
-        fai_func::prepare_to_save_FAI_object($use_dn,array(),true);
+        FAI::prepare_to_save_FAI_object($use_dn,array(),true);
       }
       $this->handle_post_events("remove");
     }
@@ -336,7 +336,7 @@ class faiVariable extends plugin
     plugin::save();
  
     $ldap = $this->config->get_ldap_link();
-    fai_func::prepare_to_save_FAI_object($this->dn,$this->attrs);
+    FAI::prepare_to_save_FAI_object($this->dn,$this->attrs);
     show_ldap_error($ldap->get_error(), sprintf(_("Saving of FAI/variable with dn '%s' failed."),$this->dn));
 
     if($this->initially_was_account){
@@ -402,13 +402,13 @@ class faiVariable extends plugin
       }
       
       if($obj['status'] == "delete"){
-        fai_func::prepare_to_save_FAI_object($sub_dn,array(),true);
+        FAI::prepare_to_save_FAI_object($sub_dn,array(),true);
         $this->handle_post_events("remove");
       }elseif($obj['status'] == "edited"){
-        fai_func::prepare_to_save_FAI_object($sub_dn,$tmp);
+        FAI::prepare_to_save_FAI_object($sub_dn,$tmp);
         $this->handle_post_events("modify");
       }elseif($obj['status']=="new"){
-        fai_func::prepare_to_save_FAI_object($sub_dn,$tmp);
+        FAI::prepare_to_save_FAI_object($sub_dn,$tmp);
         $this->handle_post_events("add");
       }
 
diff --git a/gosa-core/plugins/admin/fai/class_fai_func.inc b/gosa-core/plugins/admin/fai/class_fai_func.inc
deleted file mode 100644 (file)
index 822860a..0000000
+++ /dev/null
@@ -1,742 +0,0 @@
-<?php
-
-define("DEBUG_FAI_FUNC",FALSE);
-
-
-class fai_func
-{
-
-  /* TEST PHASE .... */
-
-  /* Returns all object for the given release.
-     This function resolves the releases  
-     from base up to the given dn.
-   */
-  static function get_all_objects_for_given_base($Current_DN,$filter,$detailed = false)
-  {
-    global $config;
-    $ldap = $config->get_ldap_link();
-    $ldap->cd($config->current['BASE']);
-    $res = array();
-    $tmp = array();
-
-    if(!fai_func::is_release_department($Current_DN)) {
-      return($res);
-    }
-
-    /* Collect some basic informations and initialize some variables */ 
-    $base_release       = fai_func::get_release_dn($Current_DN);
-    $previous_releases  = array_reverse(fai_func::             get_previous_releases_of_this_release($base_release,true));
-
-    /* We must also include the given release dn */
-    $previous_releases[] = $base_release;
-
-    /* Walk through all releases */
-    foreach($previous_releases as $release){
-
-      /* Get fai departments */
-      $deps_to_search = fai_func::get_FAI_departments($release); 
-
-      /* For every single department  (ou=hoos,ou ..) */
-      foreach($deps_to_search as $fai_base){
-
-        /* Ldap search for fai classes specified in this release */
-        $attributes  = array("dn","objectClass","FAIstate","cn");
-        $res_tmp = get_list($filter,"fai",$fai_base,$attributes,GL_SUBSEARCH | GL_SIZELIMIT);
-
-        /* check the returned objects, and add/replace them in our return variable */
-        foreach($res_tmp as $attr){
-
-          $buffer = array();
-          $name = preg_replace("/".normalizePreg($release)."/i","",$attr['dn']);
-
-          if(isset($attr['FAIstate'][0])){
-            if(preg_match("/removed$/",$attr['FAIstate'][0])){
-              if(isset($res[$name])){
-                unset($res[$name]);
-              }
-              continue;
-            }
-          }
-
-          /* In detailed mode are some additonal informations visible */
-          if($detailed){
-
-            /* Create list of parents */
-            if(isset($res[$name])){
-              $buffer = $res[$name];
-              $buffer['parents'][] = $res[$name]['dn'];
-            }else{
-              $buffer['parents'] = array();
-            }
-
-            /* Append objectClass to resulsts */
-            foreach($attributes as $val){
-              if(isset($attr[$val])){
-                $buffer[$val] = $attr[$val];
-              }
-            }
-            unset($buffer['objectClass']['count']);
-          }
-
-          /* Add this object to our list */
-          $buffer['dn']           = $attr['dn'];
-          $res[$name] = $buffer;
-        }
-      }
-    }
-    return($res);
-  }
-
-
-  /* Return all relevant FAI departments */
-  static function get_FAI_departments($suffix = "")
-  {
-    $arr = array("hooks","scripts","disk","packages","profiles","templates","variables");
-    $tmp = array();
-    if(preg_match("/^,/",$suffix)){
-      $suffix = preg_replace("/^,/","",$suffix);
-    }
-    foreach($arr as $name){
-      if(empty($suffix)){
-        $tmp[$name] = "ou=".$name;
-      }else{
-        $tmp[$name] = "ou=".$name.",".$suffix;
-      }
-    }
-    return($tmp);
-  }
-
-
-  /* Return all releases within the given base */
-  static function get_all_releases_from_base($dn,$appendedName=false)
-  {
-    global $config;
-
-    if(!preg_match("/".normalizePreg(get_ou('faiou'))."/",$dn)){
-      $base = get_ou('faiou').$dn;
-    }else{
-      $base = $dn;
-    }
-    $res = array();  
-
-    $ldap = $config->get_ldap_link();
-    $ldap->cd($base);
-    $ldap->search("(objectClass=FAIbranch)",array("ou","dn"));
-    while($attrs = $ldap->fetch()){
-      if($appendedName){
-        $res[$attrs['dn']] = convert_department_dn(preg_replace("/,".normalizePreg(get_ou('faiou')).".*$/","",$attrs['dn']));
-      }else{
-        $res[$attrs['dn']] = $attrs['ou'][0];
-      }
-    }
-    return($res);
-  }
-
-
-  /* Add this object to list of objects, that must be checked for release saving */
-  static function prepare_to_save_FAI_object($Current_DN,$objectAttrs,$removed = false)
-  {
-    /* Get ldap object */  
-    global $config;
-    $addObj['Current_DN'] = $Current_DN;
-    $addObj['objectAttrs']= $objectAttrs;
-    $addObj['removed']    = $removed;
-    $addObj['diff']       = TRUE;
-
-    if(!$removed){
-      $ldap = $config->get_ldap_link();
-      $ldap->cd($config->current['BASE']);
-
-      /* Get some basic informations */
-      $parent_obj   = fai_func::get_parent_release_object($Current_DN);
-      if(!empty($parent_obj)){
-        $ldap->cat($parent_obj,array("*"));
-        $attrs = fai_func::                           prepare_ldap_fetch_to_be_saved($ldap->fetch());
-
-        if(!fai_func::array_diff_FAI( $attrs,$objectAttrs)){
-          $addObj['diff'] = FALSE;
-        }
-      } 
-    }
-    $FAI_objects_to_save = session::get('FAI_objects_to_save') ;
-    $FAI_objects_to_save[$Current_DN] =  $addObj;
-    session::set('FAI_objects_to_save',$FAI_objects_to_save);
-  }
-
-
-  /* Detect differences in attribute arrays  */
-  static function array_diff_FAI($ar1,$ar2)
-  {
-
-    if((!isset($ar1['description'])) || (isset($ar1['description']) && (count($ar1['description']) == 0))){
-      $ar1['description'] = "";
-    }
-    if((!isset($ar2['description'])) || (isset($ar2['description']) && (count($ar2['description']) == 0))){
-      $ar2['description'] = "";
-    }
-
-    if(count($ar1) != count($ar2)) {
-      return (true);
-    }
-
-    foreach($ar1 as $key1 => $val1){
-
-      if((is_array($val1)) && (count($val1)==1)){
-        $ar1[$key1] = $val1[0];
-      }
-
-      if((is_array($ar2[$key1])) && (count($ar2[$key1])==1)){
-        $val1 = $val1[0];
-        $ar2[$key1] = $ar2[$key1][0];
-      }
-    }
-    ksort($ar1);
-    ksort($ar2);
-    if(count( array_diff($ar1,$ar2)) || fai_func::arr_diff($ar1,$ar2)){
-      return(true);
-    }else{
-      return(false);
-    }
-  }
-
-
-  static function arr_diff($ar1,$ar2)
-  {
-    foreach($ar1 as $ak1 => $av1){
-      if(!isset($ar2[$ak1]) || (!($av1 === $ar2[$ak1]))){
-        return(true);
-      }elseif(is_array($av1)){
-        return(fai_func::arr_diff($av1,$ar2[$ak1]));
-      }
-    }
-    return(FALSE);
-  }
-
-
-
-
-  /* check which objects must be saved, and save them */
-  static function save_release_changes_now()
-  {
-    /* Variable init*/
-    $to_save = array();
-
-    /* check which objects must be saved */
-    $FAI_objects_to_save = session::get('FAI_objects_to_save');
-    foreach($FAI_objects_to_save as $Current_DN => $object){
-      if($object['diff']){
-        $sub_name = $Current_DN;
-        while(isset($FAI_objects_to_save[$sub_name])){
-          $to_save[strlen($sub_name)][$sub_name] = $FAI_objects_to_save[$sub_name]; 
-          unset($FAI_objects_to_save[$sub_name]);
-          $sub_name = preg_replace('/^[^,]+,/', '', $sub_name);
-        }
-      }
-    }
-    session::set('FAI_objects_to_save',$FAI_objects_to_save);
-
-    /* Sort list of objects that must be saved, and ensure that 
-       container   objects are safed, before their childs are saved */
-    ksort($to_save);
-    $tmp = array();
-    foreach($to_save as $SubObjects){
-      foreach($SubObjects as $object){
-        $tmp[] = $object;
-      }
-    }
-    $to_save = $tmp;
-
-    /* Save objects and manage the correct release behavior*/
-    foreach($to_save as $save){
-
-      $Current_DN = $save['Current_DN'];
-      $removed    = $save['removed'];
-      $objectAttrs= $save['objectAttrs'];
-
-      /* Get ldap object */ 
-      global $config;
-      $ldap = $config->get_ldap_link();
-      $ldap->cd($config->current['BASE']);
-
-      /* Get some basic informations */
-      $base_release       = fai_func::get_release_dn($Current_DN);
-      $sub_releases       = fai_func::                       get_sub_releases_of_this_release($base_release,true);
-      $parent_obj         = fai_func::get_parent_release_object($Current_DN);
-      $following_releases = fai_func::                       get_sub_releases_of_this_release($base_release,true);
-
-      /* Check if given dn exists or if is a new entry */
-      $ldap->cat($Current_DN);
-      if(!$ldap->count()){
-        $is_new = true;
-      }else{
-        $is_new = false;
-      }
-
-      /* if parameter removed is true, we have to add FAIstate to the current attrs 
-         FAIstate should end with ...|removed after this operation */  
-      if($removed ){
-        $ldap->cat($Current_DN);
-
-        /* Get current object, because we must add the FAIstate ...|removed */
-        if((!$ldap->count()) && !empty($parent_obj)){
-          $ldap->cat($parent_obj);
-        }
-
-        /* Check if we have found a suiteable object */ 
-        if(!$ldap->count()){
-          echo "Error can't remove this object ".$Current_DN;
-          return;
-        }else{
-
-          /* Set FAIstate to current objectAttrs */
-          $objectAttrs = fai_func::                           prepare_ldap_fetch_to_be_saved($ldap->fetch());
-          if(isset($objectAttrs['FAIstate'][0])){
-            if(!preg_match("/removed$/",$objectAttrs['FAIstate'][0])){
-              $objectAttrs['FAIstate'][0] .= "|removed";
-            }
-          }else{
-            $objectAttrs['FAIstate'][0] = "|removed";
-          }
-        }
-      }
-
-      /* Check if this a leaf release or not */ 
-      if(count($following_releases) == 0 ){
-
-        /* This is a leaf object. It isn't inherited by any other object */    
-        if(DEBUG_FAI_FUNC) { 
-          echo "<b>Saving directly, is a leaf object</b><br> ".$Current_DN;
-          print_a($objectAttrs);
-        }
-        fai_func::save_FAI_object($Current_DN,$objectAttrs);
-      }else{
-
-        /* This object is inherited by some sub releases */  
-
-        /* Get all releases, that inherit this object */ 
-        $r = get_following_releases_that_inherit_this_object($Current_DN);
-
-        /* Get parent object */
-        $ldap->cat($parent_obj);
-        $parent_attrs = fai_func::                           prepare_ldap_fetch_to_be_saved($ldap->fetch());
-
-        /* New objects require special handling */
-        if($is_new){
-
-          /* check if there is already an entry named like this,
-             in one of our parent releases */
-          if(!empty($parent_obj)){
-            if(DEBUG_FAI_FUNC) { 
-              echo "There is already an entry named like this.</b><br>";
-
-              echo "<b>Saving main object</b>".$Current_DN;
-              print_a($objectAttrs);
-            }    
-            fai_func::save_FAI_object($Current_DN,$objectAttrs);
-
-            foreach($r as $key){
-              if(DEBUG_FAI_FUNC) { 
-                echo "<b>Saving parent to following release</b> ".$key;
-                print_a($parent_attrs);
-              }
-              fai_func::save_FAI_object($key,$parent_attrs);
-            }
-          }else{
-
-            if(DEBUG_FAI_FUNC) { 
-              echo "<b>Saving main object</b>".$Current_DN;
-              print_a($objectAttrs);
-            }
-            fai_func::save_FAI_object($Current_DN,$objectAttrs);
-
-            if(isset($objectAttrs['FAIstate'])){
-              $objectAttrs['FAIstate'] .= "|removed"; 
-            }else{
-              $objectAttrs['FAIstate'] = "|removed";
-            }
-
-            foreach($r as $key ){
-              if(DEBUG_FAI_FUNC) { 
-                echo "<b>Create an empty placeholder in follwing release</b> ".$key; 
-                print_a($objectAttrs);
-              }
-              fai_func::save_FAI_object($key,$objectAttrs);
-            }
-          }
-        }else{
-
-          /* check if we must patch the follwing release */
-          if(!empty($r)){
-            foreach($r as $key ){
-              if(DEBUG_FAI_FUNC) { 
-                echo "<b>Copy current objects original attributes to next release</b> ".$key;
-                print_a($parent_attrs);
-              }
-              fai_func::save_FAI_object($key,$parent_attrs);
-            }
-          }
-
-          if(DEBUG_FAI_FUNC) { 
-            echo "<b>Saving current object</b>".$parent_obj;
-            print_a($objectAttrs);
-          }
-          fai_func::save_FAI_object($parent_obj,$objectAttrs);
-
-          if(($parent_obj != $Current_DN)){
-            msg_dialog::display(_("Error"), sprintf(_("Error, following objects should be equal '%s' and '%s'"),$parent_obj,$Current_DN), ERROR_DIALOG);
-          }
-        }
-      }
-    } 
-    session::set('FAI_objects_to_save',array());
-  }
-
-
-  /* this function will remove all unused (deleted) objects,
-     that have no parent object */
-  static function clean_up_releases($Current_DN)
-  {
-    global $config;
-    $ldap = $config->get_ldap_link();
-    $ldap->cd($config->current['BASE']);
-
-    /* Collect some basic informations and initialize some variables */ 
-    $base_release       = fai_func::get_release_dn($Current_DN);
-    $previous_releases  = array_reverse(fai_func::             get_previous_releases_of_this_release($base_release,true));
-    $Kill = array();
-    $Skip = array();
-
-    /* We must also include the given release dn */
-    $previous_releases[] = $base_release;
-
-    /* Walk through all releases */
-    foreach($previous_releases as $release){
-
-      /* Get fai departments */
-      $deps_to_search = fai_func::get_FAI_departments($release); 
-
-      /* For every single department  (ou=hoos,ou ..) */
-      foreach($deps_to_search as $fai_base){
-
-        /* Ldap search for fai classes specified in this release */
-        $ldap->cd($fai_base);
-        $ldap->search("(objectClass=FAIclass)",array("dn","objectClass","FAIstate"));
-
-        /* check the returned objects, and add/replace them in our return variable */
-        while($attr = $ldap->fetch()){
-
-          $buffer = array();
-#        $name = str_ireplace($release,"",$attr['dn']);
-          $name = preg_replace("/".normalizePreg($release)."/i","",$attr['dn']);
-
-          if(isset($attr['FAIstate'][0])&&(preg_match("/removed$/",$attr['FAIstate'][0]))){
-
-            /* Check if this object is required somehow */    
-            if(!isset($Skip[$name])){
-              $Kill[$attr['dn']] = $attr['dn'];
-            }
-          }else{
-
-            /* This object is required (not removed), so do not 
-               delete any following sub releases of this object */
-            $Skip[$name] = $attr['dn'];
-          }
-        }
-      }
-    }
-    return($Kill);
-  }
-
-
-  /* Remove numeric index and 'count' from ldap->fetch result */
-  static function prepare_ldap_fetch_to_be_saved($attrs)
-  {
-    foreach($attrs as $key => $value){
-      if(is_numeric($key) || ($key == "count") || ($key == "dn")){
-        unset($attrs[$key]);
-      }
-      if(is_array($value) && isset($value['count'])){
-        unset($attrs[$key]['count']);
-      }
-    }
-    return($attrs);
-  }
-
-
-  /* Save given attrs to specified dn*/
-  static function save_FAI_object($dn,$attrs)
-  {
-    global $config;
-    $ldap = $config->get_ldap_link();
-    $ldap->cd($config->current['BASE']);
-    $ldap->create_missing_trees(preg_replace('/^[^,]+,/', '', $dn));
-    $ldap->cd($dn);
-
-    $ldap->cat($dn,array("dn"));
-    if($ldap->count()){
-
-      /* Remove FAIstate*/
-      if(!isset($attrs['FAIstate'])){
-        $attrs['FAIstate'] = array();
-      }
-
-      $ldap->modify($attrs);
-    }else{
-
-      /* Unset description if empty  */
-      if(empty($attrs['description'])){
-        unset($attrs['description']);
-      }    
-
-      $ldap->add($attrs);
-    }
-    show_ldap_error($ldap->get_error(),sprintf(_("Release management failed, can't save '%s'"),$dn));
-  }
-
-
-  /* Return FAIstate freeze branch or "" for specified release department */
-  static function get_release_tag($dn)
-  {
-    global $config;
-    $ldap = $config->get_ldap_link();
-    $ldap->cd($dn);
-    $ldap->cat($dn,array("FAIstate"));
-
-    if($ldap->count()){
-
-      $attr = $ldap->fetch();
-      if(isset($attr['FAIstate'][0])){
-        if(preg_match("/freeze/",$attr['FAIstate'][0])){
-          return("freeze");
-        }elseif(preg_match("/branch/",$attr['FAIstate'][0])){
-          return("branch");
-        }
-      }
-    }
-    return("");
-  }
-
-
-  static function get_following_releases_that_inherit_this_object($dn)
-  {
-    global $config;
-    $ldap = $config->get_ldap_link();
-    $ldap->cd($config->current['BASE']);
-
-    $ret = array();
-
-    /* Get base release */
-    $base_release = fai_func::get_release_dn($dn);
-
-    /* Get previous release dns */
-    $sub_releases = fai_func::                       get_sub_releases_of_this_release($base_release);
-
-    /* Get dn suffix. Example  "FAIvairableEntry=keksdose,FAIvariable=Keksregal," */
-#  $dn_suffix = str_ireplace($base_release,"",$dn);
-    $dn_suffix = preg_replace("/".normalizePreg($base_release)."/i","",$dn);
-
-    /* Check if given object also exists whitin one of these releases */
-    foreach($sub_releases as $p_release => $name){
-
-      $check_dn = $dn_suffix.$p_release;
-
-      $ldap->cat($check_dn,array("dn","objectClass"));
-
-      if($ldap->count()){
-        //return($ret);
-      }else{
-        $ret[$check_dn]=$check_dn;
-      }
-    }
-    return($ret);
-  }
-
-
-  /* Get previous version of the object dn */
-  static function get_parent_release_object($dn,$include_myself=true)
-  {
-    global $config;
-    $ldap = $config->get_ldap_link();
-    $ldap->cd($config->current['BASE']);
-    $previous_releases= array();
-
-    /* Get base release */
-    $base_release = fai_func::get_release_dn($dn);
-    if($include_myself){
-      $previous_releases[] = $base_release;  
-    }
-
-    /* Get previous release dns */
-    $tmp = fai_func::             get_previous_releases_of_this_release($base_release,true);
-    foreach($tmp as $release){
-      $previous_releases[] = $release;
-    }
-
-    /* Get dn suffix. Example  "FAIvairableEntry=keksdose,FAIvariable=Keksregal," */
-#  $dn_suffix = str_ireplace($base_release,"",$dn);
-    $dn_suffix = preg_replace("/".normalizePreg($base_release)."/i","",$dn);
-
-    /* Check if given object also exists whitin one of these releases */
-    foreach($previous_releases as $p_release){
-      $check_dn = $dn_suffix.$p_release;
-      $ldap->cat($check_dn,array("dn","objectClass"));
-
-      if($ldap->count()){
-        return($check_dn);
-      }
-    }
-    return("");
-  }
-
-
-  /* return release names of all parent releases */
-  static function get_previous_releases_of_this_release($dn,$flat)
-  {
-    global $config;
-    $ldap = $config->get_ldap_link();
-    $ldap->cd($config->current['BASE']);
-    $ret = array();
-
-    /* Explode dns into pieces, to be able to build parent dns */
-    $dns_to_check = gosa_ldap_explode_dn(preg_replace("/".normalizePreg(",".$config->current['BASE'])."/i","",$dn));
-
-    if(!is_array($dns_to_check)){
-      return;  
-    }
-
-    /* Unset first entry which represents the given dn */
-    unset($dns_to_check['count']); 
-    unset($dns_to_check[key($dns_to_check)]);
-
-    /* Create dns addresses and check if this dn is a release dn */
-    $id = 0;
-    while(count($dns_to_check)){
-
-      /* build parent dn */
-      $new_dn = "";
-      foreach($dns_to_check as $part){
-        $new_dn .= $part.",";
-      }
-      $new_dn .= $config->current['BASE'];
-
-      /* check if this dn is a release */
-      if(fai_func::is_release_department($new_dn)){
-        if($flat){
-          $ret[$id] = $new_dn; 
-        }else{
-          $ret = array($new_dn=>$ret); 
-        }
-        $id ++;
-      }else{
-        return($ret);
-      }
-      reset($dns_to_check);
-      unset($dns_to_check[key($dns_to_check)]);
-    }
-    return($ret);
-  } 
-
-
-  /* This function returns all sub release names, recursivly  */
-  static function get_sub_releases_of_this_release($dn,$flat = false)
-  {
-    global $config;
-    $res  = array();
-    $ldap = $config->get_ldap_link();
-    $ldap->cd($config->current['BASE']);
-    $ldap->ls("(objectClass=FAIbranch)",$dn,array("objectClass","dn","ou"));
-    while($attr = $ldap->fetch()){
-
-      /* Append department name */
-      if($flat){
-        $res[$attr['dn']] = $attr['ou'][0];
-      }else{
-        $res[$attr['dn']] = array();
-      }
-
-      /* Get sub release departments of this department */
-      if(in_array("FAIbranch",$attr['objectClass'])) {
-        if($flat){
-          $tmp = fai_func::                       get_sub_releases_of_this_release($attr['dn'],$flat);
-          foreach($tmp as $dn => $value){
-            $res[$dn]=$value;
-          }
-        }else{
-          $res[$attr['dn']] = fai_func::                       get_sub_releases_of_this_release($attr['dn']);
-        }
-      }
-    }
-    return($res);
-  }
-
-
-  /* Check if the given department is a release department */
-  static function is_release_department($dn)
-  {
-    global $config;
-    $ldap = $config->get_ldap_link();
-    $ldap->cd($config->current['BASE']);
-    $ldap->cat($dn,array("objectClass","ou"));
-
-    /* Check objectClasses and name to check if this is a release department */
-    if($ldap->count()){
-      $attrs = $ldap->fetch();
-
-      $ou = "";
-      if(isset($attrs['ou'][0])){
-        $ou = $attrs['ou'][0]; 
-      }
-
-      if((in_array("FAIbranch",$attrs['objectClass'])) || ($ou == "fai")){
-        return($attrs['dn']);
-      }
-    }
-    return(false);
-  }
-
-
-  /* This function returns the dn of the object release */
-  static function get_release_dn($Current_DN)
-  {
-    global $config;
-    $ldap = $config->get_ldap_link();
-    $ldap->cd($config->current['BASE']);
-
-    /* Split dn into pices */ 
-    $dns_to_check = gosa_ldap_explode_dn(preg_replace("/".normalizePreg(",".$config->current['BASE'])."/i","",$Current_DN));
-
-    if(!is_array($dns_to_check)){
-      return;  
-    }
-
-    /* Use dn pieces, to create sub dns like 
-       ou=test,ou=1,ou=0...
-       ou=1,ou=0...
-       ou=0... 
-       To check which dn is our release container.
-     */
-    unset($dns_to_check['count']); 
-    while(count($dns_to_check)){
-
-      /* Create dn */
-      $new_dn = "";
-      foreach($dns_to_check as $part){
-        $new_dn .= $part.",";
-      }
-      $new_dn .= $config->current['BASE'];
-
-      /* Check if this dn is a release dn */
-      if(fai_func::is_release_department($new_dn)){
-        return($new_dn);
-      }
-
-      /* Remove first element of dn pieces */
-      reset($dns_to_check);
-      unset($dns_to_check[key($dns_to_check)]);
-    }
-    return("");
-  }
-}
-// vim:tabstop=2:expandtab:shiftwidth=2:filetype=php:syntax:ruler:
-?>
index a63fdd3278576cddad550b17715a6f7e62bee0fc..90ba14cc4da3d0a4b936ad9b704e14655e2ba0c8 100644 (file)
@@ -1101,7 +1101,7 @@ class workstartup extends plugin
         $filter = "(|(objectClass=FAIpackageList)(objectClass=FAItemplate)(objectClass=FAIvariable)".
           "(objectClass=FAIscript)(objectClass=FAIhook)(objectClass=FAIprofile)".
           "(objectClass=FAIpartitionTable))";
-        $list = fai_func::get_all_objects_for_given_base($base,$filter,TRUE);
+        $list = FAI::get_all_objects_for_given_base($base,$filter,TRUE);
         foreach($list as $attrs){
           $info = $this->analyse_fai_object($attrs);
           if(count($info)){