X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=actions%2Fuserbyid.php;h=38bff2edeee6b3a18640275bcb1319990450cdb5;hb=c3f2d195f934c4deff91d30640ec703cb576e55d;hp=da61c7b6e695d47c8becd568391ac925833ececc;hpb=9b5e6de1f4f897b7d83cd76480ed0f4bf2b1edf3;p=quix0rs-gnu-social.git diff --git a/actions/userbyid.php b/actions/userbyid.php index da61c7b6e6..38bff2edee 100644 --- a/actions/userbyid.php +++ b/actions/userbyid.php @@ -20,18 +20,30 @@ if (!defined('LACONICA')) { exit(1); } class UserbyidAction extends Action { + + function is_readonly() { + return true; + } + function handle($args) { parent::handle($args); $id = $this->trimmed('id'); if (!$id) { - $this->client_error(_t('No id.')); + $this->client_error(_('No id.')); } $user =& User::staticGet($id); if (!$user) { - $this->client_error(_t('No such user.')); - } - $url=common_local_url('showstream', - array('nickname' => $user->nickname)); + $this->client_error(_('No such user.')); + } + + // support redirecting to FOAF rdf/xml if the agent prefers it + $page_prefs = 'application/rdf+xml,text/html,application/xhtml+xml,application/xml;q=0.3,text/xml;q=0.2'; + $httpaccept = isset($_SERVER['HTTP_ACCEPT']) ? $_SERVER['HTTP_ACCEPT'] : NULL; + $type = common_negotiate_type(common_accept_to_prefs($httpaccept), + common_accept_to_prefs($page_prefs)); + $page = $type == 'application/rdf+xml' ? 'foaf' : 'showstream'; + + $url = common_local_url($page, array('nickname' => $user->nickname)); common_redirect($url, 303); } }