X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=mod%2Fviewcontacts.php;h=563c13c6d4ada9ccc0242731ff29f650147e38e3;hb=7c73e8634c954cc2bd0d1138729459d7d5090f62;hp=a918c1ae57963eb06ce1f188f8c5863bdc2e0805;hpb=e36f2bb1fb3439e9993c7568e57140c4f954b772;p=friendica.git diff --git a/mod/viewcontacts.php b/mod/viewcontacts.php index a918c1ae57..563c13c6d4 100644 --- a/mod/viewcontacts.php +++ b/mod/viewcontacts.php @@ -4,53 +4,60 @@ */ use Friendica\App; use Friendica\Content\ContactSelector; +use Friendica\Content\Nav; use Friendica\Core\Config; -use Friendica\Database\DBM; +use Friendica\Core\L10n; +use Friendica\Core\Protocol; +use Friendica\Database\DBA; use Friendica\Model\Contact; use Friendica\Model\Profile; +use Friendica\Util\Proxy as ProxyUtils; +use Friendica\Core\System; -function viewcontacts_init(App $a) { - - if((Config::get('system','block_public')) && (! local_user()) && (! remote_user())) { - return; +function viewcontacts_init(App $a) +{ + if (Config::get('system', 'block_public') && !local_user() && !remote_user()) { + System::httpExit(403, ["title" => L10n::t('Access denied.')]); } - nav_set_selected('home'); - - if($a->argc > 1) { - $nick = $a->argv[1]; - $r = q("SELECT * FROM `user` WHERE `nickname` = '%s' AND `blocked` = 0 LIMIT 1", - dbesc($nick) - ); + if ($a->argc < 2) { + System::httpExit(403, ["title" => L10n::t('Access denied.')]); + } - if (! DBM::is_result($r)) { - return; - } + Nav::setSelected('home'); - $a->data['user'] = $r[0]; - $a->profile_uid = $r[0]['uid']; - $is_owner = (local_user() && (local_user() == $a->profile_uid)); + $nick = $a->argv[1]; + $r = q("SELECT * FROM `user` WHERE `nickname` = '%s' AND `blocked` = 0 LIMIT 1", + DBA::escape($nick) + ); - Profile::load($a, $a->argv[1]); + if (!DBA::isResult($r)) { + System::httpExit(404, ["title" => L10n::t('Page not found.')]); } -} + $a->data['user'] = $r[0]; + $a->profile_uid = $r[0]['uid']; + $is_owner = (local_user() && (local_user() == $a->profile_uid)); -function viewcontacts_content(App $a) { - require_once("mod/proxy.php"); + Profile::load($a, $a->argv[1]); +} - if((Config::get('system','block_public')) && (! local_user()) && (! remote_user())) { - notice( t('Public access denied.') . EOL); +function viewcontacts_content(App $a) +{ + if (Config::get('system', 'block_public') && !local_user() && !remote_user()) { + notice(L10n::t('Public access denied.') . EOL); return; } + $is_owner = $a->profile['profile_uid'] == local_user(); + $o = ""; // tabs $o .= Profile::getTabs($a, $is_owner, $a->data['user']['nickname']); - if(((! count($a->profile)) || ($a->profile['hide-friends']))) { - notice( t('Permission denied.') . EOL); + if (!count($a->profile) || $a->profile['hide-friends']) { + notice(L10n::t('Permission denied.') . EOL); return $o; } @@ -59,12 +66,13 @@ function viewcontacts_content(App $a) { AND NOT `hidden` AND NOT `archive` AND `network` IN ('%s', '%s', '%s')", intval($a->profile['uid']), - dbesc(NETWORK_DFRN), - dbesc(NETWORK_DIASPORA), - dbesc(NETWORK_OSTATUS) + DBA::escape(Protocol::DFRN), + DBA::escape(Protocol::DIASPORA), + DBA::escape(Protocol::OSTATUS) ); - if (DBM::is_result($r)) - $a->set_pager_total($r[0]['total']); + if (DBA::isResult($r)) { + $a->setPagerTotal($r[0]['total']); + } $r = q("SELECT * FROM `contact` WHERE `uid` = %d AND NOT `blocked` AND NOT `pending` @@ -72,14 +80,14 @@ function viewcontacts_content(App $a) { AND `network` IN ('%s', '%s', '%s') ORDER BY `name` ASC LIMIT %d, %d", intval($a->profile['uid']), - dbesc(NETWORK_DFRN), - dbesc(NETWORK_DIASPORA), - dbesc(NETWORK_OSTATUS), + DBA::escape(Protocol::DFRN), + DBA::escape(Protocol::DIASPORA), + DBA::escape(Protocol::OSTATUS), intval($a->pager['start']), intval($a->pager['itemspage']) ); - if (!DBM::is_result($r)) { - info(t('No contacts.').EOL); + if (!DBA::isResult($r)) { + info(L10n::t('No contacts.').EOL); return $o; } @@ -91,31 +99,20 @@ function viewcontacts_content(App $a) { continue; } - $url = $rr['url']; - - // route DFRN profiles through the redirect - - $is_owner = ((local_user() && ($a->profile['profile_uid'] == local_user())) ? true : false); - - if($is_owner && ($rr['network'] === NETWORK_DFRN) && ($rr['rel'])) - $url = 'redir/' . $rr['id']; - else - $url = Profile::zrl($url); - $contact_details = Contact::getDetailsByURL($rr['url'], $a->profile['uid'], $rr); $contacts[] = [ 'id' => $rr['id'], - 'img_hover' => sprintf( t('Visit %s\'s profile [%s]'), $contact_details['name'], $rr['url']), + 'img_hover' => L10n::t('Visit %s\'s profile [%s]', $contact_details['name'], $rr['url']), 'photo_menu' => Contact::photoMenu($rr), - 'thumb' => proxy_url($contact_details['thumb'], false, PROXY_SIZE_THUMB), - 'name' => htmlentities(substr($contact_details['name'],0,20)), + 'thumb' => ProxyUtils::proxifyUrl($contact_details['thumb'], false, ProxyUtils::SIZE_THUMB), + 'name' => htmlentities(substr($contact_details['name'], 0, 20)), 'username' => htmlentities($contact_details['name']), 'details' => $contact_details['location'], 'tags' => $contact_details['keywords'], 'about' => $contact_details['about'], 'account_type' => Contact::getAccountType($contact_details), - 'url' => $url, + 'url' => Contact::magicLink($rr['url']), 'sparkle' => '', 'itemurl' => (($contact_details['addr'] != "") ? $contact_details['addr'] : $rr['url']), 'network' => ContactSelector::networkToName($rr['network'], $rr['url']), @@ -125,11 +122,10 @@ function viewcontacts_content(App $a) { $tpl = get_markup_template("viewcontact_template.tpl"); $o .= replace_macros($tpl, [ - '$title' => t('Contacts'), + '$title' => L10n::t('Contacts'), '$contacts' => $contacts, '$paginate' => paginate($a), ]); - return $o; }