* @author Robin Millette * @license http://www.fsf.org/licensing/licenses/agpl.html AGPLv3 * @link http://status.net/ * * StatusNet - the distributed open-source microblogging tool * Copyright (C) 2008-2010, StatusNet, Inc. * * 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. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . */ if (!defined('STATUSNET') && !defined('LACONICA')) { exit(1); } /** * Documentation class. * * @category Action * @package StatusNet * @author Evan Prodromou * @author Robin Millette * @license http://www.fsf.org/licensing/licenses/agpl.html AGPLv3 * @link http://status.net/ */ class DocAction extends Action { var $output = null; var $filename = null; var $title = null; function prepare($args) { parent::prepare($args); $this->title = $this->trimmed('title'); if (!preg_match('/^[a-zA-Z0-9_-]*$/', $this->title)) { $this->title = 'help'; } $this->output = null; $this->loadDoc(); return true; } /** * Handle a request * * @param array $args array of arguments * * @return nothing */ function handle($args) { parent::handle($args); $this->showPage(); } /** * Page title * * Gives the page title of the document. Override default for hAtom entry. * * @return void */ function showPageTitle() { $this->element('h1', array('class' => 'entry-title'), $this->title()); } /** * Block for content. * * Overrides default from Action to wrap everything in an hAtom entry. * * @return void. */ function showContentBlock() { $this->elementStart('div', array('id' => 'content', 'class' => 'hentry')); $this->showPageTitle(); $this->showPageNoticeBlock(); $this->elementStart('div', array('id' => 'content_inner', 'class' => 'entry-content')); // show the actual content (forms, lists, whatever) $this->showContent(); $this->elementEnd('div'); $this->elementEnd('div'); } /** * Display content. * * Shows the content of the document. * * @return void */ function showContent() { $this->raw($this->output); } /** * Page title. * * Uses the title of the document. * * @return page title */ function title() { return ucfirst($this->title); } /** * These pages are read-only. * * @param array $args unused. * * @return boolean read-only flag (false) */ function isReadOnly($args) { return true; } function loadDoc() { if (Event::handle('StartLoadDoc', array(&$this->title, &$this->output))) { $paths = DocFile::defaultPaths(); $docfile = DocFile::forTitle($this->title, $paths); if (empty($docfile)) { // TRANS: Client exception thrown when requesting a document from the documentation that does not exist. // TRANS: %s is the non-existing document. throw new ClientException(sprintf(_('No such document "%s".'), $this->title), 404); } $this->output = $docfile->toHTML(); Event::handle('EndLoadDoc', array($this->title, &$this->output)); } } }