Simplify query merge, changed update behaviour

This commit is contained in:
Michael 2023-09-09 12:00:22 +00:00
parent e9e5bb12b9
commit 9d6166d7d6
5 changed files with 62 additions and 71 deletions

View file

@ -38,7 +38,6 @@ use Friendica\Core\L10n;
use Friendica\Core\PConfig\Capability\IManagePersonalConfigValues; use Friendica\Core\PConfig\Capability\IManagePersonalConfigValues;
use Friendica\Core\Renderer; use Friendica\Core\Renderer;
use Friendica\Core\Session\Capability\IHandleUserSessions; use Friendica\Core\Session\Capability\IHandleUserSessions;
use Friendica\Model\Post;
use Friendica\Module\Security\Login; use Friendica\Module\Security\Login;
use Friendica\Network\HTTPException; use Friendica\Network\HTTPException;
use Friendica\Database\Database; use Friendica\Database\Database;
@ -160,13 +159,6 @@ class Channel extends Timeline
throw new HTTPException\BadRequestException($this->l10n->t('Channel not available.')); throw new HTTPException\BadRequestException($this->l10n->t('Channel not available.'));
} }
if (!empty($request['item'])) {
$item = Post::selectFirst(['parent-uri-id'], ['id' => $request['item']]);
self::$item_id = $item['parent-uri-id'] ?? 0;
} else {
self::$item_id = 0;
}
self::$max_id = $request['last_created'] ?? self::$max_id; self::$max_id = $request['last_created'] ?? self::$max_id;
} }
} }

View file

@ -39,7 +39,6 @@ use Friendica\Core\L10n;
use Friendica\Core\PConfig\Capability\IManagePersonalConfigValues; use Friendica\Core\PConfig\Capability\IManagePersonalConfigValues;
use Friendica\Core\Renderer; use Friendica\Core\Renderer;
use Friendica\Core\Session\Capability\IHandleUserSessions; use Friendica\Core\Session\Capability\IHandleUserSessions;
use Friendica\Model\Post;
use Friendica\Network\HTTPException; use Friendica\Network\HTTPException;
use Friendica\Database\Database; use Friendica\Database\Database;
use Friendica\Module\Response; use Friendica\Module\Response;
@ -197,13 +196,6 @@ class Community extends Timeline
} }
} }
if (!empty($request['item'])) {
$item = Post::selectFirst(['parent'], ['id' => $request['item']]);
self::$item_id = $item['parent'] ?? 0;
} else {
self::$item_id = 0;
}
self::$max_id = $request['last_commented'] ?? self::$max_id; self::$max_id = $request['last_commented'] ?? self::$max_id;
} }
} }

View file

@ -418,6 +418,9 @@ class Network extends Timeline
} }
// Currently only the order modes "received" and "commented" are in use // Currently only the order modes "received" and "commented" are in use
if (!empty(self::$item_uri_id)) {
$conditionStrings = DBA::mergeConditions($conditionStrings, ['uri-id' => self::$item_uri_id]);
} else {
if (isset(self::$max_id)) { if (isset(self::$max_id)) {
switch (self::$order) { switch (self::$order) {
case 'received': case 'received':
@ -451,6 +454,7 @@ class Network extends Timeline
break; break;
} }
} }
}
if (isset(self::$min_id) && !isset(self::$max_id)) { if (isset(self::$min_id) && !isset(self::$max_id)) {
// min_id quirk: querying in reverse order with min_id gets the most recent rows, regardless of how close // min_id quirk: querying in reverse order with min_id gets the most recent rows, regardless of how close

View file

@ -36,6 +36,7 @@ use Friendica\Core\Session\Capability\IHandleUserSessions;
use Friendica\Model\Contact; use Friendica\Model\Contact;
use Friendica\Model\User; use Friendica\Model\User;
use Friendica\Database\Database; use Friendica\Database\Database;
use Friendica\Database\DBA;
use Friendica\Model\Item; use Friendica\Model\Item;
use Friendica\Model\Post; use Friendica\Model\Post;
use Friendica\Module\Response; use Friendica\Module\Response;
@ -58,6 +59,8 @@ class Timeline extends BaseModule
/** @var int */ /** @var int */
protected static $item_id; protected static $item_id;
/** @var int */ /** @var int */
protected static $item_uri_id;
/** @var int */
protected static $itemsPerPage; protected static $itemsPerPage;
/** @var bool */ /** @var bool */
protected static $no_sharer; protected static $no_sharer;
@ -95,6 +98,7 @@ class Timeline extends BaseModule
*/ */
protected function parseRequest(array $request) protected function parseRequest(array $request)
{ {
$this->logger->debug('Got request', $request);
self::$selectedTab = $this->parameters['content'] ?? ''; self::$selectedTab = $this->parameters['content'] ?? '';
self::$accountTypeString = $request['accounttype'] ?? $this->parameters['accounttype'] ?? ''; self::$accountTypeString = $request['accounttype'] ?? $this->parameters['accounttype'] ?? '';
@ -116,6 +120,15 @@ class Timeline extends BaseModule
); );
} }
if (!empty($request['item'])) {
$item = Post::selectFirst(['parent', 'parent-uri-id'], ['id' => $request['item']]);
self::$item_id = $item['parent'] ?? 0;
self::$item_uri_id = $item['parent-uri-id'] ?? 0;
} else {
self::$item_id = 0;
self::$item_uri_id = 0;
}
self::$min_id = $request['min_id'] ?? null; self::$min_id = $request['min_id'] ?? null;
self::$max_id = $request['max_id'] ?? null; self::$max_id = $request['max_id'] ?? null;
@ -219,33 +232,27 @@ class Timeline extends BaseModule
$condition = $this->addLanguageCondition($uid, $condition); $condition = $this->addLanguageCondition($uid, $condition);
} }
$condition[0] .= " AND NOT EXISTS(SELECT `cid` FROM `user-contact` WHERE `uid` = ? AND `cid` = `post-engagement`.`owner-id` AND (`ignored` OR `blocked` OR `collapsed`))"; $condition = DBA::mergeConditions($condition, ["NOT EXISTS(SELECT `cid` FROM `user-contact` WHERE `uid` = ? AND `cid` = `post-engagement`.`owner-id` AND (`ignored` OR `blocked` OR `collapsed`))", $uid]);
$condition[] = $uid;
if ((self::$selectedTab != TimelineEntity::WHATSHOT) && !is_null(self::$accountType)) { if ((self::$selectedTab != TimelineEntity::WHATSHOT) && !is_null(self::$accountType)) {
$condition[0] .= " AND `contact-type` = ?"; $condition = DBA::mergeConditions($condition, ['contact-type' => self::$accountType]);
$condition[] = self::$accountType;
} }
$params = ['order' => ['created' => true], 'limit' => self::$itemsPerPage]; $params = ['order' => ['created' => true], 'limit' => self::$itemsPerPage];
if (!empty(self::$item_id)) { if (!empty(self::$item_uri_id)) {
$condition[0] .= " AND `uri-id` = ?"; $condition = DBA::mergeConditions($condition, ['uri-id' => self::$item_uri_id]);
$condition[] = self::$item_id;
} else { } else {
if (self::$no_sharer) { if (self::$no_sharer) {
$condition[0] .= " AND NOT `uri-id` IN (SELECT `uri-id` FROM `post-user` WHERE `post-user`.`uid` = ? AND `post-user`.`uri-id` = `post-engagement`.`uri-id`)"; $condition = DBA::mergeConditions($condition, ["NOT `uri-id` IN (SELECT `uri-id` FROM `post-user` WHERE `post-user`.`uid` = ? AND `post-user`.`uri-id` = `post-engagement`.`uri-id`)", $this->session->getLocalUserId()]);
$condition[] = $uid;
} }
if (isset(self::$max_id)) { if (isset(self::$max_id)) {
$condition[0] .= " AND `created` < ?"; $condition = DBA::mergeConditions($condition, ["`created` < ?", self::$max_id]);
$condition[] = self::$max_id;
} }
if (isset(self::$min_id)) { if (isset(self::$min_id)) {
$condition[0] .= " AND `created` > ?"; $condition = DBA::mergeConditions($condition, ["`created` > ?", self::$min_id]);
$condition[] = self::$min_id;
// Previous page case: we want the items closest to min_id but for that we need to reverse the query order // Previous page case: we want the items closest to min_id but for that we need to reverse the query order
if (!isset(self::$max_id)) { if (!isset(self::$max_id)) {
@ -260,7 +267,7 @@ class Timeline extends BaseModule
} }
// Previous page case: once we get the relevant items closest to min_id, we need to restore the expected display order // Previous page case: once we get the relevant items closest to min_id, we need to restore the expected display order
if (empty(self::$item_id) && isset(self::$min_id) && !isset(self::$max_id)) { if (empty(self::$item_uri_id) && isset(self::$min_id) && !isset(self::$max_id)) {
$items = array_reverse($items); $items = array_reverse($items);
} }
@ -433,23 +440,19 @@ class Timeline extends BaseModule
$params = ['order' => ['commented' => true], 'limit' => self::$itemsPerPage]; $params = ['order' => ['commented' => true], 'limit' => self::$itemsPerPage];
if (!empty(self::$item_id)) { if (!empty(self::$item_uri_id)) {
$condition[0] .= " AND `id` = ?"; $condition = DBA::mergeConditions($condition, ['uri-id' => self::$item_uri_id]);
$condition[] = self::$item_id;
} else { } else {
if ($this->session->getLocalUserId() && self::$no_sharer) { if ($this->session->getLocalUserId() && self::$no_sharer) {
$condition[0] .= " AND NOT `uri-id` IN (SELECT `uri-id` FROM `post-user` WHERE `post-user`.`uid` = ? AND `post-user`.`uri-id` = `post-thread-user-view`.`uri-id`)"; $condition = DBA::mergeConditions($condition, ["NOT `uri-id` IN (SELECT `uri-id` FROM `post-user` WHERE `post-user`.`uid` = ? AND `post-user`.`uri-id` = `post-thread-user-view`.`uri-id`)", $this->session->getLocalUserId()]);
$condition[] = $this->session->getLocalUserId();
} }
if (isset(self::$max_id)) { if (isset(self::$max_id)) {
$condition[0] .= " AND `commented` < ?"; $condition = DBA::mergeConditions($condition, ["`commented` < ?", self::$max_id]);
$condition[] = self::$max_id;
} }
if (isset(self::$min_id)) { if (isset(self::$min_id)) {
$condition[0] .= " AND `commented` > ?"; $condition = DBA::mergeConditions($condition, ["`commented` > ?", self::$min_id]);
$condition[] = self::$min_id;
// Previous page case: we want the items closest to min_id but for that we need to reverse the query order // Previous page case: we want the items closest to min_id but for that we need to reverse the query order
if (!isset(self::$max_id)) { if (!isset(self::$max_id)) {
@ -466,7 +469,7 @@ class Timeline extends BaseModule
} }
// Previous page case: once we get the relevant items closest to min_id, we need to restore the expected display order // Previous page case: once we get the relevant items closest to min_id, we need to restore the expected display order
if (empty(self::$item_id) && isset(self::$min_id) && !isset(self::$max_id)) { if (empty(self::$item_uri_id) && isset(self::$min_id) && !isset(self::$max_id)) {
$items = array_reverse($items); $items = array_reverse($items);
} }

View file

@ -65,8 +65,8 @@ class Network extends NetworkModule
$conditionFields['unseen'] = true; $conditionFields['unseen'] = true;
} }
$params = ['limit' => 100]; $params = ['limit' => self::$itemsPerPage];
$table = 'network-item-view'; $table = 'network-thread-view';
$items = $this->getItems($table, $params, $conditionFields); $items = $this->getItems($table, $params, $conditionFields);