X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=actions%2Fdeletenotice.php;h=eb84b4f3ae5d877281e4d205bf4ebc5fa42359b9;hb=bc554ea9c233943e7b1077d724aa8070fdb7b0f9;hp=8f6e9bdd1f229a92f6eeb62dfd6c0a4a41d83307;hpb=c5cf2c4c94794a1aeea32a427ddd50e157fa893d;p=quix0rs-gnu-social.git diff --git a/actions/deletenotice.php b/actions/deletenotice.php index 8f6e9bdd1f..eb84b4f3ae 100644 --- a/actions/deletenotice.php +++ b/actions/deletenotice.php @@ -28,19 +28,56 @@ * @link http://status.net/ */ -if (!defined('STATUSNET')) { +if (!defined('STATUSNET') && !defined('LACONICA')) { exit(1); } -require_once INSTALLDIR.'/lib/deleteaction.php'; - -class DeletenoticeAction extends DeleteAction +// @todo FIXME: documentation needed. +class DeletenoticeAction extends Action { - var $error = null; + var $error = null; + var $user = null; + var $notice = null; + var $profile = null; + var $user_profile = null; + + function prepare($args) + { + parent::prepare($args); + + $this->user = common_current_user(); + + if (!$this->user) { + // TRANS: Error message displayed when trying to perform an action that requires a logged in user. + common_user_error(_('Not logged in.')); + exit; + } + + $notice_id = $this->trimmed('notice'); + $this->notice = Notice::getKV($notice_id); + + if (!$this->notice) { + // TRANS: Error message displayed trying to delete a non-existing notice. + common_user_error(_('No such notice.')); + exit; + } + + $this->profile = $this->notice->getProfile(); + $this->user_profile = $this->user->getProfile(); + + return true; + } function handle($args) { parent::handle($args); + + if ($this->notice->profile_id != $this->user_profile->id && + !$this->user->hasRight(Right::DELETEOTHERSNOTICE)) { + // TRANS: Error message displayed trying to delete a notice that was not made by the current user. + common_user_error(_('Cannot delete this notice.')); + exit; + } // XXX: Ajax! if ($_SERVER['REQUEST_METHOD'] == 'POST') { @@ -57,7 +94,6 @@ class DeletenoticeAction extends DeleteAction * * @return void */ - function showPageNotice() { $instr = $this->getInstructions(); @@ -70,12 +106,14 @@ class DeletenoticeAction extends DeleteAction function getInstructions() { + // TRANS: Instructions for deleting a notice. return _('You are about to permanently delete a notice. ' . 'Once this is done, it cannot be undone.'); } function title() { + // TRANS: Page title when deleting a notice. return _('Delete notice'); } @@ -88,7 +126,6 @@ class DeletenoticeAction extends DeleteAction * * @return void */ - function showForm($error = null) { $this->error = $error; @@ -100,7 +137,6 @@ class DeletenoticeAction extends DeleteAction * * @return void */ - function showContent() { $this->elementStart('form', array('id' => 'form_notice_delete', @@ -108,12 +144,26 @@ class DeletenoticeAction extends DeleteAction 'method' => 'post', 'action' => common_local_url('deletenotice'))); $this->elementStart('fieldset'); + // TRANS: Fieldset legend for the delete notice form. $this->element('legend', null, _('Delete notice')); $this->hidden('token', common_session_token()); $this->hidden('notice', $this->trimmed('notice')); + // TRANS: Message for the delete notice form. $this->element('p', null, _('Are you sure you want to delete this notice?')); - $this->submit('form_action-no', _('No'), 'submit form_action-primary', 'no', _("Do not delete this notice")); - $this->submit('form_action-yes', _('Yes'), 'submit form_action-secondary', 'yes', _('Delete this notice')); + $this->submit('form_action-no', + // TRANS: Button label on the delete notice form. + _m('BUTTON','No'), + 'submit form_action-primary', + 'no', + // TRANS: Submit button title for 'No' when deleting a notice. + _('Do not delete this notice.')); + $this->submit('form_action-yes', + // TRANS: Button label on the delete notice form. + _m('BUTTON','Yes'), + 'submit form_action-secondary', + 'yes', + // TRANS: Submit button title for 'Yes' when deleting a notice. + _('Delete this notice.')); $this->elementEnd('fieldset'); $this->elementEnd('form'); } @@ -124,13 +174,17 @@ class DeletenoticeAction extends DeleteAction $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->showForm(_('There was a problem with your session token. ' . - ' Try again, please.')); + 'Try again, please.')); return; } if ($this->arg('yes')) { - $this->notice->delete(); + if (Event::handle('StartDeleteOwnNotice', array($this->user, $this->notice))) { + $this->notice->delete(); + Event::handle('EndDeleteOwnNotice', array($this->user, $this->notice)); + } } $url = common_get_returnto();