mirror of
https://git.sekbaer.de/Friendica/friendica.git
synced 2025-06-12 01:54:26 +02:00
Added last status
This commit is contained in:
parent
2c7c63a493
commit
ab28fa32aa
4 changed files with 49 additions and 39 deletions
|
@ -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;
|
||||
|
|
|
@ -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 = [];
|
||||
}
|
||||
|
|
|
@ -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);
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue