Fix: The calculation of unseen circles can now be deactivated again
This commit is contained in:
parent
eb50618fe8
commit
174fa49b23
6 changed files with 21 additions and 10 deletions
|
@ -1,6 +1,6 @@
|
||||||
-- ------------------------------------------
|
-- ------------------------------------------
|
||||||
-- Friendica 2023.09-dev (Giant Rhubarb)
|
-- Friendica 2023.09-rc (Giant Rhubarb)
|
||||||
-- DB_UPDATE_VERSION 1534
|
-- DB_UPDATE_VERSION 1535
|
||||||
-- ------------------------------------------
|
-- ------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -169,16 +169,17 @@ class Circle
|
||||||
*
|
*
|
||||||
* Count unread items of each circle of the local user
|
* Count unread items of each circle of the local user
|
||||||
*
|
*
|
||||||
|
* @param int $uid
|
||||||
* @return array
|
* @return array
|
||||||
* 'id' => circle id
|
* 'id' => circle id
|
||||||
* 'name' => circle name
|
* 'name' => circle name
|
||||||
* 'count' => counted unseen circle items
|
* 'count' => counted unseen circle items
|
||||||
* @throws \Exception
|
* @throws \Exception
|
||||||
*/
|
*/
|
||||||
public static function countUnseen()
|
public static function countUnseen(int $uid)
|
||||||
{
|
{
|
||||||
$stmt = DBA::p("SELECT `circle`.`id`, `circle`.`name`,
|
$stmt = DBA::p("SELECT `circle`.`id`, `circle`.`name`,
|
||||||
(SELECT COUNT(*) FROM `post-user-view`
|
(SELECT COUNT(*) FROM `post-user`
|
||||||
WHERE `uid` = ?
|
WHERE `uid` = ?
|
||||||
AND `unseen`
|
AND `unseen`
|
||||||
AND `contact-id` IN
|
AND `contact-id` IN
|
||||||
|
@ -188,8 +189,8 @@ class Circle
|
||||||
) AS `count`
|
) AS `count`
|
||||||
FROM `group` AS `circle`
|
FROM `group` AS `circle`
|
||||||
WHERE `circle`.`uid` = ?;",
|
WHERE `circle`.`uid` = ?;",
|
||||||
DI::userSession()->getLocalUserId(),
|
$uid,
|
||||||
DI::userSession()->getLocalUserId()
|
$uid
|
||||||
);
|
);
|
||||||
|
|
||||||
return DBA::toArray($stmt);
|
return DBA::toArray($stmt);
|
||||||
|
|
|
@ -504,7 +504,7 @@ class Site extends BaseAdmin
|
||||||
'$max_display_comments' => ['max_display_comments', DI::l10n()->t('Maximum numbers of comments per post on the display page'), DI::config()->get('system', 'max_display_comments'), DI::l10n()->t('How many comments should be shown on the single view for each post? Default value is 1000.')],
|
'$max_display_comments' => ['max_display_comments', DI::l10n()->t('Maximum numbers of comments per post on the display page'), DI::config()->get('system', 'max_display_comments'), DI::l10n()->t('How many comments should be shown on the single view for each post? Default value is 1000.')],
|
||||||
'$temppath' => ['temppath', DI::l10n()->t('Temp path'), DI::config()->get('system', 'temppath'), DI::l10n()->t('If you have a restricted system where the webserver can\'t access the system temp path, enter another path here.')],
|
'$temppath' => ['temppath', DI::l10n()->t('Temp path'), DI::config()->get('system', 'temppath'), DI::l10n()->t('If you have a restricted system where the webserver can\'t access the system temp path, enter another path here.')],
|
||||||
'$only_tag_search' => ['only_tag_search', DI::l10n()->t('Only search in tags'), DI::config()->get('system', 'only_tag_search'), DI::l10n()->t('On large systems the text search can slow down the system extremely.')],
|
'$only_tag_search' => ['only_tag_search', DI::l10n()->t('Only search in tags'), DI::config()->get('system', 'only_tag_search'), DI::l10n()->t('On large systems the text search can slow down the system extremely.')],
|
||||||
'$compute_circle_counts' => ['compute_circle_counts', DI::l10n()->t('Generate counts per contact circle when calculating network count'), DI::config()->get('system', 'compute_group_counts') ?? DI::config()->get('system', 'compute_circle_counts'), DI::l10n()->t('On systems with users that heavily use contact circles the query can be very expensive.')],
|
'$compute_circle_counts' => ['compute_circle_counts', DI::l10n()->t('Generate counts per contact circle when calculating network count'), DI::config()->get('system', 'compute_circle_counts'), DI::l10n()->t('On systems with users that heavily use contact circles the query can be very expensive.')],
|
||||||
|
|
||||||
'$worker_queues' => ['worker_queues', DI::l10n()->t('Maximum number of parallel workers'), DI::config()->get('system', 'worker_queues'), DI::l10n()->t('On shared hosters set this to %d. On larger systems, values of %d are great. Default value is %d.', 5, 20, 10)],
|
'$worker_queues' => ['worker_queues', DI::l10n()->t('Maximum number of parallel workers'), DI::config()->get('system', 'worker_queues'), DI::l10n()->t('On shared hosters set this to %d. On larger systems, values of %d are great. Default value is %d.', 5, 20, 10)],
|
||||||
'$worker_fastlane' => ['worker_fastlane', DI::l10n()->t('Enable fastlane'), DI::config()->get('system', 'worker_fastlane'), DI::l10n()->t('When enabed, the fastlane mechanism starts an additional worker if processes with higher priority are blocked by processes of lower priority.')],
|
'$worker_fastlane' => ['worker_fastlane', DI::l10n()->t('Enable fastlane'), DI::config()->get('system', 'worker_fastlane'), DI::l10n()->t('When enabed, the fastlane mechanism starts an additional worker if processes with higher priority are blocked by processes of lower priority.')],
|
||||||
|
|
|
@ -152,10 +152,10 @@ class Ping extends BaseModule
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$compute_circle_counts = $this->config->get('system','compute_group_counts') ?? $this->config->get('system','compute_circle_counts');
|
$compute_circle_counts = $this->config->get('system','compute_circle_counts');
|
||||||
if ($network_count && $compute_circle_counts) {
|
if ($network_count && $compute_circle_counts) {
|
||||||
// Find out how unseen network posts are spread across circles
|
// Find out how unseen network posts are spread across circles
|
||||||
foreach (Circle::countUnseen() as $circle_count) {
|
foreach (Circle::countUnseen($this->session->getLocalUserId()) as $circle_count) {
|
||||||
if ($circle_count['count'] > 0) {
|
if ($circle_count['count'] > 0) {
|
||||||
$circles_unseen[] = $circle_count;
|
$circles_unseen[] = $circle_count;
|
||||||
}
|
}
|
||||||
|
|
|
@ -56,7 +56,7 @@ use Friendica\Database\DBA;
|
||||||
|
|
||||||
// This file is required several times during the test in DbaDefinition which justifies this condition
|
// This file is required several times during the test in DbaDefinition which justifies this condition
|
||||||
if (!defined('DB_UPDATE_VERSION')) {
|
if (!defined('DB_UPDATE_VERSION')) {
|
||||||
define('DB_UPDATE_VERSION', 1534);
|
define('DB_UPDATE_VERSION', 1535);
|
||||||
}
|
}
|
||||||
|
|
||||||
return [
|
return [
|
||||||
|
|
10
update.php
10
update.php
|
@ -1390,3 +1390,13 @@ function update_1531()
|
||||||
|
|
||||||
return Update::SUCCESS;
|
return Update::SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function update_1535()
|
||||||
|
{
|
||||||
|
if (DI::config()->get('system', 'compute_group_counts')) {
|
||||||
|
DI::config()->set('system', 'compute_circle_counts', true);
|
||||||
|
}
|
||||||
|
DI::config()->delete('system', 'compute_group_counts');
|
||||||
|
|
||||||
|
return Update::SUCCESS;
|
||||||
|
}
|
Loading…
Reference in a new issue