X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=actions%2Ftwitapiaccount.php;h=93c8443c9f79c9b88136319ae06eb127267f616d;hb=70fc32c5b93a6cd71cf33212ac792c38632bbdb3;hp=93e0844c1f821cea7be60c9211b7f2a5cc9de7d7;hpb=3df358a9e98328de4d865b91a5900f834a1f195a;p=quix0rs-gnu-social.git diff --git a/actions/twitapiaccount.php b/actions/twitapiaccount.php index 93e0844c1f..93c8443c9f 100644 --- a/actions/twitapiaccount.php +++ b/actions/twitapiaccount.php @@ -1,7 +1,7 @@ . */ -if (!defined('LACONICA')) { exit(1); } +if (!defined('STATUSNET') && !defined('LACONICA')) { + exit(1); +} require_once(INSTALLDIR.'/lib/twitterapi.php'); -class TwitapiaccountAction extends TwitterapiAction { - - function verify_credentials($args, $apidata) { - parent::handle($args); - common_server_error("API method under construction.", $code=501); - exit(); - } - - function end_session($args, $apidata) { - parent::handle($args); - common_server_error("API method under construction.", $code=501); - exit(); - } - - function update_location($args, $apidata) { - parent::handle($args); - common_server_error("API method under construction.", $code=501); - exit(); - } - - function update_delivery_device($args, $apidata) { - parent::handle($args); - common_server_error("API method under construction.", $code=501); - exit(); - } - - function rate_limit_status($args, $apidata) { - parent::handle($args); - common_server_error("API method under construction.", $code=501); - exit(); - } -} \ No newline at end of file +class TwitapiaccountAction extends TwitterapiAction +{ + function verify_credentials($args, $apidata) + { + parent::handle($args); + + switch ($apidata['content-type']) { + case 'xml': + case 'json': + $action_obj = new TwitapiusersAction(); + $action_obj->prepare($args); + call_user_func(array($action_obj, 'show'), $args, $apidata); + break; + default: + 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']; // Always the auth user + $profile = $user->getProfile(); + + $orig_profile = clone($profile); + $profile->location = $location; + + $result = $profile->update($orig_profile); + + if (empty($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); + } + + // We don't have a rate limit, but some clients check this method. + // It always returns the same thing: 100 hit left. + function rate_limit_status($args, $apidata) + { + parent::handle($args); + + $type = $apidata['content-type']; + $this->init_document($type); + + if ($apidata['content-type'] == 'xml') { + $this->elementStart('hash'); + $this->element('remaining-hits', array('type' => 'integer'), 100); + $this->element('hourly-limit', array('type' => 'integer'), 100); + $this->element('reset-time', array('type' => 'datetime'), null); + $this->element('reset_time_in_seconds', array('type' => 'integer'), 0); + $this->elementEnd('hash'); + } elseif ($apidata['content-type'] == 'json') { + + $out = array('reset_time_in_seconds' => 0, + 'remaining_hits' => 100, + 'hourly_limit' => 100, + 'reset_time' => ''); + print json_encode($out); + } + + $this->end_document($type); + } +}