| 
									
										
										
										
											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 | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											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; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Load related modules when needed | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param string $cls Name of the class to be loaded | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return boolean hook value; true means continue processing, | 
					
						
							|  |  |  |      *         false means stop. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     function onAutoload($cls) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         // common_debug("class = $cls");
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-03 21:12:24 -08:00
										 |  |  |         $dir = dirname(__FILE__); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-01 19:35:20 -08:00
										 |  |  |         switch ($cls) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |         case 'UserdirectoryAction': | 
					
						
							| 
									
										
										
										
											2011-04-12 21:08:02 -07:00
										 |  |  |         case 'GroupdirectoryAction': | 
					
						
							| 
									
										
										
										
											2011-03-03 21:12:24 -08:00
										 |  |  |             include_once $dir | 
					
						
							| 
									
										
										
										
											2011-03-01 19:35:20 -08:00
										 |  |  |                 . '/actions/' . strtolower(mb_substr($cls, 0, -6)) . '.php'; | 
					
						
							|  |  |  |             return false; | 
					
						
							|  |  |  |         case 'AlphaNav': | 
					
						
							| 
									
										
										
										
											2011-03-03 21:12:24 -08:00
										 |  |  |             include_once $dir | 
					
						
							|  |  |  |                 . '/lib/' . strtolower($cls) . '.php'; | 
					
						
							|  |  |  |             return false; | 
					
						
							|  |  |  |         case 'SortableSubscriptionList': | 
					
						
							| 
									
										
										
										
											2011-04-13 00:10:10 -07:00
										 |  |  |         case 'SortableGroupList': | 
					
						
							| 
									
										
										
										
											2011-03-03 21:12:24 -08:00
										 |  |  |             include_once $dir | 
					
						
							| 
									
										
										
										
											2011-03-01 19:35:20 -08:00
										 |  |  |                 . '/lib/' . strtolower($cls) . '.php'; | 
					
						
							|  |  |  |             return false; | 
					
						
							|  |  |  |         default: | 
					
						
							|  |  |  |             return true; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Map URLs to actions | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Net_URL_Mapper $m path-to-action mapper | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return boolean hook value; true means continue processing, | 
					
						
							|  |  |  |      *         false means stop. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     function onRouterInitialized($m) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2011-04-12 21:08:02 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-01 19:35:20 -08:00
										 |  |  |         $m->connect( | 
					
						
							| 
									
										
										
										
											2011-09-18 13:35:09 -07:00
										 |  |  |             'directory/users/:filter', | 
					
						
							| 
									
										
										
										
											2011-03-02 20:21:15 -08:00
										 |  |  |             array('action' => 'userdirectory'), | 
					
						
							| 
									
										
										
										
											2011-09-18 13:35:09 -07:00
										 |  |  |             array('filter' => '[0-9a-zA-Z]|(0-9)') | 
					
						
							| 
									
										
										
										
											2011-03-02 20:21:15 -08:00
										 |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $m->connect( | 
					
						
							| 
									
										
										
										
											2011-09-18 13:35:09 -07:00
										 |  |  |             'directory/users', | 
					
						
							|  |  |  |             array('action' => 'userdirectory') | 
					
						
							| 
									
										
										
										
											2011-03-01 19:35:20 -08:00
										 |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-12 21:08:02 -07:00
										 |  |  |         $m->connect( | 
					
						
							|  |  |  |             'groups/:filter', | 
					
						
							|  |  |  |             array('action' => 'groupdirectory'), | 
					
						
							| 
									
										
										
										
											2011-09-18 13:35:09 -07:00
										 |  |  |             array('filter' => '[0-9a-zA-Z]|(0-9)') | 
					
						
							| 
									
										
										
										
											2011-04-12 21:08:02 -07:00
										 |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-14 12:18:22 -04:00
										 |  |  |         $m->connect( | 
					
						
							|  |  |  |             'groups', | 
					
						
							|  |  |  |             array('action' => 'groupdirectory') | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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 | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     function onEndShowStatusNetStyles($action) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         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.
 | 
					
						
							|  |  |  |             _m('MENU','Directory'), | 
					
						
							|  |  |  |             // TRANS: Menu item title for user directory.
 | 
					
						
							|  |  |  |             _m('User Directory.'), | 
					
						
							| 
									
										
										
										
											2011-03-01 19:35:20 -08:00
										 |  |  |             $actionName == 'userdirectory', | 
					
						
							|  |  |  |             'nav_directory' | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* | 
					
						
							|  |  |  |      * Version info | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     function onPluginVersion(&$versions) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $versions[] = array( | 
					
						
							|  |  |  |             'name' => 'Directory', | 
					
						
							|  |  |  |             'version' => STATUSNET_VERSION, | 
					
						
							|  |  |  |             'author' => 'Zach Copley', | 
					
						
							|  |  |  |             'homepage' => 'http://status.net/wiki/Plugin: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; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |