X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FModule%2FNoScrape.php;h=8f799aa966150dbeacaa626bc0e52bd05b575abf;hb=3d64c3031bd79ed9162774f945ffe169954c4785;hp=26cae9817daf57806688138085f95d9cbdd179ed;hpb=4260b94fecd40fe8ca1f318524f795efeee2290c;p=friendica.git diff --git a/src/Module/NoScrape.php b/src/Module/NoScrape.php index 26cae9817d..8f799aa966 100644 --- a/src/Module/NoScrape.php +++ b/src/Module/NoScrape.php @@ -1,4 +1,23 @@ . + * + */ namespace Friendica\Module; @@ -7,14 +26,13 @@ use Friendica\Core\Protocol; use Friendica\Core\System; use Friendica\Database\DBA; use Friendica\DI; -use Friendica\Model\GContact; use Friendica\Model\Profile; use Friendica\Model\User; /** * Endpoint for getting current user infos * - * @see GContact::updateFromNoScrape() for usage + * @see Contact::updateFromNoScrape() for usage */ class NoScrape extends BaseModule { @@ -22,21 +40,27 @@ class NoScrape extends BaseModule { $a = DI::app(); - $which = DI::args()->get(1); - - $profile = 0; - if ((local_user()) && (DI::args()->get(2) === 'view')) { - $which = $a->user['nickname']; - $profile = DI::args()->get(1); + if (isset($parameters['nick'])) { + // Get infos about a specific nick (public) + $which = $parameters['nick']; + } elseif (local_user() && isset($parameters['profile']) && DI::args()->get(2) == 'view') { + // view infos about a known profile (needs a login) + $which = $a->user['nickname']; + } else { + System::jsonError(403, 'Authentication required'); } - Profile::load($a, $which, $profile); + Profile::load($a, $which); + + if (empty($a->profile['uid'])) { + System::jsonError(404, 'Profile not found'); + } $json_info = [ 'addr' => $a->profile['addr'], 'nick' => $which, 'guid' => $a->profile['guid'], - 'key' => $a->profile['pubkey'], + 'key' => $a->profile['upubkey'], 'homepage' => DI::baseUrl() . "/profile/{$which}", 'comm' => ($a->profile['account-type'] == User::ACCOUNT_TYPE_COMMUNITY), 'account-type' => $a->profile['account-type'], @@ -47,7 +71,7 @@ class NoScrape extends BaseModule $json_info["dfrn-{$dfrn}"] = DI::baseUrl() . "/dfrn_{$dfrn}/{$which}"; } - if (!$a->profile['net-publish'] || $a->profile['hidewall']) { + if (!$a->profile['net-publish']) { $json_info['hide'] = true; System::jsonExit($json_info); } @@ -63,13 +87,11 @@ class NoScrape extends BaseModule $json_info['tags'] = $keywords; $json_info['language'] = $a->profile['language']; - if (!($a->profile['hide-friends'] ?? false)) { - /// @todo What should this value tell us? - $result = DBA::p("SELECT `gcontact`.`updated` FROM `contact` INNER JOIN `gcontact` WHERE `gcontact`.`nurl` = `contact`.`nurl` AND `self` AND `uid` = %d LIMIT 1", $a->profile['uid']); - if (DBA::isResult($result)) { - $json_info["updated"] = date("c", strtotime($result[0]['updated'])); - } + if (!empty($a->profile['last-item'])) { + $json_info['updated'] = date("c", strtotime($a->profile['last-item'])); + } + if (!($a->profile['hide-friends'] ?? false)) { $json_info['contacts'] = DBA::count('contact', [ 'uid' => $a->profile['uid'], @@ -100,7 +122,7 @@ class NoScrape extends BaseModule $json_info['last-activity'] = date('o-W', $last_active); //These are optional fields. - $profile_fields = ['pdesc', 'locality', 'region', 'postal-code', 'country-name', 'gender', 'marital', 'about']; + $profile_fields = ['about', 'locality', 'region', 'postal-code', 'country-name']; foreach ($profile_fields as $field) { if (!empty($a->profile[$field])) { $json_info["$field"] = $a->profile[$field];