- Add all dependencies, necessary to run the content (baseUrl, Arguments) - Encapsulate all POST/GET/DELETE/PATCH/PUT methods as protected methods inside the BaseModule - Return Module content ONLY per `BaseModule::run()` (including the Hook logic there as well)
		
			
				
	
	
		
			96 lines
		
	
	
	
		
			3.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			96 lines
		
	
	
	
		
			3.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * @copyright Copyright (C) 2010-2021, the Friendica project
 | |
|  *
 | |
|  * @license GNU AGPL version 3 or any later version
 | |
|  *
 | |
|  * This program is free software: you can redistribute it and/or modify
 | |
|  * it under the terms of the GNU Affero General Public License as
 | |
|  * published by the Free Software Foundation, either version 3 of the
 | |
|  * License, or (at your option) any later version.
 | |
|  *
 | |
|  * This program is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|  * GNU Affero General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU Affero General Public License
 | |
|  * along with this program.  If not, see <https://www.gnu.org/licenses/>.
 | |
|  *
 | |
|  */
 | |
| 
 | |
| namespace Friendica\Module\Api\Twitter\Friends;
 | |
| 
 | |
| use Friendica\Core\System;
 | |
| 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
 | |
|  */
 | |
| class Ids extends ContactEndpoint
 | |
| {
 | |
| 	protected function rawContent(array $request = [])
 | |
| 	{
 | |
| 		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');
 | |
| 		$profile_url   = filter_input(INPUT_GET, 'profile_url');
 | |
| 		$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,
 | |
| 			'max_range' => self::MAX_COUNT,
 | |
| 		]]);
 | |
| 		// Friendica-specific
 | |
| 		$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);
 | |
| 
 | |
| 		$cid = BaseApi::getContactIDForSearchterm($screen_name, $profile_url, $contact_id, $uid);
 | |
| 
 | |
| 		$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);
 | |
| 	}
 | |
| }
 |