X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FModel%2FSubscription.php;h=10a2d9b4d10d1af6b9b0e051b2c5a4db7c6b4e06;hb=2b819b8f8c1eacced3bc40bc98c33410df27f92c;hp=f9498af986a5b5fb2205c84b76bc8c3c5d2968b3;hpb=3e6fea30f2f3bc2352b6e16e1d48e204cde3696b;p=friendica.git diff --git a/src/Model/Subscription.php b/src/Model/Subscription.php index f9498af986..10a2d9b4d1 100644 --- a/src/Model/Subscription.php +++ b/src/Model/Subscription.php @@ -1,6 +1,6 @@ $applicationid, 'uid' => $uid]); } @@ -63,10 +64,9 @@ class Subscription * @param int $applicationid * @param int $uid * @param array $fields subscription fields - * * @return bool result of update */ - public static function update(int $applicationid, int $uid, array $fields) + public static function update(int $applicationid, int $uid, array $fields): bool { return DBA::update('subscription', $fields, ['application-id' => $applicationid, 'uid' => $uid]); } @@ -75,10 +75,9 @@ class Subscription * Insert or replace a subscription record * * @param array $fields subscription fields - * * @return bool result of replace */ - public static function replace(array $fields) + public static function replace(array $fields): bool { return DBA::replace('subscription', $fields); } @@ -90,7 +89,7 @@ class Subscription * @param int $uid * @return bool */ - public static function delete(int $applicationid, int $uid) + public static function delete(int $applicationid, int $uid): bool { return DBA::delete('subscription', ['application-id' => $applicationid, 'uid' => $uid]); } @@ -135,37 +134,25 @@ class Subscription /** * Prepare push notification * - * @param int $nid + * @param Notification $Notification * @return void */ - public static function pushByNotificationId(int $nid) + public static function pushByNotification(Entity\Notification $notification) { - $notification = DBA::selectFirst('notification', [], ['id' => $nid]); - - $type = Notification::getType($notification); - $desktop_notification = !in_array($type, [Notification::TYPE_RESHARE, Notification::TYPE_LIKE]); - - - if (DI::pConfig()->get($notification['uid'], 'system', 'notify_like') && ($type == 'favourite')) { - $desktop_notification = true; - } - - if (DI::pConfig()->get($notification['uid'], 'system', 'notify_announce') && ($type == 'reblog')) { - $desktop_notification = true; - } + $type = NotificationFactory::getType($notification); - if ($desktop_notification) { - notification_from_array($notification); + if (DI::notify()->shouldShowOnDesktop($notification, $type)) { + DI::notify()->createFromNotification($notification); } if (empty($type)) { return; } - $subscriptions = DBA::select('subscription', [], ['uid' => $notification['uid'], $type => true]); + $subscriptions = DBA::select('subscription', [], ['uid' => $notification->uid, $type => true]); while ($subscription = DBA::fetch($subscriptions)) { Logger::info('Push notification', ['id' => $subscription['id'], 'uid' => $subscription['uid'], 'type' => $type]); - Worker::add(PRIORITY_HIGH, 'PushSubscription', $subscription['id'], $nid); + Worker::add(Worker::PRIORITY_HIGH, 'PushSubscription', $subscription['id'], $notification->id); } DBA::close($subscriptions); }