X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=actions%2Fshowmessage.php;h=86fbee8b73f95c303ac21f477da1a474d997b00c;hb=fb4b004435403dd0d4126a0c11c9fa5c557e9dba;hp=d737f85d3a0b2ba3b4bb0531f5344f023c5eb4ed;hpb=2503c33502607ad81da69dece32c6b981a4db335;p=quix0rs-gnu-social.git diff --git a/actions/showmessage.php b/actions/showmessage.php index d737f85d3a..86fbee8b73 100644 --- a/actions/showmessage.php +++ b/actions/showmessage.php @@ -30,20 +30,17 @@ if (!defined('STATUSNET') && !defined('LACONICA')) { exit(1); } -require_once INSTALLDIR.'/lib/mailbox.php'; - /** * Show a single message * - * // XXX: It is totally weird how this works! - * * @category Personal * @package StatusNet * @author Evan Prodromou * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 * @link http://status.net/ */ -class ShowmessageAction extends MailboxAction + +class ShowmessageAction extends Action { /** * Message object to show @@ -72,32 +69,29 @@ class ShowmessageAction extends MailboxAction $this->page = 1; $id = $this->trimmed('message'); - $this->message = Message::staticGet('id', $id); + $this->message = Message::getKV('id', $id); if (!$this->message) { // TRANS: Client error displayed requesting a single message that does not exist. $this->clientError(_('No such message.'), 404); - return false; } $this->user = common_current_user(); + if (empty($this->user) || + ($this->user->id != $this->message->from_profile && + $this->user->id != $this->message->to_profile)) { + // TRANS: Client error displayed requesting a single direct message the requesting user was not a party in. + throw new ClientException(_('Only the sender and recipient ' . + 'may read this message.'), 403); + } + return true; } function handle($args) { - Action::handle($args); - - if ($this->user && ($this->user->id == $this->message->from_profile || - $this->user->id == $this->message->to_profile)) { - $this->showPage(); - } else { - // TRANS: Client error displayed requesting a single direct message the requesting user was not a party in. - $this->clientError(_('Only the sender and recipient ' . - 'may read this message.'), 403); - return; - } + $this->showPage(); } function title() @@ -121,42 +115,18 @@ class ShowmessageAction extends MailboxAction } } - function getMessages() - { - $message = new Message(); - $message->id = $this->message->id; - $message->find(); - return $message; - } - function getMessageProfile() + function showContent() { - if ($this->user->id == $this->message->from_profile) { - return $this->message->getTo(); - } else if ($this->user->id == $this->message->to_profile) { - return $this->message->getFrom(); - } else { - // This shouldn't happen - return null; - } + $this->elementStart('ul', 'notices messages'); + $ml = new ShowMessageListItem($this, $this->message, $this->user); + $ml->show(); + $this->elementEnd('ul'); } - /** - * Don't show local navigation - * - * @return void - */ - function showLocalNavBlock() - { - } - - /** - * Don't show page notice - * - * @return void - */ - function showPageNoticeBlock() + function isReadOnly($args) { + return true; } /** @@ -164,22 +134,30 @@ class ShowmessageAction extends MailboxAction * * @return void */ - function showAside() - { + + function showAside() { } +} - /** - * Don't show any instructions - * - * @return string - */ - function getInstructions() +class ShowMessageListItem extends MessageListItem +{ + var $user; + + function __construct($out, $message, $user) { - return ''; + parent::__construct($out, $message); + $this->user = $user; } - function isReadOnly($args) + function getMessageProfile() { - return true; + if ($this->user->id == $this->message->from_profile) { + return $this->message->getTo(); + } else if ($this->user->id == $this->message->to_profile) { + return $this->message->getFrom(); + } else { + // This shouldn't happen + return null; + } } }