Reworked friendship API endpoints
This commit is contained in:
		
					parent
					
						
							
								87084a3e85
							
						
					
				
			
			
				commit
				
					
						a4ef4589e6
					
				
			
		
					 7 changed files with 250 additions and 191 deletions
				
			
		|  | @ -80,8 +80,9 @@ abstract class ContactEndpoint extends BaseApi | |||
| 	/** | ||||
| 	 * This methods expands the contact ids into full user objects in an existing result set. | ||||
| 	 * | ||||
| 	 * @param mixed $rel A relationship constant or a list of them | ||||
| 	 * @param int   $uid The local user id we query the contacts from | ||||
| 	 * @param array $ids           List of contact ids | ||||
| 	 * @param int   $total_count   Total list of contacts | ||||
| 	 * @param int   $uid           The local user id we query the contacts from | ||||
| 	 * @param int   $cursor | ||||
| 	 * @param int   $count | ||||
| 	 * @param bool  $skip_status | ||||
|  | @ -91,9 +92,9 @@ abstract class ContactEndpoint extends BaseApi | |||
| 	 * @throws HTTPException\NotFoundException | ||||
| 	 * @throws \ImagickException | ||||
| 	 */ | ||||
| 	protected static function list($rel, int $uid, int $cursor = -1, int $count = self::DEFAULT_COUNT, bool $skip_status = false, bool $include_user_entities = true) | ||||
| 	protected static function list(array $ids, int $total_count, int $uid, int $cursor = -1, int $count = self::DEFAULT_COUNT, bool $skip_status = false, bool $include_user_entities = true) | ||||
| 	{ | ||||
| 		$return = self::ids($rel, $uid, $cursor, $count); | ||||
| 		$return = self::ids($ids, $total_count, $cursor, $count, false); | ||||
| 
 | ||||
| 		$users = []; | ||||
| 		foreach ($return['ids'] as $contactId) { | ||||
|  | @ -109,108 +110,57 @@ abstract class ContactEndpoint extends BaseApi | |||
| 			'next_cursor_str' => $return['next_cursor_str'], | ||||
| 			'previous_cursor' => $return['previous_cursor'], | ||||
| 			'previous_cursor_str' => $return['previous_cursor_str'], | ||||
| 			'total_count' => (int)$return['total_count'], | ||||
| 			'total_count' => $return['total_count'], | ||||
| 		]; | ||||
| 
 | ||||
| 		return $return; | ||||
| 	} | ||||
| 
 | ||||
| 	/** | ||||
| 	 * @param mixed $rel A relationship constant or a list of them | ||||
| 	 * @param int   $uid The local user id we query the contacts from | ||||
| 	 * @param array $ids           List of contact ids | ||||
| 	 * @param int   $total_count   Total list of contacts | ||||
| 	 * @param int   $cursor | ||||
| 	 * @param int   $count | ||||
| 	 * @param bool  $stringify_ids | ||||
| 	 * @param int   $count         Number of elements to return | ||||
| 	 * @param bool  $stringify_ids if "true" then the id is converted to a string | ||||
| 	 * @return array | ||||
| 	 * @throws HTTPException\NotFoundException | ||||
| 	 */ | ||||
| 	protected static function ids($rel, int $uid, int $cursor = -1, int $count = self::DEFAULT_COUNT, bool $stringify_ids = false) | ||||
| 	protected static function ids(array $ids, int $total_count, int $cursor = -1, int $count = self::DEFAULT_COUNT, bool $stringify_ids = false) | ||||
| 	{ | ||||
| 		$hide_friends = false; | ||||
| 		if ($uid != self::getCurrentUserID()) { | ||||
| 			$profile = Profile::getByUID($uid); | ||||
| 			if (empty($profile)) { | ||||
| 				throw new HTTPException\NotFoundException(DI::l10n()->t('Profile not found')); | ||||
| 			} | ||||
| 
 | ||||
| 			$hide_friends = (bool)$profile['hide-friends']; | ||||
| 		} | ||||
| 
 | ||||
| 		$ids = []; | ||||
| 		$next_cursor = 0; | ||||
| 		$previous_cursor = 0; | ||||
| 		$total_count = 0; | ||||
| 		if (!$hide_friends) { | ||||
| 			$condition = [ | ||||
| 				'rel' => $rel, | ||||
| 				'uid' => $uid, | ||||
| 				'self' => false, | ||||
| 				'deleted' => false, | ||||
| 				'hidden' => false, | ||||
| 				'archive' => false, | ||||
| 				'pending' => false | ||||
| 			]; | ||||
| 
 | ||||
| 			$total_count = (int)DBA::count('contact', $condition); | ||||
| 		// Cursor is on the user-specific contact id since it's the sort field
 | ||||
| 		if (count($ids)) { | ||||
| 			$previous_cursor = -$ids[0]; | ||||
| 			$next_cursor = (int)$ids[count($ids) -1]; | ||||
| 		} | ||||
| 
 | ||||
| 			$params = ['limit' => $count, 'order' => ['id' => 'ASC']]; | ||||
| 		// No next page
 | ||||
| 		if ($total_count <= count($ids) || count($ids) < $count) { | ||||
| 			$next_cursor = 0; | ||||
| 		} | ||||
| 		// End of results
 | ||||
| 		if ($cursor < 0 && count($ids) === 0) { | ||||
| 			$next_cursor = -1; | ||||
| 		} | ||||
| 
 | ||||
| 			if ($cursor !== -1) { | ||||
| 				if ($cursor > 0) { | ||||
| 					$condition = DBA::mergeConditions($condition, ['`id` > ?', $cursor]); | ||||
| 				} else { | ||||
| 					$condition = DBA::mergeConditions($condition, ['`id` < ?', -$cursor]); | ||||
| 					// Previous page case: we want the items closest to cursor but for that we need to reverse the query order
 | ||||
| 					$params['order']['id'] = 'DESC'; | ||||
| 				} | ||||
| 			} | ||||
| 		// No previous page
 | ||||
| 		if ($cursor === -1) { | ||||
| 			$previous_cursor = 0; | ||||
| 		} | ||||
| 
 | ||||
| 			$contacts = Contact::selectToArray(['id'], $condition, $params); | ||||
| 		if ($cursor > 0 && count($ids) === 0) { | ||||
| 			$previous_cursor = -$cursor; | ||||
| 		} | ||||
| 
 | ||||
| 			// Previous page case: once we get the relevant items closest to cursor, we need to restore the expected display order
 | ||||
| 			if ($cursor !== -1 && $cursor <= 0) { | ||||
| 				$contacts = array_reverse($contacts); | ||||
| 			} | ||||
| 		if ($cursor < 0 && count($ids) === 0) { | ||||
| 			$next_cursor = -1; | ||||
| 		} | ||||
| 
 | ||||
| 			// Contains user-specific contact ids
 | ||||
| 			$ids = array_column($contacts, 'id'); | ||||
| 
 | ||||
| 			// Cursor is on the user-specific contact id since it's the sort field
 | ||||
| 			if (count($ids)) { | ||||
| 				$previous_cursor = -$ids[0]; | ||||
| 				$next_cursor = (int)$ids[count($ids) -1]; | ||||
| 			} | ||||
| 
 | ||||
| 			// No next page
 | ||||
| 			if ($total_count <= count($contacts) || count($contacts) < $count) { | ||||
| 				$next_cursor = 0; | ||||
| 			} | ||||
| 			// End of results
 | ||||
| 			if ($cursor < 0 && count($contacts) === 0) { | ||||
| 				$next_cursor = -1; | ||||
| 			} | ||||
| 
 | ||||
| 			// No previous page
 | ||||
| 			if ($cursor === -1) { | ||||
| 				$previous_cursor = 0; | ||||
| 			} | ||||
| 
 | ||||
| 			if ($cursor > 0 && count($contacts) === 0) { | ||||
| 				$previous_cursor = -$cursor; | ||||
| 			} | ||||
| 
 | ||||
| 			if ($cursor < 0 && count($contacts) === 0) { | ||||
| 				$next_cursor = -1; | ||||
| 			} | ||||
| 
 | ||||
| 			// Conversion to public contact ids
 | ||||
| 			array_walk($ids, function (&$contactId) use ($uid, $stringify_ids) { | ||||
| 				$cdata = Contact::getPublicAndUserContactID($contactId, $uid); | ||||
| 				if ($stringify_ids) { | ||||
| 					$contactId = (string)$cdata['public']; | ||||
| 				} else { | ||||
| 					$contactId = (int)$cdata['public']; | ||||
| 				} | ||||
| 		if ($stringify_ids) { | ||||
| 			array_walk($ids, function (&$contactId) { | ||||
| 				$contactId = (string)$contactId; | ||||
| 			}); | ||||
| 		} | ||||
| 
 | ||||
|  |  | |||
|  | @ -22,21 +22,25 @@ | |||
| namespace Friendica\Module\Api\Twitter\Followers; | ||||
| 
 | ||||
| use Friendica\Core\System; | ||||
| use Friendica\Model\Contact; | ||||
| use Friendica\Database\DBA; | ||||
| use Friendica\Module\Api\Twitter\ContactEndpoint; | ||||
| use Friendica\Module\BaseApi; | ||||
| 
 | ||||
| /** | ||||
|  * @see https://developer.twitter.com/en/docs/accounts-and-users/follow-search-get-users/api-reference/get-followers-ids | ||||
|  */ | ||||
| class FollowersIds extends ContactEndpoint | ||||
| class Ids extends ContactEndpoint | ||||
| { | ||||
| 	public function rawContent() | ||||
| 	{ | ||||
| 		self::checkAllowedScope(self::SCOPE_READ); | ||||
| 		$uid = BaseApi::getCurrentUserID(); | ||||
| 
 | ||||
| 		// Expected value for user_id parameter: public/user contact id
 | ||||
| 		$contact_id    = filter_input(INPUT_GET, 'user_id'      , FILTER_VALIDATE_INT); | ||||
| 		$screen_name   = filter_input(INPUT_GET, 'screen_name'); | ||||
| 		$cursor        = filter_input(INPUT_GET, 'cursor'       , FILTER_VALIDATE_INT); | ||||
| 		$stringify_ids = filter_input(INPUT_GET, 'stringify_ids', FILTER_VALIDATE_BOOLEAN); | ||||
| 		$cursor        = filter_input(INPUT_GET, 'cursor'       , FILTER_VALIDATE_INT, ['options' => ['default' => -1]]); | ||||
| 		$stringify_ids = filter_input(INPUT_GET, 'stringify_ids', FILTER_VALIDATE_BOOLEAN, ['options' => ['default' => false]]); | ||||
| 		$count         = filter_input(INPUT_GET, 'count'        , FILTER_VALIDATE_INT, ['options' => [ | ||||
| 			'default' => self::DEFAULT_COUNT, | ||||
| 			'min_range' => 1, | ||||
|  | @ -44,18 +48,48 @@ class FollowersIds extends ContactEndpoint | |||
| 		]]); | ||||
| 		// Friendica-specific
 | ||||
| 		$since_id      = filter_input(INPUT_GET, 'since_id'     , FILTER_VALIDATE_INT); | ||||
| 		$max_id        = filter_input(INPUT_GET, 'max_id'       , FILTER_VALIDATE_INT, ['options' => [ | ||||
| 			'default' => 1, | ||||
| 		]]); | ||||
| 		$max_id        = filter_input(INPUT_GET, 'max_id'       , FILTER_VALIDATE_INT); | ||||
| 		$min_id        = filter_input(INPUT_GET, 'min_id'       , FILTER_VALIDATE_INT); | ||||
| 
 | ||||
| 		// @todo Use Model\Contact\Relation::listFollowers($cid, $condition, $count);
 | ||||
| 		$cid = BaseApi::getContactIDForSearchterm($screen_name, $contact_id, $uid); | ||||
| 
 | ||||
| 		System::jsonExit(self::ids( | ||||
| 			[Contact::FOLLOWER, Contact::FRIEND], | ||||
| 			self::getUid($contact_id, $screen_name), | ||||
| 			$cursor ?? $since_id ?? - $max_id, | ||||
| 			$count, | ||||
| 			$stringify_ids | ||||
| 		)); | ||||
| 		$params = ['order' => ['relation-cid' => true], 'limit' => $count]; | ||||
| 
 | ||||
| 		$condition = ['cid' => $cid, 'follows' => true]; | ||||
| 
 | ||||
| 		$total_count = (int)DBA::count('contact-relation', $condition); | ||||
| 
 | ||||
| 		if (!empty($max_id)) { | ||||
| 			$condition = DBA::mergeConditions($condition, ["`relation-cid` < ?", $max_id]); | ||||
| 		} | ||||
| 
 | ||||
| 		if (!empty($since_id)) { | ||||
| 			$condition = DBA::mergeConditions($condition, ["`relation-cid` > ?", $since_id]); | ||||
| 		} | ||||
| 
 | ||||
| 		if (!empty($min_id)) { | ||||
| 			$condition = DBA::mergeConditions($condition, ["`relation-cid` > ?", $min_id]); | ||||
| 
 | ||||
| 			$params['order'] = ['relation-cid']; | ||||
| 		} | ||||
| 
 | ||||
| 		$ids = []; | ||||
| 
 | ||||
| 		$followers = DBA::select('contact-relation', ['relation-cid'], $condition, $params); | ||||
| 		while ($follower = DBA::fetch($followers)) { | ||||
| 			self::setBoundaries($follower['relation-cid']); | ||||
| 			$ids[] = $follower['relation-cid']; | ||||
| 		} | ||||
| 		DBA::close($followers); | ||||
| 
 | ||||
| 		if (!empty($min_id)) { | ||||
| 			array_reverse($ids); | ||||
| 		} | ||||
| 
 | ||||
| 		$return = self::ids($ids, $total_count, $cursor, $count, $stringify_ids); | ||||
| 
 | ||||
| 		self::setLinkHeader(); | ||||
| 
 | ||||
| 		System::jsonExit($return); | ||||
| 	} | ||||
| } | ||||
|  |  | |||
|  | @ -22,43 +22,75 @@ | |||
| namespace Friendica\Module\Api\Twitter\Followers; | ||||
| 
 | ||||
| use Friendica\Core\System; | ||||
| use Friendica\Model\Contact; | ||||
| use Friendica\Database\DBA; | ||||
| use Friendica\Module\Api\Twitter\ContactEndpoint; | ||||
| use Friendica\Module\BaseApi; | ||||
| 
 | ||||
| /** | ||||
|  * @see https://developer.twitter.com/en/docs/accounts-and-users/follow-search-get-users/api-reference/get-followers-list | ||||
|  */ | ||||
| class FollowersList extends ContactEndpoint | ||||
| class Lists extends ContactEndpoint | ||||
| { | ||||
| 	public function rawContent() | ||||
| 	{ | ||||
| 		self::checkAllowedScope(self::SCOPE_READ); | ||||
| 		$uid = BaseApi::getCurrentUserID(); | ||||
| 
 | ||||
| 		// Expected value for user_id parameter: public/user contact id
 | ||||
| 		$contact_id    = filter_input(INPUT_GET, 'user_id'      , FILTER_VALIDATE_INT); | ||||
| 		$screen_name   = filter_input(INPUT_GET, 'screen_name'); | ||||
| 		$cursor        = filter_input(INPUT_GET, 'cursor'       , FILTER_VALIDATE_INT); | ||||
| 		$count         = filter_input(INPUT_GET, 'count'        , FILTER_VALIDATE_INT, ['options' => [ | ||||
| 		$contact_id            = filter_input(INPUT_GET, 'user_id'              , FILTER_VALIDATE_INT); | ||||
| 		$screen_name           = filter_input(INPUT_GET, 'screen_name'); | ||||
| 		$cursor                = filter_input(INPUT_GET, 'cursor'               , FILTER_VALIDATE_INT, ['options' => ['default' => -1]]); | ||||
| 		$skip_status           = filter_input(INPUT_GET, 'skip_status'          , FILTER_VALIDATE_BOOLEAN, ['options' => ['default' => false]]); | ||||
| 		$include_user_entities = filter_input(INPUT_GET, 'include_user_entities', FILTER_VALIDATE_BOOLEAN, ['options' => ['default' => false]]); | ||||
| 		$count                 = filter_input(INPUT_GET, 'count'                , FILTER_VALIDATE_INT, ['options' => [ | ||||
| 			'default' => self::DEFAULT_COUNT, | ||||
| 			'min_range' => 1, | ||||
| 			'max_range' => self::MAX_COUNT, | ||||
| 		]]); | ||||
| 		$skip_status           = filter_input(INPUT_GET, 'skip_status'          , FILTER_VALIDATE_BOOLEAN); | ||||
| 		$include_user_entities = filter_input(INPUT_GET, 'include_user_entities', FILTER_VALIDATE_BOOLEAN); | ||||
| 
 | ||||
| 		// Friendica-specific
 | ||||
| 		$since_id      = filter_input(INPUT_GET, 'since_id'     , FILTER_VALIDATE_INT); | ||||
| 		$max_id        = filter_input(INPUT_GET, 'max_id'       , FILTER_VALIDATE_INT, ['options' => [ | ||||
| 			'default' => 1, | ||||
| 		]]); | ||||
| 		$since_id              = filter_input(INPUT_GET, 'since_id', FILTER_VALIDATE_INT); | ||||
| 		$max_id                = filter_input(INPUT_GET, 'max_id'  , FILTER_VALIDATE_INT); | ||||
| 		$min_id                = filter_input(INPUT_GET, 'min_id'  , FILTER_VALIDATE_INT); | ||||
| 
 | ||||
| 		// @todo Use Model\Contact\Relation::listFollowers($cid, $condition, $count);
 | ||||
| 		$cid = BaseApi::getContactIDForSearchterm($screen_name, $contact_id, $uid); | ||||
| 
 | ||||
| 		System::jsonExit(self::list( | ||||
| 			[Contact::FOLLOWER, Contact::FRIEND], | ||||
| 			self::getUid($contact_id, $screen_name), | ||||
| 			$cursor ?? $since_id ?? - $max_id, | ||||
| 			$count, | ||||
| 			$skip_status, | ||||
| 			$include_user_entities | ||||
| 		)); | ||||
| 		$params = ['order' => ['relation-cid' => true], 'limit' => $count]; | ||||
| 
 | ||||
| 		$condition = ['cid' => $cid, 'follows' => true]; | ||||
| 
 | ||||
| 		$total_count = (int)DBA::count('contact-relation', $condition); | ||||
| 
 | ||||
| 		if (!empty($max_id)) { | ||||
| 			$condition = DBA::mergeConditions($condition, ["`relation-cid` < ?", $max_id]); | ||||
| 		} | ||||
| 
 | ||||
| 		if (!empty($since_id)) { | ||||
| 			$condition = DBA::mergeConditions($condition, ["`relation-cid` > ?", $since_id]); | ||||
| 		} | ||||
| 
 | ||||
| 		if (!empty($min_id)) { | ||||
| 			$condition = DBA::mergeConditions($condition, ["`relation-cid` > ?", $min_id]); | ||||
| 
 | ||||
| 			$params['order'] = ['relation-cid']; | ||||
| 		} | ||||
| 
 | ||||
| 		$ids = []; | ||||
| 
 | ||||
| 		$followers = DBA::select('contact-relation', ['relation-cid'], $condition, $params); | ||||
| 		while ($follower = DBA::fetch($followers)) { | ||||
| 			self::setBoundaries($follower['relation-cid']); | ||||
| 			$ids[] = $follower['relation-cid']; | ||||
| 		} | ||||
| 		DBA::close($followers); | ||||
| 
 | ||||
| 		if (!empty($min_id)) { | ||||
| 			array_reverse($ids); | ||||
| 		} | ||||
| 
 | ||||
| 		$return = self::list($ids, $total_count, $uid, $cursor, $count, $skip_status, $include_user_entities); | ||||
| 
 | ||||
| 		self::setLinkHeader(); | ||||
| 
 | ||||
| 		System::jsonExit($return); | ||||
| 	} | ||||
| } | ||||
|  |  | |||
|  | @ -22,8 +22,9 @@ | |||
| namespace Friendica\Module\Api\Twitter\Friends; | ||||
| 
 | ||||
| use Friendica\Core\System; | ||||
| use Friendica\Model\Contact; | ||||
| use Friendica\Database\DBA; | ||||
| use Friendica\Module\Api\Twitter\ContactEndpoint; | ||||
| use Friendica\Module\BaseApi; | ||||
| 
 | ||||
| /** | ||||
|  * @see https://developer.twitter.com/en/docs/accounts-and-users/follow-search-get-users/api-reference/get-friends-ids | ||||
|  | @ -32,11 +33,14 @@ class Ids extends ContactEndpoint | |||
| { | ||||
| 	public function rawContent() | ||||
| 	{ | ||||
| 		self::checkAllowedScope(self::SCOPE_READ); | ||||
| 		$uid = BaseApi::getCurrentUserID(); | ||||
| 
 | ||||
| 		// Expected value for user_id parameter: public/user contact id
 | ||||
| 		$contact_id    = filter_input(INPUT_GET, 'user_id'      , FILTER_VALIDATE_INT); | ||||
| 		$screen_name   = filter_input(INPUT_GET, 'screen_name'); | ||||
| 		$cursor        = filter_input(INPUT_GET, 'cursor'       , FILTER_VALIDATE_INT); | ||||
| 		$stringify_ids = filter_input(INPUT_GET, 'stringify_ids', FILTER_VALIDATE_BOOLEAN); | ||||
| 		$cursor        = filter_input(INPUT_GET, 'cursor'       , FILTER_VALIDATE_INT, ['options' => ['default' => -1]]); | ||||
| 		$stringify_ids = filter_input(INPUT_GET, 'stringify_ids', FILTER_VALIDATE_BOOLEAN, ['options' => ['default' => false]]); | ||||
| 		$count         = filter_input(INPUT_GET, 'count'        , FILTER_VALIDATE_INT, ['options' => [ | ||||
| 			'default' => self::DEFAULT_COUNT, | ||||
| 			'min_range' => 1, | ||||
|  | @ -44,18 +48,48 @@ class Ids extends ContactEndpoint | |||
| 		]]); | ||||
| 		// Friendica-specific
 | ||||
| 		$since_id      = filter_input(INPUT_GET, 'since_id'     , FILTER_VALIDATE_INT); | ||||
| 		$max_id        = filter_input(INPUT_GET, 'max_id'       , FILTER_VALIDATE_INT, ['options' => [ | ||||
| 			'default' => 1, | ||||
| 		]]); | ||||
| 		$max_id        = filter_input(INPUT_GET, 'max_id'       , FILTER_VALIDATE_INT); | ||||
| 		$min_id        = filter_input(INPUT_GET, 'min_id'       , FILTER_VALIDATE_INT); | ||||
| 
 | ||||
| 		// @todo Use Model\Contact\Relation::listFollows($cid, $condition, $count);
 | ||||
| 		$cid = BaseApi::getContactIDForSearchterm($screen_name, $contact_id, $uid); | ||||
| 
 | ||||
| 		System::jsonExit(self::ids( | ||||
| 			[Contact::SHARING, Contact::FRIEND], | ||||
| 			self::getUid($contact_id, $screen_name), | ||||
| 			$cursor ?? $since_id ?? - $max_id, | ||||
| 			$count, | ||||
| 			$stringify_ids | ||||
| 		)); | ||||
| 		$params = ['order' => ['cid' => true], 'limit' => $count]; | ||||
| 
 | ||||
| 		$condition = ['relation-cid' => $cid, 'follows' => true]; | ||||
| 
 | ||||
| 		$total_count = (int)DBA::count('contact-relation', $condition); | ||||
| 
 | ||||
| 		if (!empty($max_id)) { | ||||
| 			$condition = DBA::mergeConditions($condition, ["`cid` < ?", $max_id]); | ||||
| 		} | ||||
| 
 | ||||
| 		if (!empty($since_id)) { | ||||
| 			$condition = DBA::mergeConditions($condition, ["`cid` > ?", $since_id]); | ||||
| 		} | ||||
| 
 | ||||
| 		if (!empty($min_id)) { | ||||
| 			$condition = DBA::mergeConditions($condition, ["`cid` > ?", $min_id]); | ||||
| 
 | ||||
| 			$params['order'] = ['cid']; | ||||
| 		} | ||||
| 
 | ||||
| 		$ids = []; | ||||
| 
 | ||||
| 		$followers = DBA::select('contact-relation', ['cid'], $condition, $params); | ||||
| 		while ($follower = DBA::fetch($followers)) { | ||||
| 			self::setBoundaries($follower['cid']); | ||||
| 			$ids[] = $follower['cid']; | ||||
| 		} | ||||
| 		DBA::close($followers); | ||||
| 
 | ||||
| 		if (!empty($min_id)) { | ||||
| 			array_reverse($ids); | ||||
| 		} | ||||
| 
 | ||||
| 		$return = self::ids($ids, $total_count, $cursor, $count, $stringify_ids); | ||||
| 
 | ||||
| 		self::setLinkHeader(); | ||||
| 
 | ||||
| 		System::jsonExit($return); | ||||
| 	} | ||||
| } | ||||
|  |  | |||
|  | @ -22,8 +22,9 @@ | |||
| namespace Friendica\Module\Api\Twitter\Friends; | ||||
| 
 | ||||
| use Friendica\Core\System; | ||||
| use Friendica\Model\Contact; | ||||
| use Friendica\Database\DBA; | ||||
| use Friendica\Module\Api\Twitter\ContactEndpoint; | ||||
| use Friendica\Module\BaseApi; | ||||
| 
 | ||||
| /** | ||||
|  * @see https://developer.twitter.com/en/docs/accounts-and-users/follow-search-get-users/api-reference/get-friends-list | ||||
|  | @ -32,33 +33,64 @@ class Lists extends ContactEndpoint | |||
| { | ||||
| 	public function rawContent() | ||||
| 	{ | ||||
| 		self::checkAllowedScope(self::SCOPE_READ); | ||||
| 		$uid = BaseApi::getCurrentUserID(); | ||||
| 
 | ||||
| 		// Expected value for user_id parameter: public/user contact id
 | ||||
| 		$contact_id    = filter_input(INPUT_GET, 'user_id'      , FILTER_VALIDATE_INT); | ||||
| 		$screen_name   = filter_input(INPUT_GET, 'screen_name'); | ||||
| 		$cursor        = filter_input(INPUT_GET, 'cursor'       , FILTER_VALIDATE_INT); | ||||
| 		$count         = filter_input(INPUT_GET, 'count'        , FILTER_VALIDATE_INT, ['options' => [ | ||||
| 		$contact_id            = filter_input(INPUT_GET, 'user_id'              , FILTER_VALIDATE_INT); | ||||
| 		$screen_name           = filter_input(INPUT_GET, 'screen_name'); | ||||
| 		$cursor                = filter_input(INPUT_GET, 'cursor'               , FILTER_VALIDATE_INT, ['options' => ['default' => -1]]); | ||||
| 		$skip_status           = filter_input(INPUT_GET, 'skip_status'          , FILTER_VALIDATE_BOOLEAN, ['options' => ['default' => false]]); | ||||
| 		$include_user_entities = filter_input(INPUT_GET, 'include_user_entities', FILTER_VALIDATE_BOOLEAN, ['options' => ['default' => false]]); | ||||
| 		$count                 = filter_input(INPUT_GET, 'count'                , FILTER_VALIDATE_INT, ['options' => [ | ||||
| 			'default' => self::DEFAULT_COUNT, | ||||
| 			'min_range' => 1, | ||||
| 			'max_range' => self::MAX_COUNT, | ||||
| 		]]); | ||||
| 		$skip_status           = filter_input(INPUT_GET, 'skip_status'          , FILTER_VALIDATE_BOOLEAN); | ||||
| 		$include_user_entities = filter_input(INPUT_GET, 'include_user_entities', FILTER_VALIDATE_BOOLEAN); | ||||
| 
 | ||||
| 		// Friendica-specific
 | ||||
| 		$since_id      = filter_input(INPUT_GET, 'since_id'     , FILTER_VALIDATE_INT); | ||||
| 		$max_id        = filter_input(INPUT_GET, 'max_id'       , FILTER_VALIDATE_INT, ['options' => [ | ||||
| 			'default' => 1, | ||||
| 		]]); | ||||
| 		$since_id              = filter_input(INPUT_GET, 'since_id', FILTER_VALIDATE_INT); | ||||
| 		$max_id                = filter_input(INPUT_GET, 'max_id'  , FILTER_VALIDATE_INT); | ||||
| 		$min_id                = filter_input(INPUT_GET, 'min_id'  , FILTER_VALIDATE_INT); | ||||
| 
 | ||||
| 		// @todo Use Model\Contact\Relation::listFollows($cid, $condition, $count);
 | ||||
| 		$cid = BaseApi::getContactIDForSearchterm($screen_name, $contact_id, $uid); | ||||
| 
 | ||||
| 		System::jsonExit(self::list( | ||||
| 			[Contact::SHARING, Contact::FRIEND], | ||||
| 			self::getUid($contact_id, $screen_name), | ||||
| 			$cursor ?? $since_id ?? - $max_id, | ||||
| 			$count, | ||||
| 			$skip_status, | ||||
| 			$include_user_entities | ||||
| 		)); | ||||
| 		$params = ['order' => ['cid' => true], 'limit' => $count]; | ||||
| 
 | ||||
| 		$condition = ['relation-cid' => $cid, 'follows' => true]; | ||||
| 
 | ||||
| 		$total_count = (int)DBA::count('contact-relation', $condition); | ||||
| 
 | ||||
| 		if (!empty($max_id)) { | ||||
| 			$condition = DBA::mergeConditions($condition, ["`cid` < ?", $max_id]); | ||||
| 		} | ||||
| 
 | ||||
| 		if (!empty($since_id)) { | ||||
| 			$condition = DBA::mergeConditions($condition, ["`cid` > ?", $since_id]); | ||||
| 		} | ||||
| 
 | ||||
| 		if (!empty($min_id)) { | ||||
| 			$condition = DBA::mergeConditions($condition, ["`cid` > ?", $min_id]); | ||||
| 
 | ||||
| 			$params['order'] = ['cid']; | ||||
| 		} | ||||
| 
 | ||||
| 		$ids = []; | ||||
| 
 | ||||
| 		$followers = DBA::select('contact-relation', ['cid'], $condition, $params); | ||||
| 		while ($follower = DBA::fetch($followers)) { | ||||
| 			self::setBoundaries($follower['cid']); | ||||
| 			$ids[] = $follower['cid']; | ||||
| 		} | ||||
| 		DBA::close($followers); | ||||
| 
 | ||||
| 		if (!empty($min_id)) { | ||||
| 			array_reverse($ids); | ||||
| 		} | ||||
| 
 | ||||
| 		$return = self::list($ids, $total_count, $uid, $cursor, $count, $skip_status, $include_user_entities); | ||||
| 
 | ||||
| 		self::setLinkHeader(); | ||||
| 
 | ||||
| 		System::jsonExit($return); | ||||
| 	} | ||||
| } | ||||
|  |  | |||
|  | @ -293,7 +293,7 @@ class BaseApi extends BaseModule | |||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	public static function getContactIDForSearchterm(string $screen_name, int $cid, int $uid) | ||||
| 	public static function getContactIDForSearchterm(string $screen_name = null, int $cid = null, int $uid) | ||||
| 	{ | ||||
| 		if (!empty($cid)) { | ||||
| 			return $cid; | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue