X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=gosa-core%2Finclude%2Fclass_CopyPasteHandler.inc;h=f0cb85d7db7e1ea8d8124508195231ee0ac515ac;hb=756a035712ab9baa43653e323a6d482343ba7355;hp=5c021bfbcc4a31696193c48dcfbc6edfdfdac239;hpb=894aa86d1d4d57416d43052ea7b781ff680f03c9;p=gosa.git
diff --git a/gosa-core/include/class_CopyPasteHandler.inc b/gosa-core/include/class_CopyPasteHandler.inc
index 5c021bfbc..f0cb85d7d 100644
--- a/gosa-core/include/class_CopyPasteHandler.inc
+++ b/gosa-core/include/class_CopyPasteHandler.inc
@@ -1,6 +1,26 @@
config->data['TABS'][$tab_object])){
- trigger_error(sprintf("Specified tab object '%s' does not exists.",$tab_object));
+ trigger_error(sprintf("Specified tab object %s does not exists.", bold($tab_object)));
return(FALSE);
}
if(!in_array($action,array("cut","copy"))){
- trigger_error(sprintf("Specified action '%s' does not exists for copy & paste.",$action));
+ trigger_error(sprintf("Specified action %s does not exists for copy & paste.", bold($action)));
return(FALSE);
}
@@ -60,7 +86,9 @@ class CopyPasteHandler {
$tmp['tab_class'] = $tab_class;
$tmp['tab_object']= $tab_object;
$tmp['tab_acl_category']= $tab_acl_category;
+ $tmp['parent'] = $parent;
$this->queue[] = $tmp;
+ $this->require_update = TRUE;
}
}
@@ -72,6 +100,7 @@ class CopyPasteHandler {
function cleanup_queue()
{
$this->current = FALSE;
+ $this->require_update = TRUE;
$this->setvar_array = array();
/* Remove all entries from queue */
@@ -83,13 +112,21 @@ class CopyPasteHandler {
/* Create patch if it doesn't exists */
if(!is_dir(LDAP_DUMP_PATH)){
@mkdir(LDAP_DUMP_PATH);
+
+ /* Update folder permissions */
+ if(!@chmod(LDAP_DUMP_PATH,0700)){
+ $msg= sprintf(_("Copy and paste failed!")."
"._("Error").": "._("Cannot set permission for %s"), bold(LDAP_DUMP_PATH));
+ msg_dialog::display(_("Configuration error"), $msg, ERROR_DIALOG);
+ new log("copy","all/all","copy & paste, event queue.",array(), $msg);
+ return(FALSE);
+ }
}
/* check if we are able to create a new file the given directory */
if(!is_writeable(LDAP_DUMP_PATH)){
- print_red(sprintf(_("Could not cleanup copy & paste queue. We are not allowed to save ldap dump to '%s', please check permissions."),LDAP_DUMP_PATH));
- new log("copy","all/all","copy & paste, event queue.",array(),
- sprintf("Could not cleanup copy & paste queue. We are not allowed to save ldap dump to '%s', please check permissions.",LDAP_DUMP_PATH));
+ $msg= _("Copy and paste failed!")."
"._("Error").": ".msgPool::cannotWriteFile(LDAP_DUMP_PATH)."";
+ msg_dialog::display(_("Configuration error"), $msg, ERROR_DIALOG);
+ new log("copy","all/all","copy & paste, event queue.",array(), $msg);
return(FALSE);
}
@@ -119,8 +156,9 @@ class CopyPasteHandler {
/* Check if given dn is valid and ldap search was succesfull */
if(!$res){
- print_red(sprintf(_("Specified object '%s' is not a valid ldap object, please check copy & paste methods.")));
- new log("copy","all/all",$dn,array(),"Could not create dump of ldap object, given object is not present in the ldap database.");
+ $msg= sprintf(_("Copy and paste failed!")."
"._("Error").": "._("'%s' is no vaild LDAP object"), bold(LDAP::fix($dn)));
+ msg_dialog::display(_("Internal error"), $msg, ERROR_DIALOG);
+ new log("copy","all/all",$dn,array(), $msg);
return(FALSE);
}
@@ -135,21 +173,29 @@ class CopyPasteHandler {
/* check if we are able to create a new file the given directory */
if(!is_writeable($path)){
- print_red(sprintf(_("We are not allowed to save ldap dump to '%s', please check permissions."),$path));
- new log("copy","all/all",$dn,array(),
- sprintf("We are not allowed to save ldap dump to '%s', please check permissions.",$path));
+ $msg= sprintf(_("Copy and paste failed!")."
"._("Error").": "._("No write permission in '%s'"), bold(LDAP_DUMP_PATH));
+ msg_dialog::display(_("Configuration error"), $msg, ERROR_DIALOG);
+ new log("copy","all/all",$dn,array(), $msg);
return(FALSE);
}
/* Create file handle */
$fp = @fopen($path."/".$filename,"w+");
if(!$fp){
- print_red(sprintf(_("We are not allowed to save ldap dump to '%s/%s', please check permissions."),$path,$filename));
- new log("copy","all/all",$dn,array(),
- sprintf("We are not allowed to save ldap dump to '%s/%s', please check permissions.",$path,$filename));
+ $msg= _("Copy and paste failed!")."
"._("Error").": ".msgPool::cannotWriteFile("$path/$filename")."";
+ msg_dialog::display(_("Configuration error"), $msg, ERROR_DIALOG);
+ new log("copy","all/all",$dn,array(), $msg);
return(FALSE);
}
+ /* Update folder permissions */
+ if(!@chmod($path."/".$filename,0700)){
+ $msg= sprintf(_("Copy and paste failed!")."
"._("Error").": "._("Cannot set permission for '%s'"), bold(LDAP_DUMP_PATH));
+ msg_dialog::display(_("Configuration error"), $msg, ERROR_DIALOG);
+ new log("copy","all/all","copy & paste, event queue.",array(), $msg);
+ return(FALSE);
+ }
+
$data = serialize($ldap->fetch());
fwrite($fp,$data,strlen($data));
fclose($fp);
@@ -168,51 +214,46 @@ class CopyPasteHandler {
/* 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'];
+ $parent = $entry['parent'];
- $entry['source_data'] = $this->load_attributes_from_hdd($entry['file_name']);
+ 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);
+ }
- if($entry['method'] == "copy"){
+ if($parent ){
+ $entry['object']->parent = $parent;
+ }
+ $entry['source_data'] = $this->load_attributes_from_hdd($entry['file_name']);
- /* Prepare each plugin of this tab object to be posted */
- foreach($entry['object']->by_object as $name => $obj){
+ if($entry['method'] == "copy"){
- /* Prepare every single class, to be copied */
- $entry['object']->by_object[$name]->PrepareForCopyPaste($entry['source_data']);
+ /* Prepare each plugin of this tab object to be posted */
+ foreach($entry['object']->by_object as $name => $obj){
- /* 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];
- }
+ /* 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];
}
}
}
-
- /* Assign created object as current */
- $this->current = $entry;
- unset($this->queue[$key]);
}
+ return($entry);
}
@@ -229,9 +270,9 @@ class CopyPasteHandler {
}
return(unserialize($data));
}else{
- print_red(sprintf(_("Could not load dumped file '%s', from hard disk drive."),$filename));
- new log("copy","all/all",$dn,array(),
- sprintf(sprintf("Could not load dumped file '%s', from hard disk drive.",$filename)));
+ $msg= sprintf(_("Copy and paste failed!")."
"._("Error").": ".msgPool::cannotReadFile($filename)."");
+ msg_dialog::display(_("Internal error"), $msg, ERROR_DIALOG);
+ new log("copy","all/all",$dn,array(), $msg);
return(FALSE);
}
}
@@ -243,83 +284,144 @@ class CopyPasteHandler {
{
$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)){
- print_red(sprintf(_("You are not allowed to cut and paste the following object '%s'."),$this->current['dn']));
- }elseif(count ($msgs) ){
- foreach( $msgs as $msg){
- print_red($msg);
- }
- }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);
+ $this->queue[$key] = $entry;
+ }
+ $entry= $this->_update_vars($entry);
+ $msgs = $entry['object']->check();
+
+ /* To copy an object we require full read access to the object category
+ */
+ $copy_acl = preg_match("/r/",$ui->has_complete_category_acls($entry['dn'], $entry['tab_acl_category']));
+
+ /* In order to copy an object we require read an delete acls
+ */
+ $cut_acl = preg_match("/d/",$ui->has_complete_category_acls($entry['dn'], $entry['tab_acl_category']));
+ $cut_acl &= preg_match("/r/",$ui->has_complete_category_acls($entry['dn'], $entry['tab_acl_category']));
+
+ /* Check permissions */
+ if($entry['method'] == "copy" && !$copy_acl){
+ $this->disallowed_objects[$key] = $entry;
+ }elseif($entry['method'] == "cut" && !$cut_acl){
+ $this->disallowed_objects[$key] = $entry;
+ }elseif(!count($msgs)){
+ $this->clean_objects[$key] = $entry;
+ }else{
+ $this->objects_to_fix[$key] = $entry;
}
}
- if($this->current){
-
- $dns = $this->current['dn']."\n";
- foreach($this->queue as $entry){
- $dns .= $entry['dn']."\n";
+ if(count($this->disallowed_objects)){
+ $dns = array();
+ foreach($this->disallowed_objects as $entry){
+ $dns[] = $entry['dn'];
}
+# msg_dialog::display(_("Permission"),msgPool::permCreate($dns),INFO_DIALOG);
+ }
+ $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'."), "
".$dns."")); - 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= $this->_update_vars($this->current); + $this->current['object']->save(); + $this->handleReferences(); + $this->current = FALSE; + } + } + + /* Save edited entry and force loading new one + */ + if(isset($this->current['object']) && method_exists($this->current['object'],"saveCopyDialog")) { + $this->current['object']->saveCopyDialog(); + } + + if(isset($_POST['PerformCopyPaste']) && $this->current){ + $msgs = $this->check(); + + /* Load next queue entry */ + if(!count($msgs)){ + $this->current['object']->save(); + $this->handleReferences(); + $this->lastdn = $this->current['object']->dn; + $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)){ - print_red(sprintf(_("You are not allowed to copy and paste the following object '%s'."),$this->current['dn'])); - }elseif(count ($msgs) ){ - foreach( $msgs as $msg){ - print_red($msg); - } - }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 = array(); + foreach($this->clean_objects as $object){ + $dns[] = $object['dn']; + } - /* Load next queue entry */ - $this->load_entry_from_queue(); + $smarty = get_smarty(); + $smarty->assign("type","directly"); + $smarty->assign("Complete",false); + $smarty->assign("AttributesToFix"," "); + $smarty->assign("SubDialog",""); + $smarty->assign("message" , sprintf(_("These objects will be pasted: %s"), "