more work on firehose
This commit is contained in:
		| @@ -29,6 +29,10 @@ function expire_run($argv, $argc){ | |||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	$x = get_sys_channel(); | ||||||
|  | 	if($x) | ||||||
|  | 		item_expire($x['channel_id'],30); | ||||||
|  |  | ||||||
| 	return; | 	return; | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -3767,7 +3767,7 @@ function zot_feed($uid,$observer_xchan,$mindate) { | |||||||
| 		$r = q("SELECT item.*, item.id as item_id from item | 		$r = q("SELECT item.*, item.id as item_id from item | ||||||
| 			WHERE uid in (" . stream_perms_api_uids(PERMS_PUBLIC) . ") AND item_restrict = 0 and id = parent | 			WHERE uid in (" . stream_perms_api_uids(PERMS_PUBLIC) . ") AND item_restrict = 0 and id = parent | ||||||
| 			AND (item_flags &  %d)  | 			AND (item_flags &  %d)  | ||||||
| 			$sql_extra ORDER BY created ASC $limit", | 			and item_private = 0 ORDER BY created ASC $limit", | ||||||
| 			intval($uid), | 			intval($uid), | ||||||
| 			intval(ITEM_WALL) | 			intval(ITEM_WALL) | ||||||
| 		); | 		); | ||||||
|   | |||||||
| @@ -167,6 +167,30 @@ function poller_run($argv, $argc){ | |||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	// pull in some public posts | ||||||
|  |  | ||||||
|  | 	$r = q("select site_url from site where site_url != '%s'  order by rand() limit 1", | ||||||
|  | 		dbesc(z_root()) | ||||||
|  | 	); | ||||||
|  |  | ||||||
|  | 	if($r) { | ||||||
|  | 		$feedurl = $r[0]['site_url'] . '/zotfeed?f=&mindate=' . urlencode(datetime_convert('','','now - 1 month')); | ||||||
|  | 		$x = z_fetch_url($feedurl); | ||||||
|  | 		if(($x) && ($x['success'])) { | ||||||
|  | 			$total = 0; | ||||||
|  | 			$j = json_decode($x['body'],true); | ||||||
|  | 			if($j['success'] && $j['messages']) { | ||||||
|  | 				require_once('include/identity.php'); | ||||||
|  | 				$sys = get_sys_channel(); | ||||||
|  | 				foreach($j['messages'] as $message) { | ||||||
|  | 					$results = process_delivery(array('hash' => 'undefined'), get_item_elements($message), | ||||||
|  | 						array(array('hash' => $sys['xchan_hash'])), false, true); | ||||||
|  | 					$total ++; | ||||||
|  | 				} | ||||||
|  | 				logger('import_public_posts: ' . $total . ' messages imported', LOGGER_DEBUG); | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	$manual_id  = 0; | 	$manual_id  = 0; | ||||||
| 	$generation = 0; | 	$generation = 0; | ||||||
|   | |||||||
| @@ -346,9 +346,10 @@ function stream_perms_api_uids($perms_min = PERMS_SITE) { | |||||||
| 	$ret = array(); | 	$ret = array(); | ||||||
| 	if(local_user()) | 	if(local_user()) | ||||||
| 		$ret[] = local_user(); | 		$ret[] = local_user(); | ||||||
| 	$r = q("select channel_id from channel where channel_r_stream > 0 and channel_r_stream <= %d and not (channel_pageflags & %d)", | 	$r = q("select channel_id from channel where channel_r_stream > 0 and channel_r_stream <= %d and not (channel_pageflags & %d) and not (channel_pageflags & %d)", | ||||||
| 		intval($perms_min), | 		intval($perms_min), | ||||||
| 		intval(PAGE_CENSORED) | 		intval(PAGE_CENSORED), | ||||||
|  | 		intval(PAGE_SYSTEM) | ||||||
| 	); | 	); | ||||||
| 	if($r) | 	if($r) | ||||||
| 		foreach($r as $rr) | 		foreach($r as $rr) | ||||||
| @@ -371,9 +372,10 @@ function stream_perms_xchans($perms_min = PERMS_SITE) { | |||||||
| 	if(local_user()) | 	if(local_user()) | ||||||
| 		$ret[] = get_observer_hash(); | 		$ret[] = get_observer_hash(); | ||||||
|  |  | ||||||
| 	$r = q("select channel_hash from channel where channel_r_stream > 0 and channel_r_stream <= %d and not (channel_pageflags & %d)", | 	$r = q("select channel_hash from channel where channel_r_stream > 0 and channel_r_stream <= %d and not (channel_pageflags & %d) and not (channel_pageflags & %d)", | ||||||
| 		intval($perms_min), | 		intval($perms_min), | ||||||
| 		intval(PAGE_CENSORED) | 		intval(PAGE_CENSORED), | ||||||
|  | 		intval(PAGE_SYSTEM) | ||||||
| 	); | 	); | ||||||
| 	if($r) | 	if($r) | ||||||
| 		foreach($r as $rr) | 		foreach($r as $rr) | ||||||
|   | |||||||
| @@ -1354,17 +1354,19 @@ function allowed_public_recips($msg) { | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| function process_delivery($sender,$arr,$deliveries,$relay) { | function process_delivery($sender,$arr,$deliveries,$relay,$public = false) { | ||||||
|  |  | ||||||
| 	$result = array(); | 	$result = array(); | ||||||
|  |  | ||||||
|  |  | ||||||
| 	// We've validated the sender. Now make sure that the sender is the owner or author | 	// We've validated the sender. Now make sure that the sender is the owner or author | ||||||
|  |  | ||||||
|  | 	if(! $public) { | ||||||
| 		if($sender['hash'] != $arr['owner_xchan'] && $sender['hash'] != $arr['author_xchan']) { | 		if($sender['hash'] != $arr['owner_xchan'] && $sender['hash'] != $arr['author_xchan']) { | ||||||
| 			logger("process_delivery: sender {$sender['hash']} is not owner {$arr['owner_xchan']} or author {$arr['author_xchan']} - mid {$arr['mid']}"); | 			logger("process_delivery: sender {$sender['hash']} is not owner {$arr['owner_xchan']} or author {$arr['author_xchan']} - mid {$arr['mid']}"); | ||||||
| 			return; | 			return; | ||||||
| 		} | 		} | ||||||
|  | 	} | ||||||
| 	 | 	 | ||||||
| 	foreach($deliveries as $d) { | 	foreach($deliveries as $d) { | ||||||
| 		$r = q("select * from channel where channel_hash = '%s' limit 1", | 		$r = q("select * from channel where channel_hash = '%s' limit 1", | ||||||
| @@ -1394,7 +1396,7 @@ function process_delivery($sender,$arr,$deliveries,$relay) { | |||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		if((! perm_is_allowed($channel['channel_id'],$sender['hash'],$perm)) && (! $tag_delivery)) { | 		if((! perm_is_allowed($channel['channel_id'],$sender['hash'],$perm)) && (! $tag_delivery) && (! $public)) { | ||||||
| 			logger("permission denied for delivery {$channel['channel_id']}"); | 			logger("permission denied for delivery {$channel['channel_id']}"); | ||||||
| 			$result[] = array($d['hash'],'permission denied',$channel['channel_name'] . ' <' . $channel['channel_address'] . '@' . get_app()->get_hostname() . '>'); | 			$result[] = array($d['hash'],'permission denied',$channel['channel_name'] . ' <' . $channel['channel_address'] . '@' . get_app()->get_hostname() . '>'); | ||||||
| 			continue; | 			continue; | ||||||
|   | |||||||
| @@ -324,6 +324,8 @@ function dir_parse_query($s) { | |||||||
|  |  | ||||||
|  |  | ||||||
| function list_public_sites() { | function list_public_sites() { | ||||||
|  |  | ||||||
|  |  | ||||||
| 	$r = q("select * from site where site_access != 0 and site_register !=0 order by rand()"); | 	$r = q("select * from site where site_access != 0 and site_register !=0 order by rand()"); | ||||||
| 	$ret = array('success' => false); | 	$ret = array('success' => false); | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user