diff options
author | ehs <ehs@pobox.com> | 2008-08-01 12:46:23 -0400 |
---|---|---|
committer | ehs <ehs@pobox.com> | 2008-08-01 12:46:23 -0400 |
commit | 48fcfb8b0daeb272cb9d116af617daf15930d909 (patch) | |
tree | 8764a12274c0b8f25451a1d692baf1443335bc18 /actions | |
parent | 9676315b2eb2d888d9b7333c3f95a524a3e74712 (diff) |
added conneg for action/userbyid so that foaf can be delivered to clients that want application/rdf+xml
darcs-hash:20080801164623-b1e77-1e8786743cc02e3d6f2320edff0f2f474f4ed76b.gz
Diffstat (limited to 'actions')
-rw-r--r-- | actions/userbyid.php | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/actions/userbyid.php b/actions/userbyid.php index c42cad083..38bff2ede 100644 --- a/actions/userbyid.php +++ b/actions/userbyid.php @@ -34,9 +34,16 @@ class UserbyidAction extends Action { $user =& User::staticGet($id); if (!$user) { $this->client_error(_('No such user.')); - } - $url=common_local_url('showstream', - array('nickname' => $user->nickname)); + } + + // 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); } } |