child conversations inherit ACL's from parent

This commit is contained in:
Mike Macgirvin 2010-07-13 16:09:53 -07:00
parent e4325bc565
commit c4f31ec65a
2 changed files with 30 additions and 1 deletions

View file

@ -36,7 +36,7 @@ if($argc < 3)
$recipients = array(); $recipients = array();
// fetch requested item // fetch requested item(s)
$r = q("SELECT `item`.*, `contact`.*,`item`.`id` AS `item_id` FROM `item` LEFT JOIN `contact` ON `item`.`contact-id` = `contact`.`id` $r = q("SELECT `item`.*, `contact`.*,`item`.`id` AS `item_id` FROM `item` LEFT JOIN `contact` ON `item`.`contact-id` = `contact`.`id`
WHERE `item`.`id` = %d LIMIT 1", WHERE `item`.`id` = %d LIMIT 1",

View file

@ -13,6 +13,20 @@ function item_post(&$a) {
$uid = $_SESSION['uid']; $uid = $_SESSION['uid'];
$parent = ((x($_POST,'parent')) ? intval($_POST['parent']) : 0); $parent = ((x($_POST,'parent')) ? intval($_POST['parent']) : 0);
$parent_item = null;
if($parent) {
$r = q("SELECT * FROM `item` WHERE `id` = %d LIMIT 1",
intval($parent)
);
if(! count($r)) {
notice("Unable to locate original post." . EOL);
goaway($a->get_baseurl() . "/profile/$profile_uid");
}
$parent_item = $r[0];
}
$profile_uid = ((x($_POST,'profile_uid')) ? intval($_POST['profile_uid']) : 0); $profile_uid = ((x($_POST,'profile_uid')) ? intval($_POST['profile_uid']) : 0);
if(! can_write_wall($a,$profile_uid)) { if(! can_write_wall($a,$profile_uid)) {
@ -99,10 +113,25 @@ function item_post(&$a) {
dbesc($hash)); dbesc($hash));
if(count($r)) { if(count($r)) {
$post_id = $r[0]['id']; $post_id = $r[0]['id'];
if($parent) { if($parent) {
// This item is the last leaf and gets the comment box, clear any ancestors
$r = q("UPDATE `item` SET `last-child` = 0 WHERE `parent` = %d ", $r = q("UPDATE `item` SET `last-child` = 0 WHERE `parent` = %d ",
intval($parent) intval($parent)
); );
// Inherit ACL's from the parent item.
// TODO merge with subsequent UPDATE operation and save a db write
$r = q("UPDATE `item` SET `allow_cid` = '%s', `allow_gid` = '%s', `deny_cid` = '%s', `deny_gid` = '%s'
WHERE `id` = %d LIMIT 1",
intval($parent_item['allow_cid']),
intval($parent_item['allow_gid']),
intval($parent_item['deny_cid']),
intval($parent_item['deny_gid']),
intval($post_id)
);
} }
else { else {
$parent = $post_id; $parent = $post_id;