MediaWiki
1.34.0
|
Helper class for the password reset functionality shared by the web UI and the API. More...
Public Member Functions | |
__construct ( $config, AuthManager $authManager, PermissionManager $permissionManager, ILoadBalancer $loadBalancer=null, LoggerInterface $logger=null) | |
This class is managed by MediaWikiServices, don't instantiate directly. More... | |
execute (User $performingUser, $username=null, $email=null) | |
Do a password reset. More... | |
isAllowed (User $user) | |
Check if a given user has permission to use this functionality. More... | |
Public Attributes | |
const | CONSTRUCTOR_OPTIONS |
Protected Member Functions | |
getUsersByEmail ( $email) | |
isBlocked (User $user) | |
Check whether the user is blocked. More... | |
lookupUser ( $username) | |
User object creation helper for testability. More... | |
Protected Attributes | |
AuthManager | $authManager |
ServiceOptions Config | $config |
ILoadBalancer | $loadBalancer |
PermissionManager | $permissionManager |
Private Attributes | |
MapCacheLRU | $permissionCache |
In-process cache for isAllowed lookups, by username. More... | |
Helper class for the password reset functionality shared by the web UI and the API.
Requires the TemporaryPasswordPrimaryAuthenticationProvider and the EmailNotificationSecondaryAuthenticationProvider (or something providing equivalent functionality) to be enabled.
Definition at line 41 of file PasswordReset.php.
PasswordReset::__construct | ( | $config, | |
AuthManager | $authManager, | ||
PermissionManager | $permissionManager, | ||
ILoadBalancer | $loadBalancer = null , |
||
LoggerInterface | $logger = null |
||
) |
This class is managed by MediaWikiServices, don't instantiate directly.
ServiceOptions | Config | $config | |
AuthManager | $authManager | |
PermissionManager | $permissionManager | |
ILoadBalancer | null | $loadBalancer | |
LoggerInterface | null | $logger |
Definition at line 78 of file PasswordReset.php.
References $authManager, $config, $loadBalancer, $permissionManager, and wfDeprecated().
PasswordReset::execute | ( | User | $performingUser, |
$username = null , |
|||
$email = null |
|||
) |
Do a password reset.
Authorization is the caller's responsibility.
Process the form. At this point we know that the user passes all the criteria in userCanExecute(), and if the data array contains 'Username', etc, then Username resets are allowed.
User | $performingUser | The user that does the password reset |
string | null | $username | The user whose password is reset |
string | null | Alternative way to specify the user |
LogicException | When the user is not allowed to perform the action |
MWException | On unexpected DB errors |
Definition at line 162 of file PasswordReset.php.
References $status, User\getId(), User\getName(), User\getRequest(), getUsersByEmail(), isAllowed(), lookupUser(), StatusValue\newFatal(), StatusValue\newGood(), User\pingLimiter(), Hooks\run(), wfEscapeWikiText(), and wfMessage().
|
protected |
string |
MWException | On unexpected database errors |
Definition at line 327 of file PasswordReset.php.
References $res, DB_REPLICA, User\getQueryInfo(), and User\newFromRow().
Referenced by execute().
PasswordReset::isAllowed | ( | User | $user | ) |
Check if a given user has permission to use this functionality.
User | $user |
Definition at line 110 of file PasswordReset.php.
References $status, User\getName(), isBlocked(), StatusValue\newFatal(), and StatusValue\newGood().
Referenced by execute().
|
protected |
Check whether the user is blocked.
Ignores certain types of system blocks that are only meant to force users to log in.
User | $user |
Definition at line 314 of file PasswordReset.php.
References User\getBlock(), and User\getGlobalBlock().
Referenced by isAllowed().
|
protected |
User object creation helper for testability.
string | $username |
Definition at line 357 of file PasswordReset.php.
References User\newFromName().
Referenced by execute().
|
protected |
Definition at line 48 of file PasswordReset.php.
Referenced by __construct().
|
protected |
Definition at line 45 of file PasswordReset.php.
Referenced by __construct().
|
protected |
Definition at line 54 of file PasswordReset.php.
Referenced by __construct().
|
private |
In-process cache for isAllowed lookups, by username.
Contains a StatusValue object
Definition at line 61 of file PasswordReset.php.
|
protected |
Definition at line 51 of file PasswordReset.php.
Referenced by __construct().
const PasswordReset::CONSTRUCTOR_OPTIONS |
Definition at line 63 of file PasswordReset.php.