API: accounts and trends
This commit is contained in:
		
					parent
					
						
							
								0e60520a36
							
						
					
				
			
			
				commit
				
					
						c030275815
					
				
			
		
					 9 changed files with 316 additions and 6 deletions
				
			
		
							
								
								
									
										52
									
								
								src/Module/Api/Mastodon/Accounts.php
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								src/Module/Api/Mastodon/Accounts.php
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,52 @@ | |||
| <?php | ||||
| /** | ||||
|  * @copyright Copyright (C) 2020, Friendica | ||||
|  * | ||||
|  * @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\Mastodon; | ||||
| 
 | ||||
| use Friendica\Core\System; | ||||
| use Friendica\Database\DBA; | ||||
| use Friendica\DI; | ||||
| use Friendica\Module\BaseApi; | ||||
| 
 | ||||
| /** | ||||
|  * @see https://docs.joinmastodon.org/methods/accounts/ | ||||
|  */ | ||||
| class Accounts extends BaseApi | ||||
| { | ||||
| 	/** | ||||
| 	 * @param array $parameters | ||||
| 	 * @throws \Friendica\Network\HTTPException\InternalServerErrorException | ||||
| 	 */ | ||||
| 	public static function rawContent(array $parameters = []) | ||||
| 	{ | ||||
| 		if (empty($parameters['id'])) { | ||||
| 			DI::mstdnError()->RecordNotFound(); | ||||
| 		} | ||||
| 
 | ||||
| 		$id = $parameters['id']; | ||||
| 		if (!DBA::exists('contact', ['id' => $id, 'uid' => 0])) { | ||||
| 			DI::mstdnError()->RecordNotFound(); | ||||
| 		} | ||||
| 
 | ||||
| 		$account = DI::mstdnAccount()->createFromContactId($id); | ||||
| 		System::jsonExit($account); | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										94
									
								
								src/Module/Api/Mastodon/Accounts/Statuses.php
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										94
									
								
								src/Module/Api/Mastodon/Accounts/Statuses.php
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,94 @@ | |||
| <?php | ||||
| /** | ||||
|  * @copyright Copyright (C) 2020, Friendica | ||||
|  * | ||||
|  * @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\Mastodon\Accounts; | ||||
| 
 | ||||
| use Friendica\Core\Protocol; | ||||
| use Friendica\Core\System; | ||||
| use Friendica\Database\DBA; | ||||
| use Friendica\DI; | ||||
| use Friendica\Model\Item; | ||||
| use Friendica\Module\BaseApi; | ||||
| 
 | ||||
| /** | ||||
|  * @see https://docs.joinmastodon.org/methods/accounts/ | ||||
|  */ | ||||
| class Statuses extends BaseApi | ||||
| { | ||||
| 	/** | ||||
| 	 * @param array $parameters | ||||
| 	 * @throws \Friendica\Network\HTTPException\InternalServerErrorException | ||||
| 	 */ | ||||
| 	public static function rawContent(array $parameters = []) | ||||
| 	{ | ||||
| 		if (empty($parameters['id'])) { | ||||
| 			DI::mstdnError()->RecordNotFound(); | ||||
| 		} | ||||
| 
 | ||||
| 		$id = $parameters['id']; | ||||
| 		if (!DBA::exists('contact', ['id' => $id, 'uid' => 0])) { | ||||
| 			DI::mstdnError()->RecordNotFound(); | ||||
| 		} | ||||
| 
 | ||||
| 		// Show only statuses with media attached? Defaults to false.
 | ||||
| 		$only_media = (bool)!isset($_REQUEST['only_media']) ? false : ($_REQUEST['only_media'] == 'true'); // Currently not supported
 | ||||
| 		// Return results older than this id
 | ||||
| 		$max_id = (int)!isset($_REQUEST['max_id']) ? 0 : $_REQUEST['max_id']; | ||||
| 		// Return results newer than this id
 | ||||
| 		$since_id = (int)!isset($_REQUEST['since_id']) ? 0 : $_REQUEST['since_id']; | ||||
| 		// Return results immediately newer than this id
 | ||||
| 		$min_id = (int)!isset($_REQUEST['min_id']) ? 0 : $_REQUEST['min_id']; | ||||
| 		// Maximum number of results to return. Defaults to 20.
 | ||||
| 		$limit = (int)!isset($_REQUEST['limit']) ? 20 : $_REQUEST['limit']; | ||||
| 
 | ||||
| 		$params = ['order' => ['uri-id' => true], 'limit' => $limit]; | ||||
| 
 | ||||
| 		$condition = ['author-id' => $id, 'gravity' => [GRAVITY_PARENT, GRAVITY_COMMENT], | ||||
| 			'private' => Item::PUBLIC, 'uid' => 0, 'network' => Protocol::FEDERATED]; | ||||
| 
 | ||||
| 		if (!empty($max_id)) { | ||||
| 			$condition = DBA::mergeConditions($condition, ["`uri-id` < ?", $max_id]); | ||||
| 		} | ||||
| 
 | ||||
| 		if (!empty($since_id)) { | ||||
| 			$condition = DBA::mergeConditions($condition, ["`uri-id` > ?", $since_id]); | ||||
| 		} | ||||
| 
 | ||||
| 		if (!empty($min_id)) { | ||||
| 			$condition = DBA::mergeConditions($condition, ["`uri-id` > ?", $min_id]); | ||||
| 			$params['order'] = ['uri-id']; | ||||
| 		} | ||||
| 
 | ||||
| 		$items = Item::selectForUser(0, ['uri-id', 'uid'], $condition, $params); | ||||
| 
 | ||||
| 		$statuses = []; | ||||
| 		while ($item = Item::fetch($items)) { | ||||
| 			$statuses[] = DI::mstdnStatus()->createFromUriId($item['uri-id'], $item['uid']); | ||||
| 		} | ||||
| 		DBA::close($items); | ||||
| 
 | ||||
| 		if (!empty($min_id)) { | ||||
| 			array_reverse($statuses); | ||||
| 		} | ||||
| 
 | ||||
| 		System::jsonExit($statuses); | ||||
| 	} | ||||
| } | ||||
|  | @ -84,9 +84,10 @@ class PublicTimeline extends BaseApi | |||
| 		$items = Item::selectForUser(0, ['uri-id', 'uid'], $condition, $params); | ||||
| 
 | ||||
| 		$statuses = []; | ||||
| 		foreach ($items as $item) { | ||||
| 		while ($item = Item::fetch($items)) { | ||||
| 			$statuses[] = DI::mstdnStatus()->createFromUriId($item['uri-id'], $item['uid']); | ||||
| 		} | ||||
| 		DBA::close($items); | ||||
| 
 | ||||
| 		if (!empty($min_id)) { | ||||
| 			array_reverse($statuses); | ||||
|  |  | |||
							
								
								
									
										53
									
								
								src/Module/Api/Mastodon/Trends.php
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								src/Module/Api/Mastodon/Trends.php
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,53 @@ | |||
| <?php | ||||
| /** | ||||
|  * @copyright Copyright (C) 2020, Friendica | ||||
|  * | ||||
|  * @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\Mastodon; | ||||
| 
 | ||||
| use Friendica\Core\System; | ||||
| use Friendica\DI; | ||||
| use Friendica\Model\Tag; | ||||
| use Friendica\Module\BaseApi; | ||||
| 
 | ||||
| /** | ||||
|  * @see https://docs.joinmastodon.org/methods/instance/trends/ | ||||
|  */ | ||||
| class Trends extends BaseApi | ||||
| { | ||||
| 	/** | ||||
| 	 * @param array $parameters | ||||
| 	 * @throws \Friendica\Network\HTTPException\InternalServerErrorException | ||||
| 	 */ | ||||
| 	public static function rawContent(array $parameters = []) | ||||
| 	{ | ||||
| 		// Maximum number of results to return. Defaults to 10.
 | ||||
| 		$limit = (int)!isset($_REQUEST['limit']) ? 10 : $_REQUEST['limit']; | ||||
| 
 | ||||
| 		$trending = []; | ||||
| 		$tags = Tag::getGlobalTrendingHashtags(24, 20); | ||||
| 		foreach ($tags as $tag) { | ||||
| 			$tag['name'] = $tag['term']; | ||||
| 			$hashtag = new \Friendica\Object\Api\Mastodon\Tag(DI::baseUrl(), $tag); | ||||
| 			$trending[] = $hashtag->toArray(); | ||||
| 		} | ||||
| 
 | ||||
| 		System::jsonExit(array_slice($trending, 0, $limit)); | ||||
| 	} | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue