Added last status

This commit is contained in:
Michael 2021-11-24 20:47:37 +00:00
parent 2c7c63a493
commit ab28fa32aa
4 changed files with 49 additions and 39 deletions

View file

@ -67,7 +67,7 @@ class Activities extends BaseFactory
while ($parent_item = Post::fetch($ret)) {
// get user data and add it to the array of the activity
$user = $this->twitterUser->createFromContactId($parent_item['author-id'], $uid)->toArray();
$user = $this->twitterUser->createFromContactId($parent_item['author-id'], $uid, true)->toArray();
switch ($parent_item['verb']) {
case Activity::LIKE:
$activities['like'][] = $user;

View file

@ -114,8 +114,8 @@ class Status extends BaseFactory
*/
private function createFromArray(array $item, $include_entities): \Friendica\Object\Api\Twitter\Status
{
$author = $this->twitterUser->createFromContactId($item['author-id'], $item['uid']);
$owner = $this->twitterUser->createFromContactId($item['owner-id'], $item['uid']);
$author = $this->twitterUser->createFromContactId($item['author-id'], $item['uid'], true);
$owner = $this->twitterUser->createFromContactId($item['owner-id'], $item['uid'], true);
$friendica_comments = Post::countPosts(['thr-parent-id' => $item['uri-id'], 'deleted' => false, 'gravity' => GRAVITY_COMMENT]);
@ -169,7 +169,7 @@ class Status extends BaseFactory
$retweeted_item = Post::selectFirst(['title', 'body', 'author-id'], ['uri-id' => $item['thr-parent-id'],'uid' => [0, $item['uid']]]);
$item['title'] = $retweeted_item['title'] ?? $item['title'];
$item['body'] = $retweeted_item['body'] ?? $item['body'];
$author = $this->twitterUser->createFromContactId($retweeted_item['author-id'], $item['uid']);
$author = $this->twitterUser->createFromContactId($retweeted_item['author-id'], $item['uid'], true);
} else {
$retweeted = [];
}

View file

@ -25,9 +25,23 @@ use Friendica\BaseFactory;
use Friendica\Model\APContact;
use Friendica\Model\Contact;
use Friendica\Network\HTTPException;
use Friendica\Factory\Api\Twitter\Status;
use Friendica\Model\Item;
use Friendica\Model\Post;
use Psr\Log\LoggerInterface;
class User extends BaseFactory
{
/** @var Status entity */
private $status;
public function __construct(LoggerInterface $logger, Status $status)
{
parent::__construct($logger);
$this->status = $status;
}
/**
* @param int $contactId
* @param int $uid Public contact (=0) or owner user id
@ -37,7 +51,7 @@ class User extends BaseFactory
* @throws HTTPException\InternalServerErrorException
* @throws \ImagickException
*/
public function createFromContactId(int $contactId, $uid = 0, $skip_status = false, $include_user_entities = true)
public function createFromContactId(int $contactId, $uid = 0, $skip_status = true, $include_user_entities = true)
{
$cdata = Contact::getPublicAndUserContactID($contactId, $uid);
if (!empty($cdata)) {
@ -50,12 +64,21 @@ class User extends BaseFactory
$apcontact = APContact::getByURL($publicContact['url'], false);
$status = null; // @todo fetch last status
$status = null;
if (!$skip_status) {
$post = Post::selectFirstPost(['uri-id'],
['author-id' => $publicContact['id'], 'gravity' => [GRAVITY_COMMENT, GRAVITY_PARENT], 'private' => [Item::PUBLIC, Item::UNLISTED]],
['order' => ['uri-id' => true]]);
if (!empty($post['uri-id'])) {
$status = $this->status->createFromUriId($post['uri-id'], $uid)->toArray();
}
}
return new \Friendica\Object\Api\Twitter\User($publicContact, $apcontact, $userContact, $status, $include_user_entities);
}
public function createFromUserId(int $uid, $skip_status = false, $include_user_entities = true)
public function createFromUserId(int $uid, $skip_status = true, $include_user_entities = true)
{
return $this->createFromContactId(Contact::getPublicIdByUserId($uid), $uid, $skip_status, $include_user_entities);
}