Delete removed contacts
This commit is contained in:
		
					parent
					
						
							
								cb5362f499
							
						
					
				
			
			
				commit
				
					
						a331a8cf0a
					
				
			
		
					 7 changed files with 59 additions and 15 deletions
				
			
		|  | @ -147,14 +147,25 @@ class APContact | |||
| 			$url = $apcontact['url']; | ||||
| 		} | ||||
| 
 | ||||
| 		$data = ActivityPub::fetchContent($url); | ||||
| 		if (empty($data)) { | ||||
| 		$curlResult = HTTPSignature::fetchRaw($url); | ||||
| 		$failed = empty($curlResult) || empty($curlResult->getBody()) || | ||||
| 			(!$curlResult->isSuccess() && ($curlResult->getReturnCode() != 410)); | ||||
| 
 | ||||
| 		if (!$failed) { | ||||
| 			$data = json_decode($curlResult->getBody(), true); | ||||
| 			$failed = empty($data) || !is_array($data); | ||||
| 		} | ||||
| 
 | ||||
| 		if (!$failed && ($curlResult->getReturnCode() == 410)) { | ||||
| 			$data = ['@context' => ActivityPub::CONTEXT, 'id' => $url, 'type' => 'Tombstone']; | ||||
| 		} | ||||
| 
 | ||||
| 		if ($failed) { | ||||
| 			self::markForArchival($fetched_contact ?: []); | ||||
| 			return $fetched_contact; | ||||
| 		} | ||||
| 
 | ||||
| 		$compacted = JsonLD::compact($data); | ||||
| 
 | ||||
| 		if (empty($compacted['@id'])) { | ||||
| 			return $fetched_contact; | ||||
| 		} | ||||
|  | @ -207,8 +218,11 @@ class APContact | |||
| 		} | ||||
| 
 | ||||
| 		// Quit if none of the basic values are set
 | ||||
| 		if (empty($apcontact['url']) || empty($apcontact['inbox']) || empty($apcontact['type'])) { | ||||
| 		if (empty($apcontact['url']) || empty($apcontact['type']) || (($apcontact['type'] != 'Tombstone') && empty($apcontact['inbox']))) { | ||||
| 			return $fetched_contact; | ||||
| 		} elseif ($apcontact['type'] == 'Tombstone') { | ||||
| 			// The "inbox" field must have a content
 | ||||
| 			$apcontact['inbox'] = ''; | ||||
| 		} | ||||
| 
 | ||||
| 		// Quit if this doesn't seem to be an account at all
 | ||||
|  |  | |||
|  | @ -724,7 +724,7 @@ class Contact | |||
| 	{ | ||||
| 		// We want just to make sure that we don't delete our "self" contact
 | ||||
| 		$contact = DBA::selectFirst('contact', ['uid'], ['id' => $id, 'self' => false]); | ||||
| 		if (!DBA::isResult($contact) || !intval($contact['uid'])) { | ||||
| 		if (!DBA::isResult($contact)) { | ||||
| 			return; | ||||
| 		} | ||||
| 
 | ||||
|  | @ -1762,6 +1762,17 @@ class Contact | |||
| 		DBA::update('contact', $fields, ['id' => $cids]); | ||||
| 	} | ||||
| 
 | ||||
| 	public static function deleteContactByUrl(string $url) | ||||
| 	{ | ||||
| 		// Update contact data for all users
 | ||||
| 		$condition = ['self' => false, 'nurl' => Strings::normaliseLink($url)]; | ||||
| 		$contacts = DBA::select('contact', ['id', 'uid'], $condition); | ||||
| 		while ($contact = DBA::fetch($contacts)) { | ||||
| 			Logger::info('Deleting contact', ['id' => $contact['id'], 'uid' => $contact['uid'], 'url' => $url]); | ||||
| 			self::remove($contact['id']); | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	/** | ||||
| 	 * Helper function for "updateFromProbe". Updates personal and public contact | ||||
| 	 * | ||||
|  | @ -1914,6 +1925,15 @@ class Contact | |||
| 			return false; | ||||
| 		} | ||||
| 
 | ||||
| 		if (!empty($ret['account-type']) && $ret['account-type'] == User::ACCOUNT_TYPE_DELETED) { | ||||
| 			Logger::info('Deleted account', ['id' => $id, 'url' => $ret['url'], 'ret' => $ret]); | ||||
| 			self::remove($id); | ||||
| 
 | ||||
| 			// Delete all contacts with the same URL
 | ||||
| 			self::deleteContactByUrl($ret['url']); | ||||
| 			return true; | ||||
| 		} | ||||
| 
 | ||||
| 		$uid = $contact['uid']; | ||||
| 		unset($contact['uid']); | ||||
| 
 | ||||
|  |  | |||
|  | @ -97,6 +97,7 @@ class User | |||
| 	const ACCOUNT_TYPE_NEWS =         2; | ||||
| 	const ACCOUNT_TYPE_COMMUNITY =    3; | ||||
| 	const ACCOUNT_TYPE_RELAY =        4; | ||||
| 	const ACCOUNT_TYPE_DELETED =    127; | ||||
| 	/** | ||||
| 	 * @} | ||||
| 	 */ | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue