From b8fe69db1f49364860eb291ae22457e98d51461c Mon Sep 17 00:00:00 2001 From: hickert Date: Fri, 6 Nov 2009 07:49:41 +0000 Subject: [PATCH] Startet porting the application management git-svn-id: https://oss.gonicus.de/repositories/gosa/trunk@14770 594d385d-05f5-0310-b6e9-bd551577e9d8 --- .../admin/applications/application-filter.tpl | 33 + .../admin/applications/application-filter.xml | 40 + .../admin/applications/application-list.tpl | 31 + .../admin/applications/application-list.xml | 156 ++++ .../class_applicationManagement.inc | 808 ++---------------- .../applications/class_divListApplication.inc | 266 ------ gosa-plugins/goto/admin/applications/main.inc | 73 +- 7 files changed, 362 insertions(+), 1045 deletions(-) create mode 100644 gosa-plugins/goto/admin/applications/application-filter.tpl create mode 100644 gosa-plugins/goto/admin/applications/application-filter.xml create mode 100644 gosa-plugins/goto/admin/applications/application-list.tpl create mode 100644 gosa-plugins/goto/admin/applications/application-list.xml delete mode 100644 gosa-plugins/goto/admin/applications/class_divListApplication.inc diff --git a/gosa-plugins/goto/admin/applications/application-filter.tpl b/gosa-plugins/goto/admin/applications/application-filter.tpl new file mode 100644 index 000000000..ba7af5cde --- /dev/null +++ b/gosa-plugins/goto/admin/applications/application-filter.tpl @@ -0,0 +1,33 @@ +
+

+ [F]{t}Filter{/t} +

+
+ +
+ +
+ + {$SCOPE} + + + + + + +
+ + + {$NAME} +
+ + + + + +
+ {$APPLY} +
+
diff --git a/gosa-plugins/goto/admin/applications/application-filter.xml b/gosa-plugins/goto/admin/applications/application-filter.xml new file mode 100644 index 000000000..bcdcb01b3 --- /dev/null +++ b/gosa-plugins/goto/admin/applications/application-filter.xml @@ -0,0 +1,40 @@ + + + + + application + + true + + + + + LDAP + (&(objectClass=gosaApplication)$NAME) + dn + objectClass + cn + description + + auto + + + + textfield + NAME + 20 + 60 + + + (|(cn=*$*)(description=*$*)) + true + + LDAP + (&(objectClass=gosaApplication)(|(cn=*$NAME*)(description=*$NAME*))) + cn + 0.5 + 3 + + + + diff --git a/gosa-plugins/goto/admin/applications/application-list.tpl b/gosa-plugins/goto/admin/applications/application-list.tpl new file mode 100644 index 000000000..b233c5874 --- /dev/null +++ b/gosa-plugins/goto/admin/applications/application-list.tpl @@ -0,0 +1,31 @@ + + + + + + + +
+
+

 {$HEADLINE} {$SIZELIMIT}

+
+ +
+
+ + +
{$ROOT} {$BACK} {$HOME} {$RELOAD} {$SEPARATOR} {t}Base{/t} {$BASE}  {$SEPARATOR}  {$ACTIONS}
+
+
+ +
+
+ + + + {$LIST} +
+ {$FILTER} +
+ + diff --git a/gosa-plugins/goto/admin/applications/application-list.xml b/gosa-plugins/goto/admin/applications/application-list.xml new file mode 100644 index 000000000..07ca7379c --- /dev/null +++ b/gosa-plugins/goto/admin/applications/application-list.xml @@ -0,0 +1,156 @@ + + + + + true + false + true + true + + applications + + 1 + + + + posixGroup + application + application + plugins/applications/images/applications.png + + + + + + |16px|||120px|150px;r| + + + %{filter:objectType(dn,objectClass)} + + + + %{filter:departmentLink(row,dn,description)} + 2 + + + + %{filter:objectType(dn,objectClass)} + + + + + cn + string + %{filter:link(row,dn,"%s",cn)} + true + + + + + description + string + %{filter:link(row,dn,"%s",description)} + true + + + + + %{filter:filterProperties(row,objectClass)} + + + + + %{filter:actions(dn,row,objectClass)} + + +
+ + + + + sub + images/lists/new.png + + + + new + entry + plugins/applications/images/new.png + + + + + + separator + + + + edit + entry + images/lists/edit.png + + + + + remove + entry + images/lists/trash.png + + + + + sendMessage + entry + DaemonEvent_notify + plugins/goto/images/notify.png + + + + + exporter + + + + separator + + + + copypaste + + + + snapshot + + + + + + + + cp + copypaste + + + + edit + entry + images/lists/edit.png + + + + + snapshot + snapshot + + + + remove + entry + images/lists/trash.png + application/application[d] + + + + + +
diff --git a/gosa-plugins/goto/admin/applications/class_applicationManagement.inc b/gosa-plugins/goto/admin/applications/class_applicationManagement.inc index ddfb16123..15bdc7d1e 100644 --- a/gosa-plugins/goto/admin/applications/class_applicationManagement.inc +++ b/gosa-plugins/goto/admin/applications/class_applicationManagement.inc @@ -1,761 +1,91 @@ config->search("faiManagement", "CLASS",array('menu','tabs')); - if(!empty($tmp)){ - return(true); - } - return(false); - } - - - function applicationManagement (&$config, &$ui) - { - /* Save configuration for internal use */ - $this->config = &$config; - $this->ui = &$ui; - - /* Check if copy & paste is activated */ - if($this->config->boolValueIsTrue("MAIN","COPYPASTE")){ - $this->CopyPasteHandler = new CopyPasteHandler($this->config); - } - - /* Creat dialog object */ - $this->DivListApplication = new divListApplication($this->config,$this); - - if($this->IsReleaseManagementActivated()){ - $this->acl_base = $this->config->current['BASE']; - - /* Check if we should enable the release selection */ - $this->enableReleaseManagement = true; - - /* Hide SubSearch checkbox */ - $this->DivListApplication->DisableCheckBox("SubSearch"); - }else{ - $this->acl_base = &$this->DivListApplication->selectedBase; - } + var $plDescription = "Application administration"; + var $plIcon = "plugins/applications/images/plugin.png"; - /* Set default release */ - if(!$this->IsReleaseManagementActivated()){ - $this->app_base = get_ou("applicationRDN").$this->config->current['BASE']; - if(!session::is_set("app_filter")){ - session::set("app_filter",array("app_base" => $this->app_base)); - } - $app_filter = session::get("app_filter"); - }else{ + var $app_release = ""; // The currently selected release while in release management mode! - /* Set intial release */ - $this->app_base = get_ou("applicationRDN").$this->config->current['BASE']; - $rel = $config->search("faiManagement","DEFAULTFAIRELEASE",array("menu")); - $rels = array_flip($this->getReleases()); - if(isset($rels[$rel])){ - $rel = $rels[$rel]; - }else{ - $rel = $this->app_base; - } + // Tab definition + protected $tabClass = "apptabs"; + protected $tabType = "APPSTABS"; + protected $aclCategory = "application"; + protected $aclPlugin = "application"; + protected $objectName = "application"; - if(!session::is_set("app_filter")){ - session::set("app_filter",array("app_base" => $this->app_base,"app_release" => $rel)); - } - $app_filter = session::get("app_filter"); - $this->app_base = $app_filter['app_base']; - $this->app_release = $app_filter['app_release']; - } - } - - - function getReleases() + function __construct($config,$ui) { - $ldap = $this->config->get_ldap_link(); - $ret = array(); - $base = $this->app_base; - - $ret[$this->app_base] = "/"; - $ldap->cd($base); - $ldap->search("(&(objectClass=organizationalUnit)(objectClass=FAIbranch))",array("ou")); - while($attrs = $ldap->fetch()){ - $str = str_replace($base,"",$attrs['dn']); - $tmp = array_reverse( split("ou=",$str)); - $str = ""; - foreach($tmp as $val){ - $val = trim(preg_replace("/,/","",$val)); - if(empty($val)) break; - $str .= "/".$val; - } - if(!empty($str)){ - $ret[$attrs['dn']]= preg_replace("/^\//","",$str); - } - } - asort($ret); - return($ret); - } - - function execute() - { - /* Call parent execute */ - plugin::execute(); - - - /**************** - Variable init - ****************/ - - /* These vars will be stored if you try to open a locked app, - to be able to perform your last requests after showing a warning message */ - session::set('LOCK_VARS_TO_USE',array("/^act$/","/^id$/","/^appl_edit_/","/^appl_del_/","/^item_selected/","/^remove_multiple_applications/","/^menu_action/")); - - $smarty = get_smarty(); // Smarty instance - $s_action = ""; // Contains the action to proceed - $s_entry = ""; // The value for s_action - $base_back = ""; // The Link for Backbutton - - /* Test Posts */ - foreach($_POST as $key => $val){ - // Post for delete - if(preg_match("/appl_del.*/",$key)){ - $s_action = "del"; - $s_entry = preg_replace("/appl_".$s_action."_/i","",$key); - // Post for edit - }elseif(preg_match("/appl_edit_.*/",$key)){ - $s_action="edit"; - $s_entry = preg_replace("/appl_".$s_action."_/i","",$key); - // Post for new - }elseif(preg_match("/^copy_.*/",$key)){ - $s_action="copy"; - $s_entry = preg_replace("/^copy_/i","",$key); - }elseif(preg_match("/^cut_.*/",$key)){ - $s_action="cut"; - $s_entry = preg_replace("/^cut_/i","",$key); - // Post for new - }elseif(preg_match("/^appl_new.*/",$key)){ - $s_action="new"; - }elseif(preg_match("/^remove_multiple_applications/",$key)){ - $s_action="del_multiple"; - }elseif(preg_match("/^editPaste.*/i",$key)){ - $s_action="editPaste"; - }elseif(preg_match("/^multiple_copy_groups/",$key)){ - $s_action = "copy_multiple"; - }elseif(preg_match("/^multiple_cut_groups/",$key)){ - $s_action = "cut_multiple"; - } - } - - if((isset($_GET['act']))&&($_GET['act']=="edit_entry")){ - $s_action ="edit"; - $s_entry = $_GET['id']; - } - - $s_entry = preg_replace("/_.$/","",$s_entry); - - - /* handle C&P from layers menu */ - if(isset($_POST['menu_action']) && preg_match("/^multiple_copy_systems/",$_POST['menu_action'])){ - $s_action = "copy_multiple"; - } - if(isset($_POST['menu_action']) && preg_match("/^multiple_cut_systems/",$_POST['menu_action'])){ - $s_action = "cut_multiple"; - } - if(isset($_POST['menu_action']) && preg_match("/^editPaste/",$_POST['menu_action'])){ - $s_action = "editPaste"; - } - - /* Create options */ - if(isset($_POST['menu_action']) && $_POST['menu_action'] == "appl_new"){ - $s_action = "new"; - } - - /* handle remove from layers menu */ - if(isset($_POST['menu_action']) && preg_match("/^remove_multiple/",$_POST['menu_action'])){ - $s_action = "del_multiple"; - } - - /**************** - Copy & Paste handling - ****************/ - - /* Display the copy & paste dialog, if it is currently open */ - $ret = $this->copyPasteHandling_from_queue($s_action,$s_entry); - if($ret){ - return($ret); - } - - /**************** - Create a new app - ****************/ - - /* New application? */ - if ($s_action=="new"){ - - /* By default we set 'dn' to 'new', all relevant plugins will - react on this. */ - $this->dn= "new"; - - /* Create new usertab object */ - $this->apptabs= new apptabs($this->config,$this->config->data['TABS']['APPSTABS'], $this->dn,"application"); - $this->apptabs->parent = &$this; - $this->apptabs->set_acl_base($this->acl_base); - } - - - /**************** - Edit entry canceled - ****************/ - - /* Cancel dialogs */ - if (isset($_POST['edit_cancel']) || isset($_POST['password_cancel'])){ - $this->remove_lock(); - $this->apptabs= NULL; - set_object_info(); - } - - - /**************** - Edit entry finished - ****************/ - - /* Finish apps edit is triggered by the tabulator dialog, so - the user wants to save edited data. Check and save at this - point. */ - if ((isset($_POST['edit_finish']) || isset($_POST['edit_apply']) ) && (isset($this->apptabs->config))){ - - /* Check tabs, will feed message array */ - $this->apptabs->last= $this->apptabs->current; - $this->apptabs->save_object(); - $message= $this->apptabs->check(); - - /* Save, or display error message? */ - if (count($message) == 0){ - - /* Save data data to ldap */ - $this->apptabs->save(); - - if (!isset($_POST['edit_apply'])){ - /* Application has been saved successfully, remove lock from - LDAP. */ - if ($this->dn != "new"){ - $this->remove_lock(); - } - $this->apptabs= NULL; - set_object_info(); - }else{ - - /* Reinitialize tab */ - if($this->apptabs instanceof tabs){ - $this->apptabs->re_init(); - } - } - } else { - /* Ok. There seem to be errors regarding to the tab data, - show message and continue as usual. */ - msg_dialog::displayChecks($message); - } - } - - - /**************** - Edit entry - ****************/ - - /* User wants to edit data? */ - if (($s_action=="edit") && (!isset($this->apptabs->config))){ - - /* Get 'dn' from posted 'applist', must be unique */ - $this->dn= $this->applications[$s_entry]['dn']; - - /* Check locking, save current plugin in 'back_plugin', so - the dialog knows where to return. */ - if (($user= get_lock($this->dn)) != ""){ - return(gen_locked_message ($user, $this->dn,TRUE)); - } - - /* Lock the current entry, so everyone will get the - above dialog */ - add_lock ($this->dn, $this->ui->dn); - - /* Register apptabs to trigger edit dialog */ - $this->apptabs= new apptabs($this->config,$this->config->data['TABS']['APPSTABS'], $this->dn,"application"); - if($this->IsReleaseManagementActivated()){ - $this->apptabs->set_FAIstate($this->applications[$s_entry]['FAIstate'][0]); - } - $this->apptabs->parent = &$this; - $this->apptabs->set_acl_base($this->dn); - set_object_info($this->dn); - } - - - - /******************** - Delete MULTIPLE entries requested, display confirm dialog - ********************/ - - if ($s_action=="del_multiple"){ - $ids = $this->list_get_selected_items(); - - if(count($ids)){ - $this->dns = array(); - - $disallowed = array(); - foreach($ids as $id){ - $dn = $this->applications[$id]['dn']; - $acl = $this->ui->get_permissions($dn, "application/application"); - if(preg_match("/d/",$acl)){ - $this->dns[$id] = $dn; - }else{ - $disallowed[] = $dn; - } - } - - if(count($disallowed)){ - msg_dialog::display(_("Permission"),msgPool::permDelete($disallowed),INFO_DIALOG); - } - - if(count($this->dns)){ - - if ($user= get_multiple_locks($this->dns)){ - return(gen_locked_message($user,$this->dns)); - } - - $dns_names = array(); - foreach($this->dns as $dn){ - add_lock ($dn, $this->ui->dn); - $dns_names[] =LDAP::fix($dn); - } - - /* Lock the current entry, so nobody will edit it during deletion */ - $smarty->assign("intro", msgPool::deleteInfo($dns_names,_("application"))); - $smarty->assign("multiple", true); - return($smarty->fetch(get_template_path('remove.tpl', TRUE))); - } - } - } - - - /******************** - Delete MULTIPLE entries confirmed - ********************/ - - /* Confirmation for deletion has been passed. Users should be deleted. */ - if (isset($_POST['delete_multiple_application_confirm'])){ - - /* Remove user by user and check acls before removeing them */ - foreach($this->dns as $key => $dn){ - - $ui = get_userinfo(); - $acl = $ui->get_permissions($dn ,"application/application"); - if (preg_match('/d/', $acl)){ - - /* Delete request is permitted, perform LDAP action */ - $this->apptabs= new apptabs($this->config, $this->config->data['TABS']['APPSTABS'], $dn,"application"); - $this->apptabs->parent = &$this; - $this->apptabs->set_acl_base($dn); - $this->apptabs->delete (); - unset ($this->apptabs); - $this->apptabs= NULL; - - } else { - /* Normally this shouldn't be reached, send some extra - logs to notify the administrator */ - msg_dialog::display(_("Permission error"), msgPool::permDelete(), INFO_DIALOG); - new log("security","application/".get_class($this),$dn,array(),"Tried to trick deletion."); - } - } - - /* Remove lock file after successfull deletion */ - $this->remove_lock(); - $this->dns = array(); - } - - - /******************** - Delete MULTIPLE entries Canceled - ********************/ - - /* Remove lock */ - if(isset($_POST['delete_multiple_application_cancel'])){ - - /* Remove lock file after successfull deletion */ - $this->remove_lock(); - $this->dns = array(); - } - - /**************** - Delete app - ****************/ - - /* Remove user was requested */ - if ($s_action == "del"){ - - /* Get 'dn' from posted 'uid' */ - $this->dn= $this->applications[$s_entry]['dn']; - - /* Load permissions for selected 'dn' and check if - we're allowed to remove this 'dn' */ - $ui = get_userinfo(); - $acl = $ui->get_permissions($this->dn ,"application/application"); - - if(preg_match("/d/",$acl)){ - /* Check locking, save current plugin in 'back_plugin', so - the dialog knows where to return. */ - if (($user= get_lock($this->dn)) != ""){ - return (gen_locked_message ($user, $this->dn)); - } - - /* Lock the current entry, so nobody will edit it during deletion */ - add_lock ($this->dn, $this->ui->dn); - $smarty= get_smarty(); - $smarty->assign("intro",msgPool::deleteInfo(LDAP::fix($this->dn),_("application"))); - $smarty->assign("multiple", false); - return($smarty->fetch (get_template_path('remove.tpl', TRUE))); - } else { - - /* Obviously the user isn't allowed to delete. Show message and - clean session. */ - msg_dialog::display(_("Permission error"), msgPool::permDelete(), INFO_DIALOG); - } - } - - - /**************** - Delete app confirmed - ****************/ - - /* Confirmation for deletion has been passed. Group should be deleted. */ - if (isset($_POST['delete_app_confirm'])){ - - /* Some nice guy may send this as POST, so we've to check - for the permissions again. */ - $ui = get_userinfo(); - $acl = $ui->get_permissions($this->dn ,"application/application"); - - if(preg_match("/d/",$acl)){ - - /* Delete request is permitted, perform LDAP action */ - $this->apptabs= new apptabs($this->config, $this->config->data['TABS']['APPSTABS'], $this->dn,"application"); - $this->apptabs->parent = &$this; - $this->apptabs->set_acl_base($this->dn); - $this->apptabs->delete (); - unset ($this->apptabs); - $this->apptabs= NULL; - - } else { - - /* Normally this shouldn't be reached, send some extra - logs to notify the administrator */ - msg_dialog::display(_("Permission error"), msgPool::permDelete(), INFO_DIALOG); - new log("security","application/".get_class($this),$dn,array(),"Tried to trick deletion."); - } - - /* Remove lock file after successfull deletion */ - $this->remove_lock(); - } - - - /**************** - Delete app canceled - ****************/ - - /* Delete application canceled? */ - if (isset($_POST['delete_cancel'])){ - $this->remove_lock(); - set_object_info(); - } - - /* Show tab dialog if object is present */ - if (($this->apptabs) && (isset($this->apptabs->config))){ - $display= $this->apptabs->execute(); - - /* Don't show buttons if tab dialog requests this */ - if (!$this->apptabs->by_object[$this->apptabs->current]->dialog){ - $display.= "

\n"; - - if(($this->apptabs instanceOf tabs || $this->apptabs instanceOf plugin) && $this->apptabs->read_only == TRUE){ - $display.= "

- -

"; - }elseif(isset($this->apptabs->FAIstate) && !preg_match("/freeze/i",$this->apptabs->FAIstate)){ - $display.= "\n"; - $display.= " \n"; - if ($this->dn != "new"){ - $display.= "\n"; - $display.= " \n"; - } - } - $display.= "\n"; - $display.= "

"; - } - return ($display); - } - - - /**************** - Dialog display - ****************/ - - /* Check if there is a snapshot dialog open */ - if($this->IsReleaseManagementActivated()){ - $base = $this->app_release; - }else{ - $base = $this->app_base; - } - if($str = $this->showSnapshotDialog($base,$this->get_used_snapshot_bases(),$this)){ - return($str); - } - - /* Display dialog with system list */ - $this->DivListApplication->parent = $this; - $this->DivListApplication->execute(); - if(!$this->IsReleaseManagementActivated()){ - $this->DivListApplication->AddDepartments($this->DivListApplication->selectedBase,3,1); - } - $this->reload(); - $this->DivListApplication->setEntries($this->applications); - return($this->DivListApplication->Draw()); - } - - - /* Return departments, that will be included within snapshot detection */ - function get_used_snapshot_bases() - { - if($this->IsReleaseManagementActivated()){ - return(array($this->app_release)); - }else{ - return(array($this->app_base)); - } - } - - - function reload() - { - $this->applications= array(); - - /* Set base for all searches */ - $Regex = $this->DivListApplication->Regex; - $SubSearch = $this->DivListApplication->SubSearch; - $Flags = GL_NONE | GL_SIZELIMIT; - $Filter = "(&(cn=".$Regex.")(objectClass=gosaApplication))"; - $tmp = array(); - - if(!$this->IsReleaseManagementActivated()){ - $use_base = $this->app_base; - if($SubSearch){ - $use_base = preg_replace("/^".preg_quote(get_ou("applicationRDN"), '/')."/","",$use_base); - } - }else{ - $use_base = $this->app_release; - $SubSearch= FALSE; - } - - /* Add FAIstate to the search attributes */ - $search_attrs = array("cn","description","dn","objectClass"); - if($this->IsReleaseManagementActivated()) { - $search_attrs[] = "FAIstate"; - } + $this->config = $config; + $this->ui = $ui; + + $this->storagePoints = array(get_ou("applicationRDN")); - if($SubSearch){ - $res= get_sub_list($Filter, "application",get_ou("applicationRDN"), $use_base, $search_attrs, $Flags); - }else{ - $res= get_list($Filter, "application",$use_base, $search_attrs, $Flags); - } - $tmp2 = array(); - foreach ($res as $val){ - if(!isset($val['FAIstate'])){ - $val['FAIstate'][0] = ""; - } - $tmp[strtolower($val['cn'][0]).$val['cn'][0].$val['dn']]=$val; - $tmp2[strtolower($val['cn'][0]).$val['cn'][0].$val['dn']] = strtolower($val['cn'][0]).$val['cn'][0].$val['dn']; - } - - natcasesort($tmp2); - $this->applications=array(); - foreach($tmp2 as $val){ - $this->applications[]=$tmp[$val]; - } - reset ($this->applications); +# // Build filter +# if (session::global_is_set(get_class($this)."_filter")){ +# $filter= session::global_get(get_class($this)."_filter"); +# } else { + $filter = new filter(get_template_path("application-filter.xml", true)); + $filter->setObjectStorage($this->storagePoints); +# } + $this->setFilter($filter); + + // Build headpage + $headpage = new listing(get_template_path("application-list.xml", true)); + $headpage->setFilter($filter); + + // Add copy&paste and snapshot handler. + if ($this->config->boolValueIsTrue("main", "copyPaste")){ + $this->cpHandler = new CopyPasteHandler($this->config); + } + if($this->config->get_cfg_value("enableSnapshots") == "true"){ + $this->snapHandler = new SnapshotHandler($this->config); + } + parent::__construct($config, $ui, "applications", $headpage); + + $this->registerAction("edit_application","editEntry"); + $this->registerAction("edit_environment","editEntry"); + $this->registerAction("edit_appapplication","editEntry"); + $this->registerAction("edit_mailapplication","editEntry"); } - function remove_from_parent() + function renderList() { - /* Optionally execute a command after we're done */ - $this->postremove(); + $headpage = $this->getHeadpage(); + return(management::renderList()); } - - function copyPasteHandling_from_queue($s_action,$s_entry) - { - /* Check if Copy & Paste is disabled */ - if(!is_object($this->CopyPasteHandler)){ - return(""); - } - - $ui = get_userinfo(); - - /* Add a single entry to queue */ - if($s_action == "cut" || $s_action == "copy"){ - - /* Cleanup object queue */ - $this->CopyPasteHandler->cleanup_queue(); - $dn = $this->applications[$s_entry]['dn']; - if($s_action == "copy" && $ui->is_copyable($dn,"application","application")){ - $this->CopyPasteHandler->add_to_queue($dn,$s_action,"apptabs","APPSTABS","application"); - } - if($s_action == "cut" && $ui->is_cutable($dn,"application","application")){ - $this->CopyPasteHandler->add_to_queue($dn,$s_action,"apptabs","APPSTABS","application"); - } - } - - - /* Add entries to queue */ - if($s_action == "copy_multiple" || $s_action == "cut_multiple"){ - - /* Cleanup object queue */ - $this->CopyPasteHandler->cleanup_queue(); - - /* Add new entries to CP queue */ - foreach($this->list_get_selected_items() as $id){ - $dn = $this->applications[$id]['dn']; - - if($s_action == "copy_multiple" && $ui->is_copyable($dn,"application","application")){ - $this->CopyPasteHandler->add_to_queue($dn,"copy","apptabs","APPSTABS","application"); - } - if($s_action == "cut_multiple" && $ui->is_cutable($dn,"application","application")){ - $this->CopyPasteHandler->add_to_queue($dn,"cut","apptabs","APPSTABS","application"); - } - } - } - - /* Start pasting entries */ - if($s_action == "editPaste"){ - $this->start_pasting_copied_objects = TRUE; - } - - - /* Return C&P dialog */ - if($this->start_pasting_copied_objects && $this->CopyPasteHandler->entries_queued()){ - - - /* Get dialog */ - $this->CopyPasteHandler->SetVar("base",$this->app_base); - $this->CopyPasteHandler->SetVar("parent",$this); - $data = $this->CopyPasteHandler->execute(); - - /* Return dialog data */ - if(!empty($data)){ - return($data); - } - } - - /* Automatically disable status for pasting */ - if(!$this->CopyPasteHandler->entries_queued()){ - $this->start_pasting_copied_objects = FALSE; - } - return(""); - } - - - function list_get_selected_items() - { - $ids = array(); - foreach($_POST as $name => $value){ - if(preg_match("/^item_selected_[0-9]*$/",$name)){ - $id = preg_replace("/^item_selected_/","",$name); - $ids[$id] = $id; - } - } - return($ids); - } - - - /* Save to LDAP */ - function save() - { - /* Optionally execute a command after we're done */ - $this->postcreate(); - } - - - function remove_lock() - { - if (isset($this->apptabs->dn)){ - del_lock ($this->apptabs->dn); - }elseif(isset($this->dn) && !empty($this->dn) && $this->dn != "new"){ - del_lock($this->dn); - } - if(isset($this->dns) && is_array($this->dns) && count($this->dns)){ - del_lock($this->dns); - } - } - - - function save_object() + function IsReleaseManagementActivated() { - $this->DivListApplication->save_object(); - if(is_object($this->CopyPasteHandler)){ - $this->CopyPasteHandler->save_object(); - } - - if($this->IsReleaseManagementActivated() && isset($_POST['app_release'])){ - $sel_rel = get_post('app_release'); - $releases = array_flip($this->getReleases()); - if(isset($releases[$sel_rel])){ - $this->app_release = $releases[$sel_rel]; - } - $app_filter = session::get("app_filter"); - $app_filter['app_release'] = $this->app_release; - session::set("app_filter",$app_filter); - }elseif(!$this->IsReleaseManagementActivated()){ - $this->app_base = get_ou("applicationRDN").$this->DivListApplication->selectedBase; - $app_filter = session::get("app_filter"); - $app_filter['app_base'] = $this->app_base; - session::set("app_filter",$app_filter); + /* Check if we should enable the release selection */ + $tmp = $this->config->search("faiManagement", "CLASS",array('menu','tabs')); + if(!empty($tmp)){ + return(true); } + return(false); } - function check() {} - function adapt_from_template($dn, $skip= array()) {} - function password_change_needed() {} -} +} // vim:tabstop=2:expandtab:shiftwidth=2:filetype=php:syntax:ruler: ?> diff --git a/gosa-plugins/goto/admin/applications/class_divListApplication.inc b/gosa-plugins/goto/admin/applications/class_divListApplication.inc deleted file mode 100644 index c281fa2c5..000000000 --- a/gosa-plugins/goto/admin/applications/class_divListApplication.inc +++ /dev/null @@ -1,266 +0,0 @@ -parent = &$parent; - $this->ui = get_userinfo(); - - /* Set list strings */ - $this->SetTitle(_("List of Applications")); - $this->SetSummary(_("This table displays all applications in the selected tree.")); - - /* Result page will look like a headpage */ - $this->SetHeadpageMode(); - - $this->EnableAplhabet(true); - - /* Disable buttonsm */ - $this->EnableCloseButton(false); - $this->EnableSaveButton (false); - - /* set Page header */ - $action_col_size = 80; - if($this->parent->snapshotEnabled()){ - $action_col_size += 38; - } - - - /* Toggle all selected / deselected */ - $chk = ""; - - /* set Page header */ - $this->AddHeader(array("string"=> $chk, "attach"=>"style='width:20px;'")); - $this->AddHeader(array("string" => " ", "attach" => "style='text-align:center;width:20px;'")); - $this->AddHeader(array("string" => _("Application name")." / "._("Department"), "attach" => "style=''")); - $this->AddHeader(array("string" => _("Actions"), "attach" => "style='width:".$action_col_size."px;border-right:0px;text-align:right;'")); - - /* Add SubSearch checkbox */ - $this->AddCheckBox("SubSearch", msgPool::selectToView("","subsearch"), msgPool::selectToView("","subsearch_small"), false); - - /* Name ,Text ,Default , Connect with alphabet */ - $this->AddRegex ("Regex", _("Display users matching"),"*" , true); - } - - - function AddUserBoxToFilter($position) - { - $str = ""; - if(($position == 2) && ($this->parent->IsReleaseManagementActivated($this->config))){ - $smarty = get_smarty(); - $releases = $this->parent->getReleases(); - $smarty->assign("app_release" , $releases[$this->parent->app_release]); - $smarty->assign("app_base" , $releases[$this->parent->app_base]); - $smarty->assign("branchimage","plugins/goto/images/branch.png"); - $smarty->assign("app_releases", $releases); - $str = $smarty->fetch(get_template_path('release_select.tpl', TRUE)); - } - return($str); - } - - - function GenHeader() - { - /* Add default header */ - $listhead = MultiSelectWindow::get_default_header(false); - - if(!$this->parent->IsReleaseManagementActivated()){ - - /* Get all departments within this subtree */ - $base = $this->config->current['BASE']; - $options = $this->create_department_list($this->module); - - /* And the rest, a base selection box */ - $listhead .= _("Base")." ". - "  "; - } - - /* Get acls */ - $ui = get_userinfo(); - - if($this->parent->IsReleaseManagementActivated()){ - $acl = $ui->get_permissions($this->parent->acl_base,"application/application"); - $acl_all = $ui->has_complete_category_acls($this->parent->acl_base,"application"); - }else{ - $acl = $ui->get_permissions($this->selectedBase,"application/application"); - $acl_all = $ui->has_complete_category_acls($this->parent->app_base,"application"); - } - - /* Create Layers menu */ - $s = ".|"._("Actions")."|\n"; - - /* Append create options */ - $s .= "..|". - " "._("Create")."|\n"; - if(preg_match("/c/",$acl)) { - $s.= "...|". - " "._("Application")."|appl_new|\n"; - } - - /* Multiple options */ - $s.= "..|---|\n"; - $s.= "..|". - " "._("Remove")."|"."remove_multiple|\n"; - - /* Add Copy & Paste header */ - $s .= $this->parent->get_copypaste_header($this->selectedBase,$this->module); - - /* Add snapshot icons */ - $s .= $this->parent->get_snapshot_header($this->selectedBase,$this->module); - - $this->SetDropDownHeaderMenu($s); - $this->SetListHeader($listhead); - } - - - /* so some basic settings */ - function execute() - { - $this->ClearElementsList(); - $this->GenHeader(); - } - - - function setEntries($list) - { - /******************** - Variable init - ********************/ - - /* Create links */ - $editlink = "%s"; - $userimg = "User"; - $applimg = "A"; - $empty = ""; - - /* set Page header */ - $action_col_size = 80; - if($this->parent->snapshotEnabled()){ - $action_col_size += 38; - } - - /******************** - Attach objects - ********************/ - - $ui = get_userinfo(); - foreach($list as $key => $val){ - - $acl = $ui->get_permissions($val['dn'],"application/application"); - $acl_all= $ui->has_complete_category_acls($val['dn'],"application"); - - /* Check FAI state - */ - $FAIstate = $val['FAIstate'][0]; - - /* Create action icons */ - $actions= ""; - - /* Add copy & cut functionality */ - if(!preg_match("/freeze/i",$FAIstate)){ - $actions.= $this->parent->get_copypaste_action($val['dn'],"application","application"); - }else{ - $actions.= " "; - $actions.= " "; - } - - /* Add edit icon */ - $actions.= ""; - - /* Add snapshot icon */ - if(!preg_match("/freeze/i",$FAIstate)){ - $actions.= $this->parent->get_snapshot_action($val['dn'],$this->module); - }else{ - $actions.= " "; - $actions.= " "; - } - - - /* If we are allowed to remove the application account, display remove icon */ - if(preg_match("/freeze/i",$FAIstate)){ - $actions .= "!"; - }elseif(preg_match("/d/",$acl)){ - $actions.= ""; - }else{ - $actions.= " "; - } - - $title = "title='".preg_replace('/ /', ' ', LDAP::fix($val['dn']))."'"; - - if(!isset($val['description'][0])){ - $desc = ""; - }else{ - $desc = " - [ ".$val['description'][0]." ]"; - } - - /* Cutted objects should be displayed in light grey */ - $display = $val['cn'][0].$desc; - if($this->parent->CopyPasteHandler){ - foreach($this->parent->CopyPasteHandler->queue as $queue_key => $queue_data){ - if($queue_data['dn'] == $val['dn']) { - $display = "".$display.""; - break; - } - } - } - - /* Create each field */ - $field0 = array("string" => "" , - "attach" => "style='width:20px;'"); - $field1 = array("string" => sprintf($applimg,$val['dn']), "attach" => "style='text-align:center;width:20px;'"); - $field2 = array("string" => sprintf($editlink,$key,$display), "attach" => "style='' ".$title); - $field3 = array("string" => preg_replace("/%KEY%/", $key, $actions), "attach" => "style='width:".$action_col_size."px;border-right:0px;text-align:right;'"); - $this->AddElement(array($field0,$field1,$field2,$field3)); - } - - /* Create summary string for list footer */ - $num_deps=0; - if(!$this->SubSearch){ - $num_deps = count($this->Added_Departments); - } - $num_apps = count($list); - - $num_app_str = _("Number of listed applications"); - $num_dep_str = _("Number of listed departments"); - - $str = "".$num_app_str." ".$num_apps."    "; - $str.= "".$num_dep_str." ".$num_deps."    "; - - $this->set_List_Bottom_Info($str); - } - - function Save() - { - MultiSelectWindow::Save(); - } - - function save_object() - { - /* Save automatic created POSTs like regex, checkboxes */ - MultiSelectWindow::save_object(); - } - -} -// vim:tabstop=2:expandtab:shiftwidth=2:filetype=php:syntax:ruler: -?> diff --git a/gosa-plugins/goto/admin/applications/main.inc b/gosa-plugins/goto/admin/applications/main.inc index 99a7a72c8..12a396a0b 100644 --- a/gosa-plugins/goto/admin/applications/main.inc +++ b/gosa-plugins/goto/admin/applications/main.inc @@ -1,24 +1,25 @@ execute(); - /* Create applicationManagement object on demand */ - if (!session::is_set('applicationManagement')){ - session::set('applicationManagement',new applicationManagement ($config, $ui)); - } - $applicationManagement = session::get('applicationManagement'); - $applicationManagement->save_object(); - $output= $applicationManagement->execute(); - - /* Page header*/ - if (get_object_info() != ""){ - $display= print_header(get_template_path($applicationManagement->plIcon), _("Application management"), "\"\" ".LDAP::fix(get_object_info())); - } else { - $display= print_header(get_template_path($applicationManagement->plIcon), _("Application management")); - } - - /* Reset requested? */ - if (isset($_GET['reset']) && $_GET['reset'] == 1){ - session::un_set ('applicationManagement'); - } + /* Reset requested? */ + if (isset($_GET['reset']) && $_GET['reset'] == 1){ + session::un_set ('applicationManagement'); + } - /* Show and save dialog */ - $display.= $output; - session::set('applicationManagement',$applicationManagement); + /* Show and save dialog */ + session::set('applicationManagement',$applicationManagement); } +// vim:tabstop=2:expandtab:shiftwidth=2:filetype=php:syntax:ruler: ?> -- 2.30.2