. */ if (!defined('LACONICA')) { exit(1); } class ConfirmemailAction extends Action { function handle($args) { parent::handle($args); if (!common_logged_in()) { common_set_returnto($this->self_url()); common_redirect(common_local_url('login')); return; } $code = $this->trimmed('code'); if (!$code) { $this->client_error(_t('No confirmation code.')); return; } $confirm_email = Confirm_email::staticGet('code', $code); if (!$confirm_email) { $this->client_error(_t('Confirmation code not found.')); return; } $cur = common_current_user(); if ($cur->id != $confirm_email->user_id) { $this->client_error(_t('That confirmation code is not for you!')); return; } if ($cur->email == $confirm_email->email) { $this->client_error(_t('That email address is already confirmed.')); return; } $cur->query('BEGIN'); $orig_user = clone($cur); $cur->email = $confirm_email->email; $result = $cur->updateKeys($orig_user); if (!$result) { common_log_db_error($cur, 'UPDATE', __FILE__); $this->server_error(_t('Couldn\'t update user.')); return; } $result = $confirm_email->delete(); if (!$result) { common_log_db_error($confirm_email, 'DELETE', __FILE__); $this->server_error(_t('Couldn\'t delete email confirmation.')); return; } $cur->query('COMMIT'); common_show_header(_t('Confirm E-mail Address')); common_element('p', NULL, _t('The email address "') . $cur->email . _t('" has been confirmed for your account.')); common_show_footer(_t('Confirm E-mail Address')); } }