3 * StatusNet, the distributed open-source microblogging tool
5 * Show notice attachments
9 * LICENCE: This program is free software: you can redistribute it and/or modify
10 * it under the terms of the GNU Affero General Public License as published by
11 * the Free Software Foundation, either version 3 of the License, or
12 * (at your option) any later version.
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU Affero General Public License for more details.
19 * You should have received a copy of the GNU Affero General Public License
20 * along with this program. If not, see <http://www.gnu.org/licenses/>.
24 * @author Evan Prodromou <evan@status.net>
25 * @copyright 2008-2009 StatusNet, Inc.
26 * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
27 * @link http://status.net/
30 if (!defined('GNUSOCIAL')) { exit(1); }
33 * Show notice attachments
37 * @author Evan Prodromou <evan@status.net>
38 * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
39 * @link http://status.net/
41 class AttachmentAction extends ManagedAction
44 * Attachment File object to show
46 var $attachment = null;
49 * Load attributes based on database arguments
51 * Loads all the DB stuff
53 * @param array $args $_REQUEST array
55 * @return success flag
58 protected function prepare(array $args=array())
60 parent::prepare($args);
62 if ($id = $this->trimmed('attachment')) {
63 $this->attachment = File::getKV($id);
66 if (!$this->attachment instanceof File) {
67 // TRANS: Client error displayed trying to get a non-existing attachment.
68 $this->clientError(_('No such attachment.'), 404);
74 * Is this action read-only?
76 * @return boolean true
78 function isReadOnly($args)
86 * @return string title of the page
90 $a = new Attachment($this->attachment);
94 public function showPage()
96 if (empty($this->attachment->filename)) {
97 // if it's not a local file, gtfo
98 common_redirect($this->attachment->getUrl(), 303);
105 * Fill the content area of the page
107 * Shows a single notice list item.
111 function showContent()
113 $ali = new Attachment($this->attachment, $this);
118 * Don't show page notice
122 function showPageNoticeBlock()
127 * Show aside: this attachments appears in what notices
131 function showSections() {
132 $ns = new AttachmentNoticeSection($this);