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, $wgMessageCache;
28 $wgMessageCache->loadAllMessages();
31 $this->outputHeader();
34 Xml
::openElement( 'table', array( 'class' => 'mw-listgrouprights-table' ) ) .
36 Xml
::element( 'th', null, wfMsg( 'listgrouprights-group' ) ) .
37 Xml
::element( 'th', null, wfMsg( 'listgrouprights-rights' ) ) .
41 foreach( $wgGroupPermissions as $group => $permissions ) {
42 $groupname = ( $group == '*' ) ?
'all' : htmlspecialchars( $group ); // Replace * with a more descriptive groupname
44 $msg = wfMsg( 'group-' . $groupname );
45 if ( wfEmptyMsg( 'group-' . $groupname, $msg ) ||
$msg == '' ) {
46 $groupnameLocalized = $groupname;
48 $groupnameLocalized = $msg;
51 if ( in_array( $group, $wgImplicitGroups ) )
52 $grouplink = $groupnameLocalized;
54 $grouplink = $this->skin
->makeKnownLinkObj( SpecialPage
::getTitleFor( 'Listusers' ), $groupnameLocalized, 'group=' . $group );
62 self
::formatPermissions( $permissions ) .
68 Xml
::closeElement( 'table' ) . "\n"
73 * Create a user-readable list of permissions from the given array.
75 * @param $permissions Array of permission => bool (from $wgGroupPermissions items)
76 * @return string List of all granted permissions, separated by comma separator
78 private static function formatPermissions( $permissions ) {
80 foreach( $permissions as $permission => $granted ) {
82 $permission = htmlspecialchars( $permission );
83 $r[] = wfMsgExt( 'listgrouprights-link', array( 'parseinline', 'content' ), $permission );
87 $r = implode( wfMsg( 'comma-separator' ), $r );