| 
									
										
										
										
											2011-03-01 19:35:20 -08:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * StatusNet - the distributed open-source microblogging tool | 
					
						
							|  |  |  |  * Copyright (C) 2011, StatusNet, Inc. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Adds a user directory | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * PHP version 5 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * 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/>. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @category  Plugin | 
					
						
							|  |  |  |  * @package   StatusNet | 
					
						
							|  |  |  |  * @author    Zach Copely <zach@status.net> | 
					
						
							|  |  |  |  * @copyright 2011 StatusNet, Inc. | 
					
						
							|  |  |  |  * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0 | 
					
						
							|  |  |  |  * @link      http://status.net/ | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if (!defined('STATUSNET')) { | 
					
						
							|  |  |  |     exit(1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Directory plugin main class | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @category  Plugin | 
					
						
							|  |  |  |  * @package   StatusNet | 
					
						
							|  |  |  |  * @author    Zach Copley <zach@status.net> | 
					
						
							|  |  |  |  * @copyright 2011 StatusNet, Inc. | 
					
						
							|  |  |  |  * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0 | 
					
						
							|  |  |  |  * @link      http://status.net/ | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class DirectoryPlugin extends Plugin | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-06-03 01:56:52 +01:00
										 |  |  |     const PLUGIN_VERSION = '2.0.0'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-02 20:21:15 -08:00
										 |  |  |     private $dir = null; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-01 19:35:20 -08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Initializer for this plugin | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return boolean hook value; true means continue processing, | 
					
						
							|  |  |  |      *         false means stop. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     function initialize() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Cleanup for this plugin. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return boolean hook value; true means continue processing, | 
					
						
							|  |  |  |      *         false means stop. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     function cleanup() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Map URLs to actions | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2014-11-07 15:24:05 +01:00
										 |  |  |      * @param URLMapper $m path-to-action mapper | 
					
						
							| 
									
										
										
										
											2011-03-01 19:35:20 -08:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return boolean hook value; true means continue processing, | 
					
						
							|  |  |  |      *         false means stop. | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2014-11-07 15:24:05 +01:00
										 |  |  |     public function onRouterInitialized(URLMapper $m) | 
					
						
							| 
									
										
										
										
											2011-03-01 19:35:20 -08:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2011-04-12 21:08:02 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-11 19:14:03 +01:00
										 |  |  |         $m->connect('directory/users/:filter/sort_by/:sort/reverse/:reverse', | 
					
						
							|  |  |  |                     ['action' => 'userdirectory'], | 
					
						
							|  |  |  |                     ['filter'  => '[0-9a-zA-Z]|(0-9)', | 
					
						
							|  |  |  |                      'sort'    => '[a-z]+', | 
					
						
							|  |  |  |                      'reverse' => '[0-9]']); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $m->connect('directory/users/:filter/sort_by/:sort', | 
					
						
							|  |  |  |                     ['action' => 'userdirectory'], | 
					
						
							|  |  |  |                     ['filter' => '[0-9a-zA-Z]|(0-9)', | 
					
						
							|  |  |  |                      'sort' => '[a-z]+']); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $m->connect('directory/users/:filter', | 
					
						
							|  |  |  |                     ['action' => 'userdirectory'], | 
					
						
							|  |  |  |                     ['filter' => '[0-9a-zA-Z]|(0-9)']); | 
					
						
							| 
									
										
										
										
											2014-10-20 16:24:53 +02:00
										 |  |  |          | 
					
						
							| 
									
										
										
										
											2019-07-11 19:14:03 +01:00
										 |  |  |         $m->connect('directory/users/sort_by/:sort/reverse/:reverse', | 
					
						
							|  |  |  |                     ['action' => 'userdirectory'], | 
					
						
							|  |  |  |                     ['sort'    => '[a-z]+', | 
					
						
							|  |  |  |                      'reverse' => '[0-9]']); | 
					
						
							| 
									
										
										
										
											2014-10-20 16:24:53 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-11 19:14:03 +01:00
										 |  |  |         $m->connect('directory/users/sort_by/:sort', | 
					
						
							|  |  |  |                     ['action' => 'userdirectory'], | 
					
						
							|  |  |  |                     ['sort' => '[a-z]+']); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $m->connect('directory/users', | 
					
						
							|  |  |  |                     ['action' => 'userdirectory']); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $m->connect('groups/:filter', | 
					
						
							|  |  |  |                     ['action' => 'groupdirectory'], | 
					
						
							|  |  |  |                     ['filter' => '[0-9a-zA-Z]|(0-9)']); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $m->connect('groups', | 
					
						
							|  |  |  |                     ['action' => 'groupdirectory']); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $m->connect('groups/all', | 
					
						
							|  |  |  |                     ['action' => 'groupdirectory']); | 
					
						
							| 
									
										
										
										
											2014-10-20 16:24:53 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-12 21:08:02 -07:00
										 |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Hijack the routing (URL -> Action) for the normal directory page | 
					
						
							|  |  |  |      * and substitute our group directory action | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param string $path     path to connect | 
					
						
							|  |  |  |      * @param array  $defaults path defaults | 
					
						
							|  |  |  |      * @param array  $rules    path rules | 
					
						
							|  |  |  |      * @param array  $result   unused | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return boolean hook return | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     function onStartConnectPath(&$path, &$defaults, &$rules, &$result) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (in_array($path, array('group', 'group/', 'groups', 'groups/'))) { | 
					
						
							|  |  |  |             $defaults['action'] = 'groupdirectory'; | 
					
						
							|  |  |  |             return true; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-13 16:11:34 -07:00
										 |  |  |     // The following three function are to replace the existing groups
 | 
					
						
							|  |  |  |     // list page with the directory plugin's group directory page
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-12 21:08:02 -07:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Hijack the mapping (Action -> URL) and return the URL to our | 
					
						
							|  |  |  |      * group directory page instead of the normal groups page | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Action    $action     action to find a path for | 
					
						
							|  |  |  |      * @param array     $params     parameters to pass to the action | 
					
						
							|  |  |  |      * @param string    $fragment   any url fragement | 
					
						
							|  |  |  |      * @param boolean   $addSession whether to add session variable | 
					
						
							|  |  |  |      * @param string    $url        resulting URL to local resource | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return string the local URL | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     function onEndLocalURL(&$action, &$params, &$fragment, &$addSession, &$url) { | 
					
						
							|  |  |  |         if (in_array($action, array('group', 'group/', 'groups', 'groups/'))) { | 
					
						
							|  |  |  |                 $url = common_local_url('groupdirectory'); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2011-03-01 19:35:20 -08:00
										 |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-02 20:21:15 -08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Link in a styelsheet for the onboarding actions | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Action $action Action being shown | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return boolean hook flag | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2013-09-17 20:41:54 +02:00
										 |  |  |     public function onEndShowStylesheets(Action $action) | 
					
						
							| 
									
										
										
										
											2011-03-02 20:21:15 -08:00
										 |  |  |     { | 
					
						
							|  |  |  |         if (in_array( | 
					
						
							|  |  |  |             $action->trimmed('action'), | 
					
						
							| 
									
										
										
										
											2011-04-13 15:08:12 -07:00
										 |  |  |             array('userdirectory', 'groupdirectory')) | 
					
						
							| 
									
										
										
										
											2011-03-02 20:21:15 -08:00
										 |  |  |         ) { | 
					
						
							|  |  |  |             $action->cssLink($this->path('css/directory.css')); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-13 16:11:34 -07:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Fool the public nav into thinking it's on the regular | 
					
						
							|  |  |  |      * group page when it's actually on our injected group | 
					
						
							|  |  |  |      * directory page. This way "Groups" gets hilighted when | 
					
						
							|  |  |  |      * when we're on the groups directory page. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param type $action the current action | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return boolean hook flag | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     function onStartPublicGroupNav($action) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if ($action->trimmed('action') == 'groupdirectory') { | 
					
						
							|  |  |  |             $action->actionName = 'groups'; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-01 19:35:20 -08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Modify the public local nav to add a link to the user directory | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Action $action The current action handler. Use this to | 
					
						
							|  |  |  |      *                       do any output. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return boolean hook value; true means continue processing, | 
					
						
							|  |  |  |      *         false means stop. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @see Action | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     function onEndPublicGroupNav($nav) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         // XXX: Maybe this should go under search instead?
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $actionName = $nav->action->trimmed('action'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $nav->out->menuItem( | 
					
						
							|  |  |  |             common_local_url('userdirectory'), | 
					
						
							| 
									
										
										
										
											2011-04-06 23:43:30 +02:00
										 |  |  |             // TRANS: Menu item text for user directory.
 | 
					
						
							| 
									
										
										
										
											2015-06-07 22:27:31 +02:00
										 |  |  |             _m('MENU','People'), | 
					
						
							| 
									
										
										
										
											2011-04-06 23:43:30 +02:00
										 |  |  |             // TRANS: Menu item title for user directory.
 | 
					
						
							| 
									
										
										
										
											2015-06-07 22:27:31 +02:00
										 |  |  |             _m('People.'), | 
					
						
							| 
									
										
										
										
											2011-03-01 19:35:20 -08:00
										 |  |  |             $actionName == 'userdirectory', | 
					
						
							|  |  |  |             'nav_directory' | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* | 
					
						
							|  |  |  |      * Version info | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-06-06 22:04:01 +02:00
										 |  |  |     function onPluginVersion(array &$versions) | 
					
						
							| 
									
										
										
										
											2011-03-01 19:35:20 -08:00
										 |  |  |     { | 
					
						
							|  |  |  |         $versions[] = array( | 
					
						
							|  |  |  |             'name' => 'Directory', | 
					
						
							| 
									
										
										
										
											2019-06-03 01:56:52 +01:00
										 |  |  |             'version' => self::PLUGIN_VERSION, | 
					
						
							| 
									
										
										
										
											2011-03-01 19:35:20 -08:00
										 |  |  |             'author' => 'Zach Copley', | 
					
						
							| 
									
										
										
										
											2016-01-22 16:38:42 +00:00
										 |  |  |             'homepage' => 'https://git.gnu.io/gnu/gnu-social/tree/master/plugins/Directory', | 
					
						
							| 
									
										
										
										
											2011-04-06 23:43:30 +02:00
										 |  |  |             // TRANS: Plugin description.
 | 
					
						
							| 
									
										
										
										
											2011-03-01 19:35:20 -08:00
										 |  |  |             'rawdescription' => _m('Add a user directory.') | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |