X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=plugins%2Fadmin%2Fgroups%2Fclass_groupApplication.inc;h=4a4fde162c069a21fe595b08f4b95b940961ac92;hb=4f507bf6c24fd9a5c50928b3a0c334ba5529c42d;hp=c899f0bff70e22847d848ea9c76660fc57f26132;hpb=9f5c407de5a79a60bd4a7aba0a3291971f9ae764;p=gosa.git diff --git a/plugins/admin/groups/class_groupApplication.inc b/plugins/admin/groups/class_groupApplication.inc index c899f0bff..4a4fde162 100644 --- a/plugins/admin/groups/class_groupApplication.inc +++ b/plugins/admin/groups/class_groupApplication.inc @@ -14,26 +14,61 @@ class appgroup extends plugin var $apps = array(); // All available applications var $used_apps = array(); // Specifies which applications are currently assigned - var $option_name = array(); - var $option_value = array(); - var $appoption = array(); + var $option_name = array(); + var $option_value = array(); + var $appoption = array(); - var $table = ""; - var $curbase = ""; - var $curCatDir ; - var $curCatDepth =0; // + var $table = ""; + var $curbase = ""; + var $curCatDir ; + var $curCatDepth =0; // /* attribute list for save action */ - var $attributes= array(); - var $objectclasses= array("gosaApplicationGroup"); + var $attributes = array("gosaMemberApplication","gosaApplicationParameter"); + var $objectclasses = array("gosaApplicationGroup"); + var $FAIrelease = "/"; + var $InitialFAIrelease = "/"; + var $Releases = array(); + var $enableReleaseManagement = false; - function appgroup ($config, $dn= NULL) + var $AllAppsForRelease = array(); + var $AllAppsForReleaseParameter = array(); + + var $CopyPasteVars = array("Categories"); + var $gosaApplicationParameter ; + + + function appgroup ($config, $dn= NULL, $parent= NULL) { - plugin::plugin ($config, $dn); + + /* prepare group app for release management */ + $tmp = search_config($config->data,"faiManagement","CLASS"); + if(!empty($tmp)){ + $this->enableReleaseManagement = true; + $this->objectclasses [] = "FAIreleaseTag"; + $this->attributes[] = "FAIrelease"; + } + + plugin::plugin ($config, $dn, $parent); + + /* In some case of old applikations with old release tag saving, we + must reassign is_account state. + (Or if release management wasn't activated before creating this app) */ + if($this->enableReleaseManagement){ + + /* Release management is activated && this is a valid group app account, + but no release class was found, so activate is_account flag */ + if($dn != "new" && ( in_array("gosaApplicationGroup",$this->attrs['objectClass'])) && + (!in_array("FAIreleaseTag",$this->attrs['objectClass']))){ + $this->is_account =true; + } + } + /* Load member applications */ if (isset ($this->attrs["gosaMemberApplication"][0])){ + $this->gosaMemberApplication = array(); for ($i= 0; $i<$this->attrs["gosaMemberApplication"]["count"]; $i++){ $this->gosaMemberApplication[]= $this->attrs["gosaMemberApplication"][$i]; @@ -52,10 +87,10 @@ class appgroup extends plugin } /* Parse MemberApplication*/ - $tmp = array(); - $tmp2 = array(); - $prios = array(); - $cats = array(); + $tmp = array(); + $tmp2 = array(); + $prios = array(); + $cats = array(); foreach($this->gosaMemberApplication as $memberApp){ if(preg_match("/\|/i",$memberApp)){ @@ -108,6 +143,12 @@ class appgroup extends plugin } $this->gosaMemberApplication = $tmp; $this->curbase = $this->config->current['BASE']; + + /* Get required release informations */ + if($this->enableReleaseManagement){ + $this->InitialFAIrelease = $this->FAIrelease; + $this->Releases = $this->getReleases(); + } } @@ -142,6 +183,64 @@ class appgroup extends plugin return(-1); } + function diffAppsInReleases() + { + /* Only diff if it is required + */ + $ret =array(); + + /* If current release has changed */ + if($this->FAIrelease != $this->InitialFAIrelease){ + + /* Walk through all apps which are currently displayed */ + if(isset($this->gosaMemberApplication[$this->curCatDir])){ + + foreach($this->gosaMemberApplication[$this->curCatDir] as $entry){ + + /* If application is also available in new release, check if parameter differs */ + if(in_array($entry['App'],$this->AllAppsForRelease)){ + + $old = array(); // Old application parameter + $new = array(); // New parameters + + /* There are possibly no parameters specified */ + if(isset($this->AllAppsForReleaseParameter[$this->InitialFAIrelease][$entry['App']])){ + $old = $this->AllAppsForReleaseParameter[$this->InitialFAIrelease][$entry['App']]; + } + + if(isset($this->AllAppsForReleaseParameter[$this->FAIrelease][$entry['App']])){ + $new = $this->AllAppsForReleaseParameter[$this->FAIrelease][$entry['App']]; + } + + /* Both (old & new) have no gosaApplicationParameter + */ + if((!isset($old['gosaApplicationParameter'])) && (!isset($new['gosaApplicationParameter']))){ + $ret[$entry['App']] = false; + + /* Both got gosaApplicationParameter + */ + }elseif((isset($old['gosaApplicationParameter'])) && (isset($new['gosaApplicationParameter']))){ + if(array_differs($old['gosaApplicationParameter'],$new['gosaApplicationParameter'])){ + $ret[$entry['App']] = true; + }else{ + $ret[$entry['App']] = false; + } + } + /* Initialy had gosaApplicationParameter bot in new release not + */ + }elseif((isset($old['gosaApplicationParameter'])) && (!isset($new['gosaApplicationParameter']))){ + $ret[$entry['App']] = true; + + /* Old release had no gosaApplicationParameter but new got some + */ + }elseif((!isset($old['gosaApplicationParameter'])) && (isset($new['gosaApplicationParameter']))){ + $ret[$entry['App']] = true; + } + } + } + } + return($ret); + } /* TRansports the geiven Arraykey one position up*/ function ArrayUp($atr,$attrs) @@ -191,12 +290,12 @@ class appgroup extends plugin } } - + function catDown($id) { - /* Get all cats depinding on current dir */ + /* Get all cats depinding on current dir */ $cats = $this->GetSubdirs($this->curCatDir); - + $newcats =$this->ArrayDown($id,$cats); foreach($newcats as $cat => $name){ @@ -217,7 +316,7 @@ class appgroup extends plugin foreach ($apps as $appkey => $name){ $appsA[$name['App']] =$name['App']; } - + $result = $this->ArrayUp($appl,$appsA); $ret = array(); @@ -247,8 +346,8 @@ class appgroup extends plugin $this->gosaMemberApplication[$cat] = $ret; } - - + + function AddSeperator($id) { $found = false; @@ -269,8 +368,8 @@ class appgroup extends plugin function execute() { - /* Call parent execute */ - plugin::execute(); + /* Call parent execute */ + plugin::execute(); if((isset($_GET['act']))&&($_GET['act']=="depopen")){ $dep = base64_decode($_GET['depid']); @@ -310,8 +409,8 @@ class appgroup extends plugin /* Add Categorie */ - - + + if((isset($_POST['AddCat']))&&(isset($_POST['CatName']))&&(!empty($_POST['CatName']))){ if(preg_match("/[\\\\\/]/i",$_POST['CatName'])){ @@ -329,6 +428,8 @@ class appgroup extends plugin $this->reload(); + + $this->diffAppsInReleases(); $only_once = false; foreach($_POST as $name => $value){ @@ -353,9 +454,15 @@ class appgroup extends plugin foreach($this->gosaMemberApplication as $key => $cat){ foreach($cat as $key2 => $app){ + if($app['App'] == $val){ unset($this->gosaMemberApplication[$key][$key2]); if(isset($this->used_apps[$val])){ + foreach($this->getParameters($val) as $para){ + if(isset($this->appoption[$para])){ + unset($this->appoption[$para]); + } + } unset($this->used_apps[$val]); } } @@ -384,10 +491,31 @@ class appgroup extends plugin $appname = $value; $appname = preg_replace("/EdiApp_/","",$name); $appname = preg_replace("/_.*$/","",$appname); - /* We've got the appname, get parameters from ldap */ + + /* We've got the appname, get parameters from ldap + */ $ldap= $this->config->get_ldap_link(); - $ldap->cd($this->config->current['BASE']); - $ldap->search("(&(objectClass=gosaApplication)(cn=$appname))"); + + $tmp = search_config($this->config->data,"faiManagement","CLASS"); + if(!empty($tmp)){ + $tmp = array_flip($this->Releases); + $base = $tmp[$this->FAIrelease]; + + $ldap->cd($this->config->current['BASE']); + $ldap->search("(&(objectClass=gosaApplication)(cn=$appname))",array("gosaApplicationParameter")); + $found = ""; + while($attrs = $ldap->fetch()) { + if(preg_match("/cn=".$appname.",".$base."/",$attrs['dn'])){ + $found = $attrs['dn']; + } + } + $ldap->cat($found, array("gosaApplicationParameter")); + }else{ + $ldap->cd($this->config->current['BASE']); + $ldap->search("(&(objectClass=gosaApplication)(cn=$appname))",array("gosaApplicationParameter")); + } + + if ($ldap->count() != 1){ print_red (_("The selected application name is not uniq. Please check your LDAP.")); } else { @@ -430,7 +558,9 @@ class appgroup extends plugin } } } + $this->reload(); + /* Add group with post */ if((isset($_GET['act']))&&($_GET['act']=="add")){ $this->used_apps[$_GET['id']]= $_GET['id']; @@ -478,33 +608,21 @@ class appgroup extends plugin $div = new DivSelectBox("appgroup"); - $div->SetHeight(400); + $div->SetHeight(300); - /* NEW LIST MANAGMENT - * We also need to search for the departments - * So we are able to navigate like in konquerer - */ - - $ldap = $this->config->get_ldap_link(); - $ldap->cd($this->curbase) ; - $ldap->ls("(objectClass=gosaDepartment)"); - $departments= array(); - $tmp = array(); - while ($value = $ldap->fetch()){ - $tmp[strtolower($value['dn']).$value['dn']]=$value; - } - ksort($tmp); - foreach($tmp as $value){ + /* get departments */ + $ui = get_userinfo(); + $departments = array(); + $res = get_list("(objectClass=gosaDepartment)",$ui->subtreeACL,$this->curbase,array("description","cn","ou"),GL_SIZELIMIT); + foreach($res as $value){ + $fdn= @LDAP::fix($value['dn']); if($value["description"][0]!=".."){ - $departments[$value['dn']]=convert_department_dn($value['dn'])." - [".$value["description"][0]."]"; + $departments[$value['dn']]= convert_department_dn($fdn)." - [".$value["description"][0]."]"; }else{ - $departments[$value['dn']]=convert_department_dn($value['dn']); + $departments[$value['dn']]=convert_department_dn($fdn); } } - /* END NEW LIST MANAGMENT - */ - $linkopen = "%s"; $linkadd = "%s"; @@ -517,15 +635,15 @@ class appgroup extends plugin } foreach($departments as $key => $app){ $div->AddEntry(array( - array("string"=>""._("department")." ".sprintf($linkopen,base64_encode($key),$app), + array("string"=>""._("department")." ".sprintf($linkopen,base64_encode($key),$app), "attach"=>"style='border:0px;'") )); } foreach($apps as $key => $app){ $div->AddEntry(array( - array("string"=>sprintf("",$key). - ""._("application")." ".sprintf($linkadd,$key,$app), + array("string"=>sprintf("",$key). + ""._("application")." ".sprintf($linkadd,$key,$app), "attach"=>"style='border:0px;'") )); } @@ -553,11 +671,11 @@ class appgroup extends plugin } $div2 = new DivSelectBox("appgroup"); - $div2->SetHeight(400); + $div2->SetHeight(300); - $linkopen = "\"\" %s"; + $linkopen = "\"\" %s"; $catremove = " "; - $app = "\"\" %s"; + $app = "\"\" %s"; $catupdown = " \"\"  @@ -595,14 +713,44 @@ class appgroup extends plugin " "; $edit= " "; + $Differences = $this->diffAppsInReleases(); + if(isset($this->gosaMemberApplication[$this->curCatDir])){ foreach($this->gosaMemberApplication[$this->curCatDir] as $cat => $entry){ + + if(preg_match("/__SEPARATOR__/",$entry['App'])){ $div2 ->AddEntry(array(array("string"=>$separator), array("string"=>preg_replace("/\%s/",htmlentities($entry['App']),$upudown),"attach"=>"align='right' style='border-right:0px;'"))); }else{ - $div2 ->AddEntry(array(array("string"=>sprintf($app,$entry['App'])), - array("string"=>preg_replace("/\%s/",htmlentities($entry['App']),$sep.$edit.$upudown),"attach"=>"align='right' style='border-right:0px;'"))); + + $image = ""; + /* Check if application was available within selected release + * or application list if release management is not active + */ + if(!in_array($entry['App'],$this->AllAppsForRelease)){ + + /* release managent is active + */ + if(!$this->enableReleaseManagement){ + $image = " "; + }else{ + $image = " "; + } + + }elseif(isset($Differences[$entry['App']]) && ($Differences[$entry['App']] == true)) { + $entry['App'].=" ["._("Check parameter")."]"; + $image = " "; + }else{ + $image = "\"\" "; + } + + $div2->AddEntry(array(array("string"=>sprintf($image."%s",$entry['App'])), + array("string"=>preg_replace("/\%s/",htmlentities($entry['App']),$sep.$edit.$upudown), + "attach"=>"align='right' style='width:100px;border-right:0px;'"))); } } } @@ -610,6 +758,20 @@ class appgroup extends plugin $smarty->assign("UsedApps", $div2->DrawList()); $smarty->assign("List", $div->DrawList()); $smarty->assign("apps", $apps); + + $smarty->assign("enableReleaseManagement",$this->enableReleaseManagement); + + if($this->enableReleaseManagement){ + $smarty->assign("FAIrelease", $this->FAIrelease); + $smarty->assign("Releases", $this->Releases); + + if(count($this->used_apps)){ + $smarty->assign("ReleaseSelectAble", false); + }else{ + $smarty->assign("ReleaseSelectAble", true); + } + } + $smarty->assign("ReleaseSelectAble", true); /* Show main page */ if ($this->dialog){ @@ -622,16 +784,52 @@ class appgroup extends plugin } + function getReleases() + { + $dn = $this->config->current['BASE']; + $ldap = $this->config->get_ldap_link(); + $ldap->cd($dn); + $ldap->search("(&(objectClass=organizationalUnit)(objectClass=FAIbranch))",array("ou")); + $ret =array(); + while($attrs = $ldap->fetch()){ + if(preg_match("/ou=apps,/",$attrs['dn'])){ + $bb = preg_replace("/ou=apps,.*/","",$attrs['dn']); + $parts = array_reverse(split("ou=",$bb)); + + $str =""; + foreach($parts as $part){ + if(empty($part)) { + continue; + } + $str .= str_replace(",","",$part)."/"; + } + $name = preg_replace("/\/$/","",$str); + if(empty($name)) { + $name ="/"; + } + $ret[$attrs['dn']] = $name; + } + } + return($ret); + } + + function save_object() + { + plugin::save_object(); + } + + function remove_from_parent() { plugin::remove_from_parent(); - $this->attrs["gosaMemberApplication"]= array(); - $ldap= $this->config->get_ldap_link(); $ldap->cd($this->dn); - $ldap->modify($this->attrs); - show_ldap_error($ldap->get_error()); + $this->cleanup(); + + $ldap->modify ($this->attrs); + + show_ldap_error($ldap->get_error(), _("Removing application information failed")); /* Optionally execute a command after we're done */ $this->handle_post_events("remove"); @@ -646,19 +844,19 @@ class appgroup extends plugin /* Copy members */ $this->Categories[""]=""; $this->attrs["gosaMemberApplication"]= array(); - $cats = array(); + $this->attrs["gosaApplicationParameter"]= array(); foreach($this->Categories as $name => $cats){ - $cats[$name] =0; + $i =0; if(isset($this->gosaMemberApplication[$name])){ foreach($this->gosaMemberApplication[$name] as $entry){ if(!preg_match("/__SEPARATOR__/",$entry['App'])){ - $this->attrs["gosaMemberApplication"][]= $entry['App']."|".$name."|".$cats[$name]; + $this->attrs["gosaMemberApplication"][]= $entry['App']."|".$name."|".$i; } - $cats[$name] = $cats[$name] + 1; + $i ++; } } - if(($cats[$name]==0)&&(!empty($name))){ - $this->attrs["gosaMemberApplication"][]= "|".$name."|".$cats[$name]; + if(($i==0)&&(!empty($name))){ + $this->attrs["gosaMemberApplication"][]= "|".$name."|".$i; } } @@ -673,8 +871,10 @@ class appgroup extends plugin /* Write back to LDAP */ $ldap= $this->config->get_ldap_link(); $ldap->cd($this->dn); - $ldap->modify($this->attrs); - show_ldap_error($ldap->get_error()); + $this->cleanup(); + $ldap->modify ($this->attrs); + + show_ldap_error($ldap->get_error(), _("Saving application information failed")); /* Optionally execute a command after we're done */ if ($this->initially_was_account == $this->is_account){ @@ -689,7 +889,9 @@ class appgroup extends plugin function check() { - $message= array(); + /* Call common method to give check the hook */ + $message= plugin::check(); + return ($message); } @@ -698,10 +900,36 @@ class appgroup extends plugin { /* Generate applist */ $this->apps= array(); - $ldap= $this->config->get_ldap_link(); - $ldap->cd ("ou=apps,".$this->curbase); - $ldap->ls ("(objectClass=gosaApplication)","ou=apps,".$this->curbase); + /* Special handling for release managed apps + */ + $tmp = search_config($this->config->data,"faiManagement","CLASS"); + if(!empty($tmp)){ + $this->enableReleaseManagement = true; + + $tmp = array_flip($this->Releases); + if(isset($tmp[$this->FAIrelease])){ + $base = $tmp[$this->FAIrelease]; + }else{ + $k = key($tmp); + $r = $tmp[$k]; + $this->FAIrelease = $k; + $base = $r; + + print_red(sprintf(_("Can't resolve the release name '%s', setting release name to '%s'. Possibly the objects base has changed."),$this->FAIrelease,$k)); + } + + $base = preg_replace("/ou=apps,.*$/","ou=apps,".$this->curbase,$base); + + $ldap = $this->config->get_ldap_link(); + $ldap->cd ($base); + $ldap->ls ("(objectClass=gosaApplication)",$base); + }else{ + $ldap = $this->config->get_ldap_link(); + $ldap->cd ("ou=apps,".$this->curbase); + $ldap->ls ("(objectClass=gosaApplication)","ou=apps,".$this->curbase); + } + while ($attrs= $ldap->fetch()){ if (isset($attrs["description"][0])){ $this->apps[$attrs["cn"][0]]= @@ -712,6 +940,32 @@ class appgroup extends plugin $attrs["cn"][0]; } } + + $ldap->cd($this->config->current['BASE']); + $ldap->search("objectClass=gosaApplication",array("gosaApplicationParameter","cn")); + $tmp = search_config($this->config->data,"faiManagement","CLASS"); + $this->AllAppsForRelease = array(); + if(!empty($tmp)){ + + $tmp = array_flip($this->Releases); + + while($attrs = $ldap->fetch()){ + + $testdn = preg_replace("/ou=apps,.*$/","ou=apps",$attrs['dn']); + $testdn = preg_replace("/^[^,]+/","",$testdn); + $testdn = preg_replace("/^,/","",$testdn); + + if($testdn == preg_replace("/ou=apps,.*$/","ou=apps",$tmp[$this->FAIrelease])){ + $this->AllAppsForRelease[$attrs['dn']] = $attrs['cn'][0]; + $this->AllAppsForReleaseParameter[$this->FAIrelease][$attrs['cn'][0]] = $attrs; + } + } + }else{ + while($attrs = $ldap->fetch()){ + $this->AllAppsForRelease[$attrs['dn']] = $attrs['cn'][0]; + } + } + natcasesort ($this->apps); reset ($this->apps); @@ -750,6 +1004,27 @@ class appgroup extends plugin $this->is_modified= TRUE; } + function getParameters($app) + { + $tmp = $this->getReleases(); + $ret = array(); + if(in_array($this->FAIrelease,$tmp)){ + $tmp2 = array_flip($tmp); + $base = $tmp2[$this->FAIrelease]; + $ldap = $this->config->get_ldap_link(); + $ldap->cd($this->config->current['BASE']); + $ldap->search("(&(objectClass=gosaApplication)(cn=".$app.")(gosaApplicationParameter=*))",array("gosaApplicationParameter")); + if($ldap->count()){ + $attrs = $ldap->fetch(); + for($i = 0 ; $i < $attrs['gosaApplicationParameter']['count'] ; $i ++ ){ + $name = preg_replace("/:.*$/","",$attrs['gosaApplicationParameter'][$i]); + $ret[$name] = $name; + } + } + } + return($ret); + } + function GetSubdirs($dir) { $ret = array(); @@ -776,7 +1051,6 @@ class appgroup extends plugin } return($ret); } - } // vim:tabstop=2:expandtab:shiftwidth=2:filetype=php:syntax:ruler: