index e7e14d6758317ef11481042e81812e2b1cdc47e7..6843c0d48610a32c24fdfcf0b5dbf5515a6f75c5 100644 (file)
global $config;
$ldap = $config->get_ldap_link();
$ldap->cd($config->current['BASE']);
+ $res = array();
+ $tmp = array();
+
+ if(!is_release_department($Current_DN)) {
+ return($res);
+ }
/* 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));
- $res = array();
- $tmp = array();
/* We must also include the given release dn */
$previous_releases[] = $base_release;
}
-
-/* Return the object defining ObjectClass e.g. FAIscriptEntry */
-function get_FAI_type($attr)
-{
- $arr = array( "FAIprofile","FAIpartitionTable", "FAIpartitionDisk","FAIpartitionEntry","FAIhook","FAIhookEntry",
- "FAIscriptEntry","FAIscript","FAIvariable","FAIvariableEntry","FAIpackageList","FAItemplate",
- "FAItemplateEntry","FAIdebconfInfo","FAIrepository","FAIrepositoryServer","FAIbranch","FAIreleaseTag");
- foreach($arr as $name){
- if(in_array($name,$attr['objectClass'])){
- preg_match("");
- return($name);
- }
- }
- if(DEBUG_FAI_FUNC) { echo "Not found"; }
- return("");
-}
-
-
/* Return all relevant FAI departments */
function get_FAI_departments($suffix = "")
{
/* Return all releases within the given base */
-function get_all_releases_from_base($dn)
+function get_all_releases_from_base($dn,$appendedName=false)
{
global $config;
- $base = "ou=fai,ou=configs,ou=systems,".$dn;
+
+ if(!preg_match("/ou=fai,ou=configs,ou=systems,/",$dn)){
+ $base = "ou=fai,ou=configs,ou=systems,".$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()){
- $res[$attrs['dn']] = $attrs['ou'][0];
- }
+ if($appendedName){
+ $res[$attrs['dn']] = convert_department_dn(preg_replace("/,ou=fai,ou=configs,ou=system.*$/","",$attrs['dn']));
+ }else{
+ $res[$attrs['dn']] = $attrs['ou'][0];
+ }
+ }
return($res);
}
@@ -148,14 +143,16 @@ function prepare_to_save_FAI_object($Current_DN,$objectAttrs,$removed = false)
/* 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(!empty($parent_obj)){
+ $ldap->cat($parent_obj,array("*"));
+ $attrs = prepare_ldap_fetch_to_be_saved($ldap->fetch());
- if(!array_diff_FAI( $attrs,$objectAttrs)){
- $addObj['diff'] = FALSE;
- }
+ if(!array_diff_FAI( $attrs,$objectAttrs)){
+ $addObj['diff'] = FALSE;
+ }
+ }
}
-
+
$_SESSION['FAI_objects_to_save'][$Current_DN] = $addObj;
}
/* Detect differences in attribute arrays */
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)){
$ar2[$key1] = $ar2[$key1][0];
}
}
+ ksort($ar1);
+ ksort($ar2);
if(count( array_diff($ar1,$ar2))){
return(true);
}else{
{
/* Variable init*/
$to_save = array();
-
- /* check which attributes must realy be saved */
+
+ /* check which objects must 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];
+ $to_save[strlen($sub_name)][$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);
+ $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){
}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 ){
}
}
-
/* Check if this a leaf release or not */
if(count($following_releases) == 0 ){
}
+/* Remove numeric index and 'count' from ldap->fetch result */
function prepare_ldap_fetch_to_be_saved($attrs)
{
foreach($attrs as $key => $value){
}
+/* Save given attrs to specified dn*/
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()){
+
+ /* 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 */
+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("");
+}
+
+
function get_following_releases_that_inherit_this_object($dn)
{
global $config;