Merge "Fix Selenium tests"
[mediawiki.git] / maintenance / resetUserEmail.php
blob8d0873f1b508526a43423ebc09a8f338bd135cea
1 <?php
2 /**
3 * Reset user email.
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
20 * @file
21 * @ingroup Maintenance
24 require_once __DIR__ . '/Maintenance.php';
26 /**
27 * Maintenance script that resets user email.
29 * @since 1.27
30 * @ingroup Maintenance
32 class ResetUserEmail extends Maintenance {
33 public function __construct() {
34 $this->addDescription( "Resets a user's email" );
35 $this->addArg( 'user', 'Username or user ID, if starts with #', true );
36 $this->addArg( 'email', 'Email to assign' );
38 $this->addOption( 'no-reset-password', 'Don\'t reset the user\'s password', false, false );
40 parent::__construct();
43 public function execute() {
44 $userName = $this->getArg( 0 );
45 if ( preg_match( '/^#\d+$/', $userName ) ) {
46 $user = User::newFromId( substr( $userName, 1 ) );
47 } else {
48 $user = User::newFromName( $userName );
50 if ( !$user || !$user->getId() || !$user->loadFromId() ) {
51 $this->error( "Error: user '$userName' does not exist\n", 1 );
54 $email = $this->getArg( 1 );
55 if ( !Sanitizer::validateEmail( $email ) ) {
56 $this->error( "Error: email '$email' is not valid\n", 1 );
59 // Code from https://wikitech.wikimedia.org/wiki/Password_reset
60 $user->setEmail( $email );
61 $user->setEmailAuthenticationTimestamp( wfTimestampNow() );
62 $user->saveSettings();
64 if ( !$this->hasOption( 'no-reset-password' ) ) {
65 // Kick whomever is currently controlling the account off
66 $user->setPassword( PasswordFactory::generateRandomPasswordString( 128 ) );
71 $maintClass = 'ResetUserEmail';
72 require_once RUN_MAINTENANCE_IF_MAIN;