<?php
/**
- * @copyright Copyright (C) 2010-2021, the Friendica project
+ * @copyright Copyright (C) 2010-2023, the Friendica project
*
* @license GNU AGPL version 3 or any later version
*
use Friendica\Core\Logger;
use Friendica\Database\DBA;
+use Friendica\Model\Item;
use Friendica\Module\BaseApi;
use Friendica\DI;
use Friendica\Model\Contact;
Logger::info(BaseApi::LOG_PREFIX . 'for {self}', ['module' => 'api', 'action' => 'favorites']);
// params
- $since_id = $request['since_id'] ?? 0;
- $max_id = $request['max_id'] ?? 0;
- $count = $request['count'] ?? 20;
- $page = $request['page'] ?? 1;
+ $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);
+ $include_entities = $this->getRequestValue($request, 'include_entities', false);
$start = max(0, ($page - 1) * $count);
- $condition = ["`uid` = ? AND `gravity` IN (?, ?) AND `id` > ? AND `starred`",
- $uid, GRAVITY_PARENT, GRAVITY_COMMENT, $since_id];
+ $condition = ["`uid` = ? AND `gravity` IN (?, ?) AND `uri-id` > ? AND `starred`",
+ $uid, Item::GRAVITY_PARENT, Item::GRAVITY_COMMENT, $since_id];
- $params = ['order' => ['id' => true], 'limit' => [$start, $count]];
+ $params = ['order' => ['uri-id' => true], 'limit' => [$start, $count]];
if ($max_id > 0) {
- $condition[0] .= " AND `id` <= ?";
+ $condition[0] .= " AND `uri-id` <= ?";
$condition[] = $max_id;
}
$statuses = Post::selectForUser($uid, [], $condition, $params);
- $include_entities = strtolower(($request['include_entities'] ?? 'false') == 'true');
-
$ret = [];
while ($status = DBA::fetch($statuses)) {
$ret[] = DI::twitterStatus()->createFromUriId($status['uri-id'], $status['uid'], $include_entities)->toArray();