From 4425e6383a429c2c0b3b50344850b41e25e45b26 Mon Sep 17 00:00:00 2001 From: Ralf Becker Date: Wed, 9 Feb 2005 16:29:27 +0000 Subject: [PATCH] fixed bug [ 1051483 ] deleting an infolog entry not delete it's attachments. I also delete empty dirs (after last attachment was deleted). --- infolog/inc/class.bolink.inc.php | 20 ++++++++++++++++++-- 1 file changed, 18 insertions(+), 2 deletions(-) diff --git a/infolog/inc/class.bolink.inc.php b/infolog/inc/class.bolink.inc.php index 388f1ca02f..678744f756 100644 --- a/infolog/inc/class.bolink.inc.php +++ b/infolog/inc/class.bolink.inc.php @@ -322,6 +322,10 @@ function unlink2($link_id,$app,&$id,$owner='',$app2='',$id2='') { + if ($this->debug) + { + echo "

bolink::unlink('$link_id','$app','$id','$owner','$app2','$id2')

\n"; + } if ($link_id < 0) // vfs-link? { return $this->delete_attached(-$link_id); @@ -336,6 +340,10 @@ } if (!is_array($id)) { + if (!$app2 && !$id2) + { + $this->delete_attached($app,$id); // deleting all attachments + } return solink::unlink($link_id,$app,$id,$owner,$app2,$id2); } if (isset($id[$link_id])) @@ -654,14 +662,22 @@ return False; // dont delete more than all attachments of an entry } $vfs_data = $this->vfs_path($app,$id,$fname,RELATIVE_ROOT); + + $Ok = false; if ($this->vfs->file_exists($vfs_data)) { $this->vfs->override_acl = 1; $Ok = $this->vfs->delete($vfs_data); $this->vfs->override_acl = 0; - return $Ok; } - return False; + // if filename given (and now deleted) check if dir is empty and remove it in that case + if ($fname && !count($this->vfs->ls($vfs_data=$this->vfs_path($app,$id,'',RELATIVE_ROOT)))) + { + $this->vfs->override_acl = 1; + $this->vfs->delete($vfs_data); + $this->vfs->override_acl = 0; + } + return $Ok; } /*!