]> git.mxchange.org Git - quix0rs-gnu-social.git/blobdiff - actions/twitapiaccount.php
Completely refactored noticesearch list, now using subclassing for highlighting....
[quix0rs-gnu-social.git] / actions / twitapiaccount.php
index f6e955828e306b60425d44c9b5fa6867fb98d949..c19cd370d927f2b2bb6e8f5bf044f328f5e12926 100644 (file)
@@ -21,76 +21,84 @@ if (!defined('LACONICA')) { exit(1); }
 
 require_once(INSTALLDIR.'/lib/twitterapi.php');
 
-class TwitapiaccountAction extends TwitterapiAction {
-
-       function verify_credentials($args, $apidata) {
-               parent::handle($args);
-
-               if (!in_array($apidata['content-type'], array('xml', 'json'))) {
-                       common_user_error(_('API method not found!'), $code = 404);
-                       return;
-               }
-
-               $this->show_extended_profile($apidata['user'], $apidata);
-       }
-
-       function end_session($args, $apidata) {
-               parent::handle($args);
-               common_server_error(_('API method under construction.'), $code=501);
-       }
-
-       function update_location($args, $apidata) {
-               parent::handle($args);
-
-               if ($_SERVER['REQUEST_METHOD'] != 'POST') {
-                       $this->client_error(_('This method requires a POST.'), 400, $apidata['content-type']);
-                       return;
-               }
-
-               $location = trim($this->arg('location'));
-
-               if (!is_null($location) && strlen($location) > 255) {
-
-                       // XXX: But Twitter just truncates and runs with it. -- Zach
-                       $this->client_error(_('That\'s too long. Max notice size is 255 chars.'), 406, $apidate['content-type']);
-                       return;
-               }
-
-               $user = $apidata['user'];
-               $profile = $user->getProfile();
-
-               if (!$profile) {
-                       common_server_error(_('User has no profile.'));
-                       return;
-               }
-
-               $orig_profile = clone($profile);
-               $profile->location = $location;
-
-               $result = $profile->update($orig_profile);
-
-               if (!$result) {
-                       common_log_db_error($profile, 'UPDATE', __FILE__);
-                       common_server_error(_('Couldn\'t save profile.'));
-                       return;
-               }
-
-               common_broadcast_profile($profile);
-               $type = $apidata['content-type'];
-
-               $this->init_document($type);
-               $this->show_profile($profile, $type);
-               $this->end_document($type);
-       }
-
-
-       function update_delivery_device($args, $apidata) {
-               parent::handle($args);
-               common_server_error(_('API method under construction.'), $code=501);
-       }
-
-       function rate_limit_status($args, $apidata) {
-               parent::handle($args);
-               common_server_error(_('API method under construction.'), $code=501);
-       }
-}
\ No newline at end of file
+class TwitapiaccountAction extends TwitterapiAction
+{
+
+    function verify_credentials($args, $apidata)
+    {
+        if ($apidata['content-type'] == 'xml') {
+            header('Content-Type: application/xml; charset=utf-8');
+            print '<authorized>true</authorized>';
+        } elseif ($apidata['content-type'] == 'json') {
+            header('Content-Type: application/json; charset=utf-8');
+            print '{"authorized":true}';
+        } else {
+            header('Content-Type: text/html; charset=utf-8');
+            print 'Authorized';
+        }
+    }
+
+    function end_session($args, $apidata)
+    {
+        parent::handle($args);
+        $this->serverError(_('API method under construction.'), $code=501);
+    }
+
+    function update_location($args, $apidata)
+    {
+        parent::handle($args);
+
+        if ($_SERVER['REQUEST_METHOD'] != 'POST') {
+            $this->clientError(_('This method requires a POST.'), 400, $apidata['content-type']);
+            return;
+        }
+
+        $location = trim($this->arg('location'));
+
+        if (!is_null($location) && mb_strlen($location) > 255) {
+
+            // XXX: But Twitter just truncates and runs with it. -- Zach
+            $this->clientError(_('That\'s too long. Max notice size is 255 chars.'), 406, $apidate['content-type']);
+            return;
+        }
+
+        $user = $apidata['user'];
+        $profile = $user->getProfile();
+
+        if (!$profile) {
+            $this->serverError(_('User has no profile.'));
+            return;
+        }
+
+        $orig_profile = clone($profile);
+        $profile->location = $location;
+
+        $result = $profile->update($orig_profile);
+
+        if (!$result) {
+            common_log_db_error($profile, 'UPDATE', __FILE__);
+            $this->serverError(_('Couldn\'t save profile.'));
+            return;
+        }
+
+        common_broadcast_profile($profile);
+        $type = $apidata['content-type'];
+
+        $this->init_document($type);
+        $this->show_profile($profile, $type);
+        $this->end_document($type);
+    }
+
+
+    function update_delivery_device($args, $apidata)
+    {
+        parent::handle($args);
+        $this->serverError(_('API method under construction.'), $code=501);
+    }
+
+    function rate_limit_status($args, $apidata)
+    {
+        parent::handle($args);
+        $this->serverError(_('API method under construction.'), $code=501);
+    }
+}