X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FModel%2FUserItem.php;h=38e9adc6ea26d451375347d144525b46ebfeebd1;hb=bd9f36622e056c83e8bfef2920640285ce9672b0;hp=db73ab45f7dce0f777bb5f0b29cf54b51a6a1d4e;hpb=e92904c3f34f68b8329f4c4b856b946083d5d9d2;p=friendica.git diff --git a/src/Model/UserItem.php b/src/Model/UserItem.php index db73ab45f7..38e9adc6ea 100644 --- a/src/Model/UserItem.php +++ b/src/Model/UserItem.php @@ -63,8 +63,15 @@ class UserItem return; } - // fetch all users in the thread - $uids = []; + if ($item['uid'] == 0) { + $uids = []; + } else { + // Always include the item user + $uids = [$item['uid']]; + } + + // Add every user who participated so far in this thread + // This can only happen with participations on global items. (means: uid = 0) $users = DBA::p("SELECT DISTINCT(`contact`.`uid`) FROM `item` INNER JOIN `contact` ON `contact`.`id` = `item`.`contact-id` AND `contact`.`uid` != 0 WHERE `parent` IN (SELECT `parent` FROM `item` WHERE `id`=?)", $iid); @@ -73,24 +80,6 @@ class UserItem } DBA::close($users); - // Add item users - $users = Item::select(['uid'], ["`parent-uri-id` = ? AND `uid` != ?", $item['parent-uri-id'], 0], ['group_by' => ['uid']]); - while ($user = DBA::fetch($users)) { - $uids[] = $user['uid']; - } - DBA::close($users); - - // Check for mentions to local users - if (in_array($item['private'], [Item::PUBLIC, Item::UNLISTED])) { - $mentions = Tag::getByURIId($item['uri-id'], [Tag::MENTION, Tag::IMPLICIT_MENTION, Tag::EXCLUSIVE_MENTION]); - foreach ($mentions as $mention) { - $uid = User::getIdForURL($mention['url']); - if (!empty($uid)) { - $uids[] = $uid; - } - } - } - foreach (array_unique($uids) as $uid) { self::setNotificationForUser($item, $uid); } @@ -167,7 +156,9 @@ class UserItem Logger::info('Set notification', ['iid' => $item['id'], 'uid' => $uid, 'notification-type' => $notification_type]); - DBA::update('user-item', ['notification-type' => $notification_type], ['iid' => $item['id'], 'uid' => $uid], true); + $fields = ['notification-type' => $notification_type]; + Post\User::update($item['uri-id'], $uid, $fields); + DBA::update('user-item', $fields, ['iid' => $item['id'], 'uid' => $uid], true); } /**