3 * @copyright Copyright (C) 2010-2021, the Friendica project
5 * @license GNU AGPL version 3 or any later version
7 * This program is free software: you can redistribute it and/or modify
8 * it under the terms of the GNU Affero General Public License as
9 * published by the Free Software Foundation, either version 3 of the
10 * License, or (at your option) any later version.
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU Affero General Public License for more details.
17 * You should have received a copy of the GNU Affero General Public License
18 * along with this program. If not, see <https://www.gnu.org/licenses/>.
22 namespace Friendica\Factory\Api\Mastodon;
24 use Friendica\App\BaseURL;
25 use Friendica\BaseFactory;
26 use Friendica\Content\ContactSelector;
27 use Friendica\Content\Text\BBCode;
28 use Friendica\Database\DBA;
30 use Friendica\Model\Item;
31 use Friendica\Model\Post;
32 use Friendica\Model\Verb;
33 use Friendica\Network\HTTPException;
34 use Friendica\Protocol\Activity;
35 use Friendica\Repository\ProfileField;
36 use Psr\Log\LoggerInterface;
38 class Status extends BaseFactory
42 /** @var ProfileField */
43 protected $profileField;
45 protected $mstdnField;
47 public function __construct(LoggerInterface $logger, BaseURL $baseURL, ProfileField $profileField, Field $mstdnField)
49 parent::__construct($logger);
51 $this->baseUrl = $baseURL;
52 $this->profileField = $profileField;
53 $this->mstdnField = $mstdnField;
57 * @param int $uriId Uri-ID of the item
58 * @param int $uid Item user
59 * @return \Friendica\Object\Api\Mastodon\Status
60 * @throws HTTPException\InternalServerErrorException
61 * @throws \ImagickException
63 public function createFromUriId(int $uriId, $uid = 0)
65 $fields = ['uri-id', 'uid', 'author-id', 'author-link', 'starred', 'app', 'title', 'body', 'raw-body', 'created', 'network',
66 'thr-parent-id', 'parent-author-id', 'language', 'uri', 'plink', 'private', 'vid', 'gravity'];
67 $item = Post::selectFirst($fields, ['uri-id' => $uriId, 'uid' => [0, $uid]], ['order' => ['uid' => true]]);
69 throw new HTTPException\NotFoundException('Item with URI ID ' . $uriId . 'not found' . ($uid ? ' for user ' . $uid : '.'));
72 $account = DI::mstdnAccount()->createFromContactId($item['author-id']);
74 $counts = new \Friendica\Object\Api\Mastodon\Status\Counts(
75 Post::count(['thr-parent-id' => $uriId, 'gravity' => GRAVITY_COMMENT, 'deleted' => false], [], false),
76 Post::count(['thr-parent-id' => $uriId, 'gravity' => GRAVITY_ACTIVITY, 'vid' => Verb::getID(Activity::ANNOUNCE), 'deleted' => false], [], false),
77 Post::count(['thr-parent-id' => $uriId, 'gravity' => GRAVITY_ACTIVITY, 'vid' => Verb::getID(Activity::LIKE), 'deleted' => false], [], false)
80 $userAttributes = new \Friendica\Object\Api\Mastodon\Status\UserAttributes(
81 Post::exists(['thr-parent-id' => $uriId, 'uid' => $uid, 'origin' => true, 'gravity' => GRAVITY_ACTIVITY, 'vid' => Verb::getID(Activity::LIKE), 'deleted' => false]),
82 Post::exists(['thr-parent-id' => $uriId, 'uid' => $uid, 'origin' => true, 'gravity' => GRAVITY_ACTIVITY, 'vid' => Verb::getID(Activity::ANNOUNCE), 'deleted' => false]),
83 Post\ThreadUser::getIgnored($uriId, $uid),
84 (bool)$item['starred'],
85 Post\ThreadUser::getPinned($uriId, $uid)
88 $sensitive = DBA::exists('tag-view', ['uri-id' => $uriId, 'name' => 'nsfw']);
89 $application = new \Friendica\Object\Api\Mastodon\Application($item['app'] ?: ContactSelector::networkToName($item['network'], $item['author-link']));
91 $mentions = DI::mstdnMention()->createFromUriId($uriId);
92 $tags = DI::mstdnTag()->createFromUriId($uriId);
93 $card = DI::mstdnCard()->createFromUriId($uriId);
94 $attachments = DI::mstdnAttachment()->createFromUriId($uriId);
96 $shared = BBCode::fetchShareAttributes($item['body']);
97 if (!empty($shared['guid'])) {
98 $shared_item = Post::selectFirst(['uri-id', 'plink'], ['guid' => $shared['guid']]);
100 $shared_uri_id = $shared_item['uri-id'] ?? 0;
102 $mentions = array_merge($mentions, DI::mstdnMention()->createFromUriId($shared_uri_id));
103 $tags = array_merge($tags, DI::mstdnTag()->createFromUriId($shared_uri_id));
104 $attachments = array_merge($attachments, DI::mstdnAttachment()->createFromUriId($shared_uri_id));
106 if (empty($card->toArray())) {
107 $card = DI::mstdnCard()->createFromUriId($shared_uri_id);
112 if ($item['vid'] == Verb::getID(Activity::ANNOUNCE)) {
113 $reshare = $this->createFromUriId($item['thr-parent-id'], $uid)->toArray();
114 $reshared_item = Post::selectFirst(['title', 'body'], ['uri-id' => $item['thr-parent-id'], 'uid' => [0, $uid]]);
115 $item['title'] = $reshared_item['title'] ?? $item['title'];
116 $item['body'] = $reshared_item['body'] ?? $item['body'];
121 return new \Friendica\Object\Api\Mastodon\Status($item, $account, $counts, $userAttributes, $sensitive, $application, $mentions, $tags, $card, $attachments, $reshare);
125 * @param int $uriId id of the mail
126 * @param int $uid mail user
127 * @return \Friendica\Object\Api\Mastodon\Status
128 * @throws HTTPException\InternalServerErrorException
129 * @throws \ImagickException
131 public function createFromMailId(int $id, $uid = 0)
133 $mail = DBA::selectFirst('mail', [], ['id' => $id, 'uid' => $uid]);
135 DI::mstdnError()->RecordNotFound();
138 $conv = DBA::selectFirst('conv', ['subject'], ['id' => $mail['convid'], 'uid' => $uid]);
140 DI::mstdnError()->RecordNotFound();
143 $account = DI::mstdnAccount()->createFromContactId($mail['contact-id']);
145 $counts = new \Friendica\Object\Api\Mastodon\Status\Counts(0, 0, 0);
147 $userAttributes = new \Friendica\Object\Api\Mastodon\Status\UserAttributes(false, false, false, false, false);
150 $application = new \Friendica\Object\Api\Mastodon\Application('');
153 $card = new \Friendica\Object\Api\Mastodon\Card([]);
158 'uri-id' => $mail['id'],
159 'created' => $mail['created'],
160 'thr-parent-id' => 0,
161 'parent-author-id' => 0,
162 'title' => $conv['subject'],
163 'private' => Item::PRIVATE,
165 'uri' => $mail['uri'],
167 'body' => BBCode::convert($mail['body'], false, BBCode::API)
170 return new \Friendica\Object\Api\Mastodon\Status($item, $account, $counts, $userAttributes, $sensitive, $application, $mentions, $tags, $card, $attachments, $reshare);