diff --git a/src/Model/Profile.php b/src/Model/Profile.php index 147c1f3cab..660cc5fb3d 100644 --- a/src/Model/Profile.php +++ b/src/Model/Profile.php @@ -255,7 +255,7 @@ class Profile * By now, the contact block isn't shown, when a different profile is given * But: When this profile was on the same server, then we could display the contacts */ - DI::page()['aside'] .= self::sidebar($profile, $block, $show_contacts); + DI::page()['aside'] .= self::getVCardHtml($profile, $block, $show_contacts); return $profile; } @@ -281,7 +281,7 @@ class Profile * @hooks 'profile_sidebar' * array $arr */ - private static function sidebar(array $profile, bool $block, bool $show_contacts) + public static function getVCardHtml(array $profile, bool $block, bool $show_contacts) { $o = ''; $location = false; diff --git a/src/Module/HCard.php b/src/Module/HCard.php index 3310749bc3..079f240ae4 100644 --- a/src/Module/HCard.php +++ b/src/Module/HCard.php @@ -34,13 +34,11 @@ use Friendica\Network\HTTPException; */ class HCard extends BaseModule { - public static function rawContent(array $parameters = []) + public static function content(array $parameters = []) { - $a = DI::app(); - if ((local_user()) && ($parameters['action'] ?? '') === 'view') { // A logged in user views a profile of a user - $nickname = $a->getLoggedInUserNickname(); + $nickname = DI::app()->getLoggedInUserNickname(); } elseif (empty($parameters['action'])) { // Show the profile hCard $nickname = $parameters['profile']; @@ -48,7 +46,7 @@ class HCard extends BaseModule throw new HTTPException\NotFoundException(DI::l10n()->t('No profile')); } - $profile = Profile::load($a, $nickname, false); + $profile = User::getOwnerDataByNick($nickname); if (empty($profile)) { throw new HTTPException\NotFoundException(DI::l10n()->t('User not found.')); @@ -67,15 +65,6 @@ class HCard extends BaseModule $page['htmlhead'] .= '' . "\r\n"; } - // check if blocked - if (DI::config()->get('system', 'block_public') && !Session::isAuthenticated()) { - $keywords = $profile['pub_keywords'] ?? ''; - $keywords = str_replace([',', ' ', ',,'], [' ', ',', ','], $keywords); - if (strlen($keywords)) { - $page['htmlhead'] .= '' . "\r\n"; - } - } - $baseUrl = DI::baseUrl(); $uri = urlencode('acct:' . $profile['nickname'] . '@' . $baseUrl->getHostname() . ($baseUrl->getUrlPath() ? '/' . $baseUrl->getUrlPath() : '')); @@ -88,5 +77,20 @@ class HCard extends BaseModule foreach (['request', 'confirm', 'notify', 'poll'] as $dfrn) { $page['htmlhead'] .= "get() . "/dfrn_{$dfrn}/{$nickname}\" />\r\n"; } + + $block = (DI::config()->get('system', 'block_public') && !Session::isAuthenticated()); + + // check if blocked + if ($block) { + $keywords = $profile['pub_keywords'] ?? ''; + $keywords = str_replace([',', ' ', ',,'], [' ', ',', ','], $keywords); + if (strlen($keywords)) { + $page['htmlhead'] .= '' . "\r\n"; + } + } + + $page['aside'] = Profile::getVCardHtml($profile, $block, false); + + return ''; } }