. * * PHP version 5 * * @category Action * @package StatusNet * @author Brion Vibber * @copyright 2010 StatusNet, Inc. * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPLv3 * @link http://status.net/ */ if (!defined('GNUSOCIAL') && !defined('STATUSNET')) { exit(1); } /** * Takes parameters: * * - feed: a profile ID * - token: session token to prevent CSRF attacks * - ajax: boolean; whether to return Ajax or full-browser results * * Only works if the current user is logged in. * * @category Action * @package StatusNet * @copyright 2010 StatusNet, Inc. * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPLv3 * @link http://status.net/ */ abstract class BaseMirrorAction extends Action { var $user; var $profile; /** * Check pre-requisites and instantiate attributes * * @param Array $args array of arguments (URL, GET, POST) * * @return boolean success flag */ protected function prepare(array $args=array()) { parent::prepare($args); return $this->sharedBoilerplate(); } protected function validateFeedUrl($url) { if (common_valid_http_url($url)) { return $url; } else { // TRANS: Client error displayed when entering an invalid URL for a feed. // TRANS: %s is the invalid feed URL. $this->clientError(sprintf(_m("Invalid feed URL: %s."), $url)); } } protected function validateProfile($id) { $id = intval($id); $profile = Profile::getKV('id', $id); if ($profile && $profile->id != $this->user->id) { return $profile; } // TRANS: Error message returned to user when setting up feed mirroring, // TRANS: but we were unable to resolve the given URL to a working feed. $this->clientError(_m('Invalid profile for mirroring.')); } /** * * @param string $url * @return Profile */ protected function profileForFeed($url) { try { // Maybe we got a web page? $oprofile = Ostatus_profile::ensureProfileURL($url); } catch (Exception $e) { // Direct feed URL? $oprofile = Ostatus_profile::ensureFeedURL($url); } if ($oprofile->isGroup()) { // TRANS: Client error displayed when trying to mirror a GNU social group feed. $this->clientError(_m('Cannot mirror a GNU social group at this time.')); } $this->oprofile = $oprofile; // @todo FIXME: ugly side effect :D return $oprofile->localProfile(); } /** * @todo FIXME: none of this belongs in end classes * this stuff belongs in shared code! */ function sharedBoilerplate() { // Only allow POST requests if ($_SERVER['REQUEST_METHOD'] != 'POST') { // TRANS: Client error displayed when trying to use another method than POST. $this->clientError(_m('This action only accepts POST requests.')); return false; } // CSRF protection $token = $this->trimmed('token'); if (!$token || $token != common_session_token()) { // TRANS: Client error displayed when the session token does not match or is not given. $this->clientError(_m('There was a problem with your session token.'. ' Try again, please.')); return false; } // Only for logged-in users $this->user = common_current_user(); if (empty($this->user)) { // TRANS: Error message displayed when trying to perform an action that requires a logged in user. $this->clientError(_m('Not logged in.')); return false; } return true; } /** * Handle request * * Does the subscription and returns results. * * @param Array $args unused. * * @return void */ protected function handle() { // Throws exception on error $this->saveMirror(); if ($this->boolean('ajax')) { $this->startHTML('text/xml;charset=utf-8'); $this->elementStart('head'); // TRANS: Page title for subscribed feed mirror. $this->element('title', null, _m('Subscribed')); $this->elementEnd('head'); $this->elementStart('body'); $unsubscribe = new EditMirrorForm($this, $this->profile); $unsubscribe->show(); $this->elementEnd('body'); $this->endHTML(); } else { $url = common_local_url('mirrorsettings'); common_redirect($url, 303); } } abstract protected function saveMirror(); }