X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;ds=sidebyside;f=actions%2Fuserbyid.php;h=4bb896c38e11cd7d67635da6b6e90208cf7feeca;hb=bc15d027a804e60e76bdaf6fd47e69d41b395e7e;hp=da61c7b6e695d47c8becd568391ac925833ececc;hpb=9b5e6de1f4f897b7d83cd76480ed0f4bf2b1edf3;p=quix0rs-gnu-social.git diff --git a/actions/userbyid.php b/actions/userbyid.php index da61c7b6e6..4bb896c38e 100644 --- a/actions/userbyid.php +++ b/actions/userbyid.php @@ -19,19 +19,34 @@ if (!defined('LACONICA')) { exit(1); } -class UserbyidAction extends Action { - function handle($args) { +class UserbyidAction extends Action +{ + + function isReadOnly() + { + return true; + } + + function handle($args) + { parent::handle($args); $id = $this->trimmed('id'); if (!$id) { - $this->client_error(_t('No id.')); - } - $user =& User::staticGet($id); - if (!$user) { - $this->client_error(_t('No such user.')); - } - $url=common_local_url('showstream', - array('nickname' => $user->nickname)); - common_redirect($url, 303); - } + $this->clientError(_('No id.')); + } + $user =& User::staticGet($id); + if (!$user) { + $this->clientError(_('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); + } }