X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=include%2Ffunctions_FAI.inc;h=e7e14d6758317ef11481042e81812e2b1cdc47e7;hb=f15be1a7b19fb3011c05484627e506a23c1c5d61;hp=b884925ad6f108e5f1705f92174f76ff65e7b4d1;hpb=31ad1193eaf79a30a3e0cd11c509c7f89d5364f7;p=gosa.git
diff --git a/include/functions_FAI.inc b/include/functions_FAI.inc
index b884925ad..e7e14d675 100644
--- a/include/functions_FAI.inc
+++ b/include/functions_FAI.inc
@@ -1,12 +1,14 @@
get_ldap_link();
@@ -32,14 +34,24 @@ function get_all_objects_for_given_base($Current_DN,$detailed = false)
/* Ldap search for fai classes specified in this release */
$ldap->cd($fai_base);
- $ldap->search("(objectClass=FAIclass)",array("dn","objectClass"));
+ $ldap->search($filter,array("dn","objectClass","FAIstate"));
- /* check the returned objects, and add/replace them in our return vareable */
+ /* check the returned objects, and add/replace them in our return variable */
while($attr = $ldap->fetch()){
-
+
$buffer = array();
$name = str_ireplace($release,"",$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){
@@ -79,7 +91,7 @@ function get_FAI_type($attr)
return($name);
}
}
- echo "Not found";
+ if(DEBUG_FAI_FUNC) { echo "Not found"; }
return("");
}
@@ -103,6 +115,7 @@ function get_FAI_departments($suffix = "")
}
+/* Return all releases within the given base */
function get_all_releases_from_base($dn)
{
global $config;
@@ -119,42 +132,311 @@ function get_all_releases_from_base($dn)
}
-/* This function does everything to be able to save the given dn.
+/* Add this object to list of objects, that must be checked for release saving */
+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 = get_parent_release_object($Current_DN);
+ $ldap->cat($parent_obj,array("*"));
+ $attrs = prepare_ldap_fetch_to_be_saved($ldap->fetch());
+
+ if(!array_diff_FAI( $attrs,$objectAttrs)){
+ $addObj['diff'] = FALSE;
+ }
+ }
+
+ $_SESSION['FAI_objects_to_save'][$Current_DN] = $addObj;
+}
+
- !!!!!!! No functionality just output
-
- */
-function prepare_to_save_FAI_object($Current_DN)
+/* Detect differences in attribute arrays */
+function array_diff_FAI($ar1,$ar2)
{
- /* Get some basic informations */
- $base_release = get_release_dn($Current_DN);
- $sub_releases = get_sub_releases_of_this_release($base_release,true);
- $parent_obj = get_parent_release_object($Current_DN);
-
- $previous_releases = get_previous_releases_of_this_release($base_release,true);
- $following_releases= get_sub_releases_of_this_release($base_release,true);
-
- echo "
".$Current_DN."
";
-
- /* If we are a leaf object */
- if(count($following_releases) == 0 ){
- echo "Saving dircetly, is a leaf object
";
+ 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];
+ }
+ }
+ if(count( array_diff($ar1,$ar2))){
+ return(true);
}else{
+ return(false);
+ }
+}
+
+
+/* check which objects must be saved, and save them */
+function save_release_changes_now()
+{
+ /* Variable init*/
+ $to_save = array();
+
+ /* check which attributes must realy be saved */
+ foreach($_SESSION['FAI_objects_to_save'] as $Current_DN => $object){
+ if($object['diff']){
+ $sub_name = $Current_DN;
+ while(isset($_SESSION['FAI_objects_to_save'][$sub_name])){
+
+ $to_save[strlen($sub_name)] = $_SESSION['FAI_objects_to_save'][$sub_name];
+ unset($_SESSION['FAI_objects_to_save'][$sub_name]);
+ $sub_name = preg_replace('/^[^,]+,/', '', $sub_name);
+ }
+ }
+ }
+
+ /* Sort list of objects that must be saved, and ensure that
+ container objects are safed, before their childs are saved */
+ ksort($to_save);
+
+ /* 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 = get_release_dn($Current_DN);
+ $sub_releases = get_sub_releases_of_this_release($base_release,true);
+ $parent_obj = get_parent_release_object($Current_DN);
+ $following_releases = get_sub_releases_of_this_release($base_release,true);
- echo "This object has sub releases:
";
+ /* 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 = 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 unherited by any other object */
+ if(DEBUG_FAI_FUNC) {
+ echo "Saving directly, is a leaf object
".$Current_DN;
+ print_a($objectAttrs);
+ }
+ 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 = 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.
";
+
+ echo "Saving main object".$Current_DN;
+ print_a($objectAttrs);
+ }
+ save_FAI_object($Current_DN,$objectAttrs);
+
+ foreach($r as $key){
+ if(DEBUG_FAI_FUNC) {
+ echo "Saving parent to following release ".$key;
+ print_a($parent_attrs);
+ }
+ save_FAI_object($key,$parent_attrs);
+ }
+ }else{
+
+ if(DEBUG_FAI_FUNC) {
+ echo "Saving main object".$Current_DN;
+ print_a($objectAttrs);
+ }
+ 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 "Create an empty placeholder in follwing release ".$key;
+ print_a($objectAttrs);
+ }
+ 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 "Copy current objects original attributes to next release ".$key;
+ print_a($parent_attrs);
+ }
+ save_FAI_object($key,$parent_attrs);
+ }
+ }
- $r = get_following_releases_that_inherit_this_object($Current_DN);
- echo "This object must be updated ".$r[key($r)]." with ".$parent_obj."
";
- unset($r[key($r)]);
+ if(DEBUG_FAI_FUNC) {
+ echo "Saving current object".$parent_obj;
+ print_a($objectAttrs);
+ }
+ save_FAI_object($parent_obj,$objectAttrs);
- echo "
the result will be inherited by .";
- foreach($r as $release => $value){
- echo " : ".$release."
";
+ if(($parent_obj != $Current_DN)){
+ print_red(sprintf(_("Error, following objects should be equal '%s' and '%s'"),$parent_obj,$Current_DN));
+ }
+ }
}
}
+ $_SESSION['FAI_objects_to_save'] = array();
+}
+
+
+/* this function will remove all unused (deleted) objects,
+ that have no parent object */
+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 = get_release_dn($Current_DN);
+ $previous_releases = array_reverse(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 = 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']);
+
+ 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);
+}
- echo "
.--------------------------------------------------------------------.
";
+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);
+}
+
+
+function save_FAI_object($dn,$attrs)
+{
+ print_a(array($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()){
+ $ldap->modify($attrs);
+ }else{
+ $ldap->add($attrs);
+ }
+ show_ldap_error($ldap->get_error(),sprintf(_("Release management failed, can't save '%s'"),$dn));
}
@@ -170,11 +452,11 @@ function get_following_releases_that_inherit_this_object($dn)
$base_release = get_release_dn($dn);
/* Get previous release dns */
- $sub_releases = get_sub_releases_of_this_release($base_release,true);
+ $sub_releases = get_sub_releases_of_this_release($base_release);
/* Get dn suffix. Example "FAIvairableEntry=keksdose,FAIvariable=Keksregal," */
$dn_suffix = str_ireplace($base_release,"",$dn);
-
+
/* Check if given object also exists whitin one of these releases */
foreach($sub_releases as $p_release => $name){
@@ -183,7 +465,7 @@ function get_following_releases_that_inherit_this_object($dn)
$ldap->cat($check_dn,array("dn","objectClass"));
if($ldap->count()){
- return($ret);
+ //return($ret);
}else{
$ret[$check_dn]=$check_dn;
}
@@ -193,7 +475,7 @@ function get_following_releases_that_inherit_this_object($dn)
/* Get previous version of the object dn */
-function get_parent_release_object($dn)
+function get_parent_release_object($dn,$include_myself=true)
{
global $config;
$ldap = $config->get_ldap_link();
@@ -202,7 +484,9 @@ function get_parent_release_object($dn)
/* Get base release */
$base_release = get_release_dn($dn);
- $previous_releases[] = $base_release;
+ if($include_myself){
+ $previous_releases[] = $base_release;
+ }
/* Get previous release dns */
$tmp = get_previous_releases_of_this_release($base_release,true);
@@ -317,7 +601,13 @@ function is_release_department($dn)
/* Check objectClasses and name to check if this is a release department */
if($ldap->count()){
$attrs = $ldap->fetch();
- if((in_array("FAIbranch",$attrs['objectClass'])) || ($attrs['ou'][0] == "fai")){
+
+ $ou = "";
+ if(isset($attrs['ou'][0])){
+ $ou = $attrs['ou'][0];
+ }
+
+ if((in_array("FAIbranch",$attrs['objectClass'])) || ($ou == "fai")){
return($attrs['dn']);
}
}
@@ -366,5 +656,5 @@ function get_release_dn($Current_DN)
return("");
}
-
+// vim:tabstop=2:expandtab:shiftwidth=2:filetype=php:syntax:ruler:
?>