diff --git a/plugins/admin/groups/class_groupApplication.inc b/plugins/admin/groups/class_groupApplication.inc
index d95e2801df74fcce92d9bc801a9020edd4255a58..df6f8c094fa44ec231f94f5bc2b0978c49ce3534 100644 (file)
var $curCatDepth =0; //
/* attribute list for save action */
- var $attributes = array("gosaMemberApplication");
+ var $attributes = array("gosaMemberApplication","gosaApplicationParameter");
var $objectclasses = array("gosaApplicationGroup");
- var $Release = "/";
- var $InitialRelease = "/";
+ var $FAIrelease = "/";
+ var $InitialFAIrelease = "/";
var $Releases = array();
var $enableReleaseManagement = false;
var $AllAppsForReleaseParameter = array();
var $CopyPasteVars = array("Categories");
+ var $gosaApplicationParameter ;
- function appgroup ($config, $dn= NULL)
+ 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 = $tmp;
$this->curbase = $this->config->current['BASE'];
- /* Check if we should enable the release selection
- */
- $tmp = search_config($config->data,"faiManagement","CLASS");
- if(!empty($tmp)){
- $this->enableReleaseManagement = true;
- $this->Release = $this->getReleaseName();
- $this->InitialRelease = $this->Release;
+ /* Get required release informations */
+ if($this->enableReleaseManagement){
+ $this->InitialFAIrelease = $this->FAIrelease;
$this->Releases = $this->getReleases();
}
}
/* Only diff if it is required
*/
$ret =array();
-
+
/* If current release has changed */
- if($this->Release != $this->InitialRelease){
-
+ if($this->FAIrelease != $this->InitialFAIrelease){
+
/* Walk through all apps which are currently displayed */
- foreach($this->gosaMemberApplication[$this->curCatDir] as $entry){
+ if(isset($this->gosaMemberApplication[$this->curCatDir])){
- /* If application is also available in new release, check if parameter differs */
- if(in_array($entry['App'],$this->AllAppsForRelease)){
+ foreach($this->gosaMemberApplication[$this->curCatDir] as $entry){
- $old = array(); // Old application parameter
- $new = array(); // New parameters
+ /* If application is also available in new release, check if parameter differs */
+ if(in_array($entry['App'],$this->AllAppsForRelease)){
- /* There are possibly no parameters specified */
- if(isset($this->AllAppsForReleaseParameter[$this->InitialRelease][$entry['App']])){
- $old = $this->AllAppsForReleaseParameter[$this->InitialRelease][$entry['App']];
- }
+ $old = array(); // Old application parameter
+ $new = array(); // New parameters
- if(isset($this->AllAppsForReleaseParameter[$this->Release][$entry['App']])){
- $new = $this->AllAppsForReleaseParameter[$this->Release][$entry['App']];
- }
+ /* There are possibly no parameters specified */
+ if(isset($this->AllAppsForReleaseParameter[$this->InitialFAIrelease][$entry['App']])){
+ $old = $this->AllAppsForReleaseParameter[$this->InitialFAIrelease][$entry['App']];
+ }
- /* Both (old & new) have no gosaApplicationParameter
- */
- if((!isset($old['gosaApplicationParameter'])) && (!isset($new['gosaApplicationParameter']))){
- $ret[$entry['App']] = false;
+ if(isset($this->AllAppsForReleaseParameter[$this->FAIrelease][$entry['App']])){
+ $new = $this->AllAppsForReleaseParameter[$this->FAIrelease][$entry['App']];
+ }
- /* Both got gosaApplicationParameter
+ /* Both (old & new) have no gosaApplicationParameter
*/
- }elseif((isset($old['gosaApplicationParameter'])) && (isset($new['gosaApplicationParameter']))){
- if(array_differs($old['gosaApplicationParameter'],$new['gosaApplicationParameter'])){
- $ret[$entry['App']] = true;
- }else{
- $ret[$entry['App']] = false;
+ 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;
+ /* 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;
+ /* Old release had no gosaApplicationParameter but new got some
+ */
+ }elseif((!isset($old['gosaApplicationParameter'])) && (isset($new['gosaApplicationParameter']))){
+ $ret[$entry['App']] = true;
+ }
}
}
}
/* Call parent execute */
plugin::execute();
-
if((isset($_GET['act']))&&($_GET['act']=="depopen")){
$dep = base64_decode($_GET['depid']);
if(isset($this->config->idepartments[$dep])){
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]);
}
}
$tmp = search_config($this->config->data,"faiManagement","CLASS");
if(!empty($tmp)){
$tmp = array_flip($this->Releases);
- $base = $tmp[$this->Release];
+ $base = $tmp[$this->FAIrelease];
$ldap->cd($this->config->current['BASE']);
$ldap->search("(&(objectClass=gosaApplication)(cn=$appname))",array("gosaApplicationParameter"));
$found = $attrs['dn'];
}
}
- $ldap->cat($found);
+ $ldap->cat($found, array("gosaApplicationParameter"));
}else{
$ldap->cd($this->config->current['BASE']);
$ldap->search("(&(objectClass=gosaApplication)(cn=$appname))",array("gosaApplicationParameter"));
-
}
$div->SetHeight(300);
- /* NEW LIST MANAGMENT
- * We also need to search for the departments
- * So we are able to navigate like in konquerer
- */
+ /* 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){
- //FIXME: Why do we not use get_list here? It's the same code all over the time...
- $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){
- $fdn= @LDAP::fix($value['dn']);
+ $fdn = $value['dn'];
+ $fdn = preg_replace("/".normalizePreg($this->curbase)."/","",$fdn);
+ $fdn= @LDAP::fix($fdn);
if($value["description"][0]!=".."){
$departments[$value['dn']]= convert_department_dn($fdn)." - [".$value["description"][0]."]";
}else{
- $departments[$value['dn']]=convert_department_dn($fdn);
+ $departments[$value['dn']]= convert_department_dn($fdn);
}
}
- /* END NEW LIST MANAGMENT
- */
-
$linkopen = "<a href='?plug=".$_GET['plug']."&act=depopen&depid=%s'>%s</a>";
$linkadd = "<a href='?plug=".$_GET['plug']."&act=add&id=%s'>%s</a>";
title='"._("This application is no longer available.")."'> ";
}else{
$image = "<img class='center' src='images/select_invalid_application.png'
- title='".sprintf(_("This application is not available in any release named %s."),$this->Release)."'> ";
+ title='".sprintf(_("This application is not available in any release named %s."),$this->FAIrelease)."'> ";
}
}elseif(isset($Differences[$entry['App']]) && ($Differences[$entry['App']] == true)) {
$smarty->assign("enableReleaseManagement",$this->enableReleaseManagement);
if($this->enableReleaseManagement){
- $smarty->assign("Release", $this->Release);
+ $smarty->assign("FAIrelease", $this->FAIrelease);
$smarty->assign("Releases", $this->Releases);
if(count($this->used_apps)){
function getReleases()
{
- $dn = "ou=apps,".$this->config->current['BASE'];
+ $dn = $this->config->current['BASE'];
$ldap = $this->config->get_ldap_link();
$ldap->cd($dn);
- $ldap->search("objectClass=organizationalUnit",array("ou"));
+ $ldap->search("(&(objectClass=organizationalUnit)(objectClass=FAIbranch))",array("ou"));
$ret =array();
while($attrs = $ldap->fetch()){
if(preg_match("/ou=apps,/",$attrs['dn'])){
$ret[$attrs['dn']] = $name;
}
}
+
+ /* Set releases to / id nor presenet */
+ if (!count($ret)){
+ $ret['/']= '/';
+ }
+
return($ret);
}
function save_object()
{
- if(isset($_POST ['Release'])){
- $this->Release = $_POST['Release'];
- }
+ plugin::save_object();
}
{
plugin::remove_from_parent();
- $this->attrs["gosaMemberApplication"]= array();
-
$ldap= $this->config->get_ldap_link();
$ldap->cd($this->dn);
$this->cleanup();
-$ldap->modify ($this->attrs);
+
+ $ldap->modify ($this->attrs);
- show_ldap_error($ldap->get_error());
+ show_ldap_error($ldap->get_error(), _("Removing application information failed"));
/* Optionally execute a command after we're done */
$this->handle_post_events("remove");
/* Copy members */
$this->Categories[""]="";
$this->attrs["gosaMemberApplication"]= array();
+ $this->attrs["gosaApplicationParameter"]= array();
foreach($this->Categories as $name => $cats){
$i =0;
if(isset($this->gosaMemberApplication[$name])){
$ldap= $this->config->get_ldap_link();
$ldap->cd($this->dn);
$this->cleanup();
-$ldap->modify ($this->attrs);
+ $ldap->modify ($this->attrs);
- show_ldap_error($ldap->get_error());
+ 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){
/* Special handling for release managed apps
*/
$tmp = search_config($this->config->data,"faiManagement","CLASS");
- if(!empty($tmp)){
+ if(!empty($tmp) && count($this->Releases)){
$this->enableReleaseManagement = true;
$tmp = array_flip($this->Releases);
- if(isset($tmp[$this->Release])){
- $base = $tmp[$this->Release];
+ if(isset($tmp[$this->FAIrelease])){
+ $base = $tmp[$this->FAIrelease];
}else{
+ $old_r = $this->FAIrelease;
$k = key($tmp);
$r = $tmp[$k];
- $this->Release = $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->Release,$k));
+ print_red(sprintf(_("Can't resolve the release name '%s', setting release name to '%s'. Possibly the objects base has changed."),$old_r,$k));
}
$base = preg_replace("/ou=apps,.*$/","ou=apps,".$this->curbase,$base);
$testdn = preg_replace("/^[^,]+/","",$testdn);
$testdn = preg_replace("/^,/","",$testdn);
- if($testdn == preg_replace("/ou=apps,.*$/","ou=apps",$tmp[$this->Release])){
+ if($testdn == preg_replace("/ou=apps,.*$/","ou=apps",$tmp[$this->FAIrelease])){
$this->AllAppsForRelease[$attrs['dn']] = $attrs['cn'][0];
- $this->AllAppsForReleaseParameter[$this->Release][$attrs['cn'][0]] = $attrs;
+ $this->AllAppsForReleaseParameter[$this->FAIrelease][$attrs['cn'][0]] = $attrs;
}
}
}else{
$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();
}
return($ret);
}
-
-
- /* Get selected release name.
- * it is written in the description tag
- * within ... (.*)$
- */
- function getReleaseName()
- {
-
- if(isset($this->parent)){
- $base = $this->parent->by_object['group'];
- }else{
- $base = $this;
- }
-
- if(isset($base->attrs['description'][0])){
- $desc = $base->attrs['description'][0];
- }else{
- $desc = "";
- }
-
- if(preg_match("/\(.*\)$/",$desc)){
- $str = preg_replace("/^.*\((.*)\)$/","\\1",$desc);
- }else{
- $str = "/";
- }
- return($str);
- }
}
// vim:tabstop=2:expandtab:shiftwidth=2:filetype=php:syntax:ruler: