4 * This special page lists all defined user groups and the associated rights.
5 * See also @ref $wgGroupPermissions.
7 * @addtogroup SpecialPage
8 * @author Petr Kadlec <mormegil@centrum.cz>
10 class SpecialListGroupRights
extends SpecialPage
{
17 function __construct() {
19 parent
::__construct( 'Listgrouprights' );
20 $this->skin
= $wgUser->getSkin();
24 * Show the special page
26 public function execute( $par ) {
27 global $wgOut, $wgGroupPermissions, $wgImplicitGroups;
30 $this->outputHeader();
33 Xml
::openElement( 'table', array( 'class' => 'mw-listgrouprights-table' ) ) .
35 Xml
::element( 'th', null, wfMsg( 'listgrouprights-group' ) ) .
36 Xml
::element( 'th', null, wfMsg( 'listgrouprights-rights' ) ) .
40 foreach( $wgGroupPermissions as $group => $permissions ) {
41 $groupname = htmlspecialchars( $group );
42 if ( in_array( $group, $wgImplicitGroups ) )
43 $grouplink = $groupname;
45 $grouplink = $this->skin
->makeKnownLinkObj( SpecialPage
::getTitleFor( 'Listusers' ), $groupname, 'group=' . $group );
53 self
::formatPermissions( $permissions ) .
59 Xml
::closeElement( 'table' ) . "\n"
64 * Create a user-readable list of permissions from the given array.
66 * @param $permissions Array of permission => bool (from $wgGroupPermissions items)
67 * @return string List of all granted permissions, separated by comma separator
69 private static function formatPermissions( $permissions ) {
71 foreach( $permissions as $permission => $granted ) {
73 $permission = htmlspecialchars( $permission );
74 $r[] = wfMsgExt( 'listgrouprights-link', array( 'parseinline', 'content' ), $permission );
78 $r = implode( wfMsg( 'comma-separator' ), $r );