]> git.mxchange.org Git - quix0rs-gnu-social.git/blobdiff - actions/twitapifriendships.php
if-else instead of ?:
[quix0rs-gnu-social.git] / actions / twitapifriendships.php
index c603761a2ba997985ed612a1818470f47da25a51..05c192ea6fc8bc46938c64d5a60b2dac2539a9bf 100644 (file)
@@ -23,6 +23,20 @@ require_once(INSTALLDIR.'/lib/twitterapi.php');
 
 class TwitapifriendshipsAction extends TwitterapiAction {
 
+       function is_readonly() {
+               
+               static $write_methods = array(  'create',
+                                                                               'destroy');
+               
+               $cmdtext = explode('.', $this->arg('method'));          
+               
+               if (in_array($cmdtext[0], $write_methods)) {                    
+                       return false;
+               }
+                               
+               return true;
+       }
+
        function create($args, $apidata) {
                parent::handle($args);
 
@@ -31,17 +45,15 @@ class TwitapifriendshipsAction extends TwitterapiAction {
                $other = $this->get_user($id);
 
                if (!$other) {
-                       $this->client_error(_('No such user'));
+                       $this->client_error(_('Could not follow user: User not found.'), 403, $apidata['content-type']);
                        exit();
-                       return;
                }
                
                $user = $apidata['user'];
                
                if ($user->isSubscribed($other)) {
-                       $this->client_error(_('Already subscribed.'));
+                       $this->client_error("Could not follow user: $other->nickname is already on your list.", 403, $apidata['content-type']);
                        exit();
-                       return;
                }
                
                $sub = new Subscription();
@@ -50,13 +62,13 @@ class TwitapifriendshipsAction extends TwitterapiAction {
                
                $sub->subscriber = $user->id;
                $sub->subscribed = $other->id;
-
+               $sub->created = DB_DataObject_Cast::dateTime(); # current time
+                 
                $result = $sub->insert();
 
                if (!$result) {
-                       $this->server_error(_('Could not subscribe'));
+                       $this->client_error("Could not follow user: $other->nickname.", 400, $apidata['content-type']);                 
                        exit();
-                       return;
                }
                
                $sub->query('COMMIT');
@@ -65,7 +77,7 @@ class TwitapifriendshipsAction extends TwitterapiAction {
 
                $type = $apidata['content-type'];
                $this->init_document($type);
-               $this->show_profile($other);
+               $this->show_profile($other, $type);
                $this->end_document($type);
                exit();
        }
@@ -95,15 +107,18 @@ class TwitapifriendshipsAction extends TwitterapiAction {
                $sub->subscriber = $user->id;
                $sub->subscribed = $other->id;
                
-               if ($sub->fetch(TRUE)) {
+               if ($sub->find(TRUE)) {
                        $sub->query('BEGIN');
                        $sub->delete();
                        $sub->query('COMMIT');
+               } else {
+                       $this->client_error(_('You are not friends with the specified user.'), 403, $apidata['content-type']);                  
+                       exit();
                }
 
                $type = $apidata['content-type'];
-               $this->init_document($type);
-               $this->show_profile($other);
+               $this->init_document($type);    
+               $this->show_profile($other, $type);
                $this->end_document($type);
                exit();
        }
@@ -123,14 +138,17 @@ class TwitapifriendshipsAction extends TwitterapiAction {
        
        function exists($args, $apidata) {
                parent::handle($args);
+               
+               
                $user_a_id = $this->trimmed('user_a');
                $user_b_id = $this->trimmed('user_b');
-               $user_a = $this->get_profile($user_a_id);
-               $user_b = $this->get_profile($user_b_id);
+               
+               $user_a = $this->get_user($user_a_id);
+               $user_b = $this->get_user($user_b_id);
                
                if (!$user_a || !$user_b) {
-                       $this->client_error(_('No such user'));
-                       return;
+                       $this->client_error(_('Two user ids or screen_names must be supplied.'), 400, $apidata['content-type']);
+                       exit();
                }
                
                if ($user_a->isSubscribed($user_b)) {
@@ -141,26 +159,28 @@ class TwitapifriendshipsAction extends TwitterapiAction {
                
                switch ($apidata['content-type']) {
                 case 'xml':
-                       common_start_xml();
+                       $this->init_document('xml');
                        common_element('friends', NULL, $result);
-                       common_end_xml();
+                       $this->end_document('xml');
                        break;
                 case 'json':
+                       $this->init_document('json');
                        print json_encode($result);
-                       print "\n";
+                       $this->end_document('json');
                        break;
                 default:
-                       print $result;
+                       print $result;  // Really? --Zach
                        break;
                }
                
+               exit();
        }
 
        function get_profile($id) {
                if (is_numeric($id)) {
                        return Profile::staticGet($id);
                } else {
-                       $user = User::staticGet('nickname', $id);
+                       $user = User::staticGet('nickname', $id);                       
                        if ($user) {
                                return $user->getProfile();
                        } else {