Cleanup Code

This commit is contained in:
Philipp Holzer 2021-06-09 00:09:32 +02:00
parent 263774eb46
commit d4387d45ee
No known key found for this signature in database
GPG key ID: 9A28B7D4FF5667BD
18 changed files with 86 additions and 78 deletions

View file

@ -10,7 +10,7 @@ class Mentions extends BaseCollection
/** /**
* @return Mention * @return Mention
*/ */
public function current() public function current(): Mention
{ {
return parent::current(); return parent::current();
} }

View file

@ -29,6 +29,7 @@ use Friendica\Model\Contact;
use Friendica\Network\HTTPException; use Friendica\Network\HTTPException;
use Friendica\Repository\PermissionSet; use Friendica\Repository\PermissionSet;
use Friendica\Repository\ProfileField; use Friendica\Repository\ProfileField;
use ImagickException;
use Psr\Log\LoggerInterface; use Psr\Log\LoggerInterface;
class Account extends BaseFactory class Account extends BaseFactory
@ -52,11 +53,12 @@ class Account extends BaseFactory
/** /**
* @param int $contactId * @param int $contactId
* @param int $uid Public contact (=0) or owner user id * @param int $uid Public contact (=0) or owner user id
*
* @return \Friendica\Object\Api\Mastodon\Account * @return \Friendica\Object\Api\Mastodon\Account
* @throws HTTPException\InternalServerErrorException * @throws HTTPException\InternalServerErrorException
* @throws \ImagickException * @throws ImagickException|HTTPException\NotFoundException
*/ */
public function createFromContactId(int $contactId, $uid = 0) public function createFromContactId(int $contactId, $uid = 0): \Friendica\Object\Api\Mastodon\Account
{ {
$cdata = Contact::getPublicAndUserContacID($contactId, $uid); $cdata = Contact::getPublicAndUserContacID($contactId, $uid);
if (!empty($cdata)) { if (!empty($cdata)) {
@ -87,18 +89,17 @@ class Account extends BaseFactory
/** /**
* @param int $userId * @param int $userId
* @return \Friendica\Object\Api\Mastodon\Account * @return \Friendica\Object\Api\Mastodon\Account
* @throws HTTPException\InternalServerErrorException * @throws ImagickException|HTTPException\InternalServerErrorException
* @throws \ImagickException
*/ */
public function createFromUserId(int $userId) public function createFromUserId(int $userId): \Friendica\Object\Api\Mastodon\Account
{ {
$publicContact = Contact::selectFirst([], ['uid' => $userId, 'self' => true]); $publicContact = Contact::selectFirst([], ['uid' => $userId, 'self' => true]);
$profileFields = $this->profileFieldRepo->select(['uid' => $userId, 'psid' => PermissionSet::PUBLIC]); $profileFields = $this->profileFieldRepo->select(['uid' => $userId, 'psid' => PermissionSet::PUBLIC]);
$fields = $this->mstdnFieldFactory->createFromProfileFields($profileFields); $fields = $this->mstdnFieldFactory->createFromProfileFields($profileFields);
$apcontact = APContact::getByURL($publicContact['url'], false); $apContact = APContact::getByURL($publicContact['url'], false);
return new \Friendica\Object\Api\Mastodon\Account($this->baseUrl, $publicContact, $fields, $apcontact); return new \Friendica\Object\Api\Mastodon\Account($this->baseUrl, $publicContact, $fields, $apContact);
} }
} }

View file

@ -44,11 +44,11 @@ class Application extends BaseFactory
* *
* @throws InternalServerErrorException * @throws InternalServerErrorException
*/ */
public function createFromApplicationId(int $id) public function createFromApplicationId(int $id): \Friendica\Object\Api\Mastodon\Application
{ {
$application = $this->dba->selectFirst('application', ['client_id', 'client_secret', 'id', 'name', 'redirect_uri', 'website'], ['id' => $id]); $application = $this->dba->selectFirst('application', ['client_id', 'client_secret', 'id', 'name', 'redirect_uri', 'website'], ['id' => $id]);
if (!$this->dba->isResult($application)) { if (!$this->dba->isResult($application)) {
return []; throw new InternalServerErrorException(sprintf("ID '%s' not found", $id));
} }
return new \Friendica\Object\Api\Mastodon\Application( return new \Friendica\Object\Api\Mastodon\Application(

View file

@ -46,13 +46,11 @@ class Attachment extends BaseFactory
* @param int $uriId Uri-ID of the attachments * @param int $uriId Uri-ID of the attachments
* @return array * @return array
* @throws HTTPException\InternalServerErrorException * @throws HTTPException\InternalServerErrorException
* @throws \ImagickException
*/ */
public function createFromUriId(int $uriId) public function createFromUriId(int $uriId): array
{ {
$attachments = []; $attachments = [];
foreach (Post\Media::getByURIId($uriId, [Post\Media::AUDIO, Post\Media::VIDEO, Post\Media::IMAGE]) as $attachment) { foreach (Post\Media::getByURIId($uriId, [Post\Media::AUDIO, Post\Media::VIDEO, Post\Media::IMAGE]) as $attachment) {
$filetype = !empty($attachment['mimetype']) ? strtolower(substr($attachment['mimetype'], 0, strpos($attachment['mimetype'], '/'))) : ''; $filetype = !empty($attachment['mimetype']) ? strtolower(substr($attachment['mimetype'], 0, strpos($attachment['mimetype'], '/'))) : '';
if (($filetype == 'audio') || ($attachment['type'] == Post\Media::AUDIO)) { if (($filetype == 'audio') || ($attachment['type'] == Post\Media::AUDIO)) {
@ -91,21 +89,21 @@ class Attachment extends BaseFactory
/** /**
* @param int $id id of the photo * @param int $id id of the photo
*
* @return array * @return array
* @throws HTTPException\InternalServerErrorException * @throws HTTPException\InternalServerErrorException
* @throws \ImagickException
*/ */
public function createFromPhoto(int $id) public function createFromPhoto(int $id): array
{ {
$photo = Photo::selectFirst(['resource-id', 'uid', 'id', 'title', 'type'], ['id' => $id]); $photo = Photo::selectFirst(['resource-id', 'uid', 'id', 'title', 'type'], ['id' => $id]);
if (empty($photo)) { if (empty($photo)) {
return null; return [];
} }
$attachment = ['id' => $photo['id'], 'description' => $photo['title']]; $attachment = ['id' => $photo['id'], 'description' => $photo['title']];
$phototypes = Images::supportedTypes(); $photoTypes = Images::supportedTypes();
$ext = $phototypes[$photo['type']]; $ext = $photoTypes[$photo['type']];
$url = $this->baseUrl . '/photo/' . $photo['resource-id'] . '-0.' . $ext; $url = $this->baseUrl . '/photo/' . $photo['resource-id'] . '-0.' . $ext;

View file

@ -31,11 +31,12 @@ class Card extends BaseFactory
{ {
/** /**
* @param int $uriId Uri-ID of the item * @param int $uriId Uri-ID of the item
*
* @return \Friendica\Object\Api\Mastodon\Card * @return \Friendica\Object\Api\Mastodon\Card
* @throws HTTPException\InternalServerErrorException * @throws HTTPException\InternalServerErrorException
* @throws \ImagickException * @throws \ImagickException*@throws \Exception
*/ */
public function createFromUriId(int $uriId) public function createFromUriId(int $uriId): \Friendica\Object\Api\Mastodon\Card
{ {
$item = Post::selectFirst(['body'], ['uri-id' => $uriId]); $item = Post::selectFirst(['body'], ['uri-id' => $uriId]);
if (!empty($item['body'])) { if (!empty($item['body'])) {

View file

@ -24,6 +24,8 @@ namespace Friendica\Factory\Api\Mastodon;
use Friendica\BaseFactory; use Friendica\BaseFactory;
use Friendica\Database\Database; use Friendica\Database\Database;
use Friendica\Model\Contact; use Friendica\Model\Contact;
use Friendica\Network\HTTPException;
use ImagickException;
use Psr\Log\LoggerInterface; use Psr\Log\LoggerInterface;
class Conversation extends BaseFactory class Conversation extends BaseFactory
@ -43,7 +45,10 @@ class Conversation extends BaseFactory
$this->mstdnAccountFactory = $mstdnAccountFactoryFactory; $this->mstdnAccountFactory = $mstdnAccountFactoryFactory;
} }
public function CreateFromConvId(int $id) /**
* @throws ImagickException|HTTPException\InternalServerErrorException|HTTPException\NotFoundException
*/
public function CreateFromConvId(int $id): \Friendica\Object\Api\Mastodon\Conversation
{ {
$accounts = []; $accounts = [];
$unread = false; $unread = false;

View file

@ -26,7 +26,7 @@ use Friendica\Collection\Api\Mastodon\Emojis;
class Emoji extends BaseFactory class Emoji extends BaseFactory
{ {
public function create(string $shortcode, string $url) public function create(string $shortcode, string $url): \Friendica\Object\Api\Mastodon\Emoji
{ {
return new \Friendica\Object\Api\Mastodon\Emoji($shortcode, $url); return new \Friendica\Object\Api\Mastodon\Emoji($shortcode, $url);
} }
@ -35,7 +35,7 @@ class Emoji extends BaseFactory
* @param array $smilies * @param array $smilies
* @return Emojis * @return Emojis
*/ */
public function createCollectionFromSmilies(array $smilies) public function createCollectionFromSmilies(array $smilies): Emojis
{ {
$prototype = null; $prototype = null;

View file

@ -54,49 +54,49 @@ class Error extends BaseFactory
{ {
$error = $this->l10n->t('Record not found'); $error = $this->l10n->t('Record not found');
$error_description = ''; $error_description = '';
$errorobj = New \Friendica\Object\Api\Mastodon\Error($error, $error_description); $errorObj = new \Friendica\Object\Api\Mastodon\Error($error, $error_description);
$this->logError(404, $error); $this->logError(404, $error);
System::jsonError(404, $errorobj->toArray()); System::jsonError(404, $errorObj->toArray());
} }
public function UnprocessableEntity(string $error = '') public function UnprocessableEntity(string $error = '')
{ {
$error = $error ?: $this->l10n->t('Unprocessable Entity'); $error = $error ?: $this->l10n->t('Unprocessable Entity');
$error_description = ''; $error_description = '';
$errorobj = New \Friendica\Object\Api\Mastodon\Error($error, $error_description); $errorObj = new \Friendica\Object\Api\Mastodon\Error($error, $error_description);
$this->logError(422, $error); $this->logError(422, $error);
System::jsonError(422, $errorobj->toArray()); System::jsonError(422, $errorObj->toArray());
} }
public function Unauthorized(string $error = '') public function Unauthorized(string $error = '')
{ {
$error = $error ?: $this->l10n->t('Unauthorized'); $error = $error ?: $this->l10n->t('Unauthorized');
$error_description = ''; $error_description = '';
$errorobj = New \Friendica\Object\Api\Mastodon\Error($error, $error_description); $errorObj = new \Friendica\Object\Api\Mastodon\Error($error, $error_description);
$this->logError(401, $error); $this->logError(401, $error);
System::jsonError(401, $errorobj->toArray()); System::jsonError(401, $errorObj->toArray());
} }
public function Forbidden(string $error = '') public function Forbidden(string $error = '')
{ {
$error = $error ?: $this->l10n->t('Token is not authorized with a valid user or is missing a required scope'); $error = $error ?: $this->l10n->t('Token is not authorized with a valid user or is missing a required scope');
$error_description = ''; $error_description = '';
$errorobj = New \Friendica\Object\Api\Mastodon\Error($error, $error_description); $errorObj = new \Friendica\Object\Api\Mastodon\Error($error, $error_description);
$this->logError(403, $error); $this->logError(403, $error);
System::jsonError(403, $errorobj->toArray()); System::jsonError(403, $errorObj->toArray());
} }
public function InternalError(string $error = '') public function InternalError(string $error = '')
{ {
$error = $error ?: $this->l10n->t('Internal Server Error'); $error = $error ?: $this->l10n->t('Internal Server Error');
$error_description = ''; $error_description = '';
$errorobj = New \Friendica\Object\Api\Mastodon\Error($error, $error_description); $errorObj = new \Friendica\Object\Api\Mastodon\Error($error, $error_description);
$this->logError(500, $error); $this->logError(500, $error);
System::jsonError(500, $errorobj->toArray()); System::jsonError(500, $errorObj->toArray());
} }
} }

View file

@ -35,7 +35,7 @@ class Field extends BaseFactory
* @return \Friendica\Object\Api\Mastodon\Field * @return \Friendica\Object\Api\Mastodon\Field
* @throws HTTPException\InternalServerErrorException * @throws HTTPException\InternalServerErrorException
*/ */
public function createFromProfileField(ProfileField $profileField) public function createFromProfileField(ProfileField $profileField): \Friendica\Object\Api\Mastodon\Field
{ {
return new \Friendica\Object\Api\Mastodon\Field($profileField->label, BBCode::convert($profileField->value, false, BBCode::ACTIVITYPUB)); return new \Friendica\Object\Api\Mastodon\Field($profileField->label, BBCode::convert($profileField->value, false, BBCode::ACTIVITYPUB));
} }
@ -45,7 +45,7 @@ class Field extends BaseFactory
* @return Fields * @return Fields
* @throws HTTPException\InternalServerErrorException * @throws HTTPException\InternalServerErrorException
*/ */
public function createFromProfileFields(ProfileFields $profileFields) public function createFromProfileFields(ProfileFields $profileFields): Fields
{ {
$fields = []; $fields = [];

View file

@ -27,6 +27,7 @@ use Friendica\Model\APContact;
use Friendica\Model\Contact; use Friendica\Model\Contact;
use Friendica\Model\Introduction; use Friendica\Model\Introduction;
use Friendica\Network\HTTPException; use Friendica\Network\HTTPException;
use ImagickException;
use Psr\Log\LoggerInterface; use Psr\Log\LoggerInterface;
class FollowRequest extends BaseFactory class FollowRequest extends BaseFactory
@ -44,10 +45,9 @@ class FollowRequest extends BaseFactory
/** /**
* @param Introduction $introduction * @param Introduction $introduction
* @return \Friendica\Object\Api\Mastodon\FollowRequest * @return \Friendica\Object\Api\Mastodon\FollowRequest
* @throws HTTPException\InternalServerErrorException * @throws ImagickException|HTTPException\InternalServerErrorException
* @throws \ImagickException
*/ */
public function createFromIntroduction(Introduction $introduction) public function createFromIntroduction(Introduction $introduction): \Friendica\Object\Api\Mastodon\FollowRequest
{ {
$cdata = Contact::getPublicAndUserContacID($introduction->{'contact-id'}, $introduction->uid); $cdata = Contact::getPublicAndUserContacID($introduction->{'contact-id'}, $introduction->uid);
@ -59,8 +59,8 @@ class FollowRequest extends BaseFactory
$publicContact = Contact::getById($cdata['public']); $publicContact = Contact::getById($cdata['public']);
$userContact = Contact::getById($cdata['user']); $userContact = Contact::getById($cdata['user']);
$apcontact = APContact::getByURL($publicContact['url'], false); $apContact = APContact::getByURL($publicContact['url'], false);
return new \Friendica\Object\Api\Mastodon\FollowRequest($this->baseUrl, $introduction->id, $publicContact, $apcontact, $userContact); return new \Friendica\Object\Api\Mastodon\FollowRequest($this->baseUrl, $introduction->id, $publicContact, $apContact, $userContact);
} }
} }

View file

@ -23,6 +23,7 @@ namespace Friendica\Factory\Api\Mastodon;
use Friendica\BaseFactory; use Friendica\BaseFactory;
use Friendica\Database\Database; use Friendica\Database\Database;
use Friendica\Network\HTTPException\InternalServerErrorException;
use Psr\Log\LoggerInterface; use Psr\Log\LoggerInterface;
class ListEntity extends BaseFactory class ListEntity extends BaseFactory
@ -36,7 +37,10 @@ class ListEntity extends BaseFactory
$this->dba = $dba; $this->dba = $dba;
} }
public function createFromGroupId(int $id) /**
* @throws InternalServerErrorException
*/
public function createFromGroupId(int $id): \Friendica\Object\Api\Mastodon\ListEntity
{ {
$group = $this->dba->selectFirst('group', ['name'], ['id' => $id, 'deleted' => false]); $group = $this->dba->selectFirst('group', ['name'], ['id' => $id, 'deleted' => false]);
return new \Friendica\Object\Api\Mastodon\ListEntity($id, $group['name'] ?? '', 'list'); return new \Friendica\Object\Api\Mastodon\ListEntity($id, $group['name'] ?? '', 'list');

View file

@ -45,15 +45,14 @@ class Mention extends BaseFactory
* @param int $uriId Uri-ID of the item * @param int $uriId Uri-ID of the item
* @return Mentions * @return Mentions
* @throws HTTPException\InternalServerErrorException * @throws HTTPException\InternalServerErrorException
* @throws \ImagickException
*/ */
public function createFromUriId(int $uriId) public function createFromUriId(int $uriId): Mentions
{ {
$mentions = new Mentions(); $mentions = new Mentions();
$tags = Tag::getByURIId($uriId, [Tag::MENTION, Tag::EXCLUSIVE_MENTION, Tag::IMPLICIT_MENTION]); $tags = Tag::getByURIId($uriId, [Tag::MENTION, Tag::EXCLUSIVE_MENTION, Tag::IMPLICIT_MENTION]);
foreach ($tags as $tag) { foreach ($tags as $tag) {
$contact = Contact::getByURL($tag['url'], false); $contact = Contact::getByURL($tag['url'], false);
$mentions->append(new \Friendica\Object\Api\Mastodon\Mention($this->baseUrl, $tag, $contact)); $mentions[] = new \Friendica\Object\Api\Mastodon\Mention($this->baseUrl, $tag, $contact);
} }
return $mentions; return $mentions;
} }

View file

@ -21,6 +21,7 @@
namespace Friendica\Factory\Api\Mastodon; namespace Friendica\Factory\Api\Mastodon;
use Exception;
use Friendica\Object\Api\Mastodon\Relationship as RelationshipEntity; use Friendica\Object\Api\Mastodon\Relationship as RelationshipEntity;
use Friendica\BaseFactory; use Friendica\BaseFactory;
use Friendica\Model\Contact; use Friendica\Model\Contact;
@ -31,9 +32,9 @@ class Relationship extends BaseFactory
* @param int $contactId Contact ID (public or user contact) * @param int $contactId Contact ID (public or user contact)
* @param int $uid User ID * @param int $uid User ID
* @return RelationshipEntity * @return RelationshipEntity
* @throws \Exception * @throws Exception
*/ */
public function createFromContactId(int $contactId, int $uid) public function createFromContactId(int $contactId, int $uid): RelationshipEntity
{ {
$cdata = Contact::getPublicAndUserContacID($contactId, $uid); $cdata = Contact::getPublicAndUserContacID($contactId, $uid);
if (!empty($cdata)) { if (!empty($cdata)) {

View file

@ -73,7 +73,7 @@ class Status extends BaseFactory
* @throws HTTPException\InternalServerErrorException * @throws HTTPException\InternalServerErrorException
* @throws ImagickException|HTTPException\NotFoundException * @throws ImagickException|HTTPException\NotFoundException
*/ */
public function createFromUriId(int $uriId, $uid = 0) public function createFromUriId(int $uriId, $uid = 0): \Friendica\Object\Api\Mastodon\Status
{ {
$fields = ['uri-id', 'uid', 'author-id', 'author-link', 'starred', 'app', 'title', 'body', 'raw-body', 'created', 'network', $fields = ['uri-id', 'uid', 'author-id', 'author-link', 'starred', 'app', 'title', 'body', 'raw-body', 'created', 'network',
'thr-parent-id', 'parent-author-id', 'language', 'uri', 'plink', 'private', 'vid', 'gravity']; 'thr-parent-id', 'parent-author-id', 'language', 'uri', 'plink', 'private', 'vid', 'gravity'];
@ -163,9 +163,9 @@ class Status extends BaseFactory
* *
* @return \Friendica\Object\Api\Mastodon\Status * @return \Friendica\Object\Api\Mastodon\Status
* @throws HTTPException\InternalServerErrorException * @throws HTTPException\InternalServerErrorException
* @throws ImagickException * @throws ImagickException|HTTPException\NotFoundException
*/ */
public function createFromMailId(int $id) public function createFromMailId(int $id): \Friendica\Object\Api\Mastodon\Status
{ {
$item = ActivityPub\Transmitter::ItemArrayFromMail($id, true); $item = ActivityPub\Transmitter::ItemArrayFromMail($id, true);
if (empty($item)) { if (empty($item)) {

View file

@ -43,9 +43,8 @@ class Tag extends BaseFactory
* @param int $uriId Uri-ID of the item * @param int $uriId Uri-ID of the item
* @return array * @return array
* @throws HTTPException\InternalServerErrorException * @throws HTTPException\InternalServerErrorException
* @throws \ImagickException
*/ */
public function createFromUriId(int $uriId) public function createFromUriId(int $uriId): array
{ {
$hashtags = []; $hashtags = [];
$tags = TagModel::getByURIId($uriId, [TagModel::HASHTAG]); $tags = TagModel::getByURIId($uriId, [TagModel::HASHTAG]);

View file

@ -40,7 +40,6 @@ class Error extends BaseDataTransferObject
* *
* @param string $error * @param string $error
* @param string error_description * @param string error_description
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
*/ */
public function __construct(string $error, string $error_description) public function __construct(string $error, string $error_description)
{ {

View file

@ -21,7 +21,9 @@
namespace Friendica\Object\Api\Mastodon; namespace Friendica\Object\Api\Mastodon;
use Exception;
use Friendica\BaseDataTransferObject; use Friendica\BaseDataTransferObject;
use Friendica\Network\HTTPException;
use Friendica\Util\DateTimeFormat; use Friendica\Util\DateTimeFormat;
/** /**
@ -45,8 +47,7 @@ class Notification extends BaseDataTransferObject
/** /**
* Creates a notification record * Creates a notification record
* *
* @param array $item * @throws HttpException\InternalServerErrorException|Exception
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
*/ */
public function __construct(int $id, string $type, string $created_at, Account $account = null, Status $status = null) public function __construct(int $id, string $type, string $created_at, Account $account = null, Status $status = null)
{ {