28require_once __DIR__ .
'/../Maintenance.php';
52 parent::__construct();
56 $this->
addOption(
'user',
'If specified, only checks the given user',
false,
true );
57 $this->
addOption(
'delete',
'Really delete. To prevent accidents, you must provide this flag.' );
58 $this->
addOption(
'prefix',
"Instead of deleting, make passwords invalid by prefixing with "
59 .
"':null:'. Make sure PasswordConfig has a 'null' entry. This is meant for testing before "
61 $this->
addOption(
'unprefix',
'Instead of deleting, undo the effect of --prefix.' );
67 + (
int)$this->
hasOption(
'unprefix' ) !== 1
69 $this->
fatalError(
"Exactly one of the 'delete', 'prefix', 'unprefix' options must be used\n" );
72 $passwordHashTypes = MediaWikiServices::getInstance()->getPasswordFactory()->getTypes();
74 !isset( $passwordHashTypes[
'null'] )
75 || $passwordHashTypes[
'null'][
'class'] !== InvalidPassword::class
79'null' password entry missing. To use password prefixing, add
81to your configuration (and
remove once the passwords were deleted).
88 if (
$user !==
false ) {
89 $userNameUtils = MediaWikiServices::getInstance()->getUserNameUtils();
90 $this->user = $userNameUtils->getCanonical(
$user );
91 if ( $this->user ===
false ) {
104 $this->
output(
"done. (wrote $this->total rows)\n" );
122 [
'user_password' => PasswordFactory::newInvalidPassword()->toString() ],
123 [
'user_name' => $userBatch ],
126 } elseif ( $this->
getOption(
'prefix' ) ) {
129 'user_password' ] ) ],
132 "user_password != " . $dbw->
addQuotes( PasswordFactory::newInvalidPassword()->toString() ),
133 'user_password IS NOT NULL',
134 'user_name' => $userBatch,
138 } elseif ( $this->
getOption(
'unprefix' ) ) {
140 [
'user_password = ' . $dbw->
buildSubString(
'user_password', strlen(
':null:' ) + 1 ) ],
143 'user_name' => $userBatch,
149 MediaWikiServices::getInstance()->getDBLoadBalancerFactory()->waitForReplication();
162 if ( $this->user !==
null ) {
163 $this->
output(
"\t ... querying '$this->user'\n" );
171 $this->
output(
"\t ... querying from '$lastUsername'\n" );
172 $users = $dbw->selectFieldValues(
176 'user_name > ' . $dbw->addQuotes( $lastUsername ),
180 'LIMIT' => $this->getBatchSize(),
181 'ORDER BY' =>
'user_name ASC',
186 $lastUsername = end( $users );
Delete unused local passwords.
execute()
Do the actual work.
__construct()
Default constructor.
string null $user
User to run on, or null for all.
int $total
Number of deleted passwords.
processUsers(array $userBatch, IDatabase $dbw)
getUserBatches()
This method iterates through the requested users and returns their names in batches of self::$mBatchS...
getUserDB()
Get the primary DB handle for the current user batch.
Abstract maintenance class for quickly writing and churning out maintenance scripts with minimal effo...
output( $out, $channel=null)
Throw some output to the user.
hasOption( $name)
Checks to see if a particular option was set.
getBatchSize()
Returns batch size.
addDescription( $text)
Set the description text.
addOption( $name, $description, $required=false, $withArg=false, $shortName=false, $multiOccurrence=false)
Add a parameter to the script.
getOption( $name, $default=null)
Get an option, or return the default.
fatalError( $msg, $exitCode=1)
Output a message and terminate the current script.
$wgPasswordConfig
Config variable stub for the PasswordConfig setting, for use by phpdoc and IDEs.
Advanced database interface for IDatabase handles that include maintenance methods.