some UI changes to the IM settings
darcs-hash:20080626181144-34904-87503e70e6705b06ebb6c19910583f4fba1b22e0.gz
This commit is contained in:
parent
b7d927cd41
commit
db2d79cd31
@ -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_input('jabber', _t('IM Address'),
|
common_element('h2', NULL, _t('Address'));
|
||||||
($this->arg('jabber')) ? $this->arg('jabber') : $user->jabber,
|
|
||||||
_t('Jabber or GTalk address, like "UserName@example.org"'));
|
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'),
|
||||||
|
($this->arg('jabber')) ? $this->arg('jabber') : NULL,
|
||||||
|
_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
|
||||||
@ -90,11 +127,11 @@ class ImsettingsAction extends SettingsAction {
|
|||||||
$user->query('BEGIN');
|
$user->query('BEGIN');
|
||||||
|
|
||||||
$original = clone($user);
|
$original = clone($user);
|
||||||
|
|
||||||
$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,58 +139,120 @@ class ImsettingsAction extends SettingsAction {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$confirmation_sent = false;
|
|
||||||
|
|
||||||
if ($user->jabber != $jabber) {
|
|
||||||
|
|
||||||
if ($jabber) {
|
|
||||||
$confirm = new Confirm_address();
|
|
||||||
$confirm->address = $jabber;
|
|
||||||
$confirm->address_type = 'jabber';
|
|
||||||
$confirm->user_id = $user->id;
|
|
||||||
$confirm->code = common_confirmation_code(64);
|
|
||||||
|
|
||||||
$result = $confirm->insert();
|
|
||||||
|
|
||||||
if ($result === FALSE) {
|
|
||||||
common_log_db_error($confirm, 'INSERT', __FILE__);
|
|
||||||
common_server_error(_t('Couldnt insert confirmation code.'));
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
# XXX: optionally queue for offline sending
|
|
||||||
|
|
||||||
jabber_confirm_address($confirm->code,
|
|
||||||
$user->nickname,
|
|
||||||
$jabber);
|
|
||||||
|
|
||||||
if ($result === FALSE) {
|
|
||||||
common_log_db_error($confirm, 'INSERT', __FILE__);
|
|
||||||
common_server_error(_t('Couldnt insert confirmation code.'));
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
$confirmation_sent = false;
|
|
||||||
} else {
|
|
||||||
# Clearing the ID is free
|
|
||||||
$user->jabber = NULL;
|
|
||||||
$result = $user->updateKeys($original);
|
|
||||||
if ($result === FALSE) {
|
|
||||||
common_log_db_error($user, 'UPDATE', __FILE__);
|
|
||||||
common_server_error(_t('Couldnt update user.'));
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$user->query('COMMIT');
|
$user->query('COMMIT');
|
||||||
|
|
||||||
$msg = ($confirmation_sent) ?
|
$this->show_form(_t('Preferences saved.'), true);
|
||||||
_t('Settings saved. A confirmation code was ' .
|
}
|
||||||
' sent to the IM address you added. ') :
|
|
||||||
_t('Settings saved.');
|
function add_address() {
|
||||||
|
|
||||||
$this->show_form($msg, TRUE);
|
$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;
|
||||||
|
}
|
||||||
|
|
||||||
|
$confirm = new Confirm_address();
|
||||||
|
$confirm->address = $jabber;
|
||||||
|
$confirm->address_type = 'jabber';
|
||||||
|
$confirm->user_id = $user->id;
|
||||||
|
$confirm->code = common_confirmation_code(64);
|
||||||
|
|
||||||
|
$result = $confirm->insert();
|
||||||
|
|
||||||
|
if ($result === FALSE) {
|
||||||
|
common_log_db_error($confirm, 'INSERT', __FILE__);
|
||||||
|
common_server_error(_t('Couldnt insert confirmation code.'));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
# XXX: optionally queue for offline sending
|
||||||
|
|
||||||
|
if (!jabber_is_subscribed($jabber)) {
|
||||||
|
jabber_special_presence('subscribe', $address);
|
||||||
|
} else {
|
||||||
|
jabber_confirm_address($confirm->code,
|
||||||
|
$user->nickname,
|
||||||
|
$jabber);
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->show_form(_t('A confirmation code was ' .
|
||||||
|
' sent to the IM address you added. ' .
|
||||||
|
' 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;
|
||||||
|
}
|
||||||
|
|
||||||
|
$result = $confirm->delete();
|
||||||
|
|
||||||
|
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;
|
||||||
|
$result = $user->updateKeys($original);
|
||||||
|
if ($result === FALSE) {
|
||||||
|
common_log_db_error($user, 'UPDATE', __FILE__);
|
||||||
|
common_server_error(_t('Couldnt update user.'));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
$user->query('COMMIT');
|
||||||
|
|
||||||
|
# Unsubscribe to the old address
|
||||||
|
|
||||||
|
jabber_special_presence('unsubscribe', $jabber);
|
||||||
|
|
||||||
|
$this->show_form(_t('The address was removed.'), TRUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
function jabber_exists($jabber) {
|
function jabber_exists($jabber) {
|
||||||
|
@ -81,22 +81,15 @@ 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: ' .
|
||||||
common_local_url('confirmaddress', array('code' => $code)) .
|
common_local_url('confirmaddress', array('code' => $code)) .
|
||||||
' . (If you cannot click it, copy-and-paste it into the ' .
|
' . (If you cannot click it, copy-and-paste it into the ' .
|
||||||
'address bar of your browser). If that user isn\'t you, ' .
|
'address bar of your browser). If that user isn\'t you, ' .
|
||||||
'or if you didn\'t request this confirmation, just ignore this message.';
|
'or if you didn\'t request this confirmation, just ignore this message.';
|
||||||
|
|
||||||
jabber_send_message($address, $body);
|
jabber_send_message($address, $body);
|
||||||
}
|
}
|
||||||
|
|
||||||
function jabber_special_presence($type, $to=NULL, $show=NULL, $status=NULL) {
|
function jabber_special_presence($type, $to=NULL, $show=NULL, $status=NULL) {
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
|
Loading…
Reference in New Issue
Block a user