Restructuring
This commit is contained in:
parent
8e2494568e
commit
e728c4829f
2 changed files with 74 additions and 21 deletions
|
@ -2026,7 +2026,7 @@ class Item
|
||||||
|
|
||||||
self::updateContact($item);
|
self::updateContact($item);
|
||||||
|
|
||||||
UserItem::setNotification($current_post, $item['uid']);
|
UserItem::setNotification($current_post);
|
||||||
|
|
||||||
check_user_notification($current_post);
|
check_user_notification($current_post);
|
||||||
|
|
||||||
|
|
|
@ -26,20 +26,26 @@ class UserItem
|
||||||
/**
|
/**
|
||||||
* Checks an item for notifications and sets the "notification-type" field
|
* Checks an item for notifications and sets the "notification-type" field
|
||||||
*
|
*
|
||||||
* @param array $item The message array that is checked for notifications
|
* @param int $iid Item ID
|
||||||
* @param int $uid User ID
|
|
||||||
*/
|
*/
|
||||||
public static function setNotification($iid, $uid)
|
public static function setNotification(int $iid)
|
||||||
{
|
{
|
||||||
$fields = ['id', 'body', 'origin', 'parent', 'gravity', 'tag', 'contact-id',
|
$fields = ['id', 'uid', 'body', 'parent', 'gravity', 'tag', 'contact-id',
|
||||||
'thr-parent', 'parent-uri', 'mention'];
|
'thr-parent', 'parent-uri', 'mention'];
|
||||||
$item = Item::selectFirst($fields, ['id' => $iid]);
|
$item = Item::selectFirst($fields, ['id' => $iid, 'origin' => false]);
|
||||||
|
if (!DBA::isResult($item)) {
|
||||||
// Don't check for own posts
|
|
||||||
if ($item['origin'] || empty($uid)) {
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!empty($item['uid'])) {
|
||||||
|
self::setNotificationForUser($item, $item['uid']);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// Alle user des Threads ermitteln
|
||||||
|
}
|
||||||
|
|
||||||
|
private static function setNotificationForUser(array $item, int $uid)
|
||||||
|
{
|
||||||
$fields = ['ignored', 'mention'];
|
$fields = ['ignored', 'mention'];
|
||||||
$thread = Item::selectFirstThreadForUser($uid, $fields, ['iid' => $item['parent'], 'deleted' => false]);
|
$thread = Item::selectFirstThreadForUser($uid, $fields, ['iid' => $item['parent'], 'deleted' => false]);
|
||||||
if ($thread['ignored']) {
|
if ($thread['ignored']) {
|
||||||
|
@ -62,6 +68,7 @@ class UserItem
|
||||||
$notification_type = $notification_type | self::NOTIF_EXPLICIT_TAGGED;
|
$notification_type = $notification_type | self::NOTIF_EXPLICIT_TAGGED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Fetch all contacts for the given profiles
|
||||||
$contacts = [];
|
$contacts = [];
|
||||||
$ret = DBA::select('contact', ['id'], ['uid' => 0, 'nurl' => $profiles]);
|
$ret = DBA::select('contact', ['id'], ['uid' => 0, 'nurl' => $profiles]);
|
||||||
while ($contact = DBA::fetch($ret)) {
|
while ($contact = DBA::fetch($ret)) {
|
||||||
|
@ -77,11 +84,11 @@ class UserItem
|
||||||
$notification_type = $notification_type | self::NOTIF_DIRECT_COMMENT;
|
$notification_type = $notification_type | self::NOTIF_DIRECT_COMMENT;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (self::checkCommentedParticipation($item, $uid, $contacts)) {
|
if (self::checkCommentedParticipation($item, $contacts)) {
|
||||||
$notification_type = $notification_type | self::NOTIF_COMMENT_PARTICIPATION;
|
$notification_type = $notification_type | self::NOTIF_COMMENT_PARTICIPATION;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (self::checkActivityParticipation($item, $uid, $contacts)) {
|
if (self::checkActivityParticipation($item, $contacts)) {
|
||||||
$notification_type = $notification_type | self::NOTIF_ACTIVITY_PARTICIPATION;
|
$notification_type = $notification_type | self::NOTIF_ACTIVITY_PARTICIPATION;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -94,7 +101,12 @@ class UserItem
|
||||||
DBA::update('user-item', ['notification-type' => $notification_type], ['iid' => $item['id'], 'uid' => $uid], true);
|
DBA::update('user-item', ['notification-type' => $notification_type], ['iid' => $item['id'], 'uid' => $uid], true);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fetch all contacts for the given profiles
|
/**
|
||||||
|
* Fetch all profiles of a given user
|
||||||
|
* @param int $uid User ID
|
||||||
|
*
|
||||||
|
* @return array Profiles
|
||||||
|
*/
|
||||||
private static function getProfileForUser($uid)
|
private static function getProfileForUser($uid)
|
||||||
{
|
{
|
||||||
$notification_data = ['uid' => $uid, 'profiles' => []];
|
$notification_data = ['uid' => $uid, 'profiles' => []];
|
||||||
|
@ -105,12 +117,12 @@ class UserItem
|
||||||
$fields = ['nickname'];
|
$fields = ['nickname'];
|
||||||
$user = DBA::selectFirst('user', $fields, ['uid' => $uid]);
|
$user = DBA::selectFirst('user', $fields, ['uid' => $uid]);
|
||||||
if (!DBA::isResult($user)) {
|
if (!DBA::isResult($user)) {
|
||||||
return false;
|
return [];
|
||||||
}
|
}
|
||||||
|
|
||||||
$owner = DBA::selectFirst('contact', ['url'], ['self' => true, 'uid' => $uid]);
|
$owner = DBA::selectFirst('contact', ['url'], ['self' => true, 'uid' => $uid]);
|
||||||
if (!DBA::isResult($owner)) {
|
if (!DBA::isResult($owner)) {
|
||||||
return false;
|
return [];
|
||||||
}
|
}
|
||||||
|
|
||||||
// This is our regular URL format
|
// This is our regular URL format
|
||||||
|
@ -142,6 +154,11 @@ class UserItem
|
||||||
return $profiles2;
|
return $profiles2;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check for a "shared" notification for the given item and user
|
||||||
|
* @param array $item
|
||||||
|
* @param int $uid User ID
|
||||||
|
*/
|
||||||
private static function checkShared($item, $uid)
|
private static function checkShared($item, $uid)
|
||||||
{
|
{
|
||||||
if ($item['gravity'] != GRAVITY_PARENT) {
|
if ($item['gravity'] != GRAVITY_PARENT) {
|
||||||
|
@ -167,27 +184,48 @@ class UserItem
|
||||||
}
|
}
|
||||||
|
|
||||||
// Is the user mentioned in this post?
|
// Is the user mentioned in this post?
|
||||||
|
/**
|
||||||
|
* Check for a "shared" notification for the given item and user
|
||||||
|
* @param array $item
|
||||||
|
* @param int $uid User ID
|
||||||
|
*/
|
||||||
private static function checkImplicitMention($item, $uid, $profiles)
|
private static function checkImplicitMention($item, $uid, $profiles)
|
||||||
{
|
{
|
||||||
foreach ($profiles AS $profile) {
|
foreach ($profiles AS $profile) {
|
||||||
if (strpos($item['tag'], '='.$profile.']') || strpos($item['body'], '='.$profile.']'))
|
if (strpos($item['tag'], '='.$profile.']') || strpos($item['body'], '='.$profile.']')) {
|
||||||
return true;
|
if (strpos($item['body'], $profile) === false) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check for a "shared" notification for the given item and user
|
||||||
|
* @param array $item
|
||||||
|
* @param int $uid User ID
|
||||||
|
*/
|
||||||
private static function checkExplicitMention($item, $uid, $profiles)
|
private static function checkExplicitMention($item, $uid, $profiles)
|
||||||
{
|
{
|
||||||
foreach ($profiles AS $profile) {
|
foreach ($profiles AS $profile) {
|
||||||
if (strpos($item['tag'], '='.$profile.']') || strpos($item['body'], '='.$profile.']'))
|
if (strpos($item['tag'], '='.$profile.']') || strpos($item['body'], '='.$profile.']')) {
|
||||||
return !(strpos($item['body'], $profile) === false);
|
if (!(strpos($item['body'], $profile) === false)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Is it a post that the user had started?
|
// Is it a post that the user had started?
|
||||||
|
/**
|
||||||
|
* Check for a "shared" notification for the given item and user
|
||||||
|
* @param array $item
|
||||||
|
* @param int $uid User ID
|
||||||
|
*/
|
||||||
private static function checkCommentedThread($item, $uid, $contacts)
|
private static function checkCommentedThread($item, $uid, $contacts)
|
||||||
{
|
{
|
||||||
// Additional check for connector posts
|
// Additional check for connector posts
|
||||||
|
@ -195,6 +233,12 @@ class UserItem
|
||||||
return Item::exists($condition);
|
return Item::exists($condition);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check for a direct comment to a post of the given user
|
||||||
|
* @param array $item
|
||||||
|
* @param int $uid User ID
|
||||||
|
* @param array $contacts Array of contacts
|
||||||
|
*/
|
||||||
private static function checkDirectComment($item, $uid, $contacts)
|
private static function checkDirectComment($item, $uid, $contacts)
|
||||||
{
|
{
|
||||||
// Additional check for connector posts
|
// Additional check for connector posts
|
||||||
|
@ -202,14 +246,23 @@ class UserItem
|
||||||
return Item::exists($condition);
|
return Item::exists($condition);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check for participation of one of our contacts in the thread
|
/**
|
||||||
private static function checkCommentedParticipation($item, $uid, $contacts)
|
* Check if the user had commented in this thread
|
||||||
|
* @param array $item
|
||||||
|
* @param array $contacts Array of contacts
|
||||||
|
*/
|
||||||
|
private static function checkCommentedParticipation($item, $contacts)
|
||||||
{
|
{
|
||||||
$condition = ['parent' => $item['parent'], 'author-id' => $contacts, 'deleted' => false, 'gravity' => GRAVITY_COMMENT];
|
$condition = ['parent' => $item['parent'], 'author-id' => $contacts, 'deleted' => false, 'gravity' => GRAVITY_COMMENT];
|
||||||
return Item::exists($condition);
|
return Item::exists($condition);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static function checkActivityParticipation($item, $uid, $contacts)
|
/**
|
||||||
|
* Check if the user had interacted in this thread (Like, Dislike, ...)
|
||||||
|
* @param array $item
|
||||||
|
* @param array $contacts Array of contacts
|
||||||
|
*/
|
||||||
|
private static function checkActivityParticipation($item, $contacts)
|
||||||
{
|
{
|
||||||
$condition = ['parent' => $item['parent'], 'author-id' => $contacts, 'deleted' => false, 'gravity' => GRAVITY_ACTIVITY];
|
$condition = ['parent' => $item['parent'], 'author-id' => $contacts, 'deleted' => false, 'gravity' => GRAVITY_ACTIVITY];
|
||||||
return Item::exists($condition);
|
return Item::exists($condition);
|
||||||
|
|
Loading…
Reference in a new issue