mirror of
https://github.com/friendica/friendica
synced 2025-01-18 23:04:29 +00:00
Only use posts with wanted languages for subscribed tags
This commit is contained in:
parent
541208a6bd
commit
14266a1ca4
4 changed files with 34 additions and 5 deletions
|
@ -138,7 +138,7 @@ class Item
|
||||||
'allow_cid', 'allow_gid', 'deny_cid', 'deny_gid', 'post-type', 'post-reason',
|
'allow_cid', 'allow_gid', 'deny_cid', 'deny_gid', 'post-type', 'post-reason',
|
||||||
'private', 'pubmail', 'visible', 'starred',
|
'private', 'pubmail', 'visible', 'starred',
|
||||||
'unseen', 'deleted', 'origin', 'mention', 'global', 'network',
|
'unseen', 'deleted', 'origin', 'mention', 'global', 'network',
|
||||||
'title', 'content-warning', 'body', 'location', 'coord', 'app',
|
'title', 'content-warning', 'body', 'language', 'location', 'coord', 'app',
|
||||||
'rendered-hash', 'rendered-html', 'object-type', 'object', 'target-type', 'target',
|
'rendered-hash', 'rendered-html', 'object-type', 'object', 'target-type', 'target',
|
||||||
'author-id', 'author-link', 'author-name', 'author-avatar', 'author-network',
|
'author-id', 'author-link', 'author-name', 'author-avatar', 'author-network',
|
||||||
'owner-id', 'owner-link', 'owner-name', 'owner-avatar', 'causer-id'
|
'owner-id', 'owner-link', 'owner-name', 'owner-avatar', 'causer-id'
|
||||||
|
@ -1541,7 +1541,25 @@ class Item
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$languages = $item['language'] ? array_keys(json_decode($item['language'], true)) : [];
|
||||||
|
|
||||||
foreach (Tag::getUIDListByURIId($item['uri-id']) as $uid => $tags) {
|
foreach (Tag::getUIDListByURIId($item['uri-id']) as $uid => $tags) {
|
||||||
|
if (!empty($languages)) {
|
||||||
|
$keep = false;
|
||||||
|
$user_languages = User::getWantedLanguages($uid);
|
||||||
|
foreach ($user_languages as $language) {
|
||||||
|
if (in_array($language, $languages)) {
|
||||||
|
$keep = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if ($keep) {
|
||||||
|
Logger::debug('Wanted languages found', ['uid' => $uid, 'user-languages' => $user_languages, 'item-languages' => $languages]);
|
||||||
|
} else {
|
||||||
|
Logger::debug('No wanted languages found', ['uid' => $uid, 'user-languages' => $user_languages, 'item-languages' => $languages]);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$stored = self::storeForUserByUriId($item['uri-id'], $uid, ['post-reason' => self::PR_TAG]);
|
$stored = self::storeForUserByUriId($item['uri-id'], $uid, ['post-reason' => self::PR_TAG]);
|
||||||
Logger::info('Stored item for users', ['uri-id' => $item['uri-id'], 'uid' => $uid, 'stored' => $stored]);
|
Logger::info('Stored item for users', ['uri-id' => $item['uri-id'], 'uid' => $uid, 'stored' => $stored]);
|
||||||
foreach ($tags as $tag) {
|
foreach ($tags as $tag) {
|
||||||
|
|
|
@ -575,6 +575,17 @@ class User
|
||||||
return DI::l10n()->toISO6391(DI::config()->get('system', 'language'));
|
return DI::l10n()->toISO6391(DI::config()->get('system', 'language'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fetch the wanted languages for a given user
|
||||||
|
*
|
||||||
|
* @param integer $uid
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public static function getWantedLanguages(int $uid): array
|
||||||
|
{
|
||||||
|
return DI::pConfig()->get($uid, 'channel', 'languages', [User::getLanguageCode($uid)]) ?? [];
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get a list of all languages that are used by the users
|
* Get a list of all languages that are used by the users
|
||||||
*
|
*
|
||||||
|
|
|
@ -426,7 +426,7 @@ class Timeline extends BaseModule
|
||||||
private function addLanguageCondition(int $uid, array $condition): array
|
private function addLanguageCondition(int $uid, array $condition): array
|
||||||
{
|
{
|
||||||
$conditions = [];
|
$conditions = [];
|
||||||
$languages = $this->pConfig->get($uid, 'channel', 'languages', [User::getLanguageCode($uid)]);
|
$languages = User::getWantedLanguages($uid);
|
||||||
foreach ($languages as $language) {
|
foreach ($languages as $language) {
|
||||||
$conditions[] = "JSON_EXTRACT(JSON_KEYS(language), '$[0]') = ?";
|
$conditions[] = "JSON_EXTRACT(JSON_KEYS(language), '$[0]') = ?";
|
||||||
$condition[] = $language;
|
$condition[] = $language;
|
||||||
|
@ -439,7 +439,7 @@ class Timeline extends BaseModule
|
||||||
|
|
||||||
private function getMedianComments(int $uid, int $divider): int
|
private function getMedianComments(int $uid, int $divider): int
|
||||||
{
|
{
|
||||||
$languages = $this->pConfig->get($uid, 'channel', 'languages', [User::getLanguageCode($uid)]);
|
$languages = User::getWantedLanguages($uid);
|
||||||
$cache_key = 'Channel:getMedianComments:' . $divider . ':' . implode(':', $languages);
|
$cache_key = 'Channel:getMedianComments:' . $divider . ':' . implode(':', $languages);
|
||||||
$comments = $this->cache->get($cache_key);
|
$comments = $this->cache->get($cache_key);
|
||||||
if (!empty($comments)) {
|
if (!empty($comments)) {
|
||||||
|
@ -463,7 +463,7 @@ class Timeline extends BaseModule
|
||||||
|
|
||||||
private function getMedianActivities(int $uid, int $divider): int
|
private function getMedianActivities(int $uid, int $divider): int
|
||||||
{
|
{
|
||||||
$languages = $this->pConfig->get($uid, 'channel', 'languages', [User::getLanguageCode($uid)]);
|
$languages = User::getWantedLanguages($uid);
|
||||||
$cache_key = 'Channel:getMedianActivities:' . $divider . ':' . implode(':', $languages);
|
$cache_key = 'Channel:getMedianActivities:' . $divider . ':' . implode(':', $languages);
|
||||||
$activities = $this->cache->get($cache_key);
|
$activities = $this->cache->get($cache_key);
|
||||||
if (!empty($activities)) {
|
if (!empty($activities)) {
|
||||||
|
|
|
@ -265,7 +265,7 @@ class Display extends BaseSettings
|
||||||
|
|
||||||
$bookmarked_timelines = $this->pConfig->get($uid, 'system', 'network_timelines', $this->getAvailableTimelines($uid, true)->column('code'));
|
$bookmarked_timelines = $this->pConfig->get($uid, 'system', 'network_timelines', $this->getAvailableTimelines($uid, true)->column('code'));
|
||||||
$enabled_timelines = $this->pConfig->get($uid, 'system', 'enabled_timelines', $this->getAvailableTimelines($uid, false)->column('code'));
|
$enabled_timelines = $this->pConfig->get($uid, 'system', 'enabled_timelines', $this->getAvailableTimelines($uid, false)->column('code'));
|
||||||
$channel_languages = $this->pConfig->get($uid, 'channel', 'languages', [User::getLanguageCode($uid)]);
|
$channel_languages = User::getWantedLanguages($uid);
|
||||||
$languages = $this->l10n->getLanguageCodes(true);
|
$languages = $this->l10n->getLanguageCodes(true);
|
||||||
|
|
||||||
$timelines = [];
|
$timelines = [];
|
||||||
|
|
Loading…
Reference in a new issue