if (isset($parameters['nick'])) {
// Get infos about a specific nick (public)
$which = $parameters['nick'];
- $profile = 0;
} elseif (local_user() && isset($parameters['profile']) && DI::args()->get(2) == 'view') {
// view infos about a known profile (needs a login)
$which = $a->user['nickname'];
- $profile = $parameters['profile'];
} else {
- System::jsonError(404, 'Invalid request');
+ System::jsonError(403, 'Authentication required');
exit();
}
- Profile::load($a, $which, $profile);
+ Profile::load($a, $which);
$json_info = [
'addr' => $a->profile['addr'],
$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']));
+ $stmt = DBA::p(
+ "SELECT `gcontact`.`updated`
+ FROM `contact`
+ INNER JOIN `gcontact`
+ WHERE `gcontact`.`nurl` = `contact`.`nurl`
+ AND `self`
+ AND `uid` = ?
+ LIMIT 1",
+ intval($a->profile['uid'])
+ );
+ if ($gcontact = DBA::fetch($stmt)) {
+ $json_info["updated"] = date("c", strtotime($gcontact['updated']));
}
+ DBA::close($stmt);
$json_info['contacts'] = DBA::count('contact',
[
$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 = ['pdesc', 'locality', 'region', 'postal-code', 'country-name'];
foreach ($profile_fields as $field) {
if (!empty($a->profile[$field])) {
$json_info["$field"] = $a->profile[$field];