]> git.mxchange.org Git - friendica.git/blobdiff - src/Module/Contact.php
Ensure that cached avatar fields are set
[friendica.git] / src / Module / Contact.php
index 01af275864480e3f1e708d69b246d8571e6accd6..e9f00a1b653d6086e0a46b471324ac72a4f795b8 100644 (file)
@@ -1,4 +1,23 @@
 <?php
+/**
+ * @copyright Copyright (C) 2020, Friendica
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program.  If not, see <https://www.gnu.org/licenses/>.
+ *
+ */
 
 namespace Friendica\Module;
 
@@ -11,28 +30,26 @@ use Friendica\Content\Text\BBCode;
 use Friendica\Content\Widget;
 use Friendica\Core\ACL;
 use Friendica\Core\Hook;
-use Friendica\Core\L10n;
 use Friendica\Core\Protocol;
 use Friendica\Core\Renderer;
-use Friendica\Core\System;
 use Friendica\Core\Worker;
 use Friendica\Database\DBA;
+use Friendica\DI;
 use Friendica\Model;
+use Friendica\Model\Contact as ModelContact;
+use Friendica\Module\Security\Login;
 use Friendica\Network\HTTPException\BadRequestException;
 use Friendica\Network\HTTPException\NotFoundException;
-use Friendica\Network\Probe;
 use Friendica\Util\DateTimeFormat;
 use Friendica\Util\Proxy as ProxyUtils;
 use Friendica\Util\Strings;
 
 /**
  *  Manages and show Contacts and their content
- *
- *  @brief manages contacts
  */
 class Contact extends BaseModule
 {
-       private static function batchActions(App $a)
+       private static function batchActions()
        {
                if (empty($_POST['contact_batch']) || !is_array($_POST['contact_batch'])) {
                        return;
@@ -69,15 +86,15 @@ class Contact extends BaseModule
                        }
                }
                if ($count_actions > 0) {
-                       info(L10n::tt('%d contact edited.', '%d contacts edited.', $count_actions));
+                       info(DI::l10n()->tt('%d contact edited.', '%d contacts edited.', $count_actions));
                }
 
-               $a->internalRedirect('contact');
+               DI::baseUrl()->redirect('contact');
        }
 
        public static function post(array $parameters = [])
        {
-               $a = self::getApp();
+               $a = DI::app();
 
                if (!local_user()) {
                        return;
@@ -85,7 +102,7 @@ class Contact extends BaseModule
 
                // @TODO: Replace with parameter from router
                if ($a->argv[1] === 'batch') {
-                       self::batchActions($a);
+                       self::batchActions();
                        return;
                }
 
@@ -96,28 +113,20 @@ class Contact extends BaseModule
                }
 
                if (!DBA::exists('contact', ['id' => $contact_id, 'uid' => local_user(), 'deleted' => false])) {
-                       notice(L10n::t('Could not access contact record.') . EOL);
-                       $a->internalRedirect('contact');
+                       notice(DI::l10n()->t('Could not access contact record.'));
+                       DI::baseUrl()->redirect('contact');
                        return; // NOTREACHED
                }
 
                Hook::callAll('contact_edit_post', $_POST);
 
-               $profile_id = intval($_POST['profile-assign'] ?? 0);
-               if ($profile_id) {
-                       if (!DBA::exists('profile', ['id' => $profile_id, 'uid' => local_user()])) {
-                               notice(L10n::t('Could not locate selected profile.') . EOL);
-                               return;
-                       }
-               }
-
                $hidden = !empty($_POST['hidden']);
 
                $notify = !empty($_POST['notify']);
 
                $fetch_further_information = intval($_POST['fetch_further_information'] ?? 0);
 
-               $ffi_keyword_blacklist = Strings::escapeHtml(trim($_POST['ffi_keyword_blacklist'] ?? ''));
+               $ffi_keyword_denylist = Strings::escapeHtml(trim($_POST['ffi_keyword_denylist'] ?? ''));
 
                $priority = intval($_POST['poll'] ?? 0);
                if ($priority > 5 || $priority < 0) {
@@ -127,20 +136,17 @@ class Contact extends BaseModule
                $info = Strings::escapeHtml(trim($_POST['info'] ?? ''));
 
                $r = DBA::update('contact', [
-                       'profile-id' => $profile_id,
                        'priority'   => $priority,
                        'info'       => $info,
                        'hidden'     => $hidden,
                        'notify_new_posts' => $notify,
                        'fetch_further_information' => $fetch_further_information,
-                       'ffi_keyword_blacklist'     => $ffi_keyword_blacklist],
+                       'ffi_keyword_denylist'     => $ffi_keyword_denylist],
                        ['id' => $contact_id, 'uid' => local_user()]
                );
 
-               if (DBA::isResult($r)) {
-                       info(L10n::t('Contact updated.') . EOL);
-               } else {
-                       notice(L10n::t('Failed to update contact record.') . EOL);
+               if (!DBA::isResult($r)) {
+                       notice(DI::l10n()->t('Failed to update contact record.'));
                }
 
                $contact = DBA::selectFirst('contact', [], ['id' => $contact_id, 'uid' => local_user(), 'deleted' => false]);
@@ -160,10 +166,9 @@ class Contact extends BaseModule
                        return;
                }
 
-               $uid = $contact['uid'];
-
                if ($contact['network'] == Protocol::OSTATUS) {
-                       $result = Model\Contact::createFromProbe($uid, $contact['url'], false, $contact['network']);
+                       $user = Model\User::getById($contact['uid']);
+                       $result = Model\Contact::createFromProbe($user, $contact['url'], false, $contact['network']);
 
                        if ($result['success']) {
                                DBA::update('contact', ['subhub' => 1], ['id' => $contact_id]);
@@ -246,13 +251,15 @@ class Contact extends BaseModule
                        return Login::form($_SERVER['REQUEST_URI']);
                }
 
-               $a = self::getApp();
+               $a = DI::app();
 
-               $nets = $_GET['nets'] ?? '';
-               $rel  = $_GET['rel']  ?? '';
+               $search = Strings::escapeTags(trim($_GET['search'] ?? ''));
+               $nets   = Strings::escapeTags(trim($_GET['nets']   ?? ''));
+               $rel    = Strings::escapeTags(trim($_GET['rel']    ?? ''));
+               $group  = Strings::escapeTags(trim($_GET['group']  ?? ''));
 
-               if (empty($a->page['aside'])) {
-                       $a->page['aside'] = '';
+               if (empty(DI::page()['aside'])) {
+                       DI::page()['aside'] = '';
                }
 
                $contact_id = null;
@@ -272,15 +279,17 @@ class Contact extends BaseModule
                        if ($contact['network'] == Protocol::PHANTOM) {
                                $contact = false;
                        }
+
+                       $contact = ModelContact::checkAvatarCacheArray($contact);
                }
 
                if (DBA::isResult($contact)) {
                        if ($contact['self']) {
                                // @TODO: Replace with parameter from router
                                if (($a->argc == 3) && intval($a->argv[1]) && in_array($a->argv[2], ['posts', 'conversations'])) {
-                                       $a->internalRedirect('profile/' . $contact['nick']);
+                                       DI::baseUrl()->redirect('profile/' . $contact['nick']);
                                } else {
-                                       $a->internalRedirect('profile/' . $contact['nick'] . '?tab=profile');
+                                       DI::baseUrl()->redirect('profile/' . $contact['nick'] . '/profile');
                                }
                        }
 
@@ -313,13 +322,13 @@ class Contact extends BaseModule
                                '$url'          => Model\Contact::magicLinkByContact($contact, $contact['url']),
                                '$addr'         => $contact['addr'] ?? '',
                                '$network_link' => $network_link,
-                               '$network'      => L10n::t('Network:'),
+                               '$network'      => DI::l10n()->t('Network:'),
                                '$account_type' => Model\Contact::getAccountType($contact),
-                               '$follow'       => L10n::t('Follow'),
+                               '$follow'       => DI::l10n()->t('Follow'),
                                '$follow_link'   => $follow_link,
-                               '$unfollow'     => L10n::t('Unfollow'),
+                               '$unfollow'     => DI::l10n()->t('Unfollow'),
                                '$unfollow_link' => $unfollow_link,
-                               '$wallmessage'  => L10n::t('Message'),
+                               '$wallmessage'  => DI::l10n()->t('Message'),
                                '$wallmessage_link' => $wallmessage_link,
                        ]);
 
@@ -327,6 +336,12 @@ class Contact extends BaseModule
                        $follow_widget = '';
                        $networks_widget = '';
                        $rel_widget = '';
+
+                       if ($contact['uid'] != 0) {
+                               $groups_widget = Model\Group::sidebarWidget('contact', 'group', 'full', 'everyone', $contact_id);
+                       } else {
+                               $groups_widget = '';
+                       }
                } else {
                        $vcard_widget = '';
                        $findpeople_widget = Widget::findPeople();
@@ -338,27 +353,21 @@ class Contact extends BaseModule
 
                        $networks_widget = Widget::networks($_SERVER['REQUEST_URI'], $nets);
                        $rel_widget = Widget::contactRels($_SERVER['REQUEST_URI'], $rel);
+                       $groups_widget = Widget::groups($_SERVER['REQUEST_URI'], $group);
                }
 
-               if ($contact['uid'] != 0) {
-                       $groups_widget = Model\Group::sidebarWidget('contact', 'group', 'full', 'everyone', $contact_id);
-               } else {
-                       $groups_widget = null;
-               }
-
-               $a->page['aside'] .= $vcard_widget . $findpeople_widget . $follow_widget . $groups_widget . $networks_widget . $rel_widget;
+               DI::page()['aside'] .= $vcard_widget . $findpeople_widget . $follow_widget . $groups_widget . $networks_widget . $rel_widget;
 
                $tpl = Renderer::getMarkupTemplate('contacts-head.tpl');
-               $a->page['htmlhead'] .= Renderer::replaceMacros($tpl, [
-                       '$baseurl' => $a->getBaseURL(true),
+               DI::page()['htmlhead'] .= Renderer::replaceMacros($tpl, [
+                       '$baseurl' => DI::baseUrl()->get(true),
                ]);
 
-               $sort_type = 0;
                $o = '';
                Nav::setSelected('contact');
 
                if (!local_user()) {
-                       notice(L10n::t('Permission denied.') . EOL);
+                       notice(DI::l10n()->t('Permission denied.'));
                        return Login::form();
                }
 
@@ -373,18 +382,18 @@ class Contact extends BaseModule
 
                        $orig_record = DBA::selectFirst('contact', [], ['id' => $contact_id, 'uid' => [0, local_user()], 'self' => false, 'deleted' => false]);
                        if (!DBA::isResult($orig_record)) {
-                               throw new NotFoundException(L10n::t('Contact not found'));
+                               throw new NotFoundException(DI::l10n()->t('Contact not found'));
                        }
 
                        if ($cmd === 'update' && ($orig_record['uid'] != 0)) {
                                self::updateContactFromPoll($contact_id);
-                               $a->internalRedirect('contact/' . $contact_id);
+                               DI::baseUrl()->redirect('contact/' . $contact_id);
                                // NOTREACHED
                        }
 
                        if ($cmd === 'updateprofile' && ($orig_record['uid'] != 0)) {
                                self::updateContactFromProbe($contact_id);
-                               $a->internalRedirect('crepair/' . $contact_id);
+                               DI::baseUrl()->redirect('contact/' . $contact_id . '/advanced/');
                                // NOTREACHED
                        }
 
@@ -392,9 +401,9 @@ class Contact extends BaseModule
                                self::blockContact($contact_id);
 
                                $blocked = Model\Contact::isBlockedByUser($contact_id, local_user());
-                               info(($blocked ? L10n::t('Contact has been blocked') : L10n::t('Contact has been unblocked')) . EOL);
+                               info(($blocked ? DI::l10n()->t('Contact has been blocked') : DI::l10n()->t('Contact has been unblocked')));
 
-                               $a->internalRedirect('contact/' . $contact_id);
+                               DI::baseUrl()->redirect('contact/' . $contact_id);
                                // NOTREACHED
                        }
 
@@ -402,9 +411,9 @@ class Contact extends BaseModule
                                self::ignoreContact($contact_id);
 
                                $ignored = Model\Contact::isIgnoredByUser($contact_id, local_user());
-                               info(($ignored ? L10n::t('Contact has been ignored') : L10n::t('Contact has been unignored')) . EOL);
+                               info(($ignored ? DI::l10n()->t('Contact has been ignored') : DI::l10n()->t('Contact has been unignored')));
 
-                               $a->internalRedirect('contact/' . $contact_id);
+                               DI::baseUrl()->redirect('contact/' . $contact_id);
                                // NOTREACHED
                        }
 
@@ -412,10 +421,10 @@ class Contact extends BaseModule
                                $r = self::archiveContact($contact_id, $orig_record);
                                if ($r) {
                                        $archived = (($orig_record['archive']) ? 0 : 1);
-                                       info((($archived) ? L10n::t('Contact has been archived') : L10n::t('Contact has been unarchived')) . EOL);
+                                       info((($archived) ? DI::l10n()->t('Contact has been archived') : DI::l10n()->t('Contact has been unarchived')));
                                }
 
-                               $a->internalRedirect('contact/' . $contact_id);
+                               DI::baseUrl()->redirect('contact/' . $contact_id);
                                // NOTREACHED
                        }
 
@@ -424,7 +433,7 @@ class Contact extends BaseModule
                                if (!empty($_REQUEST['confirm'])) {
                                        // <form> can't take arguments in its 'action' parameter
                                        // so add any arguments as hidden inputs
-                                       $query = explode_querystring($a->query_string);
+                                       $query = explode_querystring(DI::args()->getQueryString());
                                        $inputs = [];
                                        foreach ($query['args'] as $arg) {
                                                if (strpos($arg, 'confirm=') === false) {
@@ -433,29 +442,29 @@ class Contact extends BaseModule
                                                }
                                        }
 
-                                       $a->page['aside'] = '';
+                                       DI::page()['aside'] = '';
 
                                        return Renderer::replaceMacros(Renderer::getMarkupTemplate('contact_drop_confirm.tpl'), [
-                                               '$header' => L10n::t('Drop contact'),
+                                               '$header' => DI::l10n()->t('Drop contact'),
                                                '$contact' => self::getContactTemplateVars($orig_record),
                                                '$method' => 'get',
-                                               '$message' => L10n::t('Do you really want to delete this contact?'),
+                                               '$message' => DI::l10n()->t('Do you really want to delete this contact?'),
                                                '$extra_inputs' => $inputs,
-                                               '$confirm' => L10n::t('Yes'),
+                                               '$confirm' => DI::l10n()->t('Yes'),
                                                '$confirm_url' => $query['base'],
                                                '$confirm_name' => 'confirmed',
-                                               '$cancel' => L10n::t('Cancel'),
+                                               '$cancel' => DI::l10n()->t('Cancel'),
                                        ]);
                                }
                                // Now check how the user responded to the confirmation query
                                if (!empty($_REQUEST['canceled'])) {
-                                       $a->internalRedirect('contact');
+                                       DI::baseUrl()->redirect('contact');
                                }
 
                                self::dropContact($orig_record);
-                               info(L10n::t('Contact has been removed.') . EOL);
+                               info(DI::l10n()->t('Contact has been removed.'));
 
-                               $a->internalRedirect('contact');
+                               DI::baseUrl()->redirect('contact');
                                // NOTREACHED
                        }
                        if ($cmd === 'posts') {
@@ -466,13 +475,13 @@ class Contact extends BaseModule
                        }
                }
 
-               $_SESSION['return_path'] = $a->query_string;
+               $_SESSION['return_path'] = DI::args()->getQueryString();
 
                if (!empty($a->data['contact']) && is_array($a->data['contact'])) {
                        $contact = $a->data['contact'];
 
-                       $a->page['htmlhead'] .= Renderer::replaceMacros(Renderer::getMarkupTemplate('contact_head.tpl'), [
-                               '$baseurl' => $a->getBaseURL(true),
+                       DI::page()['htmlhead'] .= Renderer::replaceMacros(Renderer::getMarkupTemplate('contact_head.tpl'), [
+                               '$baseurl' => DI::baseUrl()->get(true),
                        ]);
 
                        $contact['blocked']  = Model\Contact::isBlockedByUser($contact['id'], local_user());
@@ -483,17 +492,17 @@ class Contact extends BaseModule
                        switch ($contact['rel']) {
                                case Model\Contact::FRIEND:
                                        $dir_icon = 'images/lrarrow.gif';
-                                       $relation_text = L10n::t('You are mutual friends with %s');
+                                       $relation_text = DI::l10n()->t('You are mutual friends with %s');
                                        break;
 
                                case Model\Contact::FOLLOWER;
                                        $dir_icon = 'images/larrow.gif';
-                                       $relation_text = L10n::t('You are sharing with %s');
+                                       $relation_text = DI::l10n()->t('You are sharing with %s');
                                        break;
 
                                case Model\Contact::SHARING;
                                        $dir_icon = 'images/rarrow.gif';
-                                       $relation_text = L10n::t('%s is sharing with you');
+                                       $relation_text = DI::l10n()->t('%s is sharing with you');
                                        break;
 
                                default:
@@ -504,7 +513,7 @@ class Contact extends BaseModule
                                $relation_text = '';
                        }
 
-                       if (!in_array($contact['network'], Protocol::FEDERATED)) {
+                       if (!in_array($contact['network'], array_merge(Protocol::FEDERATED, [Protocol::TWITTER]))) {
                                $relation_text = '';
                        }
 
@@ -517,36 +526,36 @@ class Contact extends BaseModule
                                $sparkle = '';
                        }
 
-                       $insecure = L10n::t('Private communications are not available for this contact.');
+                       $insecure = DI::l10n()->t('Private communications are not available for this contact.');
 
-                       $last_update = (($contact['last-update'] <= DBA::NULL_DATETIME) ? L10n::t('Never') : DateTimeFormat::local($contact['last-update'], 'D, j M Y, g:i A'));
+                       $last_update = (($contact['last-update'] <= DBA::NULL_DATETIME) ? DI::l10n()->t('Never') : DateTimeFormat::local($contact['last-update'], 'D, j M Y, g:i A'));
 
                        if ($contact['last-update'] > DBA::NULL_DATETIME) {
-                               $last_update .= ' ' . (($contact['last-update'] <= $contact['success_update']) ? L10n::t('(Update was successful)') : L10n::t('(Update was not successful)'));
+                               $last_update .= ' ' . (($contact['last-update'] <= $contact['success_update']) ? DI::l10n()->t('(Update was successful)') : DI::l10n()->t('(Update was not successful)'));
                        }
-                       $lblsuggest = (($contact['network'] === Protocol::DFRN) ? L10n::t('Suggest friends') : '');
+                       $lblsuggest = (($contact['network'] === Protocol::DFRN) ? DI::l10n()->t('Suggest friends') : '');
 
                        $poll_enabled = in_array($contact['network'], [Protocol::DFRN, Protocol::OSTATUS, Protocol::FEED, Protocol::MAIL]);
 
-                       $nettype = L10n::t('Network type: %s', ContactSelector::networkToName($contact['network'], $contact['url']));
+                       $nettype = DI::l10n()->t('Network type: %s', ContactSelector::networkToName($contact['network'], $contact['url'], $contact['protocol']));
 
                        // tabs
                        $tab_str = self::getTabsHTML($a, $contact, 3);
 
-                       $lost_contact = (($contact['archive'] && $contact['term-date'] > DBA::NULL_DATETIME && $contact['term-date'] < DateTimeFormat::utcNow()) ? L10n::t('Communications lost with this contact!') : '');
+                       $lost_contact = (($contact['archive'] && $contact['term-date'] > DBA::NULL_DATETIME && $contact['term-date'] < DateTimeFormat::utcNow()) ? DI::l10n()->t('Communications lost with this contact!') : '');
 
                        $fetch_further_information = null;
                        if ($contact['network'] == Protocol::FEED) {
                                $fetch_further_information = [
                                        'fetch_further_information',
-                                       L10n::t('Fetch further information for feeds'),
+                                       DI::l10n()->t('Fetch further information for feeds'),
                                        $contact['fetch_further_information'],
-                                       L10n::t('Fetch information like preview pictures, title and teaser from the feed item. You can activate this if the feed doesn\'t contain much text. Keywords are taken from the meta header in the feed item and are posted as hash tags.'),
+                                       DI::l10n()->t('Fetch information like preview pictures, title and teaser from the feed item. You can activate this if the feed doesn\'t contain much text. Keywords are taken from the meta header in the feed item and are posted as hash tags.'),
                                        [
-                                               '0' => L10n::t('Disabled'),
-                                               '1' => L10n::t('Fetch information'),
-                                               '3' => L10n::t('Fetch keywords'),
-                                               '2' => L10n::t('Fetch information and keywords')
+                                               '0' => DI::l10n()->t('Disabled'),
+                                               '1' => DI::l10n()->t('Fetch information'),
+                                               '3' => DI::l10n()->t('Fetch keywords'),
+                                               '2' => DI::l10n()->t('Fetch information and keywords')
                                        ]
                                ];
                        }
@@ -556,87 +565,76 @@ class Contact extends BaseModule
                                $poll_interval = ContactSelector::pollInterval($contact['priority'], !$poll_enabled);
                        }
 
-                       $profile_select = null;
-                       if ($contact['network'] == Protocol::DFRN) {
-                               $profile_select = ContactSelector::profileAssign($contact['profile-id'], $contact['network'] !== Protocol::DFRN);
-                       }
-
                        // Load contactact related actions like hide, suggest, delete and others
                        $contact_actions = self::getContactActions($contact);
 
                        if ($contact['uid'] != 0) {
-                               $lbl_vis1 = L10n::t('Profile Visibility');
-                               $lbl_info1 = L10n::t('Contact Information / Notes');
-                               $contact_settings_label = L10n::t('Contact Settings');
+                               $lbl_info1 = DI::l10n()->t('Contact Information / Notes');
+                               $contact_settings_label = DI::l10n()->t('Contact Settings');
                        } else {
-                               $lbl_vis1 = null;
                                $lbl_info1 = null;
                                $contact_settings_label = null;
                        }
 
                        $tpl = Renderer::getMarkupTemplate('contact_edit.tpl');
                        $o .= Renderer::replaceMacros($tpl, [
-                               '$header'         => L10n::t('Contact'),
+                               '$header'         => DI::l10n()->t('Contact'),
                                '$tab_str'        => $tab_str,
-                               '$submit'         => L10n::t('Submit'),
-                               '$lbl_vis1'       => $lbl_vis1,
-                               '$lbl_vis2'       => L10n::t('Please choose the profile you would like to display to %s when viewing your profile securely.', $contact['name']),
+                               '$submit'         => DI::l10n()->t('Submit'),
                                '$lbl_info1'      => $lbl_info1,
-                               '$lbl_info2'      => L10n::t('Their personal note'),
+                               '$lbl_info2'      => DI::l10n()->t('Their personal note'),
                                '$reason'         => trim(Strings::escapeTags($contact['reason'])),
-                               '$infedit'        => L10n::t('Edit contact notes'),
+                               '$infedit'        => DI::l10n()->t('Edit contact notes'),
                                '$common_link'    => 'common/loc/' . local_user() . '/' . $contact['id'],
                                '$relation_text'  => $relation_text,
-                               '$visit'          => L10n::t('Visit %s\'s profile [%s]', $contact['name'], $contact['url']),
-                               '$blockunblock'   => L10n::t('Block/Unblock contact'),
-                               '$ignorecont'     => L10n::t('Ignore contact'),
-                               '$lblcrepair'     => L10n::t('Repair URL settings'),
-                               '$lblrecent'      => L10n::t('View conversations'),
+                               '$visit'          => DI::l10n()->t('Visit %s\'s profile [%s]', $contact['name'], $contact['url']),
+                               '$blockunblock'   => DI::l10n()->t('Block/Unblock contact'),
+                               '$ignorecont'     => DI::l10n()->t('Ignore contact'),
+                               '$lblrecent'      => DI::l10n()->t('View conversations'),
                                '$lblsuggest'     => $lblsuggest,
                                '$nettype'        => $nettype,
                                '$poll_interval'  => $poll_interval,
                                '$poll_enabled'   => $poll_enabled,
-                               '$lastupdtext'    => L10n::t('Last update:'),
+                               '$lastupdtext'    => DI::l10n()->t('Last update:'),
                                '$lost_contact'   => $lost_contact,
-                               '$updpub'         => L10n::t('Update public posts'),
+                               '$updpub'         => DI::l10n()->t('Update public posts'),
                                '$last_update'    => $last_update,
-                               '$udnow'          => L10n::t('Update now'),
-                               '$profile_select' => $profile_select,
+                               '$udnow'          => DI::l10n()->t('Update now'),
                                '$contact_id'     => $contact['id'],
-                               '$block_text'     => ($contact['blocked'] ? L10n::t('Unblock') : L10n::t('Block')),
-                               '$ignore_text'    => ($contact['readonly'] ? L10n::t('Unignore') : L10n::t('Ignore')),
+                               '$block_text'     => ($contact['blocked'] ? DI::l10n()->t('Unblock') : DI::l10n()->t('Block')),
+                               '$ignore_text'    => ($contact['readonly'] ? DI::l10n()->t('Unignore') : DI::l10n()->t('Ignore')),
                                '$insecure'       => (in_array($contact['network'], [Protocol::ACTIVITYPUB, Protocol::DFRN, Protocol::MAIL, Protocol::DIASPORA]) ? '' : $insecure),
                                '$info'           => $contact['info'],
                                '$cinfo'          => ['info', '', $contact['info'], ''],
-                               '$blocked'        => ($contact['blocked'] ? L10n::t('Currently blocked') : ''),
-                               '$ignored'        => ($contact['readonly'] ? L10n::t('Currently ignored') : ''),
-                               '$archived'       => ($contact['archive'] ? L10n::t('Currently archived') : ''),
-                               '$pending'        => ($contact['pending'] ? L10n::t('Awaiting connection acknowledge') : ''),
-                               '$hidden'         => ['hidden', L10n::t('Hide this contact from others'), ($contact['hidden'] == 1), L10n::t('Replies/likes to your public posts <strong>may</strong> still be visible')],
-                               '$notify'         => ['notify', L10n::t('Notification for new posts'), ($contact['notify_new_posts'] == 1), L10n::t('Send a notification of every new post of this contact')],
+                               '$blocked'        => ($contact['blocked'] ? DI::l10n()->t('Currently blocked') : ''),
+                               '$ignored'        => ($contact['readonly'] ? DI::l10n()->t('Currently ignored') : ''),
+                               '$archived'       => ($contact['archive'] ? DI::l10n()->t('Currently archived') : ''),
+                               '$pending'        => ($contact['pending'] ? DI::l10n()->t('Awaiting connection acknowledge') : ''),
+                               '$hidden'         => ['hidden', DI::l10n()->t('Hide this contact from others'), ($contact['hidden'] == 1), DI::l10n()->t('Replies/likes to your public posts <strong>may</strong> still be visible')],
+                               '$notify'         => ['notify', DI::l10n()->t('Notification for new posts'), ($contact['notify_new_posts'] == 1), DI::l10n()->t('Send a notification of every new post of this contact')],
                                '$fetch_further_information' => $fetch_further_information,
-                               '$ffi_keyword_blacklist' => ['ffi_keyword_blacklist', L10n::t('Blacklisted keywords'), $contact['ffi_keyword_blacklist'], L10n::t('Comma separated list of keywords that should not be converted to hashtags, when "Fetch information and keywords" is selected')],
+                               '$ffi_keyword_denylist' => ['ffi_keyword_denylist', DI::l10n()->t('Keyword Deny List'), $contact['ffi_keyword_denylist'], DI::l10n()->t('Comma separated list of keywords that should not be converted to hashtags, when "Fetch information and keywords" is selected')],
                                '$photo'          => $contact['photo'],
                                '$name'           => $contact['name'],
                                '$dir_icon'       => $dir_icon,
                                '$sparkle'        => $sparkle,
                                '$url'            => $url,
-                               '$profileurllabel'=> L10n::t('Profile URL'),
+                               '$profileurllabel'=> DI::l10n()->t('Profile URL'),
                                '$profileurl'     => $contact['url'],
                                '$account_type'   => Model\Contact::getAccountType($contact),
                                '$location'       => BBCode::convert($contact['location']),
-                               '$location_label' => L10n::t('Location:'),
+                               '$location_label' => DI::l10n()->t('Location:'),
                                '$xmpp'           => BBCode::convert($contact['xmpp']),
-                               '$xmpp_label'     => L10n::t('XMPP:'),
+                               '$xmpp_label'     => DI::l10n()->t('XMPP:'),
                                '$about'          => BBCode::convert($contact['about'], false),
-                               '$about_label'    => L10n::t('About:'),
+                               '$about_label'    => DI::l10n()->t('About:'),
                                '$keywords'       => $contact['keywords'],
-                               '$keywords_label' => L10n::t('Tags:'),
-                               '$contact_action_button' => L10n::t('Actions'),
+                               '$keywords_label' => DI::l10n()->t('Tags:'),
+                               '$contact_action_button' => DI::l10n()->t('Actions'),
                                '$contact_actions'=> $contact_actions,
-                               '$contact_status' => L10n::t('Status'),
+                               '$contact_status' => DI::l10n()->t('Status'),
                                '$contact_settings_label' => $contact_settings_label,
-                               '$contact_profile_label' => L10n::t('Profile'),
+                               '$contact_profile_label' => DI::l10n()->t('Profile'),
                        ]);
 
                        $arr = ['contact' => $contact, 'output' => $o];
@@ -646,165 +644,191 @@ class Contact extends BaseModule
                        return $arr['output'];
                }
 
-               $select_uid = local_user();
+               $sql_values = [local_user()];
 
                // @TODO: Replace with parameter from router
                $type = $a->argv[1] ?? '';
 
                switch ($type) {
                        case 'blocked':
-                               $sql_extra = sprintf(" AND EXISTS(SELECT `id` from `user-contact` WHERE `contact`.`id` = `user-contact`.`cid` and `user-contact`.`uid` = %d and `user-contact`.`blocked`)", intval(local_user()));
-                               $select_uid = 0;
+                               $sql_extra = " AND EXISTS(SELECT `id` from `user-contact` WHERE `contact`.`id` = `user-contact`.`cid` and `user-contact`.`uid` = ? and `user-contact`.`blocked`)";
+                               // This makes the query look for contact.uid = 0
+                               array_unshift($sql_values, 0);
                                break;
                        case 'hidden':
                                $sql_extra = " AND `hidden` AND NOT `blocked` AND NOT `pending`";
                                break;
                        case 'ignored':
-                               $sql_extra = sprintf(" AND EXISTS(SELECT `id` from `user-contact` WHERE `contact`.`id` = `user-contact`.`cid` and `user-contact`.`uid` = %d and `user-contact`.`ignored`)", intval(local_user()));
-                               $select_uid = 0;
+                               $sql_extra = " AND EXISTS(SELECT `id` from `user-contact` WHERE `contact`.`id` = `user-contact`.`cid` and `user-contact`.`uid` = ? and `user-contact`.`ignored`)";
+                               // This makes the query look for contact.uid = 0
+                               array_unshift($sql_values, 0);
                                break;
                        case 'archived':
                                $sql_extra = " AND `archive` AND NOT `blocked` AND NOT `pending`";
                                break;
                        case 'pending':
-                               $sql_extra = sprintf(" AND `pending` AND NOT `archive` AND ((`rel` = %d)
-                                       OR EXISTS (SELECT `id` FROM `intro` WHERE `contact-id` = `contact`.`id` AND NOT `ignore`))", Model\Contact::SHARING);
+                               $sql_extra = " AND `pending` AND NOT `archive` AND ((`rel` = ?)
+                                       OR EXISTS (SELECT `id` FROM `intro` WHERE `contact-id` = `contact`.`id` AND NOT `ignore`))";
+                               $sql_values[] = Model\Contact::SHARING;
                                break;
                        default:
                                $sql_extra = " AND NOT `archive` AND NOT `blocked` AND NOT `pending`";
+                               break;
                }
 
-               $sql_extra .= sprintf(" AND `network` != '%s' ", Protocol::PHANTOM);
+               $searching = false;
+               $search_hdr = null;
+               if ($search) {
+                       $searching = true;
+                       $search_hdr = $search;
+                       $search_txt = preg_quote($search);
+                       $sql_extra .= " AND (name REGEXP ? OR url REGEXP ? OR nick REGEXP ?)";
+                       $sql_values[] = $search_txt;
+                       $sql_values[] = $search_txt;
+                       $sql_values[] = $search_txt;
+               }
 
-               $search = Strings::escapeTags(trim($_GET['search'] ?? ''));
-               $nets   = Strings::escapeTags(trim($_GET['nets']   ?? ''));
-               $rel    = Strings::escapeTags(trim($_GET['rel']    ?? ''));
+               if ($nets) {
+                       $sql_extra .= " AND network = ? ";
+                       $sql_values[] = $nets;
+               }
+
+               switch ($rel) {
+                       case 'followers':
+                               $sql_extra .= " AND `rel` IN (?, ?)";
+                               $sql_values[] = Model\Contact::FOLLOWER;
+                               $sql_values[] = Model\Contact::FRIEND;
+                               break;
+                       case 'following':
+                               $sql_extra .= " AND `rel` IN (?, ?)";
+                               $sql_values[] = Model\Contact::SHARING;
+                               $sql_values[] = Model\Contact::FRIEND;
+                               break;
+                       case 'mutuals':
+                               $sql_extra .= " AND `rel` = ?";
+                               $sql_values[] = Model\Contact::FRIEND;
+                               break;
+               }
+
+               if ($group) {
+                       $sql_extra = " AND EXISTS(SELECT `id` FROM `group_member` WHERE `gid` = ? AND `contact`.`id` = `contact-id`)";
+                       $sql_values[] = $group;
+               }
+
+               $total = 0;
+               $stmt = DBA::p("SELECT COUNT(*) AS `total`
+                       FROM `contact`
+                       WHERE `uid` = ?
+                       AND `self` = 0
+                       AND NOT `deleted`
+                       $sql_extra
+                       " . Widget::unavailableNetworks(),
+                       $sql_values
+               );
+               if (DBA::isResult($stmt)) {
+                       $total = DBA::fetch($stmt)['total'];
+               }
+               DBA::close($stmt);
+
+               $pager = new Pager(DI::l10n(), DI::args()->getQueryString());
+
+               $sql_values[] = $pager->getStart();
+               $sql_values[] = $pager->getItemsPerPage();
+
+               $contacts = [];
+
+               $stmt = DBA::p("SELECT *
+                       FROM `contact`
+                       WHERE `uid` = ?
+                       AND `self` = 0
+                       AND NOT `deleted`
+                       $sql_extra
+                       ORDER BY `name` ASC
+                       LIMIT ?, ?",
+                       $sql_values
+               );
+               while ($contact = DBA::fetch($stmt)) {
+                       $contact['blocked'] = Model\Contact::isBlockedByUser($contact['id'], local_user());
+                       $contact['readonly'] = Model\Contact::isIgnoredByUser($contact['id'], local_user());
+                       $contacts[] = self::getContactTemplateVars($contact);
+               }
+               DBA::close($stmt);
 
                $tabs = [
                        [
-                               'label' => L10n::t('All Contacts'),
+                               'label' => DI::l10n()->t('All Contacts'),
                                'url'   => 'contact',
                                'sel'   => !$type ? 'active' : '',
-                               'title' => L10n::t('Show all contacts'),
+                               'title' => DI::l10n()->t('Show all contacts'),
                                'id'    => 'showall-tab',
                                'accesskey' => 'l',
                        ],
                        [
-                               'label' => L10n::t('Pending'),
+                               'label' => DI::l10n()->t('Pending'),
                                'url'   => 'contact/pending',
                                'sel'   => $type == 'pending' ? 'active' : '',
-                               'title' => L10n::t('Only show pending contacts'),
+                               'title' => DI::l10n()->t('Only show pending contacts'),
                                'id'    => 'showpending-tab',
                                'accesskey' => 'p',
                        ],
                        [
-                               'label' => L10n::t('Blocked'),
+                               'label' => DI::l10n()->t('Blocked'),
                                'url'   => 'contact/blocked',
                                'sel'   => $type == 'blocked' ? 'active' : '',
-                               'title' => L10n::t('Only show blocked contacts'),
+                               'title' => DI::l10n()->t('Only show blocked contacts'),
                                'id'    => 'showblocked-tab',
                                'accesskey' => 'b',
                        ],
                        [
-                               'label' => L10n::t('Ignored'),
+                               'label' => DI::l10n()->t('Ignored'),
                                'url'   => 'contact/ignored',
                                'sel'   => $type == 'ignored' ? 'active' : '',
-                               'title' => L10n::t('Only show ignored contacts'),
+                               'title' => DI::l10n()->t('Only show ignored contacts'),
                                'id'    => 'showignored-tab',
                                'accesskey' => 'i',
                        ],
                        [
-                               'label' => L10n::t('Archived'),
+                               'label' => DI::l10n()->t('Archived'),
                                'url'   => 'contact/archived',
                                'sel'   => $type == 'archived' ? 'active' : '',
-                               'title' => L10n::t('Only show archived contacts'),
+                               'title' => DI::l10n()->t('Only show archived contacts'),
                                'id'    => 'showarchived-tab',
                                'accesskey' => 'y',
                        ],
                        [
-                               'label' => L10n::t('Hidden'),
+                               'label' => DI::l10n()->t('Hidden'),
                                'url'   => 'contact/hidden',
                                'sel'   => $type == 'hidden' ? 'active' : '',
-                               'title' => L10n::t('Only show hidden contacts'),
+                               'title' => DI::l10n()->t('Only show hidden contacts'),
                                'id'    => 'showhidden-tab',
                                'accesskey' => 'h',
                        ],
                        [
-                               'label' => L10n::t('Groups'),
+                               'label' => DI::l10n()->t('Groups'),
                                'url'   => 'group',
                                'sel'   => '',
-                               'title' => L10n::t('Organize your contact groups'),
+                               'title' => DI::l10n()->t('Organize your contact groups'),
                                'id'    => 'contactgroups-tab',
                                'accesskey' => 'e',
                        ],
                ];
 
-               $tab_tpl = Renderer::getMarkupTemplate('common_tabs.tpl');
-               $t = Renderer::replaceMacros($tab_tpl, ['$tabs' => $tabs]);
-
-               $total = 0;
-               $searching = false;
-               $search_hdr = null;
-               if ($search) {
-                       $searching = true;
-                       $search_hdr = $search;
-                       $search_txt = DBA::escape(Strings::protectSprintf(preg_quote($search)));
-                       $sql_extra .= " AND (name REGEXP '$search_txt' OR url REGEXP '$search_txt'  OR nick REGEXP '$search_txt') ";
-               }
-
-               if ($nets) {
-                       $sql_extra .= sprintf(" AND network = '%s' ", DBA::escape($nets));
-               }
+               $tabs_tpl = Renderer::getMarkupTemplate('common_tabs.tpl');
+               $tabs_html = Renderer::replaceMacros($tabs_tpl, ['$tabs' => $tabs]);
 
                switch ($rel) {
-                       case 'followers': $sql_extra .= " AND `rel` IN (1, 3)"; break;
-                       case 'following': $sql_extra .= " AND `rel` IN (2, 3)"; break;
-                       case 'mutuals': $sql_extra .= " AND `rel` = 3"; break;
-               }
-
-               $sql_extra .=  " AND NOT `deleted` ";
-
-               $sql_extra2 = ((($sort_type > 0) && ($sort_type <= Model\Contact::FRIEND)) ? sprintf(" AND `rel` = %d ", intval($sort_type)) : '');
-
-               $sql_extra3 = Widget::unavailableNetworks();
-
-               $r = q("SELECT COUNT(*) AS `total` FROM `contact`
-                       WHERE `uid` = %d AND `self` = 0 $sql_extra $sql_extra2 $sql_extra3",
-                       intval($select_uid)
-               );
-               if (DBA::isResult($r)) {
-                       $total = $r[0]['total'];
-               }
-               $pager = new Pager($a->query_string);
-
-               $contacts = [];
-
-               $r = q("SELECT * FROM `contact` WHERE `uid` = %d AND `self` = 0 $sql_extra $sql_extra2 $sql_extra3 ORDER BY `name` ASC LIMIT %d , %d ",
-                       intval($select_uid),
-                       $pager->getStart(),
-                       $pager->getItemsPerPage()
-               );
-               if (DBA::isResult($r)) {
-                       foreach ($r as $rr) {
-                               $rr['blocked'] = Model\Contact::isBlockedByUser($rr['id'], local_user());
-                               $rr['readonly'] = Model\Contact::isIgnoredByUser($rr['id'], local_user());
-                               $contacts[] = self::getContactTemplateVars($rr);
-                       }
-               }
-
-               switch ($rel) {
-                       case 'followers': $header = L10n::t('Followers'); break;
-                       case 'following': $header = L10n::t('Following'); break;
-                       case 'mutuals':   $header = L10n::t('Mutual friends'); break;
-                       default:          $header = L10n::t('Contacts');
+                       case 'followers': $header = DI::l10n()->t('Followers'); break;
+                       case 'following': $header = DI::l10n()->t('Following'); break;
+                       case 'mutuals':   $header = DI::l10n()->t('Mutual friends'); break;
+                       default:          $header = DI::l10n()->t('Contacts');
                }
 
                switch ($type) {
-                       case 'pending':  $header .= ' - ' . L10n::t('Pending'); break;
-                       case 'blocked':  $header .= ' - ' . L10n::t('Blocked'); break;
-                       case 'hidden':   $header .= ' - ' . L10n::t('Hidden'); break;
-                       case 'ignored':  $header .= ' - ' . L10n::t('Ignored'); break;
-                       case 'archived': $header .= ' - ' . L10n::t('Archived'); break;
+                       case 'pending':  $header .= ' - ' . DI::l10n()->t('Pending'); break;
+                       case 'blocked':  $header .= ' - ' . DI::l10n()->t('Blocked'); break;
+                       case 'hidden':   $header .= ' - ' . DI::l10n()->t('Hidden'); break;
+                       case 'ignored':  $header .= ' - ' . DI::l10n()->t('Ignored'); break;
+                       case 'archived': $header .= ' - ' . DI::l10n()->t('Archived'); break;
                }
 
                $header .= $nets ? ' - ' . ContactSelector::networkToName($nets) : '';
@@ -812,24 +836,24 @@ class Contact extends BaseModule
                $tpl = Renderer::getMarkupTemplate('contacts-template.tpl');
                $o .= Renderer::replaceMacros($tpl, [
                        '$header'     => $header,
-                       '$tabs'       => $t,
+                       '$tabs'       => $tabs_html,
                        '$total'      => $total,
                        '$search'     => $search_hdr,
-                       '$desc'       => L10n::t('Search your contacts'),
-                       '$finding'    => $searching ? L10n::t('Results for: %s', $search) : '',
-                       '$submit'     => L10n::t('Find'),
-                       '$cmd'        => $a->cmd,
+                       '$desc'       => DI::l10n()->t('Search your contacts'),
+                       '$finding'    => $searching ? DI::l10n()->t('Results for: %s', $search) : '',
+                       '$submit'     => DI::l10n()->t('Find'),
+                       '$cmd'        => DI::args()->getCommand(),
                        '$contacts'   => $contacts,
-                       '$contact_drop_confirm' => L10n::t('Do you really want to delete this contact?'),
+                       '$contact_drop_confirm' => DI::l10n()->t('Do you really want to delete this contact?'),
                        'multiselect' => 1,
                        '$batch_actions' => [
-                               'contacts_batch_update'  => L10n::t('Update'),
-                               'contacts_batch_block'   => L10n::t('Block') . '/' . L10n::t('Unblock'),
-                               'contacts_batch_ignore'  => L10n::t('Ignore') . '/' . L10n::t('Unignore'),
-                               'contacts_batch_archive' => L10n::t('Archive') . '/' . L10n::t('Unarchive'),
-                               'contacts_batch_drop'    => L10n::t('Delete'),
+                               'contacts_batch_update'  => DI::l10n()->t('Update'),
+                               'contacts_batch_block'   => DI::l10n()->t('Block') . '/' . DI::l10n()->t('Unblock'),
+                               'contacts_batch_ignore'  => DI::l10n()->t('Ignore') . '/' . DI::l10n()->t('Unignore'),
+                               'contacts_batch_archive' => DI::l10n()->t('Archive') . '/' . DI::l10n()->t('Unarchive'),
+                               'contacts_batch_drop'    => DI::l10n()->t('Delete'),
                        ],
-                       '$h_batch_actions' => L10n::t('Batch Actions'),
+                       '$h_batch_actions' => DI::l10n()->t('Batch Actions'),
                        '$paginate'   => $pager->renderFull($total),
                ]);
 
@@ -837,7 +861,7 @@ class Contact extends BaseModule
        }
 
        /**
-        * @brief List of pages for the Contact TabBar
+        * List of pages for the Contact TabBar
         *
         * Available Pages are 'Status', 'Profile', 'Contacts' and 'Common Friends'
         *
@@ -853,26 +877,26 @@ class Contact extends BaseModule
                // tabs
                $tabs = [
                        [
-                               'label' => L10n::t('Status'),
+                               'label' => DI::l10n()->t('Status'),
                                'url'   => "contact/" . $contact['id'] . "/conversations",
                                'sel'   => (($active_tab == 1) ? 'active' : ''),
-                               'title' => L10n::t('Conversations started by this contact'),
+                               'title' => DI::l10n()->t('Conversations started by this contact'),
                                'id'    => 'status-tab',
                                'accesskey' => 'm',
                        ],
                        [
-                               'label' => L10n::t('Posts and Comments'),
+                               'label' => DI::l10n()->t('Posts and Comments'),
                                'url'   => "contact/" . $contact['id'] . "/posts",
                                'sel'   => (($active_tab == 2) ? 'active' : ''),
-                               'title' => L10n::t('Status Messages and Posts'),
+                               'title' => DI::l10n()->t('Status Messages and Posts'),
                                'id'    => 'posts-tab',
                                'accesskey' => 'p',
                        ],
                        [
-                               'label' => L10n::t('Profile'),
+                               'label' => DI::l10n()->t('Profile'),
                                'url'   => "contact/" . $contact['id'],
                                'sel'   => (($active_tab == 3) ? 'active' : ''),
-                               'title' => L10n::t('Profile Details'),
+                               'title' => DI::l10n()->t('Profile Details'),
                                'id'    => 'profile-tab',
                                'accesskey' => 'o',
                        ]
@@ -881,10 +905,10 @@ class Contact extends BaseModule
                // Show this tab only if there is visible friend list
                $x = Model\GContact::countAllFriends(local_user(), $contact['id']);
                if ($x) {
-                       $tabs[] = ['label' => L10n::t('Contacts'),
+                       $tabs[] = ['label' => DI::l10n()->t('Contacts'),
                                'url'   => "allfriends/" . $contact['id'],
                                'sel'   => (($active_tab == 4) ? 'active' : ''),
-                               'title' => L10n::t('View all contacts'),
+                               'title' => DI::l10n()->t('View all contacts'),
                                'id'    => 'allfriends-tab',
                                'accesskey' => 't'];
                }
@@ -892,20 +916,20 @@ class Contact extends BaseModule
                // Show this tab only if there is visible common friend list
                $common = Model\GContact::countCommonFriends(local_user(), $contact['id']);
                if ($common) {
-                       $tabs[] = ['label' => L10n::t('Common Friends'),
+                       $tabs[] = ['label' => DI::l10n()->t('Common Friends'),
                                'url'   => "common/loc/" . local_user() . "/" . $contact['id'],
                                'sel'   => (($active_tab == 5) ? 'active' : ''),
-                               'title' => L10n::t('View all common friends'),
+                               'title' => DI::l10n()->t('View all common friends'),
                                'id'    => 'common-loc-tab',
                                'accesskey' => 'd'
                        ];
                }
 
                if (!empty($contact['uid'])) {
-                       $tabs[] = ['label' => L10n::t('Advanced'),
-                               'url'   => 'crepair/' . $contact['id'],
+                       $tabs[] = ['label' => DI::l10n()->t('Advanced'),
+                               'url'   => 'contact/' . $contact['id'] . '/advanced/',
                                'sel'   => (($active_tab == 6) ? 'active' : ''),
-                               'title' => L10n::t('Advanced Contact Settings'),
+                               'title' => DI::l10n()->t('Advanced Contact Settings'),
                                'id'    => 'advanced-tab',
                                'accesskey' => 'r'
                        ];
@@ -930,7 +954,7 @@ class Contact extends BaseModule
                                        'default_location' => $a->user['default-location'],
                                        'nickname' => $a->user['nickname'],
                                        'lockstate' => (is_array($a->user) && (strlen($a->user['allow_cid']) || strlen($a->user['allow_gid']) || strlen($a->user['deny_cid']) || strlen($a->user['deny_gid'])) ? 'lock' : 'unlock'),
-                                       'acl' => ACL::getFullSelectorHTML($a->page, $a->user, true),
+                                       'acl' => ACL::getFullSelectorHTML(DI::page(), $a->user, true),
                                        'bang' => '',
                                        'visitor' => 'block',
                                        'profile_uid' => local_user(),
@@ -946,12 +970,17 @@ class Contact extends BaseModule
                }
 
                if (DBA::isResult($contact)) {
-                       $a->page['aside'] = '';
+                       DI::page()['aside'] = '';
 
-                       $profiledata = Model\Contact::getDetailsByURL($contact['url']);
+                       $profiledata = Model\Contact::getByURL($contact['url'], false);
 
-                       Model\Profile::load($a, '', 0, $profiledata, true);
-                       $o .= Model\Contact::getPostsFromUrl($contact['url'], true, $update);
+                       Model\Profile::load($a, '', $profiledata, true);
+
+                       if ($contact['uid'] == 0) {
+                               $o .= Model\Contact::getPostsFromId($contact['id'], true, $update);
+                       } else {
+                               $o .= Model\Contact::getPostsFromUrl($contact['url'], true, $update);
+                       }
                }
 
                return $o;
@@ -964,16 +993,21 @@ class Contact extends BaseModule
                $o = self::getTabsHTML($a, $contact, 2);
 
                if (DBA::isResult($contact)) {
-                       $a->page['aside'] = '';
+                       DI::page()['aside'] = '';
 
-                       $profiledata = Model\Contact::getDetailsByURL($contact['url']);
+                       $profiledata = Model\Contact::getByURL($contact['url'], false);
 
                        if (local_user() && in_array($profiledata['network'], Protocol::FEDERATED)) {
-                               $profiledata['remoteconnect'] = System::baseUrl() . '/follow?url=' . urlencode($profiledata['url']);
+                               $profiledata['remoteconnect'] = DI::baseUrl() . '/follow?url=' . urlencode($profiledata['url']);
                        }
 
-                       Model\Profile::load($a, '', 0, $profiledata, true);
-                       $o .= Model\Contact::getPostsFromUrl($contact['url']);
+                       Model\Profile::load($a, '', $profiledata, true);
+
+                       if ($contact['uid'] == 0) {
+                               $o .= Model\Contact::getPostsFromId($contact['id']);
+                       } else {
+                               $o .= Model\Contact::getPostsFromUrl($contact['url']);
+                       }
                }
 
                return $o;
@@ -988,17 +1022,17 @@ class Contact extends BaseModule
                        switch ($rr['rel']) {
                                case Model\Contact::FRIEND:
                                        $dir_icon = 'images/lrarrow.gif';
-                                       $alt_text = L10n::t('Mutual Friendship');
+                                       $alt_text = DI::l10n()->t('Mutual Friendship');
                                        break;
 
                                case Model\Contact::FOLLOWER;
                                        $dir_icon = 'images/larrow.gif';
-                                       $alt_text = L10n::t('is a fan of yours');
+                                       $alt_text = DI::l10n()->t('is a fan of yours');
                                        break;
 
                                case Model\Contact::SHARING;
                                        $dir_icon = 'images/rarrow.gif';
-                                       $alt_text = L10n::t('you are a fan of');
+                                       $alt_text = DI::l10n()->t('you are a fan of');
                                        break;
 
                                default:
@@ -1016,22 +1050,22 @@ class Contact extends BaseModule
 
                if ($rr['pending']) {
                        if (in_array($rr['rel'], [Model\Contact::FRIEND, Model\Contact::SHARING])) {
-                               $alt_text = L10n::t('Pending outgoing contact request');
+                               $alt_text = DI::l10n()->t('Pending outgoing contact request');
                        } else {
-                               $alt_text = L10n::t('Pending incoming contact request');
+                               $alt_text = DI::l10n()->t('Pending incoming contact request');
                        }
                }
 
                if ($rr['self']) {
                        $dir_icon = 'images/larrow.gif';
-                       $alt_text = L10n::t('This is you');
+                       $alt_text = DI::l10n()->t('This is you');
                        $url = $rr['url'];
                        $sparkle = '';
                }
 
                return [
-                       'img_hover' => L10n::t('Visit %s\'s profile [%s]', $rr['name'], $rr['url']),
-                       'edit_hover'=> L10n::t('Edit contact'),
+                       'img_hover' => DI::l10n()->t('Visit %s\'s profile [%s]', $rr['name'], $rr['url']),
+                       'edit_hover'=> DI::l10n()->t('Edit contact'),
                        'photo_menu'=> Model\Contact::photoMenu($rr),
                        'id'        => $rr['id'],
                        'alt_text'  => $alt_text,
@@ -1043,13 +1077,13 @@ class Contact extends BaseModule
                        'sparkle'   => $sparkle,
                        'itemurl'   => ($rr['addr'] ?? '') ?: $rr['url'],
                        'url'       => $url,
-                       'network'   => ContactSelector::networkToName($rr['network'], $rr['url']),
+                       'network'   => ContactSelector::networkToName($rr['network'], $rr['url'], $rr['protocol']),
                        'nick'      => $rr['nick'],
                ];
        }
 
        /**
-        * @brief Gives a array with actions which can performed to a given contact
+        * Gives a array with actions which can performed to a given contact
         *
         * This includes actions like e.g. 'block', 'hide', 'archive', 'delete' and others
         *
@@ -1064,7 +1098,7 @@ class Contact extends BaseModule
                // Provide friend suggestion only for Friendica contacts
                if ($contact['network'] === Protocol::DFRN) {
                        $contact_actions['suggest'] = [
-                               'label' => L10n::t('Suggest friends'),
+                               'label' => DI::l10n()->t('Suggest friends'),
                                'url'   => 'fsuggest/' . $contact['id'],
                                'title' => '',
                                'sel'   => '',
@@ -1074,7 +1108,7 @@ class Contact extends BaseModule
 
                if ($poll_enabled) {
                        $contact_actions['update'] = [
-                               'label' => L10n::t('Update now'),
+                               'label' => DI::l10n()->t('Update now'),
                                'url'   => 'contact/' . $contact['id'] . '/update',
                                'title' => '',
                                'sel'   => '',
@@ -1083,34 +1117,34 @@ class Contact extends BaseModule
                }
 
                $contact_actions['block'] = [
-                       'label' => (intval($contact['blocked']) ? L10n::t('Unblock') : L10n::t('Block')),
+                       'label' => (intval($contact['blocked']) ? DI::l10n()->t('Unblock') : DI::l10n()->t('Block')),
                        'url'   => 'contact/' . $contact['id'] . '/block',
-                       'title' => L10n::t('Toggle Blocked status'),
+                       'title' => DI::l10n()->t('Toggle Blocked status'),
                        'sel'   => (intval($contact['blocked']) ? 'active' : ''),
                        'id'    => 'toggle-block',
                ];
 
                $contact_actions['ignore'] = [
-                       'label' => (intval($contact['readonly']) ? L10n::t('Unignore') : L10n::t('Ignore')),
+                       'label' => (intval($contact['readonly']) ? DI::l10n()->t('Unignore') : DI::l10n()->t('Ignore')),
                        'url'   => 'contact/' . $contact['id'] . '/ignore',
-                       'title' => L10n::t('Toggle Ignored status'),
+                       'title' => DI::l10n()->t('Toggle Ignored status'),
                        'sel'   => (intval($contact['readonly']) ? 'active' : ''),
                        'id'    => 'toggle-ignore',
                ];
 
                if ($contact['uid'] != 0) {
                        $contact_actions['archive'] = [
-                               'label' => (intval($contact['archive']) ? L10n::t('Unarchive') : L10n::t('Archive')),
+                               'label' => (intval($contact['archive']) ? DI::l10n()->t('Unarchive') : DI::l10n()->t('Archive')),
                                'url'   => 'contact/' . $contact['id'] . '/archive',
-                               'title' => L10n::t('Toggle Archive status'),
+                               'title' => DI::l10n()->t('Toggle Archive status'),
                                'sel'   => (intval($contact['archive']) ? 'active' : ''),
                                'id'    => 'toggle-archive',
                        ];
 
                        $contact_actions['delete'] = [
-                               'label' => L10n::t('Delete'),
+                               'label' => DI::l10n()->t('Delete'),
                                'url'   => 'contact/' . $contact['id'] . '/drop',
-                               'title' => L10n::t('Delete contact'),
+                               'title' => DI::l10n()->t('Delete contact'),
                                'sel'   => '',
                                'id'    => 'delete',
                        ];