Merge pull request #6972 from annando/queue-to-worker
Use deferred workers instead of the queue mechanism
This commit is contained in:
		
				commit
				
					
						26c2290fed
					
				
			
		
					 2 changed files with 9 additions and 14 deletions
				
			
		|  | @ -3223,9 +3223,9 @@ class Diaspora | ||||||
| 
 | 
 | ||||||
| 		if (!$return_code || (($return_code == 503) && (stristr($postResult->getHeader(), "retry-after")))) { | 		if (!$return_code || (($return_code == 503) && (stristr($postResult->getHeader(), "retry-after")))) { | ||||||
| 			if (!$no_queue && !empty($contact['contact-type']) && ($contact['contact-type'] != Contact::TYPE_RELAY)) { | 			if (!$no_queue && !empty($contact['contact-type']) && ($contact['contact-type'] != Contact::TYPE_RELAY)) { | ||||||
| 				Logger::log("queue message"); | 				Logger::info('defer message', ['log' => $logid, 'guid' => $guid, 'destination' => $dest_url]); | ||||||
| 				// queue message for redelivery
 | 				// defer message for redelivery
 | ||||||
| 				Queue::add($contact["id"], Protocol::DIASPORA, $envelope, $public_batch, $guid); | 				Worker::defer(); | ||||||
| 			} | 			} | ||||||
| 
 | 
 | ||||||
| 			// The message could not be delivered. We mark the contact as "dead"
 | 			// The message could not be delivered. We mark the contact as "dead"
 | ||||||
|  | @ -3263,13 +3263,12 @@ class Diaspora | ||||||
| 	 * @param array  $message      The message data | 	 * @param array  $message      The message data | ||||||
| 	 * @param bool   $public_batch Is it a public post? | 	 * @param bool   $public_batch Is it a public post? | ||||||
| 	 * @param string $guid         message guid | 	 * @param string $guid         message guid | ||||||
| 	 * @param bool   $spool        Should the transmission be spooled or transmitted? |  | ||||||
| 	 * | 	 * | ||||||
| 	 * @return int Result of the transmission | 	 * @return int Result of the transmission | ||||||
| 	 * @throws \Friendica\Network\HTTPException\InternalServerErrorException | 	 * @throws \Friendica\Network\HTTPException\InternalServerErrorException | ||||||
| 	 * @throws \ImagickException | 	 * @throws \ImagickException | ||||||
| 	 */ | 	 */ | ||||||
| 	private static function buildAndTransmit(array $owner, array $contact, $type, $message, $public_batch = false, $guid = "", $spool = false) | 	private static function buildAndTransmit(array $owner, array $contact, $type, $message, $public_batch = false, $guid = "") | ||||||
| 	{ | 	{ | ||||||
| 		$msg = self::buildPostXml($type, $message); | 		$msg = self::buildPostXml($type, $message); | ||||||
| 
 | 
 | ||||||
|  | @ -3283,12 +3282,7 @@ class Diaspora | ||||||
| 
 | 
 | ||||||
| 		$envelope = self::buildMessage($msg, $owner, $contact, $owner['uprvkey'], $contact['pubkey'], $public_batch); | 		$envelope = self::buildMessage($msg, $owner, $contact, $owner['uprvkey'], $contact['pubkey'], $public_batch); | ||||||
| 
 | 
 | ||||||
| 		if ($spool) { |  | ||||||
| 			Queue::add($contact['id'], Protocol::DIASPORA, $envelope, $public_batch, $guid); |  | ||||||
| 			return true; |  | ||||||
| 		} else { |  | ||||||
| 		$return_code = self::transmit($owner, $contact, $envelope, $public_batch, false, $guid); | 		$return_code = self::transmit($owner, $contact, $envelope, $public_batch, false, $guid); | ||||||
| 		} |  | ||||||
| 
 | 
 | ||||||
| 		Logger::log("guid: ".$guid." result ".$return_code, Logger::DEBUG); | 		Logger::log("guid: ".$guid." result ".$return_code, Logger::DEBUG); | ||||||
| 
 | 
 | ||||||
|  | @ -4284,7 +4278,7 @@ class Diaspora | ||||||
| 
 | 
 | ||||||
| 		foreach ($recips as $recip) { | 		foreach ($recips as $recip) { | ||||||
| 			Logger::log("Send updated profile data for user ".$uid." to contact ".$recip["id"], Logger::DEBUG); | 			Logger::log("Send updated profile data for user ".$uid." to contact ".$recip["id"], Logger::DEBUG); | ||||||
| 			self::buildAndTransmit($owner, $recip, "profile", $message, false, "", false); | 			self::buildAndTransmit($owner, $recip, "profile", $message, false); | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -17,6 +17,7 @@ use Friendica\Protocol\Diaspora; | ||||||
| use Friendica\Protocol\Email; | use Friendica\Protocol\Email; | ||||||
| use Friendica\Util\Strings; | use Friendica\Util\Strings; | ||||||
| use Friendica\Util\Network; | use Friendica\Util\Network; | ||||||
|  | use Friendica\Core\Worker; | ||||||
| 
 | 
 | ||||||
| class Delivery extends BaseObject | class Delivery extends BaseObject | ||||||
| { | { | ||||||
|  | @ -321,8 +322,8 @@ class Delivery extends BaseObject | ||||||
| 		Logger::log('Delivery to ' . $contact['url'] . ' with guid ' . defaults($target_item, 'guid', $target_item['id']) . ' returns ' . $deliver_status); | 		Logger::log('Delivery to ' . $contact['url'] . ' with guid ' . defaults($target_item, 'guid', $target_item['id']) . ' returns ' . $deliver_status); | ||||||
| 
 | 
 | ||||||
| 		if ($deliver_status < 0) { | 		if ($deliver_status < 0) { | ||||||
| 			Logger::log('Delivery failed: queuing message ' . defaults($target_item, 'guid', $target_item['id'])); | 			Logger::info('Delivery failed: defer message', ['id' => defaults($target_item, 'guid', $target_item['id'])]); | ||||||
| 			Model\Queue::add($contact['id'], Protocol::DFRN, $atom, false, $target_item['guid']); | 			Worker::defer(); | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		if (($deliver_status >= 200) && ($deliver_status <= 299)) { | 		if (($deliver_status >= 200) && ($deliver_status <= 299)) { | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue