some UI changes to the IM settings

darcs-hash:20080626181144-34904-87503e70e6705b06ebb6c19910583f4fba1b22e0.gz
This commit is contained in:
Evan Prodromou 2008-06-26 14:11:44 -04:00
parent b7d927cd41
commit db2d79cd31
4 changed files with 221 additions and 92 deletions

View File

@ -47,42 +47,79 @@ class ImsettingsAction extends SettingsAction {
'id' => 'imsettings', 'id' => 'imsettings',
'action' => 'action' =>
common_local_url('imsettings'))); common_local_url('imsettings')));
# too much common patterns here... abstractable?
common_element('h2', NULL, _t('Address'));
if ($user->jabber) {
common_element_start('p');
common_element('span', 'address confirmed', $user->jabber);
common_element('span', 'input_instructions',
_t('Current confirmed Jabber/GTalk address.'));
common_hidden('jabber', $user->jabber);
common_element_end('p');
common_submit('remove', 'Remove');
} else {
$confirm = $this->get_confirmation();
if ($confirm) {
common_element_start('p');
common_element('span', 'address unconfirmed', $confirm->address);
common_element('span', 'input_instructions',
_t('Current confirmed Jabber/GTalk address.'));
common_hidden('jabber', $confirm->address);
common_element_end('p');
common_submit('cancel', _t('Cancel'));
} else {
common_input('jabber', _t('IM Address'), common_input('jabber', _t('IM Address'),
($this->arg('jabber')) ? $this->arg('jabber') : $user->jabber, ($this->arg('jabber')) ? $this->arg('jabber') : NULL,
_t('Jabber or GTalk address, like "UserName@example.org"')); _t('Jabber or GTalk address, like "UserName@example.org"'));
common_submit('add', 'Add');
}
}
common_element('h2', NULL, _t('Preferences'));
common_checkbox('jabbernotify', common_checkbox('jabbernotify',
_t('Send me notices through Jabber/GTalk.')); _t('Send me notices through Jabber/GTalk.'));
common_checkbox('updatefrompresence', common_checkbox('updatefrompresence',
_t('Post a notice when my Jabber/GTalk status changes.')); _t('Post a notice when my Jabber/GTalk status changes.'));
common_submit('submit', _t('Save')); common_submit('save', _t('Save'));
common_element_end('form'); common_element_end('form');
common_show_footer(); common_show_footer();
} }
function get_confirmation() {
$user = common_current_user();
$confirm = new Confirm_address();
$confirm->user_id = $user->id;
$confirm->address_type = 'jabber';
if ($confirm->find(TRUE)) {
return $confirm;
} else {
return NULL;
}
}
function handle_post() { function handle_post() {
$jabber = $this->trimmed('jabber'); if ($this->arg('save')) {
$this->save_preferences();
} else if ($this->arg('add')) {
$this->add_address();
} else if ($this->arg('cancel')) {
$this->cancel_confirmation();
} else if ($this->arg('remove')) {
$this->remove_address();
} else {
$this->show_form(_t('Unexpected form submission.'));
}
}
function save_preferences() {
$jabbernotify = $this->boolean('jabbernotify'); $jabbernotify = $this->boolean('jabbernotify');
$updatefrompresence = $this->boolean('updatefrompresence'); $updatefrompresence = $this->boolean('updatefrompresence');
# Some validation
if ($jabber) {
$jabber = jabber_normalize_jid($jabber);
if (!$jabber) {
$this->show_form(_('Cannot normalize that Jabber ID'));
return;
}
if (!jabber_valid_base_jid($jabber)) {
$this->show_form(_('Not a valid Jabber ID'));
return;
} else if ($this->jabber_exists($jabber)) {
$this->show_form(_('Jabber ID already belongs to another user.'));
return;
}
}
$user = common_current_user(); $user = common_current_user();
assert(!is_null($user)); # should already be checked assert(!is_null($user)); # should already be checked
@ -94,7 +131,7 @@ class ImsettingsAction extends SettingsAction {
$user->jabbernotify = $jabbernotify; $user->jabbernotify = $jabbernotify;
$user->updatefrompresence = $updatefrompresence; $user->updatefrompresence = $updatefrompresence;
$result = $user->update($original); # For key columns $result = $user->update($original);
if ($result === FALSE) { if ($result === FALSE) {
common_log_db_error($user, 'UPDATE', __FILE__); common_log_db_error($user, 'UPDATE', __FILE__);
@ -102,11 +139,39 @@ class ImsettingsAction extends SettingsAction {
return; return;
} }
$confirmation_sent = false; $user->query('COMMIT');
if ($user->jabber != $jabber) { $this->show_form(_t('Preferences saved.'), true);
}
function add_address() {
$jabber = $this->trimmed('jabber');
# Some validation
if (!$jabber) {
$this->show_form(_t('No Jabber ID.'));
return;
}
$jabber = jabber_normalize_jid($jabber);
if (!$jabber) {
$this->show_form(_('Cannot normalize that Jabber ID'));
return;
}
if (!jabber_valid_base_jid($jabber)) {
$this->show_form(_('Not a valid Jabber ID'));
return;
} else if ($user->jabber == $jabber) {
$this->show_form(_('That is already your Jabber ID.'));
return;
} else if ($this->jabber_exists($jabber)) {
$this->show_form(_('Jabber ID already belongs to another user.'));
return;
}
if ($jabber) {
$confirm = new Confirm_address(); $confirm = new Confirm_address();
$confirm->address = $jabber; $confirm->address = $jabber;
$confirm->address_type = 'jabber'; $confirm->address_type = 'jabber';
@ -123,19 +188,57 @@ class ImsettingsAction extends SettingsAction {
# XXX: optionally queue for offline sending # XXX: optionally queue for offline sending
if (!jabber_is_subscribed($jabber)) {
jabber_special_presence('subscribe', $address);
} else {
jabber_confirm_address($confirm->code, jabber_confirm_address($confirm->code,
$user->nickname, $user->nickname,
$jabber); $jabber);
}
if ($result === FALSE) { $this->show_form(_t('A confirmation code was ' .
common_log_db_error($confirm, 'INSERT', __FILE__); ' sent to the IM address you added. ' .
common_server_error(_t('Couldnt insert confirmation code.')); ' You must approve ' . jabber_daemon_address() .
' for sending messages to you.'),
TRUE);
}
function cancel_confirmation() {
$jabber = $this->arg('jabber');
$confirm = $this->get_confirmation();
if (!$confirm) {
$this->show_form(_t('No pending confirmation to cancel.'));
return;
}
if ($confirm->address != $jabber) {
$this->show_form(_t('That is the wrong IM address.'));
return; return;
} }
$confirmation_sent = false; $result = $confirm->delete();
} else {
# Clearing the ID is free if (!$result) {
common_log_db_error($confirm, 'DELETE', __FILE__);
$this->server_error(_t('Couldn\'t delete email confirmation.'));
return;
}
$this->show_form(_t('Confirmation cancelled.'), TRUE);
}
function remove_address() {
$user = common_current_user();
$jabber = $this->arg('jabber');
# Maybe an old tab open...?
if ($user->jabber != $jabber) {
$this->show_form(_t('That is not your Jabber ID.'));
return;
}
$user->query('BEGIN');
$user->jabber = NULL; $user->jabber = NULL;
$result = $user->updateKeys($original); $result = $user->updateKeys($original);
if ($result === FALSE) { if ($result === FALSE) {
@ -143,17 +246,13 @@ class ImsettingsAction extends SettingsAction {
common_server_error(_t('Couldnt update user.')); common_server_error(_t('Couldnt update user.'));
return; return;
} }
}
}
$user->query('COMMIT'); $user->query('COMMIT');
$msg = ($confirmation_sent) ? # Unsubscribe to the old address
_t('Settings saved. A confirmation code was ' .
' sent to the IM address you added. ') :
_t('Settings saved.');
$this->show_form($msg, TRUE); jabber_special_presence('unsubscribe', $jabber);
$this->show_form(_t('The address was removed.'), TRUE);
} }
function jabber_exists($jabber) { function jabber_exists($jabber) {

View File

@ -81,13 +81,6 @@ function jabber_send_presence($status, $show='available', $to=Null) {
} }
function jabber_confirm_address($code, $nickname, $address) { function jabber_confirm_address($code, $nickname, $address) {
# Fire off a subscription, just in case
jabber_special_presence('subscribe', $address);
# Hopefully this goes through if we're not already subscribed
$body = 'User "' . $nickname . '" on ' . common_config('site', 'name') . ' ' . $body = 'User "' . $nickname . '" on ' . common_config('site', 'name') . ' ' .
'has said that your Jabber ID belongs to them. ' . 'has said that your Jabber ID belongs to them. ' .
'If that\'s true, you can confirm by clicking on this URL: ' . 'If that\'s true, you can confirm by clicking on this URL: ' .

View File

@ -322,6 +322,7 @@ function common_input($id, $label, $value=NULL,$instructions=NULL) {
function common_checkbox($id, $label, $instructions=NULL, $value='true') function common_checkbox($id, $label, $instructions=NULL, $value='true')
{ {
common_element_start('p'); common_element_start('p');
common_element('label', array('for' => $id), $label);
$attrs = array('name' => $id, $attrs = array('name' => $id,
'type' => 'checkbox', 'type' => 'checkbox',
'id' => $id, 'id' => $id,
@ -330,7 +331,6 @@ function common_checkbox($id, $label, $instructions=NULL, $value='true')
$attrs['value'] = htmlspecialchars($value); $attrs['value'] = htmlspecialchars($value);
} }
common_element('input', $attrs); common_element('input', $attrs);
common_element('label', array('for' => $id), $label);
if ($instructions) { if ($instructions) {
common_element('span', 'input_instructions', $instructions); common_element('span', 'input_instructions', $instructions);
} }

View File

@ -88,6 +88,22 @@ class XMPPDaemon {
} }
} }
function get_user($from) {
$user = User::staticGet('jabber', jabber_normalize_jid($from));
return $user;
}
function get_confirmation($from) {
$confirm = new Confirm_address();
$confirm->address = $from;
$confirm->address_type = 'jabber';
if ($confirm->find(TRUE)) {
return $confirm;
} else {
return NULL;
}
}
function handle_message(&$pl) { function handle_message(&$pl) {
if ($pl['type'] != 'chat') { if ($pl['type'] != 'chat') {
return; return;
@ -95,8 +111,6 @@ class XMPPDaemon {
if (strlen($pl['body']) == 0) { if (strlen($pl['body']) == 0) {
return; return;
} }
$from = jabber_normalize_jid($pl['from']);
$user = User::staticGet('jabber', $from);
if (!$user) { if (!$user) {
$this->log(LOG_WARNING, 'Message from unknown user ' . $from); $this->log(LOG_WARNING, 'Message from unknown user ' . $from);
return; return;
@ -180,8 +194,31 @@ class XMPPDaemon {
'Accepted subscription from ' . $from); 'Accepted subscription from ' . $from);
break; break;
case 'subscribed': case 'subscribed':
case 'unsubscribe': $confirm = $this->get_confirmation($from);
if ($confirm) {
$user = User::staticGet($confirm->user_id);
if ($user) {
jabber_confirm_address($confirm->code,
$user->nickname,
$confirm->address);
} else {
$this->log(LOG_WARNING,
'got unexpected subscribed message from ' . $from);
}
}
case 'unsubscribed': case 'unsubscribed':
$user = $this->get_user($from);
if ($user) {
$this->set_notify($user, false);
}
$confirm = $this->get_confirmation($from);
if ($confirm) {
$user = User::staticGet($confirm->user_id);
if ($user) {
}
}
case 'unsubscribe':
$this->log(LOG_INFO, $this->log(LOG_INFO,
'Ignoring "' . $pl['type'] . '" from ' . $from); 'Ignoring "' . $pl['type'] . '" from ' . $from);
break; break;