]> git.mxchange.org Git - quix0rs-gnu-social.git/blobdiff - actions/twitapiusers.php
Merge branch '0.7.x' of git@gitorious.org:+laconica-developers/laconica/dev into...
[quix0rs-gnu-social.git] / actions / twitapiusers.php
index b43a64152014067d22e342d26a30b80ac248f0d5..1542cfb33e3d064130093272e014ac4fa6262d81 100644 (file)
  *
  * This program is distributed in the hope that it will be useful,
  * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.         See the
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.     See the
  * GNU Affero General Public License for more details.
  *
  * You should have received a copy of the GNU Affero General Public License
- * along with this program.     If not, see <http://www.gnu.org/licenses/>.
+ * along with this program.     If not, see <http://www.gnu.org/licenses/>.
  */
 
 if (!defined('LACONICA')) { exit(1); }
 
 require_once(INSTALLDIR.'/lib/twitterapi.php');
 
-class TwitapiusersAction extends TwitterapiAction {
+class TwitapiusersAction extends TwitterapiAction
+{
 
-       function is_readonly() {                        
-               return true;
-       }
-
-/*     
-       Returns extended information of a given user, specified by ID or
-       screen name as per the required id parameter below.      This information
-       includes design settings, so third party developers can theme their
-       widgets according to a given user's preferences. You must be properly
-       authenticated to request the page of a protected user.
-
-       URL: http://twitter.com/users/show/id.format
-
-       Formats: xml, json
+    function show($args, $apidata)
+    {        
+        parent::handle($args);
 
-       Parameters:
-
-       * id.  Required.  The ID or screen name of a user.
-       Ex: http://twitter.com/users/show/12345.json or
-       http://twitter.com/users/show/bob.xml
-
-       * email. Optional.      The email address of a user.  Ex:
-       http://twitter.com/users/show.xml?email=test@example.com
-
-*/     
-       function show($args, $apidata) {
-               parent::handle($args);
-               
-               if (!in_array($apidata['content-type'], array('xml', 'json'))) {
-                       common_user_error(_('API method not found!'), $code = 404);
-                       exit;
-               }
-               
+        if (!in_array($apidata['content-type'], array('xml', 'json'))) {            
+            $this->clientError(_('API method not found!'), $code = 404);
+            return;
+        }
+                
                $user = null;
                $email = $this->arg('email');
-               
-               if (isset($apidata['api_arg'])) {
-                       if (is_numeric($apidata['api_arg'])) {
-                               // by user id
-                               $user = User::staticGet($apidata['api_arg']);                   
-                       } else {
-                               // by nickname
-                               $nickname = common_canonical_nickname($apidata['api_arg']);
-                               $user = User::staticGet('nickname', $nickname);
-                       } 
-               } elseif ($email) {
-                       // or, find user by email address
-                       // XXX: The Twitter API spec say an id is *required*, but you can actually
-                       // pull up a user with just an email address. -- Zach
-                       $user = User::staticGet('email', $email);                       
-               } 
-
-               if (!$user) {
+               $user_id = $this->arg('user_id');
+
+               if ($email) {
+                       $user = User::staticGet('email', $email);
+               } elseif ($user_id) {
+                       $user = $this->get_user($user_id);  
+               } elseif (isset($apidata['api_arg'])) {
+                       $user = $this->get_user($apidata['api_arg']);
+           } elseif (isset($apidata['user'])) {
+               $user = $apidata['user'];
+           }
+       
+               if (!$user) {               
                        // XXX: Twitter returns a random(?) user instead of throwing and err! -- Zach
-                       $this->client_error(_('User not found.'), 404, $apidata['content-type']);
-                       exit();
+                       $this->client_error(_('Not found.'), 404, $apidata['content-type']);
+                       return;
                }
-               
+
                $profile = $user->getProfile();
 
                if (!$profile) {
                        common_server_error(_('User has no profile.'));
-                       exit();
+                       return;
                }
 
                $twitter_user = $this->twitter_user_array($profile, true);
@@ -106,16 +78,43 @@ class TwitapiusersAction extends TwitterapiAction {
 
                // Other fields Twitter sends...
                $twitter_user['profile_background_color'] = '';
+               $twitter_user['profile_background_image_url'] = '';
                $twitter_user['profile_text_color'] = '';
                $twitter_user['profile_link_color'] = '';
                $twitter_user['profile_sidebar_fill_color'] = '';
-               $twitter_user['favourites_count'] = 0;
-               $twitter_user['utc_offset'] = '';
-               $twitter_user['time_zone'] = '';
-               $twitter_user['following'] = '';
-               $twitter_user['notifications'] = '';
+               $twitter_user['profile_sidebar_border_color'] = '';
+               $twitter_user['profile_background_tile'] = false;
+
+               $faves = DB_DataObject::factory('fave');
+               $faves->user_id = $user->id;
+               $faves_count = (int) $faves->count();
+               $twitter_user['favourites_count'] = $faves_count;
 
-               if ($apidata['content-type'] == 'xml') { 
+               $timezone = 'UTC';
+
+               if ($user->timezone) {
+                       $timezone = $user->timezone;
+               }
+
+               $t = new DateTime;
+               $t->setTimezone(new DateTimeZone($timezone));
+               $twitter_user['utc_offset'] = $t->format('Z');
+               $twitter_user['time_zone'] = $timezone;
+
+               if (isset($apidata['user'])) {
+
+                       $twitter_user['following'] = $apidata['user']->isSubscribed($profile);
+            
+                       // Notifications on?
+                       $sub = Subscription::pkeyGet(array('subscriber' =>
+                               $apidata['user']->id, 'subscribed' => $profile->id));
+            
+                       if ($sub) {
+                               $twitter_user['notifications'] = ($sub->jabber || $sub->sms);
+                       }
+               }
+        
+               if ($apidata['content-type'] == 'xml') {
                        $this->init_document('xml');
                        $this->show_twitter_xml_user($twitter_user);
                        $this->end_document('xml');
@@ -123,8 +122,13 @@ class TwitapiusersAction extends TwitterapiAction {
                        $this->init_document('json');
                        $this->show_json_objects($twitter_user);
                        $this->end_document('json');
-               } 
-                       
-               exit();
+               } else {
+                   
+                   // This is in case 'show' was called via /account/verify_credentials
+                   // without a format (xml or json).
+            header('Content-Type: text/html; charset=utf-8');
+            print 'Authorized';
+        }
+
        }
 }