mirror of
https://github.com/friendica/friendica
synced 2025-03-28 14:01:25 +00:00
96 lines
3.5 KiB
PHP
96 lines
3.5 KiB
PHP
<?php
|
|
|
|
// Copyright (C) 2010-2024, the Friendica project
|
|
// SPDX-FileCopyrightText: 2010-2024 the Friendica project
|
|
//
|
|
// SPDX-License-Identifier: AGPL-3.0-or-later
|
|
|
|
namespace Friendica\Module\Api\Twitter\Lists;
|
|
|
|
use Friendica\App\Arguments;
|
|
use Friendica\App\BaseURL;
|
|
use Friendica\AppHelper;
|
|
use Friendica\Core\L10n;
|
|
use Friendica\Database\Database;
|
|
use Friendica\Database\DBA;
|
|
use Friendica\Factory\Api\Twitter\Status as TwitterStatus;
|
|
use Friendica\Model\Contact;
|
|
use Friendica\Model\Item;
|
|
use Friendica\Model\Post;
|
|
use Friendica\Module\Api\ApiResponse;
|
|
use Friendica\Module\BaseApi;
|
|
use Friendica\Network\HTTPException;
|
|
use Friendica\Util\Profiler;
|
|
use Psr\Log\LoggerInterface;
|
|
|
|
/**
|
|
* Returns recent statuses from users in the specified circle.
|
|
*
|
|
* @see https://developer.twitter.com/en/docs/accounts-and-users/create-manage-lists/api-reference/get-lists-ownerships
|
|
*/
|
|
class Statuses extends BaseApi
|
|
{
|
|
/** @var TwitterStatus */
|
|
private $twitterStatus;
|
|
|
|
/** @var Database */
|
|
private $dba;
|
|
|
|
public function __construct(Database $dba, TwitterStatus $twitterStatus, \Friendica\Factory\Api\Mastodon\Error $errorFactory, AppHelper $appHelper, L10n $l10n, BaseURL $baseUrl, Arguments $args, LoggerInterface $logger, Profiler $profiler, ApiResponse $response, array $server, array $parameters = [])
|
|
{
|
|
parent::__construct($errorFactory, $appHelper, $l10n, $baseUrl, $args, $logger, $profiler, $response, $server, $parameters);
|
|
|
|
$this->dba = $dba;
|
|
$this->twitterStatus = $twitterStatus;
|
|
}
|
|
|
|
protected function rawContent(array $request = [])
|
|
{
|
|
$this->checkAllowedScope(BaseApi::SCOPE_READ);
|
|
$uid = BaseApi::getCurrentUserID();
|
|
|
|
if (empty($request['list_id'])) {
|
|
throw new HTTPException\BadRequestException('list_id not specified');
|
|
}
|
|
|
|
// params
|
|
$count = $this->getRequestValue($request, 'count', 20, 1, 100);
|
|
$page = $this->getRequestValue($request, 'page', 1, 1);
|
|
$since_id = $this->getRequestValue($request, 'since_id', 0, 0);
|
|
$max_id = $this->getRequestValue($request, 'max_id', 0, 0);
|
|
$exclude_replies = $this->getRequestValue($request, 'exclude_replies', false);
|
|
$conversation_id = $this->getRequestValue($request, 'conversation_id', 0, 0);
|
|
$include_entities = $this->getRequestValue($request, 'include_entities', false);
|
|
|
|
$start = max(0, ($page - 1) * $count);
|
|
|
|
$members = $this->dba->selectToArray('group_member', ['contact-id'], ['gid' => $request['list_id']]);
|
|
$cids = array_column($members, 'contact-id');
|
|
$condition = ['uid' => $uid, 'gravity' => [Item::GRAVITY_PARENT, Item::GRAVITY_COMMENT], 'contact-id' => $cids];
|
|
$condition = DBA::mergeConditions($condition, ["`uri-id` > ?", $since_id]);
|
|
|
|
if ($max_id > 0) {
|
|
$condition[0] .= " AND `uri-id` <= ?";
|
|
$condition[] = $max_id;
|
|
}
|
|
if ($exclude_replies) {
|
|
$condition[0] .= ' AND `gravity` = ?';
|
|
$condition[] = Item::GRAVITY_PARENT;
|
|
}
|
|
if ($conversation_id > 0) {
|
|
$condition[0] .= " AND `parent-uri-id` = ?";
|
|
$condition[] = $conversation_id;
|
|
}
|
|
|
|
$params = ['order' => ['uri-id' => true], 'limit' => [$start, $count]];
|
|
$statuses = Post::selectForUser($uid, [], $condition, $params);
|
|
|
|
$items = [];
|
|
while ($status = $this->dba->fetch($statuses)) {
|
|
$items[] = $this->twitterStatus->createFromUriId($status['uri-id'], $status['uid'], $include_entities)->toArray();
|
|
}
|
|
$this->dba->close($statuses);
|
|
|
|
$this->response->addFormattedContent('statuses', ['status' => $items], $this->parameters['extension'] ?? null, Contact::getPublicIdByUserId($uid));
|
|
}
|
|
}
|