Merge pull request #9143 from annando/api-count
API: Counts added, local query improved
This commit is contained in:
commit
d15f522752
6 changed files with 176 additions and 9 deletions
|
@ -23,9 +23,12 @@ namespace Friendica\Factory\Api\Mastodon;
|
||||||
|
|
||||||
use Friendica\App\BaseURL;
|
use Friendica\App\BaseURL;
|
||||||
use Friendica\BaseFactory;
|
use Friendica\BaseFactory;
|
||||||
|
use Friendica\Database\DBA;
|
||||||
use Friendica\DI;
|
use Friendica\DI;
|
||||||
use Friendica\Model\Item;
|
use Friendica\Model\Item;
|
||||||
|
use Friendica\Model\Verb;
|
||||||
use Friendica\Network\HTTPException;
|
use Friendica\Network\HTTPException;
|
||||||
|
use Friendica\Protocol\Activity;
|
||||||
use Friendica\Repository\ProfileField;
|
use Friendica\Repository\ProfileField;
|
||||||
use Psr\Log\LoggerInterface;
|
use Psr\Log\LoggerInterface;
|
||||||
|
|
||||||
|
@ -59,6 +62,12 @@ class Status extends BaseFactory
|
||||||
$item = Item::selectFirst([], ['uri-id' => $uriId, 'uid' => $uid]);
|
$item = Item::selectFirst([], ['uri-id' => $uriId, 'uid' => $uid]);
|
||||||
$account = DI::mstdnAccount()->createFromContactId($item['author-id']);
|
$account = DI::mstdnAccount()->createFromContactId($item['author-id']);
|
||||||
|
|
||||||
return new \Friendica\Object\Api\Mastodon\Status($item, $account);
|
$counts = new \Friendica\Object\Api\Mastodon\Status\Counts(
|
||||||
|
DBA::count('item', ['thr-parent-id' => $uriId, 'uid' => $uid, 'gravity' => GRAVITY_COMMENT]),
|
||||||
|
DBA::count('item', ['thr-parent-id' => $uriId, 'uid' => $uid, 'gravity' => GRAVITY_ACTIVITY, 'vid' => Verb::getID(Activity::ANNOUNCE)]),
|
||||||
|
DBA::count('item', ['thr-parent-id' => $uriId, 'uid' => $uid, 'gravity' => GRAVITY_ACTIVITY, 'vid' => Verb::getID(Activity::LIKE)])
|
||||||
|
);
|
||||||
|
|
||||||
|
return new \Friendica\Object\Api\Mastodon\Status($item, $account, $counts);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -57,11 +57,11 @@ class PublicTimeline extends BaseApi
|
||||||
|
|
||||||
$params = ['order' => ['uri-id' => true], 'limit' => $limit];
|
$params = ['order' => ['uri-id' => true], 'limit' => $limit];
|
||||||
|
|
||||||
$condition = ['gravity' => [GRAVITY_PARENT, GRAVITY_COMMENT], 'private' => Item::PUBLIC, 'network' => Protocol::FEDERATED];
|
$condition = ['gravity' => [GRAVITY_PARENT, GRAVITY_COMMENT], 'private' => Item::PUBLIC,
|
||||||
|
'uid' => 0, 'network' => Protocol::FEDERATED];
|
||||||
|
|
||||||
if ($local) {
|
if ($local) {
|
||||||
$condition['origin'] = true;
|
$condition = DBA::mergeConditions($condition, ["`uri-id` IN (SELECT `uri-id` FROM `item` WHERE `origin`)"]);
|
||||||
} else {
|
|
||||||
$condition['uid'] = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($remote) {
|
if ($remote) {
|
||||||
|
|
55
src/Object/Api/Mastodon/Activity.php
Normal file
55
src/Object/Api/Mastodon/Activity.php
Normal file
|
@ -0,0 +1,55 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* @copyright Copyright (C) 2020, Friendica
|
||||||
|
*
|
||||||
|
* @license GNU AGPL version 3 or any later version
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as
|
||||||
|
* published by the Free Software Foundation, either version 3 of the
|
||||||
|
* License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Affero General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Affero General Public License
|
||||||
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Friendica\Object\Api\Mastodon;
|
||||||
|
|
||||||
|
use Friendica\BaseEntity;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class Activity
|
||||||
|
*
|
||||||
|
* @see https://docs.joinmastodon.org/entities/activity
|
||||||
|
*/
|
||||||
|
class Activity extends BaseEntity
|
||||||
|
{
|
||||||
|
/** @var string (UNIX Timestamp) */
|
||||||
|
protected $week;
|
||||||
|
/** @var string */
|
||||||
|
protected $statuses;
|
||||||
|
/** @var string */
|
||||||
|
protected $logins;
|
||||||
|
/** @var string */
|
||||||
|
protected $registrations;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an activity
|
||||||
|
*
|
||||||
|
* @param array $item
|
||||||
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
|
*/
|
||||||
|
public function __construct(int $week, int $statuses, int $logins, int $registrations)
|
||||||
|
{
|
||||||
|
$this->week = (string)$week;
|
||||||
|
$this->statuses = (string)$statuses;
|
||||||
|
$this->logins = (string)$logins;
|
||||||
|
$this->registrations = (string)$registrations;
|
||||||
|
}
|
||||||
|
}
|
46
src/Object/Api/Mastodon/Application.php
Normal file
46
src/Object/Api/Mastodon/Application.php
Normal file
|
@ -0,0 +1,46 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* @copyright Copyright (C) 2020, Friendica
|
||||||
|
*
|
||||||
|
* @license GNU AGPL version 3 or any later version
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as
|
||||||
|
* published by the Free Software Foundation, either version 3 of the
|
||||||
|
* License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Affero General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Affero General Public License
|
||||||
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Friendica\Object\Api\Mastodon;
|
||||||
|
|
||||||
|
use Friendica\BaseEntity;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class Application
|
||||||
|
*
|
||||||
|
* @see https://docs.joinmastodon.org/entities/application
|
||||||
|
*/
|
||||||
|
class Application extends BaseEntity
|
||||||
|
{
|
||||||
|
/** @var string */
|
||||||
|
protected $name;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an application entry
|
||||||
|
*
|
||||||
|
* @param array $item
|
||||||
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
|
*/
|
||||||
|
public function __construct(string $name)
|
||||||
|
{
|
||||||
|
$this->name = $name;
|
||||||
|
}
|
||||||
|
}
|
|
@ -23,6 +23,7 @@ namespace Friendica\Object\Api\Mastodon;
|
||||||
|
|
||||||
use Friendica\BaseEntity;
|
use Friendica\BaseEntity;
|
||||||
use Friendica\Content\Text\BBCode;
|
use Friendica\Content\Text\BBCode;
|
||||||
|
use Friendica\Object\Api\Mastodon\Status\Counts;
|
||||||
use Friendica\Util\DateTimeFormat;
|
use Friendica\Util\DateTimeFormat;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -95,7 +96,7 @@ class Status extends BaseEntity
|
||||||
* @param array $item
|
* @param array $item
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
public function __construct(array $item, Account $account)
|
public function __construct(array $item, Account $account, Counts $counts)
|
||||||
{
|
{
|
||||||
$this->id = (string)$item['uri-id'];
|
$this->id = (string)$item['uri-id'];
|
||||||
$this->created_at = DateTimeFormat::utc($item['created'], DateTimeFormat::ATOM);
|
$this->created_at = DateTimeFormat::utc($item['created'], DateTimeFormat::ATOM);
|
||||||
|
@ -114,9 +115,9 @@ class Status extends BaseEntity
|
||||||
$this->language = null;
|
$this->language = null;
|
||||||
$this->uri = $item['uri'];
|
$this->uri = $item['uri'];
|
||||||
$this->url = $item['plink'] ?? null;
|
$this->url = $item['plink'] ?? null;
|
||||||
$this->replies_count = 0;
|
$this->replies_count = $counts->replies;
|
||||||
$this->reblogs_count = 0;
|
$this->reblogs_count = $counts->reblogs;
|
||||||
$this->favourites_count = 0;
|
$this->favourites_count = $counts->favourites;
|
||||||
$this->favourited = false;
|
$this->favourited = false;
|
||||||
$this->reblogged = false;
|
$this->reblogged = false;
|
||||||
$this->muted = false;
|
$this->muted = false;
|
||||||
|
|
56
src/Object/Api/Mastodon/Status/Counts.php
Normal file
56
src/Object/Api/Mastodon/Status/Counts.php
Normal file
|
@ -0,0 +1,56 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* @copyright Copyright (C) 2020, Friendica
|
||||||
|
*
|
||||||
|
* @license GNU AGPL version 3 or any later version
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as
|
||||||
|
* published by the Free Software Foundation, either version 3 of the
|
||||||
|
* License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Affero General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Affero General Public License
|
||||||
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Friendica\Object\Api\Mastodon\Status;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class Counts
|
||||||
|
*
|
||||||
|
* @see https://docs.joinmastodon.org/entities/status
|
||||||
|
*/
|
||||||
|
class Counts
|
||||||
|
{
|
||||||
|
/** @var int */
|
||||||
|
protected $replies;
|
||||||
|
/** @var int */
|
||||||
|
protected $reblogs;
|
||||||
|
/** @var int */
|
||||||
|
protected $favourites;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a status count object
|
||||||
|
*
|
||||||
|
* @param int $replies
|
||||||
|
* @param int $reblogs
|
||||||
|
* @param int $favourites
|
||||||
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
|
*/
|
||||||
|
public function __construct(int $replies, int $reblogs, int $favourites)
|
||||||
|
{
|
||||||
|
$this->replies = $replies;
|
||||||
|
$this->reblogs = $reblogs;
|
||||||
|
$this->favourites = $favourites;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function __get($name) {
|
||||||
|
return $this->$name;
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue