| 
									
										
										
										
											2008-05-28 14:27:07 -04:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2009-01-20 20:29:31 +00:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Documentation action. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * PHP version 5 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @category Action | 
					
						
							| 
									
										
										
										
											2009-08-25 18:12:20 -04:00
										 |  |  |  * @package  StatusNet | 
					
						
							| 
									
										
										
										
											2009-08-25 18:19:04 -04:00
										 |  |  |  * @author   Evan Prodromou <evan@status.net> | 
					
						
							|  |  |  |  * @author   Robin Millette <millette@status.net> | 
					
						
							| 
									
										
										
										
											2009-01-20 20:29:31 +00:00
										 |  |  |  * @license  http://www.fsf.org/licensing/licenses/agpl.html AGPLv3 | 
					
						
							| 
									
										
										
										
											2009-08-25 18:16:46 -04:00
										 |  |  |  * @link     http://status.net/ | 
					
						
							| 
									
										
										
										
											2009-01-20 20:29:31 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2009-08-25 18:14:12 -04:00
										 |  |  |  * StatusNet - the distributed open-source microblogging tool | 
					
						
							| 
									
										
										
										
											2010-03-10 22:05:28 +00:00
										 |  |  |  * Copyright (C) 2008-2010, StatusNet, Inc. | 
					
						
							| 
									
										
										
										
											2008-05-28 14:27:07 -04:00
										 |  |  |  * | 
					
						
							|  |  |  |  * 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 <http://www.gnu.org/licenses/>. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-15 12:07:35 +02:00
										 |  |  | if (!defined('GNUSOCIAL')) { exit(1); } | 
					
						
							| 
									
										
										
										
											2009-01-20 20:29:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Documentation class. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @category Action | 
					
						
							| 
									
										
										
										
											2009-08-25 18:12:20 -04:00
										 |  |  |  * @package  StatusNet | 
					
						
							| 
									
										
										
										
											2009-08-25 18:19:04 -04:00
										 |  |  |  * @author   Evan Prodromou <evan@status.net> | 
					
						
							|  |  |  |  * @author   Robin Millette <millette@status.net> | 
					
						
							| 
									
										
										
										
											2009-01-20 20:29:31 +00:00
										 |  |  |  * @license  http://www.fsf.org/licensing/licenses/agpl.html AGPLv3 | 
					
						
							| 
									
										
										
										
											2009-08-25 18:16:46 -04:00
										 |  |  |  * @link     http://status.net/ | 
					
						
							| 
									
										
										
										
											2009-01-20 20:44:03 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2015-09-15 12:07:35 +02:00
										 |  |  | class DocAction extends ManagedAction | 
					
						
							| 
									
										
										
										
											2008-12-23 14:49:23 -05:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-10-07 05:14:25 -04:00
										 |  |  |     var $output   = null; | 
					
						
							|  |  |  |     var $filename = null; | 
					
						
							|  |  |  |     var $title    = null; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-15 12:07:35 +02:00
										 |  |  |     protected function doPreparation() | 
					
						
							| 
									
										
										
										
											2009-10-07 05:14:25 -04:00
										 |  |  |     { | 
					
						
							|  |  |  |         $this->title  = $this->trimmed('title'); | 
					
						
							| 
									
										
										
										
											2010-02-01 11:10:36 -05:00
										 |  |  |         if (!preg_match('/^[a-zA-Z0-9_-]*$/', $this->title)) { | 
					
						
							|  |  |  |             $this->title = 'help'; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-10-07 05:14:25 -04:00
										 |  |  |         $this->output = null; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->loadDoc(); | 
					
						
							| 
									
										
										
										
											2009-10-06 15:29:22 -04:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-01-22 04:26:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-15 14:26:33 +02:00
										 |  |  |     public function title() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return ucfirst($this->title); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-20 20:29:31 +00:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Display content. | 
					
						
							| 
									
										
										
										
											2009-02-10 22:33:57 -05:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2009-10-06 15:29:22 -04:00
										 |  |  |      * Shows the content of the document. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return void | 
					
						
							| 
									
										
										
										
											2009-01-20 20:44:03 +00:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2009-01-20 20:29:31 +00:00
										 |  |  |     function showContent() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2009-08-21 16:54:35 -04:00
										 |  |  |         $this->raw($this->output); | 
					
						
							| 
									
										
										
										
											2009-01-20 20:29:31 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-15 12:07:35 +02:00
										 |  |  |     function showNoticeForm() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-09-15 14:26:33 +02:00
										 |  |  |         // no notice form
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-01-23 09:15:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-06 15:29:22 -04:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * These pages are read-only. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param array $args unused. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return boolean read-only flag (false) | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2009-04-13 15:49:26 -04:00
										 |  |  |     function isReadOnly($args) | 
					
						
							| 
									
										
										
										
											2009-01-23 09:15:15 +00:00
										 |  |  |     { | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-10-07 05:14:25 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     function loadDoc() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (Event::handle('StartLoadDoc', array(&$this->title, &$this->output))) { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-18 06:16:32 -04:00
										 |  |  |             $paths = DocFile::defaultPaths(); | 
					
						
							| 
									
										
										
										
											2009-10-07 05:14:25 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-18 06:16:32 -04:00
										 |  |  |             $docfile = DocFile::forTitle($this->title, $paths); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if (empty($docfile)) { | 
					
						
							| 
									
										
										
										
											2011-01-21 16:35:00 +01:00
										 |  |  |                 // 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); | 
					
						
							| 
									
										
										
										
											2009-10-07 05:14:25 -04:00
										 |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-18 06:16:32 -04:00
										 |  |  |             $this->output = $docfile->toHTML(); | 
					
						
							| 
									
										
										
										
											2009-10-07 05:14:25 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |             Event::handle('EndLoadDoc', array($this->title, &$this->output)); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-09-30 14:24:27 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     function showLocalNav() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $menu = new DocNav($this); | 
					
						
							|  |  |  |         $menu->show(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class DocNav extends Menu | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     function show() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-02-24 21:51:31 +01:00
										 |  |  |         if (Event::handle('StartDocNav', array($this))) { | 
					
						
							|  |  |  |             $stub = new HomeStubNav($this->action); | 
					
						
							|  |  |  |             $this->submenu(_m('MENU','Home'), $stub); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $docs = new DocListNav($this->action); | 
					
						
							|  |  |  |             $this->submenu(_m('MENU','Docs'), $docs); | 
					
						
							|  |  |  |              | 
					
						
							|  |  |  |             Event::handle('EndDocNav', array($this)); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2011-09-30 14:24:27 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class DocListNav extends Menu | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     function getItems() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $items = array(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (Event::handle('StartDocsMenu', array(&$items))) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $items = array(array('doc', | 
					
						
							|  |  |  |                                  array('title' => 'help'), | 
					
						
							|  |  |  |                                  _m('MENU', 'Help'), | 
					
						
							|  |  |  |                                  _('Getting started'), | 
					
						
							|  |  |  |                                  'nav_doc_help'), | 
					
						
							|  |  |  |                            array('doc', | 
					
						
							|  |  |  |                                  array('title' => 'about'), | 
					
						
							|  |  |  |                                  _m('MENU', 'About'), | 
					
						
							|  |  |  |                                  _('About this site'), | 
					
						
							|  |  |  |                                  'nav_doc_about'), | 
					
						
							|  |  |  |                            array('doc', | 
					
						
							|  |  |  |                                  array('title' => 'faq'), | 
					
						
							|  |  |  |                                  _m('MENU', 'FAQ'), | 
					
						
							|  |  |  |                                  _('Frequently asked questions'), | 
					
						
							|  |  |  |                                  'nav_doc_faq'), | 
					
						
							|  |  |  |                            array('doc', | 
					
						
							|  |  |  |                                  array('title' => 'contact'), | 
					
						
							|  |  |  |                                  _m('MENU', 'Contact'), | 
					
						
							|  |  |  |                                  _('Contact info'), | 
					
						
							|  |  |  |                                  'nav_doc_contact'), | 
					
						
							|  |  |  |                            array('doc', | 
					
						
							|  |  |  |                                  array('title' => 'tags'), | 
					
						
							|  |  |  |                                  _m('MENU', 'Tags'), | 
					
						
							|  |  |  |                                  _('Using tags'), | 
					
						
							|  |  |  |                                  'nav_doc_tags'), | 
					
						
							|  |  |  |                            array('doc', | 
					
						
							|  |  |  |                                  array('title' => 'groups'), | 
					
						
							|  |  |  |                                  _m('MENU', 'Groups'), | 
					
						
							|  |  |  |                                  _('Using groups'), | 
					
						
							|  |  |  |                                  'nav_doc_groups'), | 
					
						
							|  |  |  |                            array('doc', | 
					
						
							|  |  |  |                                  array('title' => 'api'), | 
					
						
							|  |  |  |                                  _m('MENU', 'API'), | 
					
						
							|  |  |  |                                  _('RESTful API'), | 
					
						
							|  |  |  |                                  'nav_doc_api')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             Event::handle('EndDocsMenu', array(&$items)); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return $items; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2008-06-30 13:03:42 -04:00
										 |  |  | } |