summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: 729363a)
raw | patch | inline | side by side (parent: 729363a)
author | hickert <hickert@594d385d-05f5-0310-b6e9-bd551577e9d8> | |
Mon, 3 Mar 2008 10:08:28 +0000 (10:08 +0000) | ||
committer | hickert <hickert@594d385d-05f5-0310-b6e9-bd551577e9d8> | |
Mon, 3 Mar 2008 10:08:28 +0000 (10:08 +0000) |
git-svn-id: https://oss.gonicus.de/repositories/gosa/trunk@9228 594d385d-05f5-0310-b6e9-bd551577e9d8
diff --git a/gosa-core/include/class_CopyPasteHandler.inc b/gosa-core/include/class_CopyPasteHandler.inc
index a7fdee4589b49899b9d8cb8fc268caf8d0c430bd..1d7364dfcde91299c5d09afa1c2f4fdfc2f62080 100644 (file)
/* The dn of the last edited object */
var $lastdn = "";
+
+ var $disallowed_objects = array();
+ var $objects_to_fix = array();
+ var $clean_objects = array();
+ var $require_update = FALSE;
+
/* Create CP handler */
$tmp['tab_object']= $tab_object;
$tmp['tab_acl_category']= $tab_acl_category;
$this->queue[] = $tmp;
+ $this->require_update = TRUE;
}
}
function cleanup_queue()
{
$this->current = FALSE;
+ $this->require_update = TRUE;
$this->setvar_array = array();
/* Remove all entries from queue */
/* Paste one entry from queue */
- function load_entry_from_queue()
+ function load_entry_from_queue($entry)
{
+ if(!isset($entry['tab_class'])){
+ return(array());
+ }
- /* Save posted variables, handle dialog posts like 'cancel' */
- $this->save_object();
- /* If there is currently no object pasted
- * create new object and prepare object to be pasted
- */
- if(!$this->current && $this->entries_queued()){
- $key = key($this->queue);
- $entry = $this->queue[$key];
- $tab_c = $entry['tab_class'];
- $tab_o = $entry['tab_object'];
- $tab_a = $entry['tab_acl_category'];
-
- if($entry['method'] == "copy"){
- $entry['object'] = new $tab_c($this->config,$this->config->data['TABS'][$tab_o],"new",$tab_a);
- }else{
- $entry['object'] = new $tab_c($this->config,$this->config->data['TABS'][$tab_o],$entry['dn'],$tab_a);
- }
+ $tab_c = $entry['tab_class'];
+ $tab_o = $entry['tab_object'];
+ $tab_a = $entry['tab_acl_category'];
+
+ if($entry['method'] == "copy"){
+ $entry['object'] = new $tab_c($this->config,$this->config->data['TABS'][$tab_o],"new",$tab_a);
+ }else{
+ $entry['object'] = new $tab_c($this->config,$this->config->data['TABS'][$tab_o],$entry['dn'],$tab_a);
+ }
- $entry['source_data'] = $this->load_attributes_from_hdd($entry['file_name']);
+ $entry['source_data'] = $this->load_attributes_from_hdd($entry['file_name']);
- if($entry['method'] == "copy"){
+ if($entry['method'] == "copy"){
- /* Prepare each plugin of this tab object to be posted */
- foreach($entry['object']->by_object as $name => $obj){
+ /* Prepare each plugin of this tab object to be posted */
+ foreach($entry['object']->by_object as $name => $obj){
- /* Prepare every single class, to be copied */
- $entry['object']->by_object[$name]->PrepareForCopyPaste($entry['source_data']);
+ /* Prepare every single class, to be copied */
+ $entry['object']->by_object[$name]->PrepareForCopyPaste($entry['source_data']);
- /* handle some special vars */
- foreach(array("is_account") as $attr){
- if(isset($entry['source_data'][$attr])){
- $entry['object']->by_object[$name]->$attr = $entry['source_data'][$attr];
- }
+ /* handle some special vars */
+ foreach(array("is_account") as $attr){
+ if(isset($entry['source_data'][$attr])){
+ $entry['object']->by_object[$name]->$attr = $entry['source_data'][$attr];
}
}
}
-
- /* Assign created object as current */
- $this->current = $entry;
- unset($this->queue[$key]);
}
+ return($entry);
}
{
$ui = get_userinfo();
$type = $this->current['method'];
- if($type == "cut"){
- if(isset($_POST['PerformCopyPaste'])){
- while($this->entries_queued()){
- $this->load_entry_from_queue();
- $this->_update_vars();
-
- $msgs = $this->check();
- $acl = $ui->get_category_permissions($this->current['dn'], $this->current['tab_acl_category']);
-
- /* Check permissions */
- if(!preg_match("/((c|w)|(w|c))/",$acl)){
- msg_dialog::display(_("Error"), sprintf(_("You have no permission to save object '%s'."), $this->current['dn']), ERROR_DIALOG);
- }elseif(count ($msgs) ){
- foreach( $msgs as $msg){
- msg_dialog::display(_("Error"), $msg, ERROR_DIALOG);
- }
- }else{
-
- /* Load next queue entry */
- $this->lastdn = $this->current['object']->dn;
- $this->current['object']->save();
- }
- $this->current =FALSE;
+ /* Check which entries can be pasted directly.
+ * Create a list of all entries that can be pasted directly.
+ */
+ if($this->require_update){
+ $this->clean_objects = array();
+ $this->objects_to_fix = array();
+ $this->disallowed_objects = array();
+
+ /* Put each queued object in one of the above arrays
+ */
+ foreach($this->queue as $key => $entry){
+
+ /* Update entries on demand
+ */
+ if(!isset($entry['object'])){
+ $entry = $this->load_entry_from_queue($entry);
+ $entry = $this->_update_vars($entry);
+ $this->queue[$key] = $entry;
}
- }
- if($this->current){
+ $msgs = $entry['object']->check();
+ $acl = $ui->get_category_permissions($entry['dn'], $entry['tab_acl_category']);
- $dns = $this->current['dn']."\n";
- foreach($this->queue as $entry){
- $dns .= $entry['dn']."\n";
+ /* Check permissions */
+ if(!preg_match("/((c|w)|(w|c))/",$acl)){
+ $this->disallowed_objects[$key] = $entry;
+ }elseif(!count($msgs)){
+ $this->clean_objects[$key] = $entry;
+ }else{
+ $this->objects_to_fix[$key] = $entry;
}
+ }
+ $this->require_update = FALSE;
+ }
- $smarty = get_smarty();
- $smarty->assign("type","cut");
- $smarty->assign("Complete",false);
- $smarty->assign("AttributesToFix"," ");
- $smarty->assign("SubDialog",$this->current['object']->SubDialog);
- $smarty->assign("objectDN" ,$dns);
- $smarty->assign("message", sprintf(_("You are going to paste the cutted entry '%s'."), "<pre>".$dns."</pre>"));
- return($smarty->fetch(get_template_path("copyPasteDialog.tpl",FALSE)));
+ /* Save objects that can be pasted directly
+ */
+ if(isset($_POST['PerformCopyPaste']) && count($this->clean_objects)){
+ $this->save_object();
+ $this->current = FALSE;
+ foreach($this->clean_objects as $key => $entry){
+
+ /* Remove from queue -> avoid saving twice */
+ unset($this->queue[$key]);
+ unset($this->clean_objects[$key]);
+
+ /* Load next queue entry */
+ $this->current = $entry;
+ $this->lastdn = $this->current['object']->dn;
+ $this->current['object']->save();
+ $this->current = FALSE;
+ }
+ }
+
+ /* Save edited entry and force loading new one
+ */
+ if(isset($_POST['PerformCopyPaste']) && $this->current){
+ $this->current['object']->saveCopyDialog();
+ $msgs = $this->check();
+
+ /* Load next queue entry */
+ if(!count($msgs)){
+ $this->lastdn = $this->current['object']->dn;
+ $this->current['object']->save();
+ $this->current = FALSE;
+ }else{
+ foreach( $msgs as $msg){
+ msg_dialog::display(_("Error"), $msg, ERROR_DIALOG);
+ }
}
}
- if($type == "copy"){
- if(isset($_POST['PerformCopyPaste'])){
- $this->_update_vars();
- $msgs = $this->check();
-
- $acl = $ui->get_category_permissions($this->current['dn'], $this->current['tab_acl_category']);
-
- /* Check permissions */
- if(!preg_match("/((c|w)|(w|c))/",$acl)){
- msg_dialog::display(_("Error"), sprintf(_("You have no permission to copy and paste object '%s'!"),$this->current['dn']), ERROR_DIALOG);
- }elseif(count ($msgs) ){
- foreach( $msgs as $msg){
- msg_dialog::display(_("Error"), $msg, ERROR_DIALOG);
- }
- }else{
- $this->current['object']->save();
- $this->lastdn = $this->current['object']->dn;
- $this->current =FALSE;
+
+ /* Display a list of all pastable entries
+ */
+ if(count($this->clean_objects)){
+ $dns = "";
+ foreach($this->clean_objects as $entry){
+ $dns .= $entry['dn']."\n";
+ }
+ $smarty = get_smarty();
+ $smarty->assign("type","cut");
+ $smarty->assign("Complete",false);
+ $smarty->assign("AttributesToFix"," ");
+ $smarty->assign("SubDialog","");
+ $smarty->assign("objectDN" ,$dns);
+ $smarty->assign("message" , sprintf(_("You are going to paste the cutted entry '%s'."), "<pre>".$dns."</pre>"));
+ return($smarty->fetch(get_template_path("copyPasteDialog.tpl",FALSE)));
+ }
- /* Load next queue entry */
- $this->load_entry_from_queue();
+ /* Display a list of all pastable entries
+ */
+ if($this->current || count($this->objects_to_fix)){
+ $this->save_object();
+ if(!$this->current){
+ $key = key($this->objects_to_fix);
+ if(isset($this->objects_to_fix[$key])){
+ $this->current = $this->objects_to_fix[$key];
+ unset($this->objects_to_fix[$key]);
+ unset($this->queue[$key]);
}
}
if($this->current){
$smarty->assign("Complete",false);
$smarty->assign("AttributesToFix",$this->generateAttributesToFix());
$smarty->assign("SubDialog",$this->current['object']->SubDialog);
- $smarty->assign("objectDN" ,$this->current['source_data']['dn']);
+ $smarty->assign("objectDN",$this->current['source_data']['dn']);
$smarty->assign("message", sprintf(_("You are going to paste the copied entry '%s'."), $this->current['source_data']['dn']));
return($smarty->fetch(get_template_path("copyPasteDialog.tpl",FALSE)));
}
}
+ return("");
}
$this->cleanup_queue();
$this->current = FALSE;
}
-
- /* Assign posted var to all tabs
- */
- if($this->current){
- $this->current['object']->saveCopyDialog();
- }
}
/* Update current object attributes, collected via SetVar */
- function _update_vars()
+ function _update_vars($entry)
{
- if($this->current){
-
- /* Update all attributes specified with SetVar */
- foreach($this->setvar_array as $name => $value){
- if(isset($this->current['object']->$name)){
- $this->current['object']->$name = $value;
- }
+ /* Update all attributes specified with SetVar */
+ foreach($this->setvar_array as $name => $value){
+ if(isset($entry['object']->$name)){
+ $entry['object']->$name = $value;
}
+ }
- /* Walk through tabs */
- foreach($this->current['object']->by_object as $key => $obj){
+ /* Walk through tabs */
+ foreach($entry['object']->by_object as $key => $obj){
- /* Update all attributes specified with SetVar */
- foreach($this->setvar_array as $name => $value){
- if(isset($this->current['object']->by_object[$key]->$name)){
- $this->current['object']->by_object[$key]->$name = $value;
- }
+ /* Update all attributes specified with SetVar */
+ foreach($this->setvar_array as $name => $value){
+ if(isset($entry['object']->by_object[$key]->$name)){
+ $entry['object']->by_object[$key]->$name = $value;
}
}
}
+ return($entry);
}
diff --git a/gosa-core/plugins/admin/acl/class_aclManagement.inc b/gosa-core/plugins/admin/acl/class_aclManagement.inc
index 8ea6390d7fdf521557105e07ba669269c1e7e96c..43b238543c3a5360929cfec5e88d21555d4c9667 100644 (file)
/* Return C&P dialog */
if($this->start_pasting_copied_objects && $this->CopyPasteHandler->entries_queued()){
- /* Load entry from queue and set base */
- $this->CopyPasteHandler->load_entry_from_queue();
- $this->CopyPasteHandler->SetVar("base",$this->DivListACL->selectedBase);
-
/* Get dialog */
+ $this->CopyPasteHandler->SetVar("base",$this->DivListACL->selectedBase);
$data = $this->CopyPasteHandler->execute();
/* Return dialog data */
diff --git a/gosa-core/plugins/admin/groups/class_groupManagement.inc b/gosa-core/plugins/admin/groups/class_groupManagement.inc
index 3f77e0bd1d9a682c506f12bf91c80b4514cb42f3..07f0eb862dc1153e80604925211606e217415e18 100644 (file)
/* Return C&P dialog */
if($this->start_pasting_copied_objects && $this->CopyPasteHandler->entries_queued()){
- /* Load entry from queue and set base */
- $this->CopyPasteHandler->load_entry_from_queue();
- $this->CopyPasteHandler->SetVar("base",$this->DivListGroup->selectedBase);
-
/* Get dialog */
$data = $this->CopyPasteHandler->execute();
+ $this->CopyPasteHandler->SetVar("base",$this->DivListGroup->selectedBase);
/* Return dialog data */
if(!empty($data)){
diff --git a/gosa-core/plugins/admin/ogroups/class_ogroupManagement.inc b/gosa-core/plugins/admin/ogroups/class_ogroupManagement.inc
index 75880ce65281c5b41b64575e7f7b65ee9852724c..76c797a846a0fac870b7bdd7fca98a4f44979500 100644 (file)
/* Return C&P dialog */
if($this->start_pasting_copied_objects && $this->CopyPasteHandler->entries_queued()){
- /* Load entry from queue and set base */
- $this->CopyPasteHandler->load_entry_from_queue();
- $this->CopyPasteHandler->SetVar("base",$this->DivListOGroup->selectedBase);
-
/* Get dialog */
$data = $this->CopyPasteHandler->execute();
+ $this->CopyPasteHandler->SetVar("base",$this->DivListOGroup->selectedBase);
/* Return dialog data */
if(!empty($data)){
diff --git a/gosa-core/plugins/admin/users/class_userManagement.inc b/gosa-core/plugins/admin/users/class_userManagement.inc
index 67ba9238fc1dfdf03ad873bd9341df569d33be5c..05592ae2c6477532df72cf094dbd2a9fe9b86b3b 100644 (file)
/* Return C&P dialog */
if($this->start_pasting_copied_objects && $this->CopyPasteHandler->entries_queued()){
- /* Load entry from queue and set base */
- $this->CopyPasteHandler->load_entry_from_queue();
- $this->CopyPasteHandler->SetVar("base",$this->DivListUsers->selectedBase);
-
/* Get dialog */
$data = $this->CopyPasteHandler->execute();
+ $this->CopyPasteHandler->SetVar("base",$this->DivListUsers->selectedBase);
/* Set CPPasswordChange to s_entry which indicates that this entry requires a new password. */
if(isset($_POST['passwordTodo']) && ($_POST['passwordTodo'] == "new")){