MediaWiki master
purgeExpiredUserrights.php
Go to the documentation of this file.
1<?php
21require_once __DIR__ . '/Maintenance.php';
22
23/*
24 * Remove expired userrights from user_groups table and move them to former_user_groups.
25 *
26 * By default, this does not need to be run. The UserGroupManager service naturally
27 * takes care of detecting expired rows when it is written to (e.g. from SpecialUserrights)
28 * and queues UserGroupExpiryJob to purge expired rows.
29 *
30 * Large wiki farms may experience stale rows if their users manage local groups
31 * via a central wiki. In that case, UserGroupExpiryJob may run rarely or never
32 * from local wikis, in which case this script can help to periodically clean up
33 * expired rows.
34 *
35 * @since 1.31
36 * @ingroup Maintenance
37 * @author Eddie Greiner-Petter <wikimedia.org at eddie-sh.de>
38 */
40 public function __construct() {
41 parent::__construct();
42 $this->addDescription( 'Move expired userrights from user_groups to former_user_groups table.' );
43 }
44
45 public function execute() {
46 $this->output( "Purging expired user rights...\n" );
47 $res = $this->getServiceContainer()->getUserGroupManager()->purgeExpired();
48 if ( $res === false ) {
49 $this->output( "Purging failed.\n" );
50 } else {
51 $this->output( "$res rows purged.\n" );
52 }
53 }
54}
55
56$maintClass = PurgeExpiredUserrights::class;
57require_once RUN_MAINTENANCE_IF_MAIN;
Abstract maintenance class for quickly writing and churning out maintenance scripts with minimal effo...
output( $out, $channel=null)
Throw some output to the user.
getServiceContainer()
Returns the main service container.
addDescription( $text)
Set the description text.
__construct()
Default constructor.