Add Twitter User Object and Factory
This commit is contained in:
		
					parent
					
						
							
								6665eb76f9
							
						
					
				
			
			
				commit
				
					
						173264eaab
					
				
			
		
					 3 changed files with 216 additions and 0 deletions
				
			
		|  | @ -279,6 +279,14 @@ abstract class DI | |||
| 		return self::$dice->create(Factory\Api\Mastodon\Relationship::class); | ||||
| 	} | ||||
| 
 | ||||
| 	/** | ||||
| 	 * @return Factory\Api\Twitter\User | ||||
| 	 */ | ||||
| 	public static function twitterUser() | ||||
| 	{ | ||||
| 		return self::$dice->create(Factory\Api\Twitter\User::class); | ||||
| 	} | ||||
| 
 | ||||
| 	/** | ||||
| 	 * @return Factory\Notification\Notification | ||||
| 	 */ | ||||
|  |  | |||
							
								
								
									
										55
									
								
								src/Factory/Api/Twitter/User.php
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								src/Factory/Api/Twitter/User.php
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,55 @@ | |||
| <?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\Factory\Api\Twitter; | ||||
| 
 | ||||
| use Friendica\BaseFactory; | ||||
| use Friendica\Model\APContact; | ||||
| use Friendica\Model\Contact; | ||||
| use Friendica\Network\HTTPException; | ||||
| 
 | ||||
| class User extends BaseFactory | ||||
| { | ||||
| 	/** | ||||
| 	 * @param int  $contactId | ||||
| 	 * @param int  $uid Public contact (=0) or owner user id | ||||
| 	 * @param bool $skip_status | ||||
| 	 * @param bool $include_user_entities | ||||
| 	 * @return \Friendica\Object\Api\Twitter\User | ||||
| 	 * @throws HTTPException\InternalServerErrorException | ||||
| 	 * @throws \ImagickException | ||||
| 	 */ | ||||
| 	public function createFromContactId(int $contactId, $uid = 0, $skip_status = false, $include_user_entities = true) | ||||
| 	{ | ||||
| 		$cdata = Contact::getPublicAndUserContacID($contactId, $uid); | ||||
| 		if (!empty($cdata)) { | ||||
| 			$publicContact = Contact::getById($cdata['public']); | ||||
| 			$userContact = Contact::getById($cdata['user']); | ||||
| 		} else { | ||||
| 			$publicContact = Contact::getById($contactId); | ||||
| 			$userContact = []; | ||||
| 		} | ||||
| 
 | ||||
| 		$apcontact = APContact::getByURL($publicContact['url'], false); | ||||
| 
 | ||||
| 		return new \Friendica\Object\Api\Twitter\User($publicContact, $apcontact, $userContact, $skip_status, $include_user_entities); | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										153
									
								
								src/Object/Api/Twitter/User.php
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										153
									
								
								src/Object/Api/Twitter/User.php
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,153 @@ | |||
| <?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\Object\Api\Twitter; | ||||
| 
 | ||||
| use Friendica\BaseEntity; | ||||
| use Friendica\Content\ContactSelector; | ||||
| use Friendica\Content\Text\BBCode; | ||||
| 
 | ||||
| /** | ||||
|  * @see https://developer.twitter.com/en/docs/tweets/data-dictionary/overview/user-object | ||||
|  */ | ||||
| class User extends BaseEntity | ||||
| { | ||||
| 	/** @var int */ | ||||
| 	protected $id; | ||||
| 	/** @var string */ | ||||
| 	protected $id_str; | ||||
| 	/** @var string */ | ||||
| 	protected $name; | ||||
| 	/** @var string */ | ||||
| 	protected $screen_name; | ||||
| 	/** @var string|null */ | ||||
| 	protected $location; | ||||
| 	/** @var array */ | ||||
| 	protected $derived; | ||||
| 	/** @var string|null */ | ||||
| 	protected $url; | ||||
| 	/** @var array */ | ||||
| 	protected $entities; | ||||
| 	/** @var string|null */ | ||||
| 	protected $description; | ||||
| 	/** @var bool */ | ||||
| 	protected $protected; | ||||
| 	/** @var bool */ | ||||
| 	protected $verified; | ||||
| 	/** @var int */ | ||||
| 	protected $followers_count; | ||||
| 	/** @var int */ | ||||
| 	protected $friends_count; | ||||
| 	/** @var int */ | ||||
| 	protected $listed_count; | ||||
| 	/** @var int */ | ||||
| 	protected $favourites_count; | ||||
| 	/** @var int */ | ||||
| 	protected $statuses_count; | ||||
| 	/** @var string */ | ||||
| 	protected $created_at; | ||||
| 	/** @var string */ | ||||
| 	protected $profile_banner_url; | ||||
| 	/** @var string */ | ||||
| 	protected $profile_image_url_https; | ||||
| 	/** @var bool */ | ||||
| 	protected $default_profile; | ||||
| 	/** @var bool */ | ||||
| 	protected $default_profile_image; | ||||
| 	/** @var Status */ | ||||
| 	protected $status; | ||||
| 	/** @var array */ | ||||
| 	protected $withheld_in_countries; | ||||
| 	/** @var string */ | ||||
| 	protected $withheld_scope; | ||||
| 
 | ||||
| 	/** | ||||
| 	 * @param array $publicContact         Full contact table record with uid = 0 | ||||
| 	 * @param array $apcontact             Optional full apcontact table record | ||||
| 	 * @param array $userContact           Optional full contact table record with uid != 0 | ||||
| 	 * @param bool  $skip_status           Whether to remove the last status property, currently unused | ||||
| 	 * @param bool  $include_user_entities Whether to add the entities property | ||||
| 	 * @throws \Friendica\Network\HTTPException\InternalServerErrorException | ||||
| 	 */ | ||||
| 	public function __construct(array $publicContact, array $apcontact = [], array $userContact = [], $skip_status = false, $include_user_entities = true) | ||||
| 	{ | ||||
| 		$this->id                      = $publicContact['id']; | ||||
| 		$this->id_str                  = (string) $publicContact['id']; | ||||
| 		$this->name                    = $publicContact['name']; | ||||
| 		$this->screen_name             = $publicContact['nick'] ?: $publicContact['name']; | ||||
| 		$this->location                = $publicContact['location'] ?: | ||||
| 			ContactSelector::networkToName($publicContact['network'], $publicContact['url'], $publicContact['protocol']); | ||||
| 		$this->derived                 = []; | ||||
| 		$this->url                     = $publicContact['url']; | ||||
| 		// No entities needed since we don't perform any shortening in the URL or description
 | ||||
| 		$this->entities            = [ | ||||
| 			'url' => ['urls' => []], | ||||
| 			'description' => ['urls' => []], | ||||
| 		]; | ||||
| 		if (!$include_user_entities) { | ||||
| 			unset($this->entities); | ||||
| 		} | ||||
| 		$this->description             = BBCode::toPlaintext($publicContact['about']); | ||||
| 		$this->profile_image_url_https = $userContact['avatar'] ?? $publicContact['avatar']; | ||||
| 		$this->protected               = false; | ||||
| 		$this->followers_count         = $apcontact['followers_count'] ?? 0; | ||||
| 		$this->friends_count           = $apcontact['following_count'] ?? 0; | ||||
| 		$this->listed_count            = 0; | ||||
| 		$this->created_at              = api_date($publicContact['created']); | ||||
| 		$this->favourites_count        = 0; | ||||
| 		$this->verified                = false; | ||||
| 		$this->statuses_count          = $apcontact['statuses_count'] ?? 0; | ||||
| 		$this->profile_banner_url      = ''; | ||||
| 		$this->default_profile         = false; | ||||
| 		$this->default_profile_image   = false; | ||||
| 
 | ||||
| 		// @TODO Replace skip_status parameter with an optional Status parameter
 | ||||
| 		unset($this->status); | ||||
| 
 | ||||
| 		//  Unused optional fields
 | ||||
| 		unset($this->withheld_in_countries); | ||||
| 		unset($this->withheld_scope); | ||||
| 
 | ||||
| 		// Deprecated
 | ||||
| 		$this->profile_image_url              = $userContact['avatar'] ?? $publicContact['avatar']; | ||||
| 		$this->profile_image_url_profile_size = $publicContact['thumb']; | ||||
| 		$this->profile_image_url_large        = $publicContact['photo']; | ||||
| 		$this->utc_offset                     = 0; | ||||
| 		$this->time_zone                      = 'UTC'; | ||||
| 		$this->geo_enabled                    = false; | ||||
| 		$this->lang                           = null; | ||||
| 		$this->contributors_enabled           = false; | ||||
| 		$this->is_translator                  = false; | ||||
| 		$this->is_translation_enabled         = false; | ||||
| 		$this->following                      = false; | ||||
| 		$this->follow_request_sent            = false; | ||||
| 		$this->statusnet_blocking             = false; | ||||
| 		$this->notifications                  = false; | ||||
| 
 | ||||
| 		// Friendica-specific
 | ||||
| 		$this->uid                   = $userContact['uid'] ?? 0; | ||||
| 		$this->cid                   = $userContact['id'] ?? 0; | ||||
| 		$this->pid                   = $publicContact['id']; | ||||
| 		$this->self                  = $userContact['self'] ?? false; | ||||
| 		$this->network               = $publicContact['network']; | ||||
| 		$this->statusnet_profile_url = $publicContact['url']; | ||||
| 	} | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue