]> git.mxchange.org Git - quix0rs-gnu-social.git/blob - actions/doc.php
Use array_merge instead of array_replace (same effect, and array_merge works with...
[quix0rs-gnu-social.git] / actions / doc.php
1 <?php
2 /**
3  * Documentation action.
4  *
5  * PHP version 5
6  *
7  * @category Action
8  * @package  StatusNet
9  * @author   Evan Prodromou <evan@status.net>
10  * @author   Robin Millette <millette@status.net>
11  * @license  http://www.fsf.org/licensing/licenses/agpl.html AGPLv3
12  * @link     http://status.net/
13  *
14  * StatusNet - the distributed open-source microblogging tool
15  * Copyright (C) 2008-2010, StatusNet, Inc.
16  *
17  * This program is free software: you can redistribute it and/or modify
18  * it under the terms of the GNU Affero General Public License as published by
19  * the Free Software Foundation, either version 3 of the License, or
20  * (at your option) any later version.
21  *
22  * This program is distributed in the hope that it will be useful,
23  * but WITHOUT ANY WARRANTY; without even the implied warranty of
24  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
25  * GNU Affero General Public License for more details.
26  *
27  * You should have received a copy of the GNU Affero General Public License
28  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
29  */
30
31 if (!defined('STATUSNET') && !defined('LACONICA')) {
32     exit(1);
33 }
34
35 /**
36  * Documentation class.
37  *
38  * @category Action
39  * @package  StatusNet
40  * @author   Evan Prodromou <evan@status.net>
41  * @author   Robin Millette <millette@status.net>
42  * @license  http://www.fsf.org/licensing/licenses/agpl.html AGPLv3
43  * @link     http://status.net/
44  */
45 class DocAction extends Action
46 {
47     var $output   = null;
48     var $filename = null;
49     var $title    = null;
50
51     function prepare($args)
52     {
53         parent::prepare($args);
54
55         $this->title  = $this->trimmed('title');
56         if (!preg_match('/^[a-zA-Z0-9_-]*$/', $this->title)) {
57             $this->title = 'help';
58         }
59         $this->output = null;
60
61         $this->loadDoc();
62         return true;
63     }
64
65     /**
66      * Handle a request
67      *
68      * @param array $args array of arguments
69      *
70      * @return nothing
71      */
72     function handle($args)
73     {
74         parent::handle($args);
75         $this->showPage();
76     }
77
78     /**
79      * Page title
80      *
81      * Gives the page title of the document. Override default for hAtom entry.
82      *
83      * @return void
84      */
85     function showPageTitle()
86     {
87         $this->element('h1', array('class' => 'entry-title'), $this->title());
88     }
89
90     /**
91      * Block for content.
92      *
93      * Overrides default from Action to wrap everything in an hAtom entry.
94      *
95      * @return void.
96      */
97     function showContentBlock()
98     {
99         $this->elementStart('div', array('id' => 'content', 'class' => 'hentry'));
100         $this->showPageTitle();
101         $this->showPageNoticeBlock();
102         $this->elementStart('div', array('id' => 'content_inner',
103                                          'class' => 'entry-content'));
104         // show the actual content (forms, lists, whatever)
105         $this->showContent();
106         $this->elementEnd('div');
107         $this->elementEnd('div');
108     }
109
110     /**
111      * Display content.
112      *
113      * Shows the content of the document.
114      *
115      * @return void
116      */
117     function showContent()
118     {
119         $this->raw($this->output);
120     }
121
122     /**
123      * Page title.
124      *
125      * Uses the title of the document.
126      *
127      * @return page title
128      */
129     function title()
130     {
131         return ucfirst($this->title);
132     }
133
134     /**
135      * These pages are read-only.
136      *
137      * @param array $args unused.
138      *
139      * @return boolean read-only flag (false)
140      */
141     function isReadOnly($args)
142     {
143         return true;
144     }
145
146     function loadDoc()
147     {
148         if (Event::handle('StartLoadDoc', array(&$this->title, &$this->output))) {
149
150             $paths = DocFile::defaultPaths();
151
152             $docfile = DocFile::forTitle($this->title, $paths);
153
154             if (empty($docfile)) {
155                 // TRANS: Client exception thrown when requesting a document from the documentation that does not exist.
156                 // TRANS: %s is the non-existing document.
157                 throw new ClientException(sprintf(_('No such document "%s".'), $this->title), 404);
158             }
159
160             $this->output = $docfile->toHTML();
161
162             Event::handle('EndLoadDoc', array($this->title, &$this->output));
163         }
164     }
165 }