summaryrefslogtreecommitdiff
path: root/actions/showmessage.php
diff options
context:
space:
mode:
authorEvan Prodromou <evan@controlyourself.ca>2009-01-20 23:13:02 -0500
committerEvan Prodromou <evan@controlyourself.ca>2009-01-20 23:13:02 -0500
commit4b9df58c90e25ea79aeec64c6e96f828fe06d7df (patch)
treeac237014d015535d07babba42d40d86608de0ec5 /actions/showmessage.php
parentbd056218f9a595184ac7bcac0c1dc6a8981d7af2 (diff)
parent65bfda33b8464caf14ce268c9bea2e7eceb27fe5 (diff)
Merge branch 'master' into groups
Conflicts: .gitignore
Diffstat (limited to 'actions/showmessage.php')
-rw-r--r--actions/showmessage.php191
1 files changed, 131 insertions, 60 deletions
diff --git a/actions/showmessage.php b/actions/showmessage.php
index 25330a568..289414153 100644
--- a/actions/showmessage.php
+++ b/actions/showmessage.php
@@ -1,9 +1,12 @@
<?php
-/*
- * Laconica - a distributed open-source microblogging tool
- * Copyright (C) 2008, Controlez-Vous, Inc.
+/**
+ * Laconica, the distributed open-source microblogging tool
*
- * This program is free software: you can redistribute it and/or modify
+ * Show a single message
+ *
+ * PHP version 5
+ *
+ * LICENCE: This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
@@ -15,94 +18,162 @@
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
+ *
+ * @category Personal
+ * @package Laconica
+ * @author Evan Prodromou <evan@controlyourself.ca>
+ * @copyright 2008-2009 Control Yourself, Inc.
+ * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
+ * @link http://laconi.ca/
*/
+if (!defined('LACONICA')) {
+ exit(1);
+}
-if (!defined('LACONICA')) { exit(1); }
+require_once INSTALLDIR.'/lib/mailbox.php';
-require_once(INSTALLDIR.'/lib/mailbox.php');
+/**
+ * Show a single message
+ *
+ * // XXX: It is totally weird how this works!
+ *
+ * @category Personal
+ * @package Laconica
+ * @author Evan Prodromou <evan@controlyourself.ca>
+ * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
+ * @link http://laconi.ca/
+ */
class ShowmessageAction extends MailboxAction
{
+ /**
+ * Message object to show
+ */
- function handle($args)
- {
-
- Action::handle($args);
+ var $message = null;
+
+ /**
+ * The current user
+ */
+
+ var $user = null;
- $message = $this->get_message();
+ /**
+ * Load attributes based on database arguments
+ *
+ * Loads all the DB stuff
+ *
+ * @param array $args $_REQUEST array
+ *
+ * @return success flag
+ */
- if (!$message) {
- $this->client_error(_('No such message.'), 404);
- return;
- }
+ function prepare($args)
+ {
+ parent::prepare($args);
- $cur = common_current_user();
+ $this->page = 1;
- if ($cur && ($cur->id == $message->from_profile || $cur->id == $message->to_profile)) {
- $this->show_page($cur, 1);
- } else {
- $this->client_error(_('Only the sender and recipient may read this message.'), 403);
- return;
+ $id = $this->trimmed('message');
+ $this->message = Message::staticGet('id', $id);
+
+ if (!$this->message) {
+ $this->clientError(_('No such message.'), 404);
+ return false;
}
+
+ $this->user = common_current_user();
+
+ return true;
}
-
- function get_message()
+
+ function handle($args)
{
- $id = $this->trimmed('message');
- $message = Message::staticGet('id', $id);
- return $message;
+ Action::handle($args);
+
+ if ($this->user && ($this->user->id == $this->message->from_profile ||
+ $this->user->id == $this->message->to_profile)) {
+ $this->showPage();
+ } else {
+ $this->clientError(_('Only the sender and recipient ' .
+ 'may read this message.'), 403);
+ return;
+ }
}
- function get_title($user, $page)
- {
- $message = $this->get_message();
- if (!$message) {
- return null;
- }
-
- if ($user->id == $message->from_profile) {
- $to = $message->getTo();
- $title = sprintf(_("Message to %1\$s on %2\$s"),
+ function title()
+ {
+ if ($this->user->id == $this->message->from_profile) {
+ $to = $this->message->getTo();
+ return sprintf(_("Message to %1\$s on %2\$s"),
$to->nickname,
- common_exact_date($message->created));
- } else if ($user->id == $message->to_profile) {
- $from = $message->getFrom();
- $title = sprintf(_("Message from %1\$s on %2\$s"),
+ common_exact_date($this->message->created));
+ } else if ($this->user->id == $this->message->to_profile) {
+ $from = $this->message->getFrom();
+ return sprintf(_("Message from %1\$s on %2\$s"),
$from->nickname,
- common_exact_date($message->created));
+ common_exact_date($this->message->created));
}
- return $title;
}
-
- function get_messages($user, $page)
- {
- $message = new Message();
- $message->id = $this->trimmed('message');
+
+ function getMessages()
+ {
+ $message = new Message();
+ $message->id = $this->message->id;
$message->find();
return $message;
}
- function get_message_profile($message)
+ function getMessageProfile()
{
- $user = common_current_user();
- if ($user->id == $message->from_profile) {
- return $message->getTo();
- } else if ($user->id == $message->to_profile) {
- return $message->getFrom();
+ 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
+ // This shouldn't happen
return null;
}
}
- function get_instructions()
+ /**
+ * Don't show local navigation
+ *
+ * @return void
+ */
+
+ function showLocalNavBlock()
{
- return '';
}
- function views_menu()
+ /**
+ * Don't show page notice
+ *
+ * @return void
+ */
+
+ function showPageNoticeBlock()
{
- return;
}
-}
- \ No newline at end of file
+
+ /**
+ * Don't show aside
+ *
+ * @return void
+ */
+
+ function showAside()
+ {
+ }
+
+ /**
+ * Don't show any instructions
+ *
+ * @return string
+ */
+
+ function getInstructions()
+ {
+ return '';
+ }
+} \ No newline at end of file