diff options
-rw-r--r-- | actions/imsettings.php | 245 | ||||
-rw-r--r-- | lib/jabber.php | 19 | ||||
-rw-r--r-- | lib/util.php | 2 | ||||
-rwxr-xr-x | xmppdaemon.php | 43 |
4 files changed, 219 insertions, 90 deletions
diff --git a/actions/imsettings.php b/actions/imsettings.php index d8fc8b87c..a5e9be307 100644 --- a/actions/imsettings.php +++ b/actions/imsettings.php @@ -47,42 +47,79 @@ class ImsettingsAction extends SettingsAction { 'id' => 'imsettings', 'action' => common_local_url('imsettings'))); - # too much common patterns here... abstractable? - common_input('jabber', _t('IM Address'), - ($this->arg('jabber')) ? $this->arg('jabber') : $user->jabber, - _t('Jabber or GTalk address, like "UserName@example.org"')); + + 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'), + ($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', _t('Send me notices through Jabber/GTalk.')); common_checkbox('updatefrompresence', _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_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() { - $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'); $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(); assert(!is_null($user)); # should already be checked @@ -90,11 +127,11 @@ class ImsettingsAction extends SettingsAction { $user->query('BEGIN'); $original = clone($user); - + $user->jabbernotify = $jabbernotify; $user->updatefrompresence = $updatefrompresence; - $result = $user->update($original); # For key columns + $result = $user->update($original); if ($result === FALSE) { common_log_db_error($user, 'UPDATE', __FILE__); @@ -102,58 +139,120 @@ class ImsettingsAction extends SettingsAction { return; } - $confirmation_sent = false; - + $user->query('COMMIT'); + + $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; + } + + $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) { - - 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; - } - } + $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'); - $msg = ($confirmation_sent) ? - _t('Settings saved. A confirmation code was ' . - ' sent to the IM address you added. ') : - _t('Settings saved.'); - - $this->show_form($msg, TRUE); + # Unsubscribe to the old address + + jabber_special_presence('unsubscribe', $jabber); + + $this->show_form(_t('The address was removed.'), TRUE); } function jabber_exists($jabber) { diff --git a/lib/jabber.php b/lib/jabber.php index 340264cc2..6ae3af208 100644 --- a/lib/jabber.php +++ b/lib/jabber.php @@ -81,22 +81,15 @@ function jabber_send_presence($status, $show='available', $to=Null) { } 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') . ' ' . 'has said that your Jabber ID belongs to them. ' . - 'If that\'s true, you can confirm by clicking on this URL: ' . - common_local_url('confirmaddress', array('code' => $code)) . - ' . (If you cannot click it, copy-and-paste it into the ' . - 'address bar of your browser). If that user isn\'t you, ' . - 'or if you didn\'t request this confirmation, just ignore this message.'; + 'If that\'s true, you can confirm by clicking on this URL: ' . + common_local_url('confirmaddress', array('code' => $code)) . + ' . (If you cannot click it, copy-and-paste it into the ' . + 'address bar of your browser). If that user isn\'t you, ' . + '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) { diff --git a/lib/util.php b/lib/util.php index 4e318a770..ccaf53123 100644 --- a/lib/util.php +++ b/lib/util.php @@ -322,6 +322,7 @@ function common_input($id, $label, $value=NULL,$instructions=NULL) { function common_checkbox($id, $label, $instructions=NULL, $value='true') { common_element_start('p'); + common_element('label', array('for' => $id), $label); $attrs = array('name' => $id, 'type' => 'checkbox', 'id' => $id, @@ -330,7 +331,6 @@ function common_checkbox($id, $label, $instructions=NULL, $value='true') $attrs['value'] = htmlspecialchars($value); } common_element('input', $attrs); - common_element('label', array('for' => $id), $label); if ($instructions) { common_element('span', 'input_instructions', $instructions); } diff --git a/xmppdaemon.php b/xmppdaemon.php index 1a77c4340..3f2b575e4 100755 --- a/xmppdaemon.php +++ b/xmppdaemon.php @@ -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) { if ($pl['type'] != 'chat') { return; @@ -95,8 +111,6 @@ class XMPPDaemon { if (strlen($pl['body']) == 0) { return; } - $from = jabber_normalize_jid($pl['from']); - $user = User::staticGet('jabber', $from); if (!$user) { $this->log(LOG_WARNING, 'Message from unknown user ' . $from); return; @@ -180,8 +194,31 @@ class XMPPDaemon { 'Accepted subscription from ' . $from); break; 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': + $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, 'Ignoring "' . $pl['type'] . '" from ' . $from); break; |