remove file/attachments when their associated photos are removed

This commit is contained in:
redmatrix
2015-06-16 17:50:15 -07:00
parent bc72d3fd26
commit d84b3cfc3c
2 changed files with 10 additions and 2 deletions

View File

@@ -818,15 +818,16 @@ function attach_change_permissions($channel_id, $resource, $allow_cid, $allow_gi
* The hash to delete * The hash to delete
* @return void * @return void
*/ */
function attach_delete($channel_id, $resource) { function attach_delete($channel_id, $resource, $is_photo = 0) {
$c = q("SELECT channel_address FROM channel WHERE channel_id = %d LIMIT 1", $c = q("SELECT channel_address FROM channel WHERE channel_id = %d LIMIT 1",
intval($channel_id) intval($channel_id)
); );
$channel_address = (($c) ? $c[0]['channel_address'] : 'notfound'); $channel_address = (($c) ? $c[0]['channel_address'] : 'notfound');
$photo_sql = (($is_photo) ? " and is_photo = 1 " : '');
$r = q("SELECT hash, flags, folder FROM attach WHERE hash = '%s' AND uid = %d limit 1", $r = q("SELECT hash, flags, folder FROM attach WHERE hash = '%s' AND uid = %d $photo_sql limit 1",
dbesc($resource), dbesc($resource),
intval($channel_id) intval($channel_id)
); );

View File

@@ -6,6 +6,7 @@ require_once('include/acl_selectors.php');
require_once('include/bbcode.php'); require_once('include/bbcode.php');
require_once('include/security.php'); require_once('include/security.php');
require_once('include/Contact.php'); require_once('include/Contact.php');
require_once('include/attach.php');
function photos_init(&$a) { function photos_init(&$a) {
@@ -140,6 +141,7 @@ function photos_post(&$a) {
); );
if($r) { if($r) {
foreach($r as $i) { foreach($r as $i) {
attach_delete($page_owner_uid, $i['resource_id'], 1 );
drop_item($i['id'],false,DROPITEM_PHASE1,true /* force removal of linked items */); drop_item($i['id'],false,DROPITEM_PHASE1,true /* force removal of linked items */);
proc_run('php','include/notifier.php','drop',$i['id']); proc_run('php','include/notifier.php','drop',$i['id']);
} }
@@ -150,6 +152,9 @@ function photos_post(&$a) {
q("delete from photo where resource_id in ( $str ) and uid = %d", q("delete from photo where resource_id in ( $str ) and uid = %d",
intval($page_owner_uid) intval($page_owner_uid)
); );
// @FIXME do the same for the linked attach
} }
goaway($a->get_baseurl() . '/photos/' . $a->data['channel']['channel_address']); goaway($a->get_baseurl() . '/photos/' . $a->data['channel']['channel_address']);
@@ -174,6 +179,8 @@ function photos_post(&$a) {
intval($page_owner_uid), intval($page_owner_uid),
dbesc($r[0]['resource_id']) dbesc($r[0]['resource_id'])
); );
attach_delete($page_owner_uid, $r[0]['resource_id'], 1 );
$i = q("SELECT * FROM `item` WHERE `resource_id` = '%s' AND resource_type = 'photo' and `uid` = %d LIMIT 1", $i = q("SELECT * FROM `item` WHERE `resource_id` = '%s' AND resource_type = 'photo' and `uid` = %d LIMIT 1",
dbesc($r[0]['resource_id']), dbesc($r[0]['resource_id']),
intval($page_owner_uid) intval($page_owner_uid)