summaryrefslogtreecommitdiff
path: root/actions/userbyid.php
diff options
context:
space:
mode:
authorehs <ehs@pobox.com>2008-08-01 12:46:23 -0400
committerehs <ehs@pobox.com>2008-08-01 12:46:23 -0400
commit48fcfb8b0daeb272cb9d116af617daf15930d909 (patch)
tree8764a12274c0b8f25451a1d692baf1443335bc18 /actions/userbyid.php
parent9676315b2eb2d888d9b7333c3f95a524a3e74712 (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/userbyid.php')
-rw-r--r--actions/userbyid.php13
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);
}
}