]> git.mxchange.org Git - friendica.git/blobdiff - mod/notifications.php
Merge pull request #1 from friendica/develop
[friendica.git] / mod / notifications.php
index bc581b6dd34ef24cda3791cb2ae9bc8f36e3914c..88972728cb7ca63b213700997efc2adc9542b3ab 100644 (file)
@@ -7,21 +7,25 @@
 use Friendica\App;
 use Friendica\Content\ContactSelector;
 use Friendica\Content\Nav;
+use Friendica\Content\Pager;
 use Friendica\Core\L10n;
-use Friendica\Core\NotificationsManager;
 use Friendica\Core\Protocol;
+use Friendica\Core\Renderer;
 use Friendica\Core\System;
 use Friendica\Database\DBA;
+use Friendica\Module\Login;
+use Friendica\Model\Contact;
+use Friendica\Model\Notify;
 
 function notifications_post(App $a)
 {
        if (!local_user()) {
-               goaway(System::baseUrl());
+               $a->internalRedirect();
        }
 
        $request_id = (($a->argc > 1) ? $a->argv[1] : 0);
 
-       if ($request_id === "all") {
+       if ($request_id === 'all') {
                return;
        }
 
@@ -43,20 +47,25 @@ function notifications_post(App $a)
 
                if ($_POST['submit'] == L10n::t('Discard')) {
                        DBA::delete('intro', ['id' => $intro_id]);
-
                        if (!$fid) {
-                               // The check for blocked and pending is in case the friendship was already approved
-                               // and we just want to get rid of the now pointless notification
+                               // When the contact entry had been created just for that intro, we want to get rid of it now
                                $condition = ['id' => $contact_id, 'uid' => local_user(),
-                                       'self' => false, 'blocked' => true, 'pending' => true];
-                               DBA::delete('contact', $condition);
+                                       'self' => false, 'pending' => true, 'rel' => [0, Contact::FOLLOWER]];
+                               $contact_pending = DBA::exists('contact', $condition);
+
+                               // Remove the "pending" to stop the reappearing in any case
+                               DBA::update('contact', ['pending' => false], ['id' => $contact_id]);
+
+                               if ($contact_pending) {
+                                       Contact::remove($contact_id);
+                               }
                        }
-                       goaway('notifications/intros');
+                       $a->internalRedirect('notifications/intros');
                }
 
                if ($_POST['submit'] == L10n::t('Ignore')) {
                        DBA::update('intro', ['ignore' => true], ['id' => $intro_id]);
-                       goaway('notifications/intros');
+                       $a->internalRedirect('notifications/intros');
                }
        }
 }
@@ -65,17 +74,18 @@ function notifications_content(App $a)
 {
        if (!local_user()) {
                notice(L10n::t('Permission denied.') . EOL);
-               return;
+               return Login::form();
        }
 
-       $page   =       (x($_REQUEST,'page')            ? $_REQUEST['page']             : 1);
-       $show   =       (x($_REQUEST,'show')            ? $_REQUEST['show']             : 0);
+       $page = ($_REQUEST['page'] ?? 0) ?: 1;
+       $show = ($_REQUEST['show'] ?? '') === 'all';
 
        Nav::setSelected('notifications');
 
        $json = (($a->argc > 1 && $a->argv[$a->argc - 1] === 'json') ? true : false);
 
-       $nm = new NotificationsManager();
+       /** @var Notify $nm */
+       $nm = \Friendica\BaseObject::getClass(Notify::class);
 
        $o = '';
        // Get the nav tabs for the notification pages
@@ -87,59 +97,70 @@ function notifications_content(App $a)
        $perpage = 20;
        $startrec = ($page * $perpage) - $perpage;
 
+       $notif_header = L10n::t('Notifications');
+
+       $all = false;
+
        // Get introductions
        if ((($a->argc > 1) && ($a->argv[1] == 'intros')) || (($a->argc == 1))) {
                Nav::setSelected('introductions');
-               $notif_header = L10n::t('Notifications');
+
+               $id = 0;
+               if (!empty($a->argv[2]) && intval($a->argv[2]) != 0) {
+                       $id = (int)$a->argv[2];
+               }
 
                $all = (($a->argc > 2) && ($a->argv[2] == 'all'));
 
-               $notifs = $nm->introNotifs($all, $startrec, $perpage);
+               $notifs = $nm->getIntroList($all, $startrec, $perpage, $id);
 
        // Get the network notifications
        } elseif (($a->argc > 1) && ($a->argv[1] == 'network')) {
                $notif_header = L10n::t('Network Notifications');
-               $notifs = $nm->networkNotifs($show, $startrec, $perpage);
+               $notifs = $nm->getNetworkList($show, $startrec, $perpage);
 
        // Get the system notifications
        } elseif (($a->argc > 1) && ($a->argv[1] == 'system')) {
                $notif_header = L10n::t('System Notifications');
-               $notifs = $nm->systemNotifs($show, $startrec, $perpage);
+               $notifs = $nm->getSystemList($show, $startrec, $perpage);
 
        // Get the personal notifications
        } elseif (($a->argc > 1) && ($a->argv[1] == 'personal')) {
                $notif_header = L10n::t('Personal Notifications');
-               $notifs = $nm->personalNotifs($show, $startrec, $perpage);
+               $notifs = $nm->getPersonalList($show, $startrec, $perpage);
 
        // Get the home notifications
        } elseif (($a->argc > 1) && ($a->argv[1] == 'home')) {
                $notif_header = L10n::t('Home Notifications');
-               $notifs = $nm->homeNotifs($show, $startrec, $perpage);
+               $notifs = $nm->getHomeList($show, $startrec, $perpage);
+       // fallback - redirect to main page
+       } else {
+               $a->internalRedirect('notifications');
        }
 
-
        // Set the pager
-       $a->set_pager_itemspage($perpage);
+       $pager = new Pager($a->query_string, $perpage);
 
        // Add additional informations (needed for json output)
-       $notifs['items_page'] = $a->pager['itemspage'];
-       $notifs['page'] = $a->pager['page'];
+       $notifs['items_page'] = $pager->getItemsPerPage();
+       $notifs['page'] = $pager->getPage();
 
        // Json output
        if (intval($json) === 1) {
                System::jsonExit($notifs);
        }
 
-       $notif_tpl = get_markup_template('notifications.tpl');
+       $notif_tpl = Renderer::getMarkupTemplate('notifications.tpl');
 
-       if (!isset($notifs['ident'])) {
-               logger('Missing data in notifs: ' . json_encode($a->argv), LOGGER_DEBUG);
-       }
+       $notif_show_lnk = [
+               'href' => ($show ? 'notifications/' . $notifs['ident'] : 'notifications/' . $notifs['ident'] . '?show=all' ),
+               'text' => ($show ? L10n::t('Show unread') : L10n::t('Show all')),
+       ];
 
        // Process the data for template creation
-       if ($notifs['ident'] === 'introductions') {
-               $sugg = get_markup_template('suggestions.tpl');
-               $tpl = get_markup_template("intros.tpl");
+       if (($notifs['ident'] ?? '') == 'introductions') {
+               $sugg = Renderer::getMarkupTemplate('suggestions.tpl');
+               $tpl = Renderer::getMarkupTemplate('intros.tpl');
 
                // The link to switch between ignored and normal connection requests
                $notif_show_lnk = [
@@ -149,127 +170,130 @@ function notifications_content(App $a)
 
                // Loop through all introduction notifications.This creates an array with the output html for each
                // introduction
-               foreach ($notifs['notifications'] as $it) {
+               foreach ($notifs['notifications'] as $notif) {
 
                        // There are two kind of introduction. Contacts suggested by other contacts and normal connection requests.
                        // We have to distinguish between these two because they use different data.
-                       switch ($it['label']) {
+                       switch ($notif['label']) {
                                case 'friend_suggestion':
-                                       $notif_content[] = replace_macros($sugg, [
-                                               '$type' => $it['label'],
+                                       $notif_content[] = Renderer::replaceMacros($sugg, [
+                                               '$type'       => $notif['label'],
                                                '$str_notifytype' => L10n::t('Notification type:'),
-                                               '$notify_type' => $it['notify_type'],
-                                               '$intro_id' => $it['intro_id'],
+                                               '$notify_type'=> $notif['notify_type'],
+                                               '$intro_id'   => $notif['intro_id'],
                                                '$lbl_madeby' => L10n::t('Suggested by:'),
-                                               '$madeby' => $it['madeby'],
-                                               '$madeby_url' => $it['madeby_url'],
-                                               '$madeby_zrl' => $it['madeby_zrl'],
-                                               '$madeby_addr' => $it['madeby_addr'],
-                                               '$contact_id' => $it['contact_id'],
-                                               '$photo' => $it['photo'],
-                                               '$fullname' => $it['name'],
-                                               '$url' => $it['url'],
-                                               '$zrl' => $it['zrl'],
-                                               '$lbl_url' => L10n::t('Profile URL'),
-                                               '$addr' => $it['addr'],
-                                               '$hidden' => ['hidden', L10n::t('Hide this contact from others'), ($it['hidden'] == 1), ''],
-
-                                               '$knowyou' => $it['knowyou'],
-                                               '$approve' => L10n::t('Approve'),
-                                               '$note' => $it['note'],
-                                               '$request' => $it['request'],
-                                               '$ignore' => L10n::t('Ignore'),
-                                               '$discard' => L10n::t('Discard'),
+                                               '$madeby'     => $notif['madeby'],
+                                               '$madeby_url' => $notif['madeby_url'],
+                                               '$madeby_zrl' => $notif['madeby_zrl'],
+                                               '$madeby_addr'=> $notif['madeby_addr'],
+                                               '$contact_id' => $notif['contact_id'],
+                                               '$photo'      => $notif['photo'],
+                                               '$fullname'   => $notif['name'],
+                                               '$url'        => $notif['url'],
+                                               '$zrl'        => $notif['zrl'],
+                                               '$lbl_url'    => L10n::t('Profile URL'),
+                                               '$addr'       => $notif['addr'],
+                                               '$hidden'     => ['hidden', L10n::t('Hide this contact from others'), ($notif['hidden'] == 1), ''],
+                                               '$knowyou'    => $notif['knowyou'],
+                                               '$approve'    => L10n::t('Approve'),
+                                               '$note'       => $notif['note'],
+                                               '$request'    => $notif['request'],
+                                               '$ignore'     => L10n::t('Ignore'),
+                                               '$discard'    => L10n::t('Discard'),
                                        ]);
                                        break;
 
                                // Normal connection requests
                                default:
-                                       $friend_selected = (($it['network'] !== Protocol::OSTATUS) ? ' checked="checked" ' : ' disabled ');
-                                       $fan_selected = (($it['network'] === Protocol::OSTATUS) ? ' checked="checked" disabled ' : '');
-                                       $dfrn_tpl = get_markup_template('netfriend.tpl');
+                                       $friend_selected = (($notif['network'] !== Protocol::OSTATUS) ? ' checked="checked" ' : ' disabled ');
+                                       $fan_selected = (($notif['network'] === Protocol::OSTATUS) ? ' checked="checked" disabled ' : '');
 
-                                       $knowyou   = '';
                                        $lbl_knowyou = '';
-                                       $dfrn_text = '';
-                                       $helptext = '';
-                                       $helptext2 = '';
-                                       $helptext3 = '';
-
-                                       if ($it['network'] === Protocol::DFRN || $it['network'] === Protocol::DIASPORA) {
-                                               if ($it['network'] === Protocol::DFRN) {
-                                                       $lbl_knowyou = L10n::t('Claims to be known to you: ');
-                                                       $knowyou = (($it['knowyou']) ? L10n::t('yes') : L10n::t('no'));
-                                                       $helptext = L10n::t('Shall your connection be bidirectional or not?');
-                                                       $helptext2 = L10n::t('Accepting %s as a friend allows %s to subscribe to your posts, and you will also receive updates from them in your news feed.', $it['name'], $it['name']);
-                                                       $helptext3 = L10n::t('Accepting %s as a subscriber allows them to subscribe to your posts, but you will not receive updates from them in your news feed.', $it['name']);
-                                               } else {
-                                                       $knowyou = '';
-                                                       $helptext = L10n::t('Shall your connection be bidirectional or not?');
-                                                       $helptext2 = L10n::t('Accepting %s as a friend allows %s to subscribe to your posts, and you will also receive updates from them in your news feed.', $it['name'], $it['name']);
-                                                       $helptext3 = L10n::t('Accepting %s as a sharer allows them to subscribe to your posts, but you will not receive updates from them in your news feed.', $it['name']);
-                                               }
+                                       $knowyou     = '';
+                                       $helptext    = '';
+                                       $helptext2   = '';
+                                       $helptext3   = '';
+
+                                       if ($notif['network'] === Protocol::DFRN) {
+                                               $lbl_knowyou = L10n::t('Claims to be known to you: ');
+                                               $knowyou   = (($notif['knowyou']) ? L10n::t('yes') : L10n::t('no'));
+                                               $helptext  = L10n::t('Shall your connection be bidirectional or not?');
+                                               $helptext2 = L10n::t('Accepting %s as a friend allows %s to subscribe to your posts, and you will also receive updates from them in your news feed.', $notif['name'], $notif['name']);
+                                               $helptext3 = L10n::t('Accepting %s as a subscriber allows them to subscribe to your posts, but you will not receive updates from them in your news feed.', $notif['name']);
+                                       } elseif ($notif['network'] === Protocol::DIASPORA) {
+                                               $helptext  = L10n::t('Shall your connection be bidirectional or not?');
+                                               $helptext2 = L10n::t('Accepting %s as a friend allows %s to subscribe to your posts, and you will also receive updates from them in your news feed.', $notif['name'], $notif['name']);
+                                               $helptext3 = L10n::t('Accepting %s as a sharer allows them to subscribe to your posts, but you will not receive updates from them in your news feed.', $notif['name']);
                                        }
 
-                                       $dfrn_text = replace_macros($dfrn_tpl,[
-                                               '$intro_id' => $it['intro_id'],
+                                       $dfrn_tpl = Renderer::getMarkupTemplate('netfriend.tpl');
+                                       $dfrn_text = Renderer::replaceMacros($dfrn_tpl, [
+                                               '$intro_id'    => $notif['intro_id'],
                                                '$friend_selected' => $friend_selected,
-                                               '$fan_selected' => $fan_selected,
+                                               '$fan_selected'=> $fan_selected,
                                                '$approve_as1' => $helptext,
                                                '$approve_as2' => $helptext2,
                                                '$approve_as3' => $helptext3,
-                                               '$as_friend' => L10n::t('Friend'),
-                                               '$as_fan' => (($it['network'] == Protocol::DIASPORA) ? L10n::t('Sharer') : L10n::t('Subscriber'))
+                                               '$as_friend'   => L10n::t('Friend'),
+                                               '$as_fan'      => (($notif['network'] == Protocol::DIASPORA) ? L10n::t('Sharer') : L10n::t('Subscriber'))
                                        ]);
 
-                                       $header = $it["name"];
+                                       $contact = DBA::selectFirst('contact', ['network', 'protocol'], ['id' => $notif['contact_id']]);
 
-                                       if ($it["addr"] != "") {
-                                               $header .= " <".$it["addr"].">";
+                                       if (($contact['network'] != Protocol::DFRN) || ($contact['protocol'] == Protocol::ACTIVITYPUB)) {
+                                               $action = 'follow_confirm';
+                                       } else {
+                                               $action = 'dfrn_confirm';
                                        }
 
-                                       $header .= " (".ContactSelector::networkToName($it['network'], $it['url']).")";
+                                       $header = $notif['name'];
 
-                                       if ($it['network'] != Protocol::DIASPORA) {
+                                       if ($notif['addr'] != '') {
+                                               $header .= ' <' . $notif['addr'] . '>';
+                                       }
+
+                                       $header .= ' (' . ContactSelector::networkToName($notif['network'], $notif['url']) . ')';
+
+                                       if ($notif['network'] != Protocol::DIASPORA) {
                                                $discard = L10n::t('Discard');
                                        } else {
                                                $discard = '';
                                        }
 
-                                       $notif_content[] = replace_macros($tpl, [
-                                               '$type' => $it['label'],
-                                               '$header' => htmlentities($header),
+                                       $notif_content[] = Renderer::replaceMacros($tpl, [
+                                               '$type'        => $notif['label'],
+                                               '$header'      => $header,
                                                '$str_notifytype' => L10n::t('Notification type:'),
-                                               '$notify_type' => $it['notify_type'],
-                                               '$dfrn_text' => $dfrn_text,
-                                               '$dfrn_id' => $it['dfrn_id'],
-                                               '$uid' => $it['uid'],
-                                               '$intro_id' => $it['intro_id'],
-                                               '$contact_id' => $it['contact_id'],
-                                               '$photo' => $it['photo'],
-                                               '$fullname' => $it['name'],
-                                               '$location' => $it['location'],
-                                               '$lbl_location' => L10n::t('Location:'),
-                                               '$about' => $it['about'],
-                                               '$lbl_about' => L10n::t('About:'),
-                                               '$keywords' => $it['keywords'],
-                                               '$lbl_keywords' => L10n::t('Tags:'),
-                                               '$gender' => $it['gender'],
-                                               '$lbl_gender' => L10n::t('Gender:'),
-                                               '$hidden' => ['hidden', L10n::t('Hide this contact from others'), ($it['hidden'] == 1), ''],
-                                               '$url' => $it['url'],
-                                               '$zrl' => $it['zrl'],
-                                               '$lbl_url' => L10n::t('Profile URL'),
-                                               '$addr' => $it['addr'],
+                                               '$notify_type' => $notif['notify_type'],
+                                               '$dfrn_text'   => $dfrn_text,
+                                               '$dfrn_id'     => $notif['dfrn_id'],
+                                               '$uid'         => $notif['uid'],
+                                               '$intro_id'    => $notif['intro_id'],
+                                               '$contact_id'  => $notif['contact_id'],
+                                               '$photo'       => $notif['photo'],
+                                               '$fullname'    => $notif['name'],
+                                               '$location'    => $notif['location'],
+                                               '$lbl_location'=> L10n::t('Location:'),
+                                               '$about'       => $notif['about'],
+                                               '$lbl_about'   => L10n::t('About:'),
+                                               '$keywords'    => $notif['keywords'],
+                                               '$lbl_keywords'=> L10n::t('Tags:'),
+                                               '$gender'      => $notif['gender'],
+                                               '$lbl_gender'  => L10n::t('Gender:'),
+                                               '$hidden'      => ['hidden', L10n::t('Hide this contact from others'), ($notif['hidden'] == 1), ''],
+                                               '$url'         => $notif['url'],
+                                               '$zrl'         => $notif['zrl'],
+                                               '$lbl_url'     => L10n::t('Profile URL'),
+                                               '$addr'        => $notif['addr'],
                                                '$lbl_knowyou' => $lbl_knowyou,
                                                '$lbl_network' => L10n::t('Network:'),
-                                               '$network' => ContactSelector::networkToName($it['network'], $it['url']),
-                                               '$knowyou' => $knowyou,
-                                               '$approve' => L10n::t('Approve'),
-                                               '$note' => $it['note'],
-                                               '$ignore' => L10n::t('Ignore'),
-                                               '$discard' => $discard,
-
+                                               '$network'     => ContactSelector::networkToName($notif['network'], $notif['url']),
+                                               '$knowyou'     => $knowyou,
+                                               '$approve'     => L10n::t('Approve'),
+                                               '$note'        => $notif['note'],
+                                               '$ignore'      => L10n::t('Ignore'),
+                                               '$discard'     => $discard,
+                                               '$action'      => $action,
                                        ]);
                                        break;
                        }
@@ -279,57 +303,47 @@ function notifications_content(App $a)
                        info(L10n::t('No introductions.') . EOL);
                }
 
-       // Normal notifications (no introductions)
-       } else {
-               // The template files we need in different cases for formatting the content
-               $tpl_item_like = 'notifications_likes_item.tpl';
-               $tpl_item_dislike = 'notifications_dislikes_item.tpl';
-               $tpl_item_attend = 'notifications_attend_item.tpl';
-               $tpl_item_attendno = 'notifications_attend_item.tpl';
-               $tpl_item_attendmaybe = 'notifications_attend_item.tpl';
-               $tpl_item_friend = 'notifications_friends_item.tpl';
-               $tpl_item_comment = 'notifications_comments_item.tpl';
-               $tpl_item_post = 'notifications_posts_item.tpl';
-               $tpl_item_notify = 'notify.tpl';
-
+               // Normal notifications (no introductions)
+       } elseif (!empty($notifs['notifications'])) {
                // Loop trough ever notification This creates an array with the output html for each
                // notification and apply the correct template according to the notificationtype (label).
-               foreach ($notifs['notifications'] as $it) {
-
-                       // We use the notification label to get the correct template file
-                       $tpl_var_name = 'tpl_item_'.$it['label'];
-                       $tpl_notif = get_markup_template($$tpl_var_name);
-
-                       $notif_content[] = replace_macros($tpl_notif,[
-                               '$item_label' => $it['label'],
-                               '$item_link' => $it['link'],
-                               '$item_image' => $it['image'],
-                               '$item_url' => $it['url'],
-                               '$item_text' => $it['text'],
-                               '$item_when' => $it['when'],
-                               '$item_ago' => $it['ago'],
-                               '$item_seen' => $it['seen'],
+               foreach ($notifs['notifications'] as $notif) {
+                       $notification_templates = [
+                               'like'        => 'notifications_likes_item.tpl',
+                               'dislike'     => 'notifications_dislikes_item.tpl',
+                               'attend'      => 'notifications_attend_item.tpl',
+                               'attendno'    => 'notifications_attend_item.tpl',
+                               'attendmaybe' => 'notifications_attend_item.tpl',
+                               'friend'      => 'notifications_friends_item.tpl',
+                               'comment'     => 'notifications_comments_item.tpl',
+                               'post'        => 'notifications_posts_item.tpl',
+                               'notify'      => 'notify.tpl',
+                       ];
+
+                       $tpl_notif = Renderer::getMarkupTemplate($notification_templates[$notif['label']]);
+
+                       $notif_content[] = Renderer::replaceMacros($tpl_notif, [
+                               '$item_label' => $notif['label'],
+                               '$item_link'  => $notif['link'],
+                               '$item_image' => $notif['image'],
+                               '$item_url'   => $notif['url'],
+                               '$item_text'  => $notif['text'],
+                               '$item_when'  => $notif['when'],
+                               '$item_ago'   => $notif['ago'],
+                               '$item_seen'  => $notif['seen'],
                        ]);
                }
-
-               $notif_show_lnk = [
-                       'href' => ($show ? 'notifications/'.$notifs['ident'] : 'notifications/'.$notifs['ident'].'?show=all' ),
-                       'text' => ($show ? L10n::t('Show unread') : L10n::t('Show all')),
-               ];
-
-               // Output if there aren't any notifications available
-               if (count($notifs['notifications']) == 0) {
-                       $notif_nocontent = L10n::t('No more %s notifications.', $notifs['ident']);
-               }
+       } else {
+               $notif_nocontent = L10n::t('No more %s notifications.', $notifs['ident']);
        }
 
-       $o .= replace_macros($notif_tpl, [
-               '$notif_header' => $notif_header,
-               '$tabs' => $tabs,
-               '$notif_content' => $notif_content,
+       $o .= Renderer::replaceMacros($notif_tpl, [
+               '$notif_header'    => $notif_header,
+               '$tabs'            => $tabs,
+               '$notif_content'   => $notif_content,
                '$notif_nocontent' => $notif_nocontent,
-               '$notif_show_lnk' => $notif_show_lnk,
-               '$notif_paginate' => alt_pager($a, count($notif_content))
+               '$notif_show_lnk'  => $notif_show_lnk,
+               '$notif_paginate'  => $pager->renderMinimal(count($notif_content))
        ]);
 
        return $o;