diff --git a/src/Model/Profile.php b/src/Model/Profile.php
index 147c1f3ca..660cc5fb3 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 3310749bc..079f240ae 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 '';
}
}