From a8a36677748b304faf20742598b90f3d9634f393 Mon Sep 17 00:00:00 2001 From: Evan Prodromou Date: Mon, 8 Sep 2008 14:16:24 -0400 Subject: initial non-Ajax version of favorites darcs-hash:20080908181624-84dde-8200e1d91eb5f560ef0f296c9e1c56f93ef1b0c5.gz --- actions/disfavor.php | 74 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 74 insertions(+) create mode 100644 actions/disfavor.php (limited to 'actions/disfavor.php') diff --git a/actions/disfavor.php b/actions/disfavor.php new file mode 100644 index 000000000..59807f5e6 --- /dev/null +++ b/actions/disfavor.php @@ -0,0 +1,74 @@ +. + */ + +if (!defined('LACONICA')) { exit(1); } + +require_once($INSTALLDIR.'/lib/mail.php'); + +class DisfavorAction extends Action { + + function handle($args) { + + parent::handle($args); + + if (!common_logged_in()) { + common_user_error(_('Not logged in.')); + return; + } + + $user = common_current_user(); + + if ($_SERVER['REQUEST_METHOD'] != 'POST') { + common_redirect(common_local_url('favorites', array('nickname' => $user->nickname))); + return; + } + + $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('notice'); + + $notice = Notice::staticGet($id); + + $fave = new Fave(); + $fave->user_id = $this->id; + $fave->notice_id = $notice->id; + if (!$fave->find(true)) { + $this->client_error(_('This notice is not a favorite!')); + return; + } + + $result = $fave->delete(); + + if (!$result) { + common_log_db_error($fave, 'DELETE', __FILE__); + $this->server_error(_('Could not delete favorite.')); + return; + } + + # XXX: ajax response + + common_redirect(common_local_url('favorites', + array('nickname' => $user->nickname))); + } +} \ No newline at end of file -- cgit v1.2.3-54-g00ecf