hopefully this won't screw up everything - if it does, revert. Otherwise this should work at delivery time to check tag deliveries and bounce the message before it's stored if the channel doesn't allow you to post and you aren't allowed to tag deliver either. Previously this was handled after the post was already stored so you needed posting permission as well as tag deliver permission to get past the checks.
This commit is contained in:
@@ -1931,45 +1931,51 @@ function tgroup_check($uid,$item) {
|
|||||||
|
|
||||||
// check that the message originated elsewhere and is a top-level post
|
// check that the message originated elsewhere and is a top-level post
|
||||||
|
|
||||||
if(($item['wall']) || ($item['origin']) || ($item['mid'] != $item['parent-mid']))
|
if($arr['mid'] != $arr['parent_mid'])
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
if(! perm_is_allowed($uid,$item['author_xchan'],'tag_deliver'))
|
||||||
|
return false;
|
||||||
|
|
||||||
$u = q("select * from user where uid = %d limit 1",
|
$u = q("select * from channel where channel_id = %d limit 1",
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
if(! count($u))
|
|
||||||
|
if(! $u)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
$community_page = (($u[0]['page-flags'] == PAGE_COMMUNITY) ? true : false);
|
$terms = get_terms_oftype($item['term'],TERM_MENTION);
|
||||||
$prvgroup = (($u[0]['page-flags'] == PAGE_PRVGROUP) ? true : false);
|
|
||||||
|
|
||||||
|
logger('tgroup_check: post mentions: ' . print_r($terms,true), LOGGER_DATA);
|
||||||
|
|
||||||
$link = normalise_link($a->get_baseurl() . '/channel/' . $u[0]['nickname']);
|
$link = normalise_link($a->get_baseurl() . '/channel/' . $u[0]['channel_address']);
|
||||||
|
|
||||||
// Diaspora uses their own hardwired link URL in @-tags
|
if($terms) {
|
||||||
// instead of the one we supply with webfinger
|
foreach($terms as $term) {
|
||||||
|
if(($term['term'] == $u[0]['channel_name']) && link_compare($term['url'],$link)) {
|
||||||
$dlink = normalise_link($a->get_baseurl() . '/u/' . $u[0]['nickname']);
|
|
||||||
|
|
||||||
$body = preg_replace("/\[share\](.*?)\[\/share\]/ism", '', $item['body']);
|
|
||||||
|
|
||||||
$cnt = preg_match_all('/[\@\!]\[zrl\=(.*?)\](.*?)\[\/zrl\]/ism',$body,$matches,PREG_SET_ORDER);
|
|
||||||
if($cnt) {
|
|
||||||
foreach($matches as $mtch) {
|
|
||||||
if(link_compare($link,$mtch[1]) || link_compare($dlink,$mtch[1])) {
|
|
||||||
$mention = true;
|
$mention = true;
|
||||||
logger('tgroup_check: mention found: ' . $mtch[2]);
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(! $mention)
|
if($mention) {
|
||||||
|
logger('tgroup_check: mention found for ' . $u[0]['channel_name']);
|
||||||
|
}
|
||||||
|
else
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if((! $community_page) && (! $prvgroup))
|
// At this point we've determined that the person receiving this post was mentioned in it.
|
||||||
return false;
|
// Now let's check if this mention was inside a reshare so we don't spam a forum
|
||||||
|
|
||||||
|
$body = preg_replace('/\[share(.*?)\[\/share\]/','',$item['body']);
|
||||||
|
|
||||||
|
$pattern = '/@\[zrl\=' . preg_quote($term['url'],'/') . '\]' . preg_quote($u[0]['channel_name'],'/') . '\[\/zrl\]/';
|
||||||
|
|
||||||
|
if(! preg_match($pattern,$body,$matches)) {
|
||||||
|
logger('tgroup_check: mention was in a reshare - ignoring');
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
@@ -1017,9 +1017,11 @@ function process_delivery($sender,$arr,$deliveries,$relay) {
|
|||||||
|
|
||||||
$channel = $r[0];
|
$channel = $r[0];
|
||||||
|
|
||||||
|
$tag_delivery = tgroup_check($channel['channel_id'],$arr);
|
||||||
|
|
||||||
$perm = (($arr['mid'] == $arr['parent_mid']) ? 'send_stream' : 'post_comments');
|
$perm = (($arr['mid'] == $arr['parent_mid']) ? 'send_stream' : 'post_comments');
|
||||||
|
|
||||||
if(! perm_is_allowed($channel['channel_id'],$sender['hash'],$perm)) {
|
if((! perm_is_allowed($channel['channel_id'],$sender['hash'],$perm)) && (! $tag_delivery)) {
|
||||||
logger("permission denied for delivery {$channel['channel_id']}");
|
logger("permission denied for delivery {$channel['channel_id']}");
|
||||||
$result[] = array($d['hash'],'permission denied');
|
$result[] = array($d['hash'],'permission denied');
|
||||||
continue;
|
continue;
|
||||||
|
Reference in New Issue
Block a user