X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=gosa-core%2Finclude%2Fclass_CopyPasteHandler.inc;h=4ceb83a1f76507f088b7a39adcbf07711acce1d8;hb=888516587f0cda06601ab943d2851bfaf5b23578;hp=b6de303d1f4659fdc7efad4a0c2507f141c23bbe;hpb=934fd8faebc9747ccd31d04d1a756ef6bdfee94e;p=gosa.git diff --git a/gosa-core/include/class_CopyPasteHandler.inc b/gosa-core/include/class_CopyPasteHandler.inc index b6de303d1..4ceb83a1f 100644 --- a/gosa-core/include/class_CopyPasteHandler.inc +++ b/gosa-core/include/class_CopyPasteHandler.inc @@ -20,7 +20,7 @@ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ -define("LDAP_DUMP_PATH","/tmp/gosa"); +define("LDAP_DUMP_PATH","/var/cache/gosa/tmp"); class CopyPasteHandler { @@ -63,7 +63,7 @@ class CopyPasteHandler { */ function add_to_queue($dn,$action,$tab_class,$tab_object,$tab_acl_category) { - if(!class_exists($tab_class)){ + if(!class_available($tab_class)){ trigger_error(sprintf("Specified class object '%s' does not exists.",$tab_class)); return(FALSE); } @@ -115,7 +115,7 @@ class CopyPasteHandler { /* Update folder permissions */ if(!@chmod(LDAP_DUMP_PATH,0700)){ - $msg= sprintf(_("Copy and paste failed!")."

"._("Error").": "._("cannot set permission for '%s'"),LDAP_DUMP_PATH); + $msg= sprintf(_("Copy and paste failed!")."

"._("Error").": "._("Cannot set permission for '%s'")."" ,LDAP_DUMP_PATH); msg_dialog::display(_("Configuration error"), $msg, ERROR_DIALOG); new log("copy","all/all","copy & paste, event queue.",array(), $msg); return(FALSE); @@ -123,7 +123,7 @@ class CopyPasteHandler { /* check if we are able to create a new file the given directory */ if(!is_writeable(LDAP_DUMP_PATH)){ - $msg= sprintf(_("Copy and paste failed!")."

"._("Error").": "._("no write permission in '%s'"),LDAP_DUMP_PATH); + $msg= _("Copy and paste failed!")."

"._("Error").": ".msgPool::cannotWrite(LDAP_DUMP_PATH).""; msg_dialog::display(_("Configuration error"), $msg, ERROR_DIALOG); new log("copy","all/all","copy & paste, event queue.",array(), $msg); return(FALSE); @@ -172,7 +172,7 @@ class CopyPasteHandler { /* check if we are able to create a new file the given directory */ if(!is_writeable($path)){ - $msg= sprintf(_("Copy and paste failed!")."

"._("Error").": "._("no write permission in '%s'"),LDAP_DUMP_PATH); + $msg= sprintf(_("Copy and paste failed!")."

"._("Error").": "._("No write permission in '%s'"),LDAP_DUMP_PATH); msg_dialog::display(_("Configuration error"), $msg, ERROR_DIALOG); new log("copy","all/all",$dn,array(), $msg); return(FALSE); @@ -180,7 +180,7 @@ class CopyPasteHandler { /* Update folder permissions */ if(!@chmod(LDAP_DUMP_PATH,0700)){ - $msg= sprintf(_("Copy and paste failed!")."

"._("Error").": "._("cannot set permission for '%s'"),LDAP_DUMP_PATH); + $msg= sprintf(_("Copy and paste failed!")."

"._("Error").": "._("Cannot set permission for '%s'"),LDAP_DUMP_PATH); msg_dialog::display(_("Configuration error"), $msg, ERROR_DIALOG); new log("copy","all/all","copy & paste, event queue.",array(), $msg); return(FALSE); @@ -189,7 +189,7 @@ class CopyPasteHandler { /* Create file handle */ $fp = @fopen($path."/".$filename,"w+"); if(!$fp){ - $msg= sprintf(_("Copy and paste failed!")."

"._("Error").": "._("cannot open file '%s' for writing"), "$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); @@ -265,7 +265,7 @@ class CopyPasteHandler { } return(unserialize($data)); }else{ - $msg= sprintf(_("Copy and paste failed!")."

"._("Error").": "._("cannot open '%s' for reading"),$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); @@ -291,18 +291,29 @@ class CopyPasteHandler { /* 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(); - $acl = $ui->get_category_permissions($entry['dn'], $entry['tab_acl_category']); + + /* 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(!preg_match("/((c|w)|(w|c))/",$acl)){ + 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; @@ -310,6 +321,13 @@ class CopyPasteHandler { $this->objects_to_fix[$key] = $entry; } } + 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; } @@ -342,7 +360,6 @@ class CopyPasteHandler { /* Load next queue entry */ if(!count($msgs)){ $this->lastdn = $this->current['object']->dn; - $this->current= $this->_update_vars($this->current); $this->current['object']->save(); $this->current = FALSE; }else{ @@ -355,13 +372,18 @@ class CopyPasteHandler { /* Display a list of all pastable entries */ if(count($this->clean_objects)){ + + $dns = array(); + foreach($this->clean_objects as $object){ + $dns[] = $object['dn']; + } + $smarty = get_smarty(); $smarty->assign("type","directly"); $smarty->assign("Complete",false); $smarty->assign("AttributesToFix"," "); $smarty->assign("SubDialog",""); - $smarty->assign("objectDN" ,$dns); - $smarty->assign("message" , sprintf(_("These objects will be pasted: %s"), "
".msgPool::buildList($this->clean_objects))); + $smarty->assign("message" , sprintf(_("These objects will be pasted: %s"), "
".msgPool::buildList($dns))); return($smarty->fetch(get_template_path("copyPasteDialog.tpl",FALSE))); } @@ -373,6 +395,7 @@ class CopyPasteHandler { $key = key($this->objects_to_fix); if(isset($this->objects_to_fix[$key])){ $this->current = $this->objects_to_fix[$key]; + $this->current= $this->_update_vars($this->current); unset($this->objects_to_fix[$key]); unset($this->queue[$key]); } @@ -447,6 +470,10 @@ class CopyPasteHandler { /* Update all attributes specified with SetVar */ foreach($this->setvar_array as $name => $value){ + + /* Do not update parent for plugins, this may break things */ + if($name == "parent") continue; + if(isset($entry['object']->by_object[$key]->$name)){ $entry['object']->by_object[$key]->$name = $value; } @@ -472,13 +499,13 @@ class CopyPasteHandler { /* returns the paste icon for headpages */ function generatePasteIcon() { - $Copy_Paste= "  "; + $Copy_Paste= "  "; if($this->entries_queued()){ - $img= "images/copypaste.png"; + $img= "images/lists/paste.png"; $Copy_Paste.= " "; }else{ - $Copy_Paste.= "\""._("Cannot "; + $Copy_Paste.= "\""._("Cannot "; } return ($Copy_Paste); }