MediaWiki
1.32.0
|
Represents a "user group membership" – a specific instance of a user belonging to a group. More...
Public Member Functions | |
__construct ( $userId=0, $group=null, $expiry=null) | |
delete (IDatabase $dbw=null) | |
Delete the row from the user_groups table. More... | |
getExpiry () | |
getGroup () | |
getUserId () | |
insert ( $allowUpdate=false, IDatabase $dbw=null) | |
Insert a user right membership into the database. More... | |
isExpired () | |
Has the membership expired? More... | |
Static Public Member Functions | |
static | getGroupMemberName ( $group, $username) |
Gets the localized name for a member of a group, if it exists. More... | |
static | getGroupName ( $group) |
Gets the localized friendly name for a group, if it exists. More... | |
static | getGroupPage ( $group) |
Gets the title of a page describing a particular user group. More... | |
static | getLink ( $ugm, IContextSource $context, $format, $userName=null) |
Gets a link for a user group, possibly including the expiry date if relevant. More... | |
static | getMembership ( $userId, $group, IDatabase $db=null) |
Returns a UserGroupMembership object that pertains to the given user and group, or false if the user does not belong to that group (or the assignment has expired). More... | |
static | getMembershipsForUser ( $userId, IDatabase $db=null) |
Returns UserGroupMembership objects for all the groups a user currently belongs to. More... | |
static | newFromRow ( $row) |
Creates a new UserGroupMembership object from a database row. More... | |
static | purgeExpired () |
Purge expired memberships from the user_groups table. More... | |
static | selectFields () |
Returns the list of user_groups fields that should be selected to create a new user group membership. More... | |
Protected Member Functions | |
getDatabaseArray (IDatabase $db) | |
Get an array suitable for passing to $dbw->insert() or $dbw->update() More... | |
initFromRow ( $row) | |
Private Attributes | |
string null | $expiry |
Timestamp of expiry in TS_MW format, or null if no expiry. More... | |
string | $group |
int | $userId |
The ID of the user who belongs to the group. More... | |
Represents a "user group membership" – a specific instance of a user belonging to a group.
For example, the fact that user Mary belongs to the sysop group is a user group membership.
The class encapsulates rows in the user_groups table. The logic is low-level and doesn't run any hooks. Often, you will want to call User::addGroup() or User::removeGroup() instead.
Definition at line 37 of file UserGroupMembership.php.
UserGroupMembership::__construct | ( | $userId = 0 , |
|
$group = null , |
|||
$expiry = null |
|||
) |
UserGroupMembership::delete | ( | IDatabase | $dbw = null | ) |
Delete the row from the user_groups table.
MWException |
IDatabase | null | $dbw | Optional master database connection to use |
Definition at line 119 of file UserGroupMembership.php.
References Wikimedia\Rdbms\IDatabase\affectedRows(), DB_MASTER, Wikimedia\Rdbms\IDatabase\delete(), group, Wikimedia\Rdbms\IDatabase\insert(), wfGetDB(), and wfReadOnly().
|
protected |
Get an array suitable for passing to $dbw->insert() or $dbw->update()
IDatabase | $db |
Definition at line 218 of file UserGroupMembership.php.
References $group, $userId, and Wikimedia\Rdbms\IDatabase\timestamp().
Referenced by insert().
UserGroupMembership::getExpiry | ( | ) |
Definition at line 75 of file UserGroupMembership.php.
References $expiry.
Referenced by MediaWiki\Preferences\DefaultPreferencesFactory\profilePreferences().
UserGroupMembership::getGroup | ( | ) |
|
static |
Gets the localized name for a member of a group, if it exists.
For example, "administrator" or "bureaucrat"
string | $group | Internal group name |
string | $username | Username for gender |
Definition at line 444 of file UserGroupMembership.php.
References $group, $username, and wfMessage().
Referenced by User\getGroupMember(), getLink(), RightsLogFormatter\getMessageParameters(), and UserrightsPage\groupCheckboxes().
|
static |
Gets the localized friendly name for a group, if it exists.
For example, "Administrators" or "Bureaucrats"
string | $group | Internal group name |
Definition at line 431 of file UserGroupMembership.php.
References $group, and wfMessage().
Referenced by SpecialActiveUsers\buildForm(), SpecialPasswordPolicies\execute(), SpecialListGroupRights\execute(), UsersPager\getAllGroups(), User\getGroupName(), getLink(), User\makeGroupLinkHTML(), and User\makeGroupLinkWiki().
|
static |
Gets the title of a page describing a particular user group.
When the name of the group appears in the UI, it can link to this page.
string | $group | Internal group name |
Definition at line 456 of file UserGroupMembership.php.
References $title, Title\newFromText(), and wfMessage().
Referenced by UsersPager\doBatchLookups(), SpecialPasswordPolicies\execute(), SpecialListGroupRights\execute(), User\getGroupPage(), getLink(), User\makeGroupLinkHTML(), and User\makeGroupLinkWiki().
|
static |
Gets a link for a user group, possibly including the expiry date if relevant.
string | UserGroupMembership | $ugm | Either a group name as a string, or a UserGroupMembership object |
IContextSource | $context | |
string | $format | Either 'wiki' or 'html' |
string | null | $userName | If you want to use the group member message ("administrator"), pass the name of the user who belongs to the group; it is used for GENDER of the group member message. If you instead want the group name message ("Administrators"), omit this parameter. |
Definition at line 373 of file UserGroupMembership.php.
References $context, $expiry, $group, getGroupMemberName(), getGroupName(), getGroupPage(), and Linker\link().
Referenced by PermissionsError\__construct(), UsersPager\buildGroupLink(), SpecialListGroupRights\formatPermissions(), User\newFatalPermissionDeniedStatus(), MediaWiki\Preferences\DefaultPreferencesFactory\profilePreferences(), and UserrightsPage\showEditUserGroupsForm().
|
static |
Returns a UserGroupMembership object that pertains to the given user and group, or false if the user does not belong to that group (or the assignment has expired).
int | $userId | ID of the user to search for |
string | $group | User group name |
IDatabase | null | $db | Optional database connection |
Definition at line 340 of file UserGroupMembership.php.
References $group, $userId, DB_REPLICA, newFromRow(), and wfGetDB().
Referenced by UserRightsProxy\removeGroup(), User\removeGroup(), and UserGroupMembershipTest\testGetMembership().
|
static |
Returns UserGroupMembership objects for all the groups a user currently belongs to.
int | $userId | ID of the user to search for |
IDatabase | null | $db | Optional database connection |
Definition at line 309 of file UserGroupMembership.php.
References $res, $userId, as, DB_REPLICA, newFromRow(), and wfGetDB().
Referenced by UserRightsProxy\getGroupMemberships(), User\loadGroups(), and UserGroupMembershipTest\testGetMembershipsForUser().
UserGroupMembership::getUserId | ( | ) |
|
protected |
Definition at line 79 of file UserGroupMembership.php.
References wfTimestamp().
Insert a user right membership into the database.
When $allowUpdate is false, the function fails if there is a conflicting membership entry (same user and group) already in the table.
MWException |
bool | $allowUpdate | Whether to perform "upsert" instead of INSERT |
IDatabase | null | $dbw | If you have one available |
Definition at line 156 of file UserGroupMembership.php.
References Wikimedia\Rdbms\IDatabase\addQuotes(), Wikimedia\Rdbms\IDatabase\affectedRows(), DB_MASTER, getDatabaseArray(), group, Wikimedia\Rdbms\IDatabase\insert(), Wikimedia\Rdbms\IDatabase\selectRow(), JobQueueGroup\singleton(), Wikimedia\Rdbms\IDatabase\timestamp(), Wikimedia\Rdbms\IDatabase\update(), and wfGetDB().
Referenced by UserGroupMembershipTest\addUserTesterToExpiredGroup().
UserGroupMembership::isExpired | ( | ) |
Has the membership expired?
Definition at line 230 of file UserGroupMembership.php.
References $expiry, and wfTimestampNow().
|
static |
Creates a new UserGroupMembership object from a database row.
stdClass | $row | The row from the user_groups table |
Definition at line 93 of file UserGroupMembership.php.
Referenced by UsersPager\doBatchLookups(), getMembership(), getMembershipsForUser(), and User\loadFromRow().
|
static |
Purge expired memberships from the user_groups table.
Definition at line 243 of file UserGroupMembership.php.
References $res, $services, Wikimedia\Rdbms\IDatabase\addQuotes(), as, DB_MASTER, Wikimedia\Rdbms\IDatabase\delete(), Wikimedia\Rdbms\IDatabase\endAtomic(), Wikimedia\Rdbms\IDatabase\getDomainID(), Wikimedia\Rdbms\IDatabase\getScopedLockAndFlush(), Wikimedia\Rdbms\IDatabase\insert(), LIST_AND, LIST_OR, Wikimedia\Rdbms\IDatabase\makeList(), Wikimedia\Rdbms\IDatabase\select(), Wikimedia\Rdbms\IDatabase\startAtomic(), and Wikimedia\Rdbms\IDatabase\timestamp().
Referenced by PurgeExpiredUserrights\execute(), and UserGroupExpiryJob\run().
|
static |
Returns the list of user_groups fields that should be selected to create a new user group membership.
Definition at line 104 of file UserGroupMembership.php.
Referenced by UsersPager\doBatchLookups(), and ApiQueryUsers\execute().
|
private |
Timestamp of expiry in TS_MW format, or null if no expiry.
Definition at line 45 of file UserGroupMembership.php.
Referenced by __construct(), getExpiry(), getLink(), and isExpired().
|
private |
Definition at line 42 of file UserGroupMembership.php.
Referenced by __construct(), getDatabaseArray(), getGroup(), getGroupMemberName(), getGroupName(), getLink(), and getMembership().
|
private |
The ID of the user who belongs to the group.
Definition at line 39 of file UserGroupMembership.php.
Referenced by __construct(), getDatabaseArray(), getMembership(), getMembershipsForUser(), and getUserId().