From 3210cd69cc295e2af9dce5daac4953822e4f9fc7 Mon Sep 17 00:00:00 2001 From: Evan Prodromou Date: Tue, 9 Dec 2008 21:44:16 -0500 Subject: [PATCH] set jabber and sms flags on subscriptions darcs-hash:20081210024416-5ed1f-ec3b22136883f66c49473a10e09c06b6b9573a22.gz --- actions/subedit.php | 89 +++++++++++++++++++++++++++++++++++++++ actions/subscriptions.php | 14 +++++- 2 files changed, 102 insertions(+), 1 deletion(-) create mode 100644 actions/subedit.php diff --git a/actions/subedit.php b/actions/subedit.php new file mode 100644 index 0000000000..e7505e3fef --- /dev/null +++ b/actions/subedit.php @@ -0,0 +1,89 @@ +. + */ + +if (!defined('LACONICA')) { exit(1); } + +class SubeditAction extends Action { + + var $profile = NULL; + + function prepare($args) { + + parent::prepare($args); + + if (!common_logged_in()) { + $this->client_error(_('Not logged in.')); + return false; + } + + $token = $this->trimmed('token'); + + if (!$token || $token != common_session_token()) { + $this->client_error(_('There was a problem with your session token. Try again, please.')); + return; + } + + $id = $this->trimmed('profile'); + + if (!$id) { + $this->client_error(_('No profile specified.')); + return false; + } + + $this->profile = Profile::staticGet('id', $id); + + if (!$this->profile) { + $this->client_error(_('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->client_error(_('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->server_error(_('Could not save subscription.')); + return false; + } + + common_redirect(common_local_url('subscriptions', + array('nickname' => $cur->nickname))); + } + } +} diff --git a/actions/subscriptions.php b/actions/subscriptions.php index 3b16590d6b..d55c15abd7 100644 --- a/actions/subscriptions.php +++ b/actions/subscriptions.php @@ -55,7 +55,19 @@ class SubscriptionsAction extends GalleryAction { class SubscriptionsList extends ProfileList { - function show_owner_controls() { + function show_owner_controls($profile) { + $sub = Subscription::pkeyGet(array('subscriber' => $this->owner->id, + 'subscribed' => $profile->id)); + common_element_start('form', array('id' => 'subedit-' . $profile->id, + 'method' => 'post', + 'class' => 'subedit', + 'action' => common_local_url('subedit'))); + common_hidden('token', common_session_token()); + common_hidden('profile', $profile->id); + common_checkbox('jabber', _('Jabber'), $sub->jabber); + common_checkbox('sms', _('SMS'), $sub->sms); + common_submit('save', _('Save')); + common_element_end('form'); return; } }