Merge "Print chained exceptions when maintenance script fails."
[lhc/web/wiklou.git] / maintenance / resetUserEmail.php
1 <?php
2 /**
3 * Reset user email.
4 *
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.
9 *
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.
14 *
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
19 *
20 * @file
21 * @ingroup Maintenance
22 */
23
24 require_once __DIR__ . '/Maintenance.php';
25
26 /**
27 * Maintenance script that resets user email.
28 *
29 * @since 1.27
30 * @ingroup Maintenance
31 */
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 #' );
36 $this->addArg( 'email', 'Email to assign' );
37
38 $this->addOption( 'no-reset-password', 'Don\'t reset the user\'s password' );
39
40 parent::__construct();
41 }
42
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 );
49 }
50 if ( !$user || !$user->getId() || !$user->loadFromId() ) {
51 $this->fatalError( "Error: user '$userName' does not exist\n" );
52 }
53
54 $email = $this->getArg( 1 );
55 if ( !Sanitizer::validateEmail( $email ) ) {
56 $this->fatalError( "Error: email '$email' is not valid\n" );
57 }
58
59 // Code from https://wikitech.wikimedia.org/wiki/Password_reset
60 $user->setEmail( $email );
61 $user->setEmailAuthenticationTimestamp( wfTimestampNow() );
62 $user->saveSettings();
63
64 if ( !$this->hasOption( 'no-reset-password' ) ) {
65 // Kick whomever is currently controlling the account off
66 $user->setPassword( PasswordFactory::generateRandomPasswordString( 128 ) );
67 }
68 $this->output( "Done!\n" );
69 }
70 }
71
72 $maintClass = ResetUserEmail::class;
73 require_once RUN_MAINTENANCE_IF_MAIN;