]> git.mxchange.org Git - quix0rs-gnu-social.git/commitdiff
Make userxrd work without OStatus enabled
authorEvan Prodromou <evan@status.net>
Sat, 27 Nov 2010 03:09:51 +0000 (22:09 -0500)
committerEvan Prodromou <evan@status.net>
Sat, 27 Nov 2010 03:09:51 +0000 (22:09 -0500)
actions/userxrd.php
lib/xrdaction.php

index 575a07c4098288a636ea56e76c9d7184552e9532..582f7a35e7ab8505154dc6b4ebfea9dce634e3ea 100644 (file)
@@ -32,9 +32,9 @@ class UserxrdAction extends XrdAction
         parent::prepare($args);
 
         $this->uri = $this->trimmed('uri');
-        $this->uri = Discovery::normalize($this->uri);
+        $this->uri = self::normalize($this->uri);
 
-        if (Discovery::isWebfinger($this->uri)) {
+        if (self::isWebfinger($this->uri)) {
             $parts = explode('@', substr(urldecode($this->uri), 5));
             if (count($parts) == 2) {
                 list($nick, $domain) = $parts;
index 85a70f8b31a91874f31c94d36fb1531c28b6c555..43826b32bb88c88216ecc9f34d680d490a785429 100644 (file)
@@ -28,6 +28,10 @@ if (!defined('STATUSNET')) {
 
 class XrdAction extends Action
 {
+    const PROFILEPAGE = 'http://webfinger.net/rel/profile-page';
+    const UPDATESFROM = 'http://schemas.google.com/g/2010#updates-from';
+    const HCARD = 'http://microformats.org/profile/hcard';
+    
     public $uri;
 
     public $user;
@@ -46,7 +50,7 @@ class XrdAction extends Action
         }
 
         if (empty($xrd->subject)) {
-            $xrd->subject = Discovery::normalize($this->uri);
+            $xrd->subject = self::normalize($this->uri);
         }
 
        if (Event::handle('StartXrdActionAliases', array(&$xrd, $this->user))) {
@@ -74,12 +78,12 @@ class XrdAction extends Action
 
        if (Event::handle('StartXrdActionLinks', array(&$xrd, $this->user))) {
            
-           $xrd->links[] = array('rel' => Discovery::PROFILEPAGE,
+           $xrd->links[] = array('rel' => self::PROFILEPAGE,
                                  'type' => 'text/html',
                                  'href' => $profile->profileurl);
            
            // hCard
-           $xrd->links[] = array('rel' => Discovery::HCARD,
+           $xrd->links[] = array('rel' => self::HCARD,
                                  'type' => 'text/html',
                                  'href' => common_local_url('hcard', array('nickname' => $nick)));
            
@@ -93,12 +97,7 @@ class XrdAction extends Action
                                  'href' => common_local_url('foaf',
                                                             array('nickname' => $nick)));
            
-           $xrd->links[] = array('rel' => Discovery::UPDATESFROM,
-                                 'href' => common_local_url('ApiTimelineUser',
-                                                            array('id' => $this->user->id,
-                                                                  'format' => 'atom')),
-                                 'type' => 'application/atom+xml');
-           
+
            Event::handle('EndXrdActionLinks', array(&$xrd, $this->user));
        }
            
@@ -106,4 +105,31 @@ class XrdAction extends Action
         header('Content-type: application/xrd+xml');
         print $xrd->toXML();
     }
+    
+    /**
+     * Given a "user id" make sure it's normalized to either a webfinger
+     * acct: uri or a profile HTTP URL.
+     */
+    
+    public static function normalize($user_id)
+    {
+        if (substr($user_id, 0, 5) == 'http:' ||
+            substr($user_id, 0, 6) == 'https:' ||
+            substr($user_id, 0, 5) == 'acct:') {
+            return $user_id;
+        }
+
+        if (strpos($user_id, '@') !== FALSE) {
+            return 'acct:' . $user_id;
+        }
+
+        return 'http://' . $user_id;
+    }
+
+    public static function isWebfinger($user_id)
+    {
+        $uri = self::normalize($user_id);
+
+        return (substr($uri, 0, 5) == 'acct:');
+    }
 }