Fixed private messaging/relaying is controlled by the parent
This commit is contained in:
		
					parent
					
						
							
								352e136132
							
						
					
				
			
			
				commit
				
					
						1e0200884f
					
				
			
		
					 3 changed files with 46 additions and 74 deletions
				
			
		|  | @ -68,6 +68,12 @@ class Diaspora | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		if (Config::get("system", "relay_directly", false)) { | 		if (Config::get("system", "relay_directly", false)) { | ||||||
|  | 			// We distribute our stuff based on the parent to ensure that the thread will be complete
 | ||||||
|  | 			$parent = dba::selectFirst('item', ['parent'], ['id' => $item_id]); | ||||||
|  | 			if (!DBM::is_result($parent)) { | ||||||
|  | 				return; | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
| 			// Servers that want to get all content
 | 			// Servers that want to get all content
 | ||||||
| 			$servers = dba::select('gserver', ['url'], ['relay-subscribe' => true, 'relay-scope' => 'all']); | 			$servers = dba::select('gserver', ['url'], ['relay-subscribe' => true, 'relay-scope' => 'all']); | ||||||
| 			while ($server = dba::fetch($servers)) { | 			while ($server = dba::fetch($servers)) { | ||||||
|  | @ -75,7 +81,7 @@ class Diaspora | ||||||
| 			} | 			} | ||||||
| 
 | 
 | ||||||
| 			// All tags of the current post
 | 			// All tags of the current post
 | ||||||
| 			$condition = ['otype' => TERM_OBJ_POST, 'type' => TERM_HASHTAG, 'oid' => $item_id]; | 			$condition = ['otype' => TERM_OBJ_POST, 'type' => TERM_HASHTAG, 'oid' => $parent['parent']]; | ||||||
| 			$tags = dba::select('term', ['term'], $condition); | 			$tags = dba::select('term', ['term'], $condition); | ||||||
| 			$taglist = []; | 			$taglist = []; | ||||||
| 			while ($tag = dba::fetch($tags)) { | 			while ($tag = dba::fetch($tags)) { | ||||||
|  |  | ||||||
|  | @ -28,6 +28,7 @@ class Delivery extends BaseObject | ||||||
| 	const DELETION =   'drop'; | 	const DELETION =   'drop'; | ||||||
| 	const POST =       'wall-new'; | 	const POST =       'wall-new'; | ||||||
| 	const COMMENT =    'comment-new'; | 	const COMMENT =    'comment-new'; | ||||||
|  | 	const REMOVAL =    'removeme'; | ||||||
| 
 | 
 | ||||||
| 	public static function execute($cmd, $item_id, $contact_id) | 	public static function execute($cmd, $item_id, $contact_id) | ||||||
| 	{ | 	{ | ||||||
|  | @ -39,13 +40,13 @@ class Delivery extends BaseObject | ||||||
| 
 | 
 | ||||||
| 		if ($cmd == self::MAIL) { | 		if ($cmd == self::MAIL) { | ||||||
| 			$target_item = dba::selectFirst('mail', [], ['id' => $item_id]); | 			$target_item = dba::selectFirst('mail', [], ['id' => $item_id]); | ||||||
| 			if (!DBM::is_result($message)) { | 			if (!DBM::is_result($target_item)) { | ||||||
| 				return; | 				return; | ||||||
| 			} | 			} | ||||||
| 			$uid = $target_item['uid']; | 			$uid = $target_item['uid']; | ||||||
| 		} elseif ($cmd == self::SUGGESTION) { | 		} elseif ($cmd == self::SUGGESTION) { | ||||||
| 			$target_item = dba::selectFirst('fsuggest', [], ['id' => $item_id]); | 			$target_item = dba::selectFirst('fsuggest', [], ['id' => $item_id]); | ||||||
| 			if (!DBM::is_result($message)) { | 			if (!DBM::is_result($target_item)) { | ||||||
| 				return; | 				return; | ||||||
| 			} | 			} | ||||||
| 			$uid = $target_item['uid']; | 			$uid = $target_item['uid']; | ||||||
|  |  | ||||||
|  | @ -15,17 +15,12 @@ use Friendica\Network\Probe; | ||||||
| use Friendica\Protocol\Diaspora; | use Friendica\Protocol\Diaspora; | ||||||
| use Friendica\Protocol\OStatus; | use Friendica\Protocol\OStatus; | ||||||
| use Friendica\Protocol\Salmon; | use Friendica\Protocol\Salmon; | ||||||
|  | use Friendica\Worker\Delivery; | ||||||
| use dba; | use dba; | ||||||
| 
 | 
 | ||||||
| require_once 'include/dba.php'; | require_once 'include/dba.php'; | ||||||
| require_once 'include/items.php'; | require_once 'include/items.php'; | ||||||
| 
 | 
 | ||||||
| /* |  | ||||||
|  * This file was at one time responsible for doing all deliveries, but this caused |  | ||||||
|  * big problems when the process was killed or stalled during the delivery process. |  | ||||||
|  * It now invokes separate queues that are delivering via delivery.php and pubsubpublish.php. |  | ||||||
|  */ |  | ||||||
| 
 |  | ||||||
| /* | /* | ||||||
|  * The notifier is typically called with: |  * The notifier is typically called with: | ||||||
|  * |  * | ||||||
|  | @ -57,9 +52,6 @@ class Notifier { | ||||||
| 
 | 
 | ||||||
| 		logger('notifier: invoked: '.$cmd.': '.$item_id, LOGGER_DEBUG); | 		logger('notifier: invoked: '.$cmd.': '.$item_id, LOGGER_DEBUG); | ||||||
| 
 | 
 | ||||||
| 		$mail = false; |  | ||||||
| 		$fsuggest = false; |  | ||||||
| 		$relocate = false; |  | ||||||
| 		$top_level = false; | 		$top_level = false; | ||||||
| 		$recipients = []; | 		$recipients = []; | ||||||
| 		$url_recipients = []; | 		$url_recipients = []; | ||||||
|  | @ -67,32 +59,23 @@ class Notifier { | ||||||
| 		$normal_mode = true; | 		$normal_mode = true; | ||||||
| 		$recipients_relocate = []; | 		$recipients_relocate = []; | ||||||
| 
 | 
 | ||||||
| 		if ($cmd === 'mail') { | 		if ($cmd == Delivery::MAIL) { | ||||||
| 			$normal_mode = false; | 			$normal_mode = false; | ||||||
| 			$mail = true; | 			$message = dba::selectFirst('mail', ['uid', 'contact-id'], ['id' => $item_id]); | ||||||
| 			$message = q("SELECT * FROM `mail` WHERE `id` = %d LIMIT 1", | 			if (!DBM::is_result($message)) { | ||||||
| 					intval($item_id) |  | ||||||
| 			); |  | ||||||
| 			if (!count($message)) { |  | ||||||
| 				return; | 				return; | ||||||
| 			} | 			} | ||||||
| 			$uid = $message[0]['uid']; | 			$uid = $message['uid']; | ||||||
| 			$recipients[] = $message[0]['contact-id']; | 			$recipients[] = $message['contact-id']; | ||||||
| 			$item = $message[0]; | 		} elseif ($cmd == Delivery::SUGGESTION) { | ||||||
| 		} elseif ($cmd === 'suggest') { |  | ||||||
| 			$normal_mode = false; | 			$normal_mode = false; | ||||||
| 			$fsuggest = true; | 			$suggest = dba::selectFirst('fsuggest', ['uid', 'cid'], ['id' => $item_id]); | ||||||
| 
 | 			if (!DBM::is_result($suggest)) { | ||||||
| 			$suggest = q("SELECT * FROM `fsuggest` WHERE `id` = %d LIMIT 1", |  | ||||||
| 				intval($item_id) |  | ||||||
| 			); |  | ||||||
| 			if (!count($suggest)) { |  | ||||||
| 				return; | 				return; | ||||||
| 			} | 			} | ||||||
| 			$uid = $suggest[0]['uid']; | 			$uid = $suggest['uid']; | ||||||
| 			$recipients[] = $suggest[0]['cid']; | 			$recipients[] = $suggest['cid']; | ||||||
| 			$item = $suggest[0]; | 		} elseif ($cmd == Delivery::REMOVAL) { | ||||||
| 		} elseif ($cmd === 'removeme') { |  | ||||||
| 			$r = q("SELECT `contact`.*, `user`.`prvkey` AS `uprvkey`,
 | 			$r = q("SELECT `contact`.*, `user`.`prvkey` AS `uprvkey`,
 | ||||||
| 					`user`.`timezone`, `user`.`nickname`, `user`.`sprvkey`, `user`.`spubkey`, | 					`user`.`timezone`, `user`.`nickname`, `user`.`sprvkey`, `user`.`spubkey`, | ||||||
| 					`user`.`page-flags`, `user`.`prvnets`, `user`.`account-type`, `user`.`guid` | 					`user`.`page-flags`, `user`.`prvnets`, `user`.`account-type`, `user`.`guid` | ||||||
|  | @ -112,9 +95,8 @@ class Notifier { | ||||||
| 				Contact::terminateFriendship($user, $contact); | 				Contact::terminateFriendship($user, $contact); | ||||||
| 			} | 			} | ||||||
| 			return; | 			return; | ||||||
| 		} elseif ($cmd === 'relocate') { | 		} elseif ($cmd == Delivery::RELOCATION) { | ||||||
| 			$normal_mode = false; | 			$normal_mode = false; | ||||||
| 			$relocate = true; |  | ||||||
| 			$uid = $item_id; | 			$uid = $item_id; | ||||||
| 
 | 
 | ||||||
| 			$recipients_relocate = q("SELECT * FROM `contact` WHERE `uid` = %d AND NOT `self` AND `network` IN ('%s', '%s')", | 			$recipients_relocate = q("SELECT * FROM `contact` WHERE `uid` = %d AND NOT `self` AND `network` IN ('%s', '%s')", | ||||||
|  | @ -174,17 +156,11 @@ class Notifier { | ||||||
| 		// Deliver directly to a forum, don't PuSH
 | 		// Deliver directly to a forum, don't PuSH
 | ||||||
| 		$direct_forum_delivery = false; | 		$direct_forum_delivery = false; | ||||||
| 
 | 
 | ||||||
| 		// fill this in with a single salmon slap if applicable
 |  | ||||||
| 		$slap = ''; |  | ||||||
| 
 |  | ||||||
| 		$followup = false; | 		$followup = false; | ||||||
| 		$recipients_followup = []; | 		$recipients_followup = []; | ||||||
| 		$conversants = []; | 		$conversants = []; | ||||||
| 		$sql_extra = ''; |  | ||||||
| 		if (! ($mail || $fsuggest || $relocate)) { |  | ||||||
| 
 |  | ||||||
| 			$slap = OStatus::salmon($target_item, $owner); |  | ||||||
| 
 | 
 | ||||||
|  | 		if (!in_array($cmd, [Delivery::MAIL, Delivery::SUGGESTION, Delivery::RELOCATION])) { | ||||||
| 			$parent = $items[0]; | 			$parent = $items[0]; | ||||||
| 
 | 
 | ||||||
| 			$thr_parent = q("SELECT `network`, `author-link`, `owner-link` FROM `item` WHERE `uri` = '%s' AND `uid` = %d", | 			$thr_parent = q("SELECT `network`, `author-link`, `owner-link` FROM `item` WHERE `uri` = '%s' AND `uid` = %d", | ||||||
|  | @ -406,19 +382,16 @@ class Notifier { | ||||||
| 				} | 				} | ||||||
| 
 | 
 | ||||||
| 				// It only makes sense to distribute answers to OStatus messages to Friendica and OStatus - but not Diaspora
 | 				// It only makes sense to distribute answers to OStatus messages to Friendica and OStatus - but not Diaspora
 | ||||||
| 				$sql_extra = " AND `network` IN ('".NETWORK_OSTATUS."', '".NETWORK_DFRN."')"; | 				$networks = [NETWORK_OSTATUS, NETWORK_DFRN]; | ||||||
| 			} else { | 			} else { | ||||||
| 				$sql_extra = " AND `network` IN ('".NETWORK_OSTATUS."', '".NETWORK_DFRN."', '".NETWORK_DIASPORA."', '".NETWORK_MAIL."')"; | 				$networks = [NETWORK_OSTATUS, NETWORK_DFRN, NETWORK_DIASPORA, NETWORK_MAIL]; | ||||||
| 			} | 			} | ||||||
| 		} else { | 		} else { | ||||||
| 			$public_message = false; | 			$public_message = false; | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		// If this is a public message and pubmail is set on the parent, include all your email contacts
 | 		// If this is a public message and pubmail is set on the parent, include all your email contacts
 | ||||||
| 
 | 		if (function_exists('imap_open') && !Config::get('system','imap_disabled')) { | ||||||
| 		$mail_disabled = ((function_exists('imap_open') && (!Config::get('system','imap_disabled'))) ? 0 : 1); |  | ||||||
| 
 |  | ||||||
| 		if (!$mail_disabled) { |  | ||||||
| 			if (!strlen($target_item['allow_cid']) && !strlen($target_item['allow_gid']) | 			if (!strlen($target_item['allow_cid']) && !strlen($target_item['allow_gid']) | ||||||
| 				&& !strlen($target_item['deny_cid']) && !strlen($target_item['deny_gid']) | 				&& !strlen($target_item['deny_cid']) && !strlen($target_item['deny_gid']) | ||||||
| 				&& intval($target_item['pubmail'])) { | 				&& intval($target_item['pubmail'])) { | ||||||
|  | @ -434,27 +407,24 @@ class Notifier { | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		if ($followup) { | 		if (($cmd == Delivery::RELOCATION)) { | ||||||
| 			$recip_str = implode(', ', $recipients_followup); |  | ||||||
| 		} else { |  | ||||||
| 			$recip_str = implode(', ', $recipients); |  | ||||||
| 		} |  | ||||||
| 		if ($relocate) { |  | ||||||
| 			$r = $recipients_relocate; | 			$r = $recipients_relocate; | ||||||
| 		} else { | 		} else { | ||||||
| 			$r = q("SELECT `id`, `url`, `network`, `self` FROM `contact`
 | 			if ($followup) { | ||||||
| 				WHERE `id` IN (%s) AND NOT `blocked` AND NOT `pending` AND NOT `archive`".$sql_extra,
 | 				$recipients = $recipients_followup; | ||||||
| 				dbesc($recip_str) | 			} | ||||||
| 			); | 			$condition = ['id' => $recipients, 'self' => false, | ||||||
|  | 				'blocked' => false, 'pending' => false, 'archive' => false]; | ||||||
|  | 			if (!empty($networks)) { | ||||||
|  | 				$condition['network'] = $networks; | ||||||
|  | 			} | ||||||
|  | 			$contacts = dba::select('contact', ['id', 'url', 'network'], $condition); | ||||||
|  | 			$r = dba::inArray($contacts); | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		// delivery loop
 | 		// delivery loop
 | ||||||
| 
 |  | ||||||
| 		if (DBM::is_result($r)) { | 		if (DBM::is_result($r)) { | ||||||
| 			foreach ($r as $contact) { | 			foreach ($r as $contact) { | ||||||
| 				if ($contact['self']) { |  | ||||||
| 					continue; |  | ||||||
| 				} |  | ||||||
| 				logger("Deliver ".$target_item["guid"]." to ".$contact['url']." via network ".$contact['network'], LOGGER_DEBUG); | 				logger("Deliver ".$target_item["guid"]." to ".$contact['url']." via network ".$contact['network'], LOGGER_DEBUG); | ||||||
| 
 | 
 | ||||||
| 				Worker::add(['priority' => $a->queue['priority'], 'created' => $a->queue['created'], 'dont_fork' => true], | 				Worker::add(['priority' => $a->queue['priority'], 'created' => $a->queue['created'], 'dont_fork' => true], | ||||||
|  | @ -464,9 +434,8 @@ class Notifier { | ||||||
| 
 | 
 | ||||||
| 		// send salmon slaps to mentioned remote tags (@foo@example.com) in OStatus posts
 | 		// send salmon slaps to mentioned remote tags (@foo@example.com) in OStatus posts
 | ||||||
| 		// They are especially used for notifications to OStatus users that don't follow us.
 | 		// They are especially used for notifications to OStatus users that don't follow us.
 | ||||||
| 
 | 		if (!Config::get('system', 'dfrn_only') && count($url_recipients) && ($public_message || $push_notify) && $normal_mode) { | ||||||
| 		if ($slap && count($url_recipients) && ($public_message || $push_notify) && $normal_mode) { | 			$slap = OStatus::salmon($target_item, $owner); | ||||||
| 			if (!Config::get('system', 'dfrn_only')) { |  | ||||||
| 			foreach ($url_recipients as $url) { | 			foreach ($url_recipients as $url) { | ||||||
| 				if ($url) { | 				if ($url) { | ||||||
| 					logger('notifier: urldelivery: ' . $url); | 					logger('notifier: urldelivery: ' . $url); | ||||||
|  | @ -475,8 +444,6 @@ class Notifier { | ||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 
 | 
 | ||||||
| 		if ($public_message) { | 		if ($public_message) { | ||||||
| 			$r1 = []; | 			$r1 = []; | ||||||
|  | @ -510,7 +477,6 @@ class Notifier { | ||||||
| 				logger('pubdeliver '.$target_item["guid"].': '.print_r($r,true), LOGGER_DEBUG); | 				logger('pubdeliver '.$target_item["guid"].': '.print_r($r,true), LOGGER_DEBUG); | ||||||
| 
 | 
 | ||||||
| 				foreach ($r as $rr) { | 				foreach ($r as $rr) { | ||||||
| 
 |  | ||||||
| 					// except for Diaspora batch jobs
 | 					// except for Diaspora batch jobs
 | ||||||
| 					// Don't deliver to folks who have already been delivered to
 | 					// Don't deliver to folks who have already been delivered to
 | ||||||
| 
 | 
 | ||||||
|  | @ -519,7 +485,7 @@ class Notifier { | ||||||
| 						continue; | 						continue; | ||||||
| 					} | 					} | ||||||
| 
 | 
 | ||||||
| 					if (!$mail && !$fsuggest && !$followup) { | 					if (!in_array($cmd, [Delivery::MAIL, Delivery::SUGGESTION]) && !$followup) { | ||||||
| 						logger('notifier: delivery agent: '.$rr['name'].' '.$rr['id'].' '.$rr['network'].' '.$target_item["guid"]); | 						logger('notifier: delivery agent: '.$rr['name'].' '.$rr['id'].' '.$rr['network'].' '.$target_item["guid"]); | ||||||
| 						Worker::add(['priority' => $a->queue['priority'], 'created' => $a->queue['created'], 'dont_fork' => true], | 						Worker::add(['priority' => $a->queue['priority'], 'created' => $a->queue['created'], 'dont_fork' => true], | ||||||
| 								'Delivery', $cmd, $item_id, (int)$rr['id']); | 								'Delivery', $cmd, $item_id, (int)$rr['id']); | ||||||
|  | @ -528,7 +494,6 @@ class Notifier { | ||||||
| 			} | 			} | ||||||
| 
 | 
 | ||||||
| 			$push_notify = true; | 			$push_notify = true; | ||||||
| 
 |  | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		// Notify PuSH subscribers (Used for OStatus distribution of regular posts)
 | 		// Notify PuSH subscribers (Used for OStatus distribution of regular posts)
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue