. */ if (!defined('STATUSNET') && !defined('LACONICA')) { exit(1); } class SubeditAction extends Action { var $profile = null; function prepare($args) { parent::prepare($args); if (!common_logged_in()) { $this->clientError(_('Not logged in.')); return false; } $token = $this->trimmed('token'); if (!$token || $token != common_session_token()) { $this->clientError(_('There was a problem with your session token. '. 'Try again, please.')); return false; } $id = $this->trimmed('profile'); if (!$id) { $this->clientError(_('No profile specified.')); return false; } $this->profile = Profile::staticGet('id', $id); if (!$this->profile) { $this->clientError(_('No profile with that ID.')); return false; } return true; } function handle($args) { parent::handle($args); if ($_SERVER['REQUEST_METHOD'] == 'POST') { $cur = common_current_user(); $sub = Subscription::pkeyGet(array('subscriber' => $cur->id, 'subscribed' => $this->profile->id)); if (!$sub) { $this->clientError(_('You are not subscribed to that profile.')); return false; } $orig = clone($sub); $sub->jabber = $this->boolean('jabber'); $sub->sms = $this->boolean('sms'); $result = $sub->update($orig); if (!$result) { common_log_db_error($sub, 'UPDATE', __FILE__); $this->serverError(_('Could not save subscription.')); return false; } common_redirect(common_local_url('subscriptions', array('nickname' => $cur->nickname)), 303); } } }