summaryrefslogtreecommitdiff
path: root/actions
diff options
context:
space:
mode:
Diffstat (limited to 'actions')
-rw-r--r--actions/subedit.php89
-rw-r--r--actions/subscriptions.php14
2 files changed, 102 insertions, 1 deletions
diff --git a/actions/subedit.php b/actions/subedit.php
new file mode 100644
index 000000000..e7505e3fe
--- /dev/null
+++ b/actions/subedit.php
@@ -0,0 +1,89 @@
+<?php
+/*
+ * Laconica - a distributed open-source microblogging tool
+ * Copyright (C) 2008, Controlez-Vous, Inc.
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+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 3b16590d6..d55c15abd 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;
}
}