. */ /** * @package SlicedFavoritesPlugin * @maintainer Brion Vibber */ if (!defined('STATUSNET')) { exit(1); } class SlicedFavoritesPlugin extends Plugin { /** * Example: * * addPlugin('SlicedFavorites', array( * 'slices' => array( * // show only pop's notices on /favorited * 'default' => array('include' => array('pop')), * * // show only son's notices on /favorited/blog * 'blog' => array('include' => array('son')), * * // show all favorited notices except pop's and son's on /favorited/submitted * 'submitted' => array('exclude' => array('pop', 'son')), * * // show all favorited notices on /favorited/everybody * 'everybody' => array(), * ) * )); * * @var array */ public $slices = array(); /** * Hook for RouterInitialized event. * * @param URLMapper $m path-to-action mapper * @return boolean hook return */ public function onRouterInitialized(URLMapper $m) { $m->connect('favorited/:slice', array('action' => 'favoritedslice'), array('slice' => '[a-zA-Z0-9]+')); return true; } // Take over the default... :D function onArgsInitialize(array &$args) { if (array_key_exists('action', $args)) { $action = trim($args['action']); if ($action == 'favorited') { common_redirect(common_local_url('favoritedslice', array('slice' => 'default'))); exit(0); } } return true; } function onSlicedFavoritesGetSettings($slice, &$data) { if (isset($this->slices[$slice])) { $data = $this->slices[$slice]; return false; } return true; } /** * Provide plugin version information. * * This data is used when showing the version page. * * @param array &$versions array of version data arrays; see EVENTS.txt * * @return boolean hook value */ function onPluginVersion(array &$versions) { $url = 'http://status.net/wiki/Plugin:SlicedFavorites'; $versions[] = array('name' => 'SlicedFavorites', 'version' => GNUSOCIAL_VERSION, 'author' => 'Brion Vibber', 'homepage' => $url, 'rawdescription' => // TRANS: Plugin description. _m('Shows timelines of popular notices for defined subsets of users.')); return true; } }