* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
* @link http://status.net/
*/
-
class JoingroupAction extends Action
{
var $group = null;
/**
* Prepare to run
*/
-
function prepare($args)
{
parent::prepare($args);
if (!common_logged_in()) {
+ // TRANS: Client error displayed when trying to join a group while not logged in.
$this->clientError(_('You must be logged in to join a group.'));
return false;
}
$nickname_arg = $this->trimmed('nickname');
- $nickname = common_canonical_nickname($nickname_arg);
+ $id = intval($this->arg('id'));
+ if ($id) {
+ $this->group = User_group::staticGet('id', $id);
+ } else if ($nickname_arg) {
+ $nickname = common_canonical_nickname($nickname_arg);
- // Permanent redirect on non-canonical nickname
+ // Permanent redirect on non-canonical nickname
- if ($nickname_arg != $nickname) {
- $args = array('nickname' => $nickname);
- common_redirect(common_local_url('joingroup', $args), 301);
- return false;
- }
+ if ($nickname_arg != $nickname) {
+ $args = array('nickname' => $nickname);
+ common_redirect(common_local_url('leavegroup', $args), 301);
+ return false;
+ }
- if (!$nickname) {
- $this->clientError(_('No nickname.'), 404);
+ $local = Local_group::staticGet('nickname', $nickname);
+
+ if (!$local) {
+ // TRANS: Client error displayed when trying to join a non-local group.
+ $this->clientError(_('No such group.'), 404);
+ return false;
+ }
+
+ $this->group = User_group::staticGet('id', $local->group_id);
+ } else {
+ // TRANS: Client error displayed when trying to join a group without providing a group name or group ID.
+ $this->clientError(_('No nickname or ID.'), 404);
return false;
}
- $this->group = User_group::staticGet('nickname', $nickname);
-
if (!$this->group) {
+ // TRANS: Client error displayed when trying to join a non-existing group.
$this->clientError(_('No such group.'), 404);
return false;
}
$cur = common_current_user();
if ($cur->isMember($this->group)) {
+ // TRANS: Client error displayed when trying to join a group while already a member.
$this->clientError(_('You are already a member of that group.'), 403);
return false;
}
if (Group_block::isBlocked($this->group, $cur->getProfile())) {
+ // TRANS: Client error displayed when trying to join a group while being blocked form joining it.
$this->clientError(_('You have been blocked from that group by the admin.'), 403);
return false;
}
*
* @return void
*/
-
function handle($args)
{
parent::handle($args);
$cur = common_current_user();
- $member = new Group_member();
-
- $member->group_id = $this->group->id;
- $member->profile_id = $cur->id;
- $member->created = common_sql_now();
-
- $result = $member->insert();
-
- if (!$result) {
- common_log_db_error($member, 'INSERT', __FILE__);
+ try {
+ $result = $cur->joinGroup($this->group);
+ } catch (Exception $e) {
+ // TRANS: Server error displayed when joining a group failed in the database.
+ // TRANS: %1$s is the joining user's nickname, $2$s is the group nickname for which the join failed.
$this->serverError(sprintf(_('Could not join user %1$s to group %2$s.'),
$cur->nickname, $this->group->nickname));
+ return;
}
if ($this->boolean('ajax')) {
$this->startHTML('text/xml;charset=utf-8');
$this->elementStart('head');
- $this->element('title', null, sprintf(_('%1$s joined group %2$s'),
+ // TRANS: Title for join group page after joining.
+ $this->element('title', null, sprintf(_m('TITLE','%1$s joined group %2$s'),
$cur->nickname,
$this->group->nickname));
$this->elementEnd('head');
$this->elementStart('body');
- $lf = new LeaveForm($this, $this->group);
- $lf->show();
+
+ if ($result instanceof Group_member) {
+ $form = new LeaveForm($this, $this->group);
+ } else if ($result instanceof Group_join_queue) {
+ $form = new CancelGroupForm($this, $this->group);
+ } else {
+ // wtf?
+ // TRANS: Exception thrown when there is an unknown error joining a group.
+ throw new Exception(_("Unknown error joining group."));
+ }
+ $form->show();
$this->elementEnd('body');
$this->elementEnd('html');
} else {
303);
}
}
-}
\ No newline at end of file
+}