3 * Check that database usernames are actually valid.
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License along
16 * with this program; if not, write to the Free Software Foundation, Inc.,
17 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
18 * http://www.gnu.org/copyleft/gpl.html
21 * @ingroup Maintenance
24 use MediaWiki\Maintenance\Maintenance
;
26 // @codeCoverageIgnoreStart
27 require_once __DIR__
. '/Maintenance.php';
28 // @codeCoverageIgnoreEnd
31 * Maintenance script to check that database usernames are actually valid.
33 * An existing usernames can become invalid if UserNameUtils::isValid()
34 * is altered or if we change the $wgMaxNameChars
36 * @ingroup Maintenance
38 class CheckUsernames
extends Maintenance
{
40 public function __construct() {
41 parent
::__construct();
42 $this->addDescription( 'Verify that database usernames are actually valid' );
43 $this->setBatchSize( 1000 );
46 public function execute() {
47 $dbr = $this->getReplicaDB();
48 $userNameUtils = $this->getServiceContainer()->getUserNameUtils();
52 $res = $dbr->newSelectQueryBuilder()
53 ->select( [ 'user_id', 'user_name' ] )
55 ->where( $dbr->expr( 'user_id', '>', $maxUserId ) )
56 ->orderBy( 'user_id' )
57 ->limit( $this->getBatchSize() )
58 ->caller( __METHOD__
)
61 foreach ( $res as $row ) {
62 if ( !$userNameUtils->isValid( $row->user_name
) ) {
63 $this->output( sprintf( "Found: %6d: '%s'\n", $row->user_id
, $row->user_name
) );
64 wfDebugLog( 'checkUsernames', $row->user_name
);
67 // @phan-suppress-next-line PhanPossiblyUndeclaredVariable $res has at at least one item
68 $maxUserId = $row->user_id
;
69 } while ( $res->numRows() );
73 // @codeCoverageIgnoreStart
74 $maintClass = CheckUsernames
::class;
75 require_once RUN_MAINTENANCE_IF_MAIN
;
76 // @codeCoverageIgnoreEnd