Manual:user_groups table
| ↑ Manual:Contents | MediaWiki database layout | user groups table |
| MediaWiki version: | ≥ 1.5 |
The user groups table maps the users in a particular MediaWiki installation to their corresponding user rights. Each group can be assigned a mixture of permissions through LocalSettings.php or via extensions; all users of a particular group have those permissions granted to them as a result of their membership in the group. As the table is separate from the user table, this allows for the creation of a shared user database with permissions that vary from wiki to wiki within a wiki farm. This table was introduced on r5648, in MediaWiki 1.5. If you are using MediaWiki 1.3 or 1.4, have a look at Manual:User rights management. Before MediaWiki 1.5, user rights were stored in the the user_rights field of the user table.
All unregistered users belong to the '*' only; all registered users are automatically part of the 'user' group. User groups are additive; as a result, all registered users have all the privileges assigned to the '*' group as well. Formerly there was a "sysop bit"; now, making a user a sysop adds a row to user_groups.
User::getEffectiveGroups().Fields [edit]
ug_user [edit]
This field links to a given user's user_id. It is a foreign key used to link accounts with their assigned privileges.
ug_group [edit]
This field stores the user's permissions, which are stored as groups. At runtime, $wgGroupPermissions will associate group keys with particular permissions; a user will have the combined permissions of any group they're explicitly in, plus the implicit '*' and 'user' groups. Example ug_group values: 'bot', 'bureaucrat', 'sysop'.
Schema summary [edit]
| MediaWiki version: | 1.19 |
mysql> describe user_groups; +----------+------------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +----------+------------------+------+-----+---------+-------+ | ug_user | int(10) unsigned | NO | PRI | 0 | | | ug_group | varbinary(32) | NO | PRI | | | +----------+------------------+------+-----+---------+-------+
| MediaWiki version: | 1.18 |
DESCRIBE user_groups in MediaWiki 1.18 gives the following:
+----------+-----------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +----------+-----------------+------+-----+---------+-------+ | ug_user | int(5) unsigned | NO | PRI | 0 | | | ug_group | varbinary(16) | NO | PRI | NULL | | +----------+-----------------+------+-----+---------+-------+
| MediaWiki version: | 1.5 |
DESCRIBE user_groups in MediaWiki 1.5-1.9 gives the following:
+----------+-----------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +----------+-----------------+------+-----+---------+-------+ | ug_user | int(5) unsigned | NO | PRI | 0 | | | ug_group | char(16) | NO | PRI | NULL | | +----------+-----------------+------+-----+---------+-------+
Default MediaWiki groups [edit]
In a default MediaWiki installation, ug_group can be one of the following :
query : SELECT DISTINCT ug_group FROM user_groups; +------------+ | ug_group | +------------+ | bot | | bureaucrat | | sysop | +------------+
| Language: | English • 日本語 |
|---|