X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=plugins%2FBookmark%2Factions%2Fnewbookmark.php;h=466cbc5d801c55534082a4d226f469f34468013e;hb=d6b28c64830f632bb2f4b6f3c9369b9e56ad217a;hp=c3987a28b8dfa730c07d60e642680a222c330e94;hpb=996345088e8d57cf39fa38129ab50ff02918a275;p=quix0rs-gnu-social.git diff --git a/plugins/Bookmark/actions/newbookmark.php b/plugins/Bookmark/actions/newbookmark.php index c3987a28b8..466cbc5d80 100644 --- a/plugins/Bookmark/actions/newbookmark.php +++ b/plugins/Bookmark/actions/newbookmark.php @@ -43,143 +43,57 @@ if (!defined('STATUSNET')) { * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0 * @link http://status.net/ */ -class NewbookmarkAction extends Action +class NewbookmarkAction extends FormAction { - protected $user = null; - protected $error = null; protected $complete = null; protected $title = null; protected $url = null; protected $tags = null; protected $description = null; - /** - * Returns the title of the action - * - * @return string Action title - */ function title() { // TRANS: Title for action to create a new bookmark. return _m('New bookmark'); } - /** - * For initializing members of the class. - * - * @param array $argarray misc. arguments - * - * @return boolean true - */ - function prepare($argarray) + protected function doPreparation() { - parent::prepare($argarray); - - if ($this->boolean('ajax')) { - StatusNet::setApi(true); - } - - $this->user = common_current_user(); - - if (empty($this->user)) { - // TRANS: Client exception thrown when trying to create a new bookmark while not logged in. - throw new ClientException(_m('Must be logged in to post a bookmark.'), - 403); - } - - if ($this->isPost()) { - $this->checkSessionToken(); - } - $this->title = $this->trimmed('title'); $this->url = $this->trimmed('url'); - $this->tags = $this->trimmed('tags'); + $this->tags = preg_split('/[\s,]+/', $this->trimmed('tags'), null, PREG_SPLIT_NO_EMPTY); $this->description = $this->trimmed('description'); return true; } - /** - * Handler method - * - * @param array $argarray is ignored since it's now passed in in prepare() - * - * @return void - */ - function handle($argarray=null) - { - parent::handle($argarray); - - if ($this->isPost()) { - $this->newBookmark(); - } else { - $this->showPage(); - } - - return; - } - /** * Add a new bookmark * * @return void */ - function newBookmark() + function handlePost() { - try { - if (empty($this->title)) { - // TRANS: Client exception thrown when trying to create a new bookmark without a title. - throw new ClientException(_m('Bookmark must have a title.')); - } - - if (empty($this->url)) { - // TRANS: Client exception thrown when trying to create a new bookmark without a URL. - throw new ClientException(_m('Bookmark must have an URL.')); - } - - $options = array(); + if (empty($this->title)) { + // TRANS: Client exception thrown when trying to create a new bookmark without a title. + throw new ClientException(_m('Bookmark must have a title.')); + } - ToSelector::fillOptions($this, $options); + if (empty($this->url)) { + // TRANS: Client exception thrown when trying to create a new bookmark without a URL. + throw new ClientException(_m('Bookmark must have an URL.')); + } - $saved = Bookmark::saveNew($this->user->getProfile(), - $this->title, - $this->url, - $this->tags, - $this->description, - $options); + $options = array(); - } catch (ClientException $ce) { - if ($this->boolean('ajax')) { - $this->startHTML('text/xml;charset=utf-8'); - $this->elementStart('head'); - // TRANS: Page title after an AJAX error occurs - $this->element('title', null, _('Ajax Error')); - $this->elementEnd('head'); - $this->elementStart('body'); - $this->element('p', array('id' => 'error'), $ce->getMessage()); - $this->elementEnd('body'); - $this->endHTML(); - return; - } else { - $this->error = $ce->getMessage(); - $this->showPage(); - return; - } - } + ToSelector::fillOptions($this, $options); - if ($this->boolean('ajax')) { - $this->startHTML('text/xml;charset=utf-8'); - $this->elementStart('head'); - // TRANS: Page title after posting a bookmark. - $this->element('title', null, _m('Bookmark posted')); - $this->elementEnd('head'); - $this->elementStart('body'); - $this->showNotice($saved); - $this->elementEnd('body'); - $this->endHTML(); - } else { - common_redirect($saved->getUrl(), 303); - } + $saved = Bookmark::addNew($this->scoped, + $this->title, + $this->url, + $this->tags, + $this->description, + $options); } /**