MediaWiki master
changePassword.php
Go to the documentation of this file.
1<?php
13// @codeCoverageIgnoreStart
14require_once __DIR__ . '/Maintenance.php';
15// @codeCoverageIgnoreEnd
16
19
26 public function __construct() {
27 parent::__construct();
28 $this->addOption( "user", "The username to operate on", false, true );
29 $this->addOption( "userid", "The user id to operate on", false, true );
30 $this->addOption( "password", "The password to use", false, true );
31 // phpcs:ignore Generic.Files.LineLength.TooLong
32 $this->addOption( "passwordstdin", "Makes the script read the password from stdin instead. Cannot be used alongside --password", false, false );
33 $this->addOption( 'reason', 'Reason for the password change (ticket number etc)', false, true );
34 $this->addDescription( "Change a user's password" );
35 }
36
37 public function execute() {
38 $user = $this->validateUserOption( "A \"user\" or \"userid\" must be set to change the password for" );
39 // phpcs:ignore Generic.Files.LineLength.TooLong
40 $password = $this->validatePasswordOption( 'Set either --password or --passwordstdin', 'Either --password or --passwordstdin must be set, not both at once' );
41 $status = $user->changeAuthenticationData( [
42 'username' => $user->getName(),
43 'password' => $password,
44 'retype' => $password,
45 ] );
46 if ( $status->isGood() ) {
47 $this->output( "Password set for " . $user->getName() . "\n" );
48
49 LoggerFactory::getInstance( 'authentication' )->info(
50 'Password for {user} changed via changePassword.php', [
51 'user' => $user->getName(),
52 'reason' => $this->getOption( 'reason', '' ),
53 ]
54 );
55
56 $invalidator = $this->createChild( InvalidateUserSessions::class );
57 $invalidator->setOption( 'user', $user->getName() );
58 $invalidator->execute();
59 } else {
60 $this->fatalError( $status );
61 }
62 }
63
72 private function validatePasswordOption( $errorMsgNoPassword, $errorMsgBothPasswords ) {
73 if ( $this->hasOption( 'password' ) && $this->hasOption( 'passwordstdin' ) ) {
74 $this->fatalError( $errorMsgBothPasswords );
75 }
76 if ( $this->hasOption( 'password' ) ) {
77 return $this->getOption( 'password' );
78 } elseif ( $this->hasOption( 'passwordstdin' ) ) {
79 return $this->getStdin( Maintenance::STDIN_ALL );
80 } else {
81 $this->fatalError( $errorMsgNoPassword );
82 }
83 }
84}
85
86// @codeCoverageIgnoreStart
87$maintClass = ChangePassword::class;
88require_once RUN_MAINTENANCE_IF_MAIN;
89// @codeCoverageIgnoreEnd
$maintClass
Maintenance script to change the password of a given user.
execute()
Do the actual work.
__construct()
Default constructor.
Create PSR-3 logger objects.
Abstract maintenance class for quickly writing and churning out maintenance scripts with minimal effo...
createChild(string $maintClass, ?string $classFile=null)
Returns an instance of the given maintenance script, with all of the current arguments passed to it.
output( $out, $channel=null)
Throw some output to the user.
fatalError( $msg, $exitCode=1)
Output a message and terminate the current script.
addOption( $name, $description, $required=false, $withArg=false, $shortName=false, $multiOccurrence=false)
Add a parameter to the script.
hasOption( $name)
Checks to see if a particular option was set.
getOption( $name, $default=null)
Get an option, or return the default.
getStdin( $len=null)
Return input from stdin.
addDescription( $text)
Set the description text.