Simplify query merge, changed update behaviour
This commit is contained in:
parent
e9e5bb12b9
commit
9d6166d7d6
5 changed files with 62 additions and 71 deletions
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue