X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=mod%2Fdirectory.php;h=202132e3667abeb7a86c4ae36153a8b4040eb1ab;hb=7c73e8634c954cc2bd0d1138729459d7d5090f62;hp=b8b0482127172fd38b4e178aa41a7f147cf4b9d6;hpb=c78572bf472f146db9272e7f8273704df03b659d;p=friendica.git diff --git a/mod/directory.php b/mod/directory.php index b8b0482127..202132e366 100644 --- a/mod/directory.php +++ b/mod/directory.php @@ -2,19 +2,21 @@ /** * @file mod/directory.php */ + use Friendica\App; use Friendica\Content\Nav; use Friendica\Content\Widget; use Friendica\Core\Addon; use Friendica\Core\Config; use Friendica\Core\L10n; -use Friendica\Database\DBM; +use Friendica\Database\DBA; use Friendica\Model\Contact; use Friendica\Model\Profile; +use Friendica\Util\Proxy as ProxyUtils; function directory_init(App $a) { - $a->set_pager_itemspage(60); + $a->setPagerItemsPage(60); if (local_user()) { $a->page['aside'] .= Widget::findPeople(); @@ -34,8 +36,6 @@ function directory_post(App $a) function directory_content(App $a) { - require_once("mod/proxy.php"); - if ((Config::get('system', 'block_public') && !local_user() && !remote_user()) || (Config::get('system', 'block_local_dir') && !local_user() && !remote_user()) ) { @@ -59,7 +59,7 @@ function directory_content(App $a) } if ($search) { - $search = dbesc($search); + $search = DBA::escape($search); $sql_extra = " AND ((`profile`.`name` LIKE '%$search%') OR (`user`.`nickname` LIKE '%$search%') OR @@ -76,37 +76,39 @@ function directory_content(App $a) (`profile`.`education` LIKE '%$search%') OR (`profile`.`pub_keywords` LIKE '%$search%') OR (`profile`.`prv_keywords` LIKE '%$search%'))"; + } else { + $sql_extra = ''; } - $publish = ((Config::get('system', 'publish_all')) ? '' : " AND `publish` = 1 " ); + $publish = (Config::get('system', 'publish_all') ? '' : " AND `publish` = 1 " ); - $total = q("SELECT COUNT(*) AS `total` FROM `profile` - LEFT JOIN `user` ON `user`.`uid` = `profile`.`uid` - WHERE `is-default` = 1 $publish AND `user`.`blocked` = 0 $sql_extra " - ); - if (DBM::is_result($total)) { - $a->set_pager_total($total[0]['total']); + $cnt = DBA::fetchFirst("SELECT COUNT(*) AS `total` FROM `profile` + LEFT JOIN `user` ON `user`.`uid` = `profile`.`uid` + WHERE `is-default` $publish AND NOT `user`.`blocked` AND NOT `user`.`account_removed` $sql_extra"); + if (DBA::isResult($cnt)) { + $a->setPagerTotal($cnt['total']); } $order = " ORDER BY `name` ASC "; $limit = intval($a->pager['start'])."," . intval($a->pager['itemspage']); - $r = dba::p("SELECT `profile`.*, `profile`.`uid` AS `profile_uid`, `user`.`nickname`, `user`.`timezone` , `user`.`page-flags`, + $r = DBA::p("SELECT `profile`.*, `profile`.`uid` AS `profile_uid`, `user`.`nickname`, `user`.`timezone` , `user`.`page-flags`, `contact`.`addr`, `contact`.`url` AS profile_url FROM `profile` LEFT JOIN `user` ON `user`.`uid` = `profile`.`uid` LEFT JOIN `contact` ON `contact`.`uid` = `user`.`uid` - WHERE `is-default` $publish AND `user`.`blocked` = 0 AND `contact`.`self` $sql_extra $order LIMIT ".$limit + WHERE `is-default` $publish AND NOT `user`.`blocked` AND NOT `user`.`account_removed` AND `contact`.`self` + $sql_extra $order LIMIT $limit" ); - if (DBM::is_result($r)) { + if (DBA::isResult($r)) { if (in_array('small', $a->argv)) { $photo = 'thumb'; } else { $photo = 'photo'; } - while ($rr = dba::fetch($r)) { + while ($rr = DBA::fetch($r)) { $itemurl= ''; $itemurl = (($rr['addr'] != "") ? $rr['addr'] : $rr['profile_url']); @@ -147,6 +149,8 @@ function directory_content(App $a) || (x($profile, 'country-name') == 1) ) { $location = L10n::t('Location:'); + } else { + $location = ''; } $gender = ((x($profile, 'gender') == 1) ? L10n::t('Gender:') : false); @@ -157,14 +161,14 @@ function directory_content(App $a) $location_e = $location; $photo_menu = [ - 'profile' => [L10n::t("View Profile"), Profile::zrl($profile_link)] + 'profile' => [L10n::t("View Profile"), Contact::magicLink($profile_link)] ]; $entry = [ 'id' => $rr['id'], 'url' => $profile_link, 'itemurl' => $itemurl, - 'thumb' => proxy_url($rr[$photo], false, PROXY_SIZE_THUMB), + 'thumb' => ProxyUtils::proxifyUrl($rr[$photo], false, ProxyUtils::SIZE_THUMB), 'img_hover' => $rr['name'], 'name' => $rr['name'], 'details' => $details, @@ -194,7 +198,7 @@ function directory_content(App $a) $entries[] = $arr['entry']; } - dba::close($r); + DBA::close($r); $tpl = get_markup_template('directory_header.tpl');