]> git.mxchange.org Git - friendica.git/blobdiff - mod/notifications.php
Fix JITConfigAdapter to retrieve non-db config.* values
[friendica.git] / mod / notifications.php
index 47e4cd03405f867f2560f5588f3fd4fa3ac5b840..b113be030d8337cc95f19d744e4f9a57f2671443 100644 (file)
@@ -1,81 +1,75 @@
 <?php
-
 /**
  * @file mod/notifications.php
  * @brief The notifications module
  */
-
-require_once("include/NotificationsManager.php");
-require_once("include/contact_selectors.php");
-require_once("include/network.php");
-
-function notifications_post(App &$a) {
-
-       if (! local_user()) {
-               goaway(z_root());
+use Friendica\App;
+use Friendica\Content\ContactSelector;
+use Friendica\Content\Nav;
+use Friendica\Core\L10n;
+use Friendica\Core\NotificationsManager;
+use Friendica\Core\System;
+use Friendica\Database\DBM;
+
+function notifications_post(App $a)
+{
+       if (!local_user()) {
+               goaway(System::baseUrl());
        }
 
        $request_id = (($a->argc > 1) ? $a->argv[1] : 0);
 
-       if($request_id === "all")
+       if ($request_id === "all") {
                return;
+       }
 
-       if($request_id) {
-
-               $r = q("SELECT * FROM `intro` WHERE `id` = %d  AND `uid` = %d LIMIT 1",
-                       intval($request_id),
-                       intval(local_user())
-               );
+       if ($request_id) {
+               $intro = dba::selectFirst('intro', ['id', 'contact-id', 'fid'], ['id' => $request_id, 'uid' => local_user()]);
 
-               if (dbm::is_result($r)) {
-                       $intro_id = $r[0]['id'];
-                       $contact_id = $r[0]['contact-id'];
-               }
-               else {
-                       notice( t('Invalid request identifier.') . EOL);
+               if (DBM::is_result($intro)) {
+                       $intro_id = $intro['id'];
+                       $contact_id = $intro['contact-id'];
+               } else {
+                       notice(L10n::t('Invalid request identifier.') . EOL);
                        return;
                }
 
                // If it is a friend suggestion, the contact is not a new friend but an existing friend
                // that should not be deleted.
 
-               $fid = $r[0]['fid'];
+               $fid = $intro['fid'];
 
-               if($_POST['submit'] == t('Discard')) {
-                       $r = q("DELETE FROM `intro` WHERE `id` = %d",
-                               intval($intro_id)
-                       );
-                       if(! $fid) {
+               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
-
-                               $r = q("DELETE FROM `contact` WHERE `id` = %d AND `uid` = %d AND `self` = 0 AND `blocked` = 1 AND `pending` = 1",
-                                       intval($contact_id),
-                                       intval(local_user())
-                               );
+                               $condition = ['id' => $contact_id, 'uid' => local_user(),
+                                       'self' => false, 'blocked' => true, 'pending' => true];
+                               dba::delete('contact', $condition);
                        }
                        goaway('notifications/intros');
                }
-               if($_POST['submit'] == t('Ignore')) {
-                       $r = q("UPDATE `intro` SET `ignore` = 1 WHERE `id` = %d",
-                               intval($intro_id));
+
+               if ($_POST['submit'] == L10n::t('Ignore')) {
+                       dba::update('intro', ['ignore' => true], ['id' => $intro_id]);
                        goaway('notifications/intros');
                }
        }
 }
 
-function notifications_content(App &$a) {
-
-       if (! local_user()) {
-               notice( t('Permission denied.') . EOL);
+function notifications_content(App $a)
+{
+       if (!local_user()) {
+               notice(L10n::t('Permission denied.') . EOL);
                return;
        }
 
        $page   =       (x($_REQUEST,'page')            ? $_REQUEST['page']             : 1);
        $show   =       (x($_REQUEST,'show')            ? $_REQUEST['show']             : 0);
 
-       nav_set_selected('notifications');
+       Nav::setSelected('notifications');
 
        $json = (($a->argc > 1 && $a->argv[$a->argc - 1] === 'json') ? true : false);
 
@@ -84,50 +78,46 @@ function notifications_content(App &$a) {
        $o = '';
        // Get the nav tabs for the notification pages
        $tabs = $nm->getTabs();
-       $notif_content = array();
+       $notif_content = [];
+       $notif_nocontent = '';
 
        // Notification results per page
        $perpage = 20;
        $startrec = ($page * $perpage) - $perpage;
 
        // Get introductions
-       if(($a->argc > 1) && ($a->argv[1] == 'intros')) || (($a->argc == 1))) {
-               nav_set_selected('introductions');
-               $notif_header = t('Notifications');
+       if ((($a->argc > 1) && ($a->argv[1] == 'intros')) || (($a->argc == 1))) {
+               Nav::setSelected('introductions');
+               $notif_header = L10n::t('Notifications');
 
                $all = (($a->argc > 2) && ($a->argv[2] == 'all'));
 
                $notifs = $nm->introNotifs($all, $startrec, $perpage);
 
        // Get the network notifications
-       } else if (($a->argc > 1) && ($a->argv[1] == 'network')) {
-
-               $notif_header = t('Network Notifications');
+       } elseif (($a->argc > 1) && ($a->argv[1] == 'network')) {
+               $notif_header = L10n::t('Network Notifications');
                $notifs = $nm->networkNotifs($show, $startrec, $perpage);
 
        // Get the system notifications
-       } else if (($a->argc > 1) && ($a->argv[1] == 'system')) {
-
-               $notif_header = t('System Notifications');
+       } elseif (($a->argc > 1) && ($a->argv[1] == 'system')) {
+               $notif_header = L10n::t('System Notifications');
                $notifs = $nm->systemNotifs($show, $startrec, $perpage);
 
        // Get the personal notifications
-       } else if (($a->argc > 1) && ($a->argv[1] == 'personal')) {
-
-               $notif_header = t('Personal Notifications');
+       } elseif (($a->argc > 1) && ($a->argv[1] == 'personal')) {
+               $notif_header = L10n::t('Personal Notifications');
                $notifs = $nm->personalNotifs($show, $startrec, $perpage);
 
        // Get the home notifications
-       } else if (($a->argc > 1) && ($a->argv[1] == 'home')) {
-
-               $notif_header = t('Home Notifications');
+       } elseif (($a->argc > 1) && ($a->argv[1] == 'home')) {
+               $notif_header = L10n::t('Home Notifications');
                $notifs = $nm->homeNotifs($show, $startrec, $perpage);
 
        }
 
 
        // Set the pager
-       $a->set_pager_total($notifs['total']);
        $a->set_pager_itemspage($perpage);
 
        // Add additional informations (needed for json output)
@@ -135,22 +125,22 @@ function notifications_content(App &$a) {
        $notifs['page'] = $a->pager['page'];
 
        // Json output
-       if(intval($json) === 1)
-               json_return_and_die($notifs);
+       if (intval($json) === 1) {
+               System::jsonExit($notifs);
+       }
 
        $notif_tpl = get_markup_template('notifications.tpl');
 
        // Process the data for template creation
-       if($notifs['ident'] === 'introductions') {
-
+       if ($notifs['ident'] === 'introductions') {
                $sugg = get_markup_template('suggestions.tpl');
                $tpl = get_markup_template("intros.tpl");
 
                // The link to switch between ignored and normal connection requests
-               $notif_show_lnk = array(
+               $notif_show_lnk = [
                        'href' => (!$all ? 'notifications/intros/all' : 'notifications/intros' ),
-                       'text' => (!$all ? t('Show Ignored Requests') : t('Hide Ignored Requests'))
-               );
+                       'text' => (!$all ? L10n::t('Show Ignored Requests') : L10n::t('Hide Ignored Requests'))
+               ];
 
                // Loop through all introduction notifications.This creates an array with the output html for each
                // introduction
@@ -160,25 +150,32 @@ function notifications_content(App &$a) {
                        // We have to distinguish between these two because they use different data.
                        switch ($it['label']) {
                                case 'friend_suggestion':
-                                       $notif_content[] = replace_macros($sugg, array(
-                                               '$str_notifytype' => t('Notification type: '),
+                                       $notif_content[] = replace_macros($sugg, [
+                                               '$type' => $it['label'],
+                                               '$str_notifytype' => L10n::t('Notification type:'),
                                                '$notify_type' => $it['notify_type'],
                                                '$intro_id' => $it['intro_id'],
-                                               '$madeby' => sprintf( t('suggested by %s'),$it['madeby']),
-                                               '$contact_id' => $it['contact-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'],
-                                               '$hidden' => array('hidden', t('Hide this contact from others'), ($it['hidden'] == 1), ''),
-                                               '$activity' => array('activity', t('Post a new friend activity'), $it['post_newfriend'], t('if applicable')),
+                                               '$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' => t('Approve'),
+                                               '$approve' => L10n::t('Approve'),
                                                '$note' => $it['note'],
                                                '$request' => $it['request'],
-                                               '$ignore' => t('Ignore'),
-                                               '$discard' => t('Discard'),
-                                       ));
+                                               '$ignore' => L10n::t('Ignore'),
+                                               '$discard' => L10n::t('Discard'),
+                                       ]);
                                        break;
 
                                // Normal connection requests
@@ -188,38 +185,56 @@ function notifications_content(App &$a) {
                                        $dfrn_tpl = get_markup_template('netfriend.tpl');
 
                                        $knowyou   = '';
+                                       $lbl_knowyou = '';
                                        $dfrn_text = '';
-
-                                       if($it['network'] === NETWORK_DFRN || $it['network'] === NETWORK_DIASPORA) {
-                                               if($it['network'] === NETWORK_DFRN) {
-                                                       $lbl_knowyou = t('Claims to be known to you: ');
-                                                       $knowyou = (($it['knowyou']) ? t('yes') : t('no'));
-                                                       $helptext = t('Shall your connection be bidirectional or not? "Friend" implies that you allow to read and you subscribe to their posts. "Fan/Admirer" means that you allow to read but you do not want to read theirs. Approve as: ');
+                                       $helptext = '';
+                                       $helptext2 = '';
+                                       $helptext3 = '';
+
+                                       if ($it['network'] === NETWORK_DFRN || $it['network'] === NETWORK_DIASPORA) {
+                                               if ($it['network'] === NETWORK_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 = t('Shall your connection be bidirectional or not? "Friend" implies that you allow to read and you subscribe to their posts. "Sharer" means that you allow to read but you do not want to read theirs. Approve as: ');
+                                                       $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']);
                                                }
                                        }
 
-                                       $dfrn_text = replace_macros($dfrn_tpl,array(
+                                       $dfrn_text = replace_macros($dfrn_tpl,[
                                                '$intro_id' => $it['intro_id'],
                                                '$friend_selected' => $friend_selected,
                                                '$fan_selected' => $fan_selected,
-                                               '$approve_as' => $helptext,
-                                               '$as_friend' => t('Friend'),
-                                               '$as_fan' => (($it['network'] == NETWORK_DIASPORA) ? t('Sharer') : t('Fan/Admirer'))
-                                       ));
+                                               '$approve_as1' => $helptext,
+                                               '$approve_as2' => $helptext2,
+                                               '$approve_as3' => $helptext3,
+                                               '$as_friend' => L10n::t('Friend'),
+                                               '$as_fan' => (($it['network'] == NETWORK_DIASPORA) ? L10n::t('Sharer') : L10n::t('Subscriber'))
+                                       ]);
 
                                        $header = $it["name"];
 
-                                       if ($it["addr"] != "")
+                                       if ($it["addr"] != "") {
                                                $header .= " <".$it["addr"].">";
+                                       }
 
-                                       $header .= " (".network_to_name($it['network'], $it['url']).")";
+                                       $header .= " (".ContactSelector::networkToName($it['network'], $it['url']).")";
 
-                                       $notif_content[] = replace_macros($tpl, array(
+                                       if ($it['network'] != NETWORK_DIASPORA) {
+                                               $discard = L10n::t('Discard');
+                                       } else {
+                                               $discard = '';
+                                       }
+
+                                       $notif_content[] = replace_macros($tpl, [
+                                               '$type' => $it['label'],
                                                '$header' => htmlentities($header),
-                                               '$str_notifytype' => t('Notification type: '),
+                                               '$str_notifytype' => L10n::t('Notification type:'),
                                                '$notify_type' => $it['notify_type'],
                                                '$dfrn_text' => $dfrn_text,
                                                '$dfrn_id' => $it['dfrn_id'],
@@ -229,39 +244,38 @@ function notifications_content(App &$a) {
                                                '$photo' => $it['photo'],
                                                '$fullname' => $it['name'],
                                                '$location' => $it['location'],
-                                               '$lbl_location' => t('Location:'),
+                                               '$lbl_location' => L10n::t('Location:'),
                                                '$about' => $it['about'],
-                                               '$lbl_about' => t('About:'),
+                                               '$lbl_about' => L10n::t('About:'),
                                                '$keywords' => $it['keywords'],
-                                               '$lbl_keywords' => t('Tags:'),
+                                               '$lbl_keywords' => L10n::t('Tags:'),
                                                '$gender' => $it['gender'],
-                                               '$lbl_gender' => t('Gender:'),
-                                               '$hidden' => array('hidden', t('Hide this contact from others'), ($it['hidden'] == 1), ''),
-                                               '$activity' => array('activity', t('Post a new friend activity'), $it['post_newfriend'], t('if applicable')),
+                                               '$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' => t('Profile URL'),
+                                               '$lbl_url' => L10n::t('Profile URL'),
                                                '$addr' => $it['addr'],
                                                '$lbl_knowyou' => $lbl_knowyou,
-                                               '$lbl_network' => t('Network:'),
-                                               '$network' => network_to_name($it['network'], $it['url']),
+                                               '$lbl_network' => L10n::t('Network:'),
+                                               '$network' => ContactSelector::networkToName($it['network'], $it['url']),
                                                '$knowyou' => $knowyou,
-                                               '$approve' => t('Approve'),
+                                               '$approve' => L10n::t('Approve'),
                                                '$note' => $it['note'],
-                                               '$ignore' => t('Ignore'),
-                                               '$discard' => t('Discard'),
+                                               '$ignore' => L10n::t('Ignore'),
+                                               '$discard' => $discard,
 
-                                       ));
+                                       ]);
                                        break;
                        }
                }
 
-               if($notifs['total'] == 0)
-                       info( t('No introductions.') . EOL);
+               if (count($notifs['notifications']) == 0) {
+                       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';
@@ -281,40 +295,37 @@ function notifications_content(App &$a) {
                        $tpl_var_name = 'tpl_item_'.$it['label'];
                        $tpl_notif = get_markup_template($$tpl_var_name);
 
-                       $notif_content[] = replace_macros($tpl_notif,array(
+                       $notif_content[] = replace_macros($tpl_notif,[
                                '$item_label' => $it['label'],
                                '$item_link' => $it['link'],
                                '$item_image' => $it['image'],
                                '$item_url' => $it['url'],
-                               '$item_text' => htmlentities($it['text']),
+                               '$item_text' => $it['text'],
                                '$item_when' => $it['when'],
                                '$item_ago' => $it['ago'],
                                '$item_seen' => $it['seen'],
-                       ));
+                       ]);
                }
 
-               // It doesn't make sense to show the Show unread / Show all link visible if the user is on the
-               // "Show all" page and there are no notifications. So we will hide it.
-               if($show == 0 || intval($show) && $notifs['total'] > 0) {
-                       $notif_show_lnk = array(
-                               'href' => ($show ? 'notifications/'.$notifs['ident'] : 'notifications/'.$notifs['ident'].'?show=all' ),
-                               'text' => ($show ? t('Show unread') : t('Show all')),
-                       );
-               }
+               $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($notifs['total'] == 0)
-                       $notif_nocontent = sprintf( t('No more %s notifications.'), $notifs['ident']);
+               if (count($notifs['notifications']) == 0) {
+                       $notif_nocontent = L10n::t('No more %s notifications.', $notifs['ident']);
+               }
        }
 
-       $o .= replace_macros($notif_tpl, array(
+       $o .= replace_macros($notif_tpl, [
                '$notif_header' => $notif_header,
                '$tabs' => $tabs,
                '$notif_content' => $notif_content,
                '$notif_nocontent' => $notif_nocontent,
                '$notif_show_lnk' => $notif_show_lnk,
-               '$notif_paginate' => paginate($a)
-       ));
+               '$notif_paginate' => alt_pager($a, count($notif_content))
+       ]);
 
        return $o;
 }