| 
									
										
										
										
											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/>. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-26 10:41:36 -04:00
										 |  |  | if (!defined('STATUSNET') && !defined('LACONICA')) { | 
					
						
							| 
									
										
										
										
											2009-01-20 20:29:31 +00:00
										 |  |  |     exit(1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * 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
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2008-12-23 14:49:23 -05:00
										 |  |  | class DocAction extends Action | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-10-07 05:14:25 -04:00
										 |  |  |     var $output   = null; | 
					
						
							|  |  |  |     var $filename = null; | 
					
						
							|  |  |  |     var $title    = null; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function prepare($args) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2010-01-22 14:13:28 -05:00
										 |  |  |         parent::prepare($args); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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(); | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2008-05-28 14:27:07 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-20 20:29:31 +00:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2009-10-06 15:29:22 -04:00
										 |  |  |      * Handle a request | 
					
						
							| 
									
										
										
										
											2009-02-10 22:33:57 -05:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2009-01-20 20:29:31 +00:00
										 |  |  |      * @param array $args array of arguments | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return nothing | 
					
						
							| 
									
										
										
										
											2009-01-20 20:44:03 +00:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2008-12-23 14:33:23 -05:00
										 |  |  |     function handle($args) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         parent::handle($args); | 
					
						
							| 
									
										
										
										
											2009-01-20 20:29:31 +00:00
										 |  |  |         $this->showPage(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-06 15:29:22 -04:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Page title | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * Gives the page title of the document. Override default for hAtom entry. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return void | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     function showPageTitle() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2009-01-22 04:26:15 +00:00
										 |  |  |         $this->element('h1', array('class' => 'entry-title'), $this->title()); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-02-10 22:33:57 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-06 15:29:22 -04:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Block for content. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * Overrides default from Action to wrap everything in an hAtom entry. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return void. | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2009-01-22 04:26:15 +00:00
										 |  |  |     function showContentBlock() | 
					
						
							| 
									
										
										
										
											2009-10-06 15:29:22 -04:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2014-06-21 21:01:17 +02:00
										 |  |  |         $this->elementStart('div', array('id' => 'content', 'class' => 'h-entry')); | 
					
						
							| 
									
										
										
										
											2009-10-06 15:29:22 -04:00
										 |  |  |         $this->showPageTitle(); | 
					
						
							|  |  |  |         $this->showPageNoticeBlock(); | 
					
						
							|  |  |  |         $this->elementStart('div', array('id' => 'content_inner', | 
					
						
							| 
									
										
										
										
											2014-06-21 21:01:17 +02:00
										 |  |  |                                          'class' => 'e-content')); | 
					
						
							| 
									
										
										
										
											2009-10-06 15:29:22 -04:00
										 |  |  |         // show the actual content (forms, lists, whatever)
 | 
					
						
							|  |  |  |         $this->showContent(); | 
					
						
							|  |  |  |         $this->elementEnd('div'); | 
					
						
							|  |  |  |         $this->elementEnd('div'); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-01-22 04:26:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											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
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Page title. | 
					
						
							| 
									
										
										
										
											2009-02-10 22:33:57 -05:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2009-10-06 15:29:22 -04:00
										 |  |  |      * Uses the title of the document. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2009-01-20 20:29:31 +00:00
										 |  |  |      * @return page title | 
					
						
							| 
									
										
										
										
											2009-01-20 20:44:03 +00:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2009-01-20 20:29:31 +00:00
										 |  |  |     function title() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return ucfirst($this->title); | 
					
						
							| 
									
										
										
										
											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
										 |  |  | } |