Also, cleanup and report errors properly when we try unsupported media types.
<?php
-
+
/**
* StatusNet, the distributed open-source microblogging tool
*
*/
var $registered = false;
- /**
- * Are we processing an invite?
- */
- var $invite = null;
+ protected $needPost = true;
+
+ protected $code = null; // invite code
+ protected $invite = null; // invite to-be-stored
/**
* Take arguments for running
*
* @return boolean success flag
*/
- function prepare($args)
+ protected function prepare($args)
{
parent::prepare($args);
+
+ if ($this->format !== 'json') {
+ $this->clientError('This method currently only serves JSON.', 415);
+ }
+
$this->code = $this->trimmed('code');
+ return true;
+ }
+
+ /**
+ * Handle the request
+ *
+ * @param array $args $_REQUEST data (unused)
+ *
+ * @return void
+ */
+ protected function handle()
+ {
+ parent::handle();
+
+ $nickname = $this->trimmed('nickname');
+ $email = $this->trimmed('email');
+ $fullname = $this->trimmed('fullname');
+ $homepage = $this->trimmed('homepage');
+ $bio = $this->trimmed('bio');
+ $location = $this->trimmed('location');
+
+ // We don't trim these... whitespace is OK in a password!
+ $password = $this->arg('password');
+ $confirm = $this->arg('confirm');
+
if (empty($this->code)) {
common_ensure_session();
if (array_key_exists('invitecode', $_SESSION)) {
if (common_config('site', 'inviteonly') && empty($this->code)) {
// TRANS: Client error displayed when trying to register to an invite-only site without an invitation.
- $this->clientError(_('Sorry, only invited people can register.'),404,'json');
- return false;
+ $this->clientError(_('Sorry, only invited people can register.'), 401);
}
if (!empty($this->code)) {
$this->invite = Invitation::staticGet('code', $this->code);
if (empty($this->invite)) {
// TRANS: Client error displayed when trying to register to an invite-only site without a valid invitation.
- $this->clientError(_('Sorry, invalid invitation code.'),404,'json');
- return false;
+ $this->clientError(_('Sorry, invalid invitation code.'), 401);
}
// Store this in case we need it
common_ensure_session();
$_SESSION['invitecode'] = $this->code;
}
- return true;
- }
-
- /**
- * Handle the request
- *
- * @param array $args $_REQUEST data (unused)
- *
- * @return void
- */
- function handle($args)
- {
- parent::handle($args);
-
- if ($_SERVER['REQUEST_METHOD'] != 'POST') {
- $this->clientError(
- _('This method requires a POST.'),
- 400, $this->format
- );
- return;
+ // Input scrubbing
+ try {
+ $nickname = Nickname::normalize($nickname);
+ } catch (NicknameException $e) {
+ // clientError handles Api exceptions with various formats and stuff
+ $this->clientError(_('Not a valid nickname.'), 400);
+ }
+ $email = common_canonical_email($email);
+ if ($email && !Validate::email($email, common_config('email', 'check_domain'))) {
+ // TRANS: Form validation error displayed when trying to register without a valid e-mail address.
+ $this->clientError(_('Not a valid email address.'), 400);
+ } else if ($this->nicknameExists($nickname)) {
+ // TRANS: Form validation error displayed when trying to register with an existing nickname.
+ $this->clientError(_('Nickname already in use. Try another one.'), 400);
+ } else if (!User::allowed_nickname($nickname)) {
+ // TRANS: Form validation error displayed when trying to register with an invalid nickname.
+ $this->clientError(_('Not a valid nickname.'), 400);
+ } else if ($this->emailExists($email)) {
+ // TRANS: Form validation error displayed when trying to register with an already registered e-mail address.
+ $this->clientError(_('Email address already exists.'), 400);
+ } else if (!is_null($homepage) && (strlen($homepage) > 0) &&
+ !common_valid_http_url($homepage)) {
+ // TRANS: Form validation error displayed when trying to register with an invalid homepage URL.
+ $this->clientError(_('Homepage is not a valid URL.'), 400);
+ } else if (!is_null($fullname) && mb_strlen($fullname) > 255) {
+ // TRANS: Form validation error displayed when trying to register with a too long full name.
+ $this->clientError(_('Full name is too long (maximum 255 characters).'), 400);
+ } else if (Profile::bioTooLong($bio)) {
+ // TRANS: Form validation error on registration page when providing too long a bio text.
+ // TRANS: %d is the maximum number of characters for bio; used for plural.
+ $this->clientError(sprintf(_m('Bio is too long (maximum %d character).',
+ 'Bio is too long (maximum %d characters).',
+ Profile::maxBio()),
+ Profile::maxBio()), 400);
+ } else if (!is_null($location) && mb_strlen($location) > 255) {
+ // TRANS: Form validation error displayed when trying to register with a too long location.
+ $this->clientError(_('Location is too long (maximum 255 characters).'), 400);
+ } else if (strlen($password) < 6) {
+ // TRANS: Form validation error displayed when trying to register with too short a password.
+ $this->clientError(_('Password must be 6 or more characters.'), 400);
+ } else if ($password != $confirm) {
+ // TRANS: Form validation error displayed when trying to register with non-matching passwords.
+ $this->clientError(_('Passwords do not match.'), 400);
} else {
-
- $nickname = $this->trimmed('nickname');
- $email = $this->trimmed('email');
- $fullname = $this->trimmed('fullname');
- $homepage = $this->trimmed('homepage');
- $bio = $this->trimmed('bio');
- $location = $this->trimmed('location');
-
- // We don't trim these... whitespace is OK in a password!
- $password = $this->arg('password');
- $confirm = $this->arg('confirm');
-
- // invitation code, if any
- $code = $this->trimmed('code');
-
- if ($code) {
- $invite = Invitation::staticGet($code);
- }
+
+ // annoy spammers
+ sleep(7);
+
+ if ($user = User::register(array('nickname' => $nickname,
+ 'password' => $password,
+ 'email' => $email,
+ 'fullname' => $fullname,
+ 'homepage' => $homepage,
+ 'bio' => $bio,
+ 'location' => $location,
+ 'code' => $code))) {
+ if (!$user) {
+ // TRANS: Form validation error displayed when trying to register with an invalid username or password.
+ $this->clientError(_('Invalid username or password.'), 400);
+ }
- if (common_config('site', 'inviteonly') && !($code && $invite)) {
- // TRANS: Client error displayed when trying to register to an invite-only site without an invitation.
- $this->clientError(_('Sorry, only invited people can register.'),404,'json');
- return;
- }
+ Event::handle('EndRegistrationTry', array($this));
- // Input scrubbing
- try {
- $nickname = Nickname::normalize($nickname);
- } catch (NicknameException $e) {
- $this->showForm($e->getMessage());
- }
- $email = common_canonical_email($email);
-
- if ($email && !Validate::email($email, common_config('email', 'check_domain'))) {
- // TRANS: Form validation error displayed when trying to register without a valid e-mail address.
- $this->clientError(_('Not a valid email address.'),404,'json');
- } else if ($this->nicknameExists($nickname)) {
- // TRANS: Form validation error displayed when trying to register with an existing nickname.
- $this->clientError(_('Nickname already in use. Try another one.'),404,'json');
- } else if (!User::allowed_nickname($nickname)) {
- // TRANS: Form validation error displayed when trying to register with an invalid nickname.
- $this->clientError(_('Not a valid nickname.'),404,'json');
- } else if ($this->emailExists($email)) {
- // TRANS: Form validation error displayed when trying to register with an already registered e-mail address.
- $this->clientError(_('Email address already exists.'),404,'json');
- } else if (!is_null($homepage) && (strlen($homepage) > 0) &&
- !common_valid_http_url($homepage)) {
- // TRANS: Form validation error displayed when trying to register with an invalid homepage URL.
- $this->clientError(_('Homepage is not a valid URL.'),404,'json');
- return;
- } else if (!is_null($fullname) && mb_strlen($fullname) > 255) {
- // TRANS: Form validation error displayed when trying to register with a too long full name.
- $this->clientError(_('Full name is too long (maximum 255 characters).'),404,'json');
- return;
- } else if (Profile::bioTooLong($bio)) {
- // TRANS: Form validation error on registration page when providing too long a bio text.
- // TRANS: %d is the maximum number of characters for bio; used for plural.
- $this->clientError(sprintf(_m('Bio is too long (maximum %d character).',
- 'Bio is too long (maximum %d characters).',
- Profile::maxBio()),
- Profile::maxBio()),404,'json');
- return;
- } else if (!is_null($location) && mb_strlen($location) > 255) {
- // TRANS: Form validation error displayed when trying to register with a too long location.
- $this->clientError(_('Location is too long (maximum 255 characters).'),404,'json');
- return;
- } else if (strlen($password) < 6) {
- // TRANS: Form validation error displayed when trying to register with too short a password.
- $this->clientError(_('Password must be 6 or more characters.'),404,'json');
- return;
- } else if ($password != $confirm) {
- // TRANS: Form validation error displayed when trying to register with non-matching passwords.
- $this->clientError(_('Passwords do not match.'),404,'json');
- } else {
-
- // annoy spammers
- sleep(7);
-
- if ($user = User::register(array('nickname' => $nickname,
- 'password' => $password,
- 'email' => $email,
- 'fullname' => $fullname,
- 'homepage' => $homepage,
- 'bio' => $bio,
- 'location' => $location,
- 'code' => $code))) {
- if (!$user) {
- // TRANS: Form validation error displayed when trying to register with an invalid username or password.
- $this->clientError(_('Invalid username or password.'),404,'json');
- return;
- }
-
- Event::handle('EndRegistrationTry', array($this));
-
- $this->initDocument('json');
- $this->showJsonObjects($this->twitterUserArray($user->getProfile()));
- $this->endDocument('json');
-
- } else {
- // TRANS: Form validation error displayed when trying to register with an invalid username or password.
- $this->clientError(_('Invalid username or password.'),404,'json');
- }
- }
- }
+ $this->initDocument('json');
+ $this->showJsonObjects($this->twitterUserArray($user->getProfile()));
+ $this->endDocument('json');
+
+ } else {
+ // TRANS: Form validation error displayed when trying to register with an invalid username or password.
+ $this->clientError(_('Invalid username or password.'), 400);
+ }
+ }
}
{
var $backgroundcolor = null;
+ protected $needPost = true;
+
/**
* Take arguments for running
*
*
* @return boolean success flag
*/
- function prepare($args)
+ protected function prepare($args)
{
parent::prepare($args);
- $this->user = $this->auth_user;
+ if ($this->format !== 'json') {
+ $this->clientError('This method currently only serves JSON.', 415);
+ }
$this->backgroundcolor = $this->trimmed('backgroundcolor');
return true;
*
* @return void
*/
- function handle($args)
+ protected function handle()
{
- parent::handle($args);
-
- if ($_SERVER['REQUEST_METHOD'] != 'POST') {
- $this->clientError(
- _('This method requires a POST.'),
- 400, $this->format
- );
- return;
+ parent::handle();
+
+ $validhex = preg_match('/^[a-f0-9]{6}$/i',$this->backgroundcolor);
+ if ($validhex === false || $validhex == 0) {
+ $this->clientError(_('Not a valid hex color.'), 400);
}
-
- $validhex = preg_match('/^[a-f0-9]{6}$/i',$this->backgroundcolor);
- if($validhex === false || $validhex == 0) {
- $this->clientError(_('Not a valid hex color.'),404,'json');
- return;
- }
-
- // save the new color
- $original = clone($this->user);
- $this->user->backgroundcolor = $this->backgroundcolor;
- if (!$this->user->update($original)) {
- $this->clientError(_('Error updating user.'),404,'json');
- return;
- }
-
- $profile = $this->user->getProfile();
-
- if (empty($profile)) {
- $this->clientError(_('User has no profile.'),'json');
- return;
+
+ // save the new color
+ $original = clone($this->auth_user);
+ $this->auth_user->backgroundcolor = $this->backgroundcolor;
+ if (!$this->auth_user->update($original)) {
+ $this->clientError(_('Error updating user.'), 404);
}
- $twitter_user = $this->twitterUserArray($profile, true);
+ $twitter_user = $this->twitterUserArray($this->scoped, true);
$this->initDocument('json');
$this->showJsonObjects($twitter_user);
{
var $linkcolor = null;
+ protected $needPost = true;
+
/**
* Take arguments for running
*
*
* @return boolean success flag
*/
- function prepare($args)
+ protected function prepare($args)
{
parent::prepare($args);
- $this->user = $this->auth_user;
+ if ($this->format !== 'json') {
+ $this->clientError('This method currently only serves JSON.', 415);
+ }
$this->linkcolor = $this->trimmed('linkcolor');
*
* @return void
*/
- function handle($args)
+ protected function handle()
{
- parent::handle($args);
-
- if ($_SERVER['REQUEST_METHOD'] != 'POST') {
- $this->clientError(
- _('This method requires a POST.'),
- 400, $this->format
- );
- return;
+ parent::handle();
+
+ $validhex = preg_match('/^[a-f0-9]{6}$/i',$this->linkcolor);
+ if ($validhex === false || $validhex == 0) {
+ $this->clientError(_('Not a valid hex color.'), 400);
}
-
- $validhex = preg_match('/^[a-f0-9]{6}$/i',$this->linkcolor);
- if($validhex === false || $validhex == 0) {
- $this->clientError(_('Not a valid hex color.'),404,'json');
- return;
- }
-
- // save the new color
- $original = clone($this->user);
- $this->user->linkcolor = $this->linkcolor;
- if (!$this->user->update($original)) {
- $this->clientError(_('Error updating user.'),404,'json');
- return;
- }
-
- $profile = $this->user->getProfile();
-
- if (empty($profile)) {
- $this->clientError(_('User has no profile.'),'json');
- return;
+
+ // save the new color
+ $original = clone($this->auth_user);
+ $this->auth_user->linkcolor = $this->linkcolor;
+ if (!$this->auth_user->update($original)) {
+ $this->clientError(_('Error updating user.'), 400);
}
- $twitter_user = $this->twitterUserArray($profile, true);
+ $twitter_user = $this->twitterUserArray($this->scoped, true);
$this->initDocument('json');
$this->showJsonObjects($twitter_user);
$this->endDocument('json');
}
-
-
}
*
* @return boolean success flag
*/
- function prepare($args)
+ protected function prepare($args)
{
parent::prepare($args);
+ if ($this->format !== 'json') {
+ $this->clientError('This method currently only serves JSON.', 415);
+ }
+
return true;
}
*
* @return void
*/
- function handle($args)
+ protected function handle()
{
- parent::handle($args);
+ parent::handle();
+
$file = new File();
$file->selectAdd(); // clears it
$file->selectAdd('url');
$file_txt = '';
if(strstr($url[0],'.html')) {
- $file_txt['txt'] = file_get_contents(str_replace('://quitter.se','://127.0.0.1',$url[0]));
+ $file_txt['txt'] = file_get_contents($url[0]);
$file_txt['body_start'] = strpos($file_txt['txt'],'<body>')+6;
$file_txt['body_end'] = strpos($file_txt['txt'],'</body>');
$file_txt = substr($file_txt['txt'],$file_txt['body_start'],$file_txt['body_end']-$file_txt['body_start']);
*/
class ApiCheckHubAction extends ApiAuthAction
{
+ protected $url = null;
+
/**
* Take arguments for running
*
{
parent::prepare($args);
+ if ($this->format !== 'json') {
+ $this->clientError('This method currently only serves JSON.', 415);
+ }
+
$this->url = urldecode($args['url']);
if (empty($this->url)) {
- $this->clientError(_('No URL.'), 403, 'json');
- return;
+ $this->clientError(_('No URL.'), 403);
}
if (!common_valid_http_url($this->url)) {
- $this->clientError(_('Invalid URL.'), 403, 'json');
- return;
+ $this->clientError(_('Invalid URL.'), 403);
}
return true;
$huburi = $discover->getHubLink();
}
} catch (FeedSubNoFeedException $e) {
- $this->clientError(_('No feed found'), 403, 'json');
- return;
+ $this->clientError(_('No feed found'), 403);
} catch (FeedSubBadResponseException $e) {
- $this->clientError(_('No hub found'), 403, 'json');
- return;
+ $this->clientError(_('No hub found'), 403);
}
$hub_status = array();
class ApiCheckNicknameAction extends ApiAction
{
- function prepare($args)
+ protected function prepare($args)
{
parent::prepare($args);
+
+ if ($this->format !== 'json') {
+ $this->clientError('This method currently only serves JSON.', 415);
+ }
return true;
}
- function handle($args)
+ protected function handle()
{
- parent::handle($args);
+ parent::handle();
$nickname = $this->trimmed('nickname');
* @return boolean success flag
*
*/
- function prepare($args)
+ protected function prepare($args)
{
parent::prepare($args);
+ if ($this->format !== 'json') {
+ $this->clientError('This method currently only serves JSON.', 415);
+ }
+
$profileurl = urldecode($this->arg('profileurl'));
+ // TODO: Make this more ... unique!
$this->profile = Profile::staticGet('profileurl', $profileurl);
+ if (!($this->profile instanceof Profile)) {
+ // TRANS: Client error displayed when requesting profile information for a non-existing profile.
+ $this->clientError(_('Profile not found.'), 404);
+ }
+
return true;
}
*
* @return void
*/
- function handle($args)
+ protected function handle()
{
- parent::handle($args);
-
- if (empty($this->profile)) {
- // TRANS: Client error displayed when requesting profile information for a non-existing profile.
- $this->clientError(_('Profile not found.'), 404, 'json');
- return;
- }
+ parent::handle();
$twitter_user = $this->twitterUserArray($this->profile, true);
*
* @return boolean success flag
*/
- function prepare($args)
+ protected function prepare($args)
{
parent::prepare($args);
$this->group = $this->getTargetGroup($this->arg('id'));
if (empty($this->group)) {
// TRANS: Client error displayed trying to show group membership on a non-existing group.
- $this->clientError(_('Group not found.'), 404, $this->format);
- return false;
+ $this->clientError(_('Group not found.'), 404);
}
$this->profiles = $this->getProfiles();
*
* @return void
*/
- function handle($args)
+ protected function handle()
{
- parent::handle($args);
+ parent::handle();
// XXX: RSS and Atom
{
const MAXCOUNT = 100;
- var $original = null;
+ var $original = null; // Notice object for which to retrieve favs
var $cnt = self::MAXCOUNT;
/**
*
* @return boolean success flag
*/
- function prepare($args)
+ protected function prepare($args)
{
parent::prepare($args);
+ if ($this->format !== 'json') {
+ $this->clientError('This method currently only serves JSON.', 415);
+ }
+
$id = $this->trimmed('id');
$this->original = Notice::staticGet('id', $id);
- if (empty($this->original)) {
+ if (!($this->original instanceof Notice)) {
// TRANS: Client error displayed trying to display redents of a non-exiting notice.
- $this->clientError(_('No such notice.'), 400, $this->format);
- return false;
+ $this->clientError(_('No such notice.'), 400);
}
$cnt = $this->trimmed('count');
*
* @return void
*/
- function handle($args)
+ protected function handle()
{
- parent::handle($args);
+ parent::handle();
$fave = new Fave();
$fave->selectAdd();
protected function prepare(array $args=array())
{
if ($this->needPost && !$this->isPost()) {
- $this->clientError(_('This method requires a POST.'), 400, $this->format);
+ $this->clientError(_('This method requires a POST.'), 405);
}
$this->args = common_copy_args($args);
// START qvitter API additions
- $m->connect('api/statuses/favs/:id.json',
- array('action' => 'ApiStatusesFavs',
- 'id' => '[0-9]+'));
+ $m->connect('api/statuses/favs/:id.:format',
+ array('action' => 'ApiStatusesFavs',
+ 'id' => '[0-9]+',
+ 'format' => '(xml|json)'));
- $m->connect('api/attachment/:id.json',
- array('action' => 'ApiAttachment',
- 'id' => '[0-9]+'));
+ $m->connect('api/attachment/:id.:format',
+ array('action' => 'ApiAttachment',
+ 'id' => '[0-9]+',
+ 'format' => '(xml|json)'));
- $m->connect('api/checkhub.json',
- array('action' => 'ApiCheckHub'));
+ $m->connect('api/checkhub.:format',
+ array('action' => 'ApiCheckHub',
+ 'format' => '(xml|json)'));
- $m->connect('api/externalprofile/show.json',
- array('action' => 'ApiExternalProfileShow'));
+ $m->connect('api/externalprofile/show.:format',
+ array('action' => 'ApiExternalProfileShow',
+ 'format' => '(xml|json)'));
$m->connect('api/statusnet/groups/admins/:id.:format',
- array('action' => 'ApiGroupAdmins',
- 'id' => Nickname::INPUT_FMT,
- 'format' => '(xml|json)'));
+ array('action' => 'ApiGroupAdmins',
+ 'id' => Nickname::INPUT_FMT,
+ 'format' => '(xml|json)'));
- $m->connect('api/account/update_link_color.json',
- array('action' => 'ApiAccountUpdateLinkColor'));
+ $m->connect('api/account/update_link_color.:format',
+ array('action' => 'ApiAccountUpdateLinkColor',
+ 'format' => '(xml|json)'));
- $m->connect('api/account/update_background_color.json',
- array('action' => 'ApiAccountUpdateBackgroundColor'));
+ $m->connect('api/account/update_background_color.:format',
+ array('action' => 'ApiAccountUpdateBackgroundColor',
+ 'format' => '(xml|json)'));
- $m->connect('api/account/register.json',
- array('action' => 'ApiAccountRegister'));
+ $m->connect('api/account/register.:format',
+ array('action' => 'ApiAccountRegister',
+ 'format' => '(xml|json)'));
- $m->connect('api/check_nickname.json',
- array('action' => 'ApiCheckNickname'));
+ $m->connect('api/check_nickname.:format',
+ array('action' => 'ApiCheckNickname',
+ 'format' => '(xml|json)'));
// END qvitter API additions