MediaWiki master
|
This is a value object for authentication requests. More...
Inherited by MediaWiki\Auth\ButtonAuthenticationRequest, MediaWiki\Auth\ConfirmLinkAuthenticationRequest, MediaWiki\Auth\CreateFromLoginAuthenticationRequest, MediaWiki\Auth\CreatedAccountAuthenticationRequest, MediaWiki\Auth\CreationReasonAuthenticationRequest, MediaWiki\Auth\PasswordAuthenticationRequest, MediaWiki\Auth\RememberMeAuthenticationRequest, MediaWiki\Auth\TemporaryPasswordAuthenticationRequest, MediaWiki\Auth\UserDataAuthenticationRequest, and MediaWiki\Auth\UsernameAuthenticationRequest.
Public Member Functions | |
describeCredentials () | |
Describe the credentials represented by this request. | |
getFieldInfo () | |
Fetch input field info. | |
getMetadata () | |
Returns metadata about this request. | |
getUniqueId () | |
Supply a unique key for deduplication. | |
loadFromSubmission (array $data) | |
Initialize form submitted form data. | |
Static Public Member Functions | |
static | __set_state ( $data) |
Implementing this mainly for use from the unit tests. | |
static | getRequestByClass (array $reqs, $class, $allowSubclasses=false) |
Select a request by class name. | |
static | getUsernameFromRequests (array $reqs) |
Get the username from the set of requests. | |
static | loadRequestsFromSubmission (array $reqs, array $data) |
Update a set of requests with form submit data, discarding ones that fail. | |
static | mergeFieldInfo (array $reqs) |
Merge the output of multiple AuthenticationRequest::getFieldInfo() calls. | |
Public Attributes | |
string null | $action = null |
The AuthManager::ACTION_* constant this request was created to be used for. | |
int | $required = self::REQUIRED |
Whether the authentication request is required (for login, continue, and link actions). | |
string null | $returnToUrl = null |
Return-to URL, in case of a REDIRECT AuthenticationResponse. | |
string null | $username = null |
Username. | |
const | OPTIONAL = 0 |
Indicates that the request is not required for authentication to proceed. | |
const | PRIMARY_REQUIRED = 2 |
Indicates that the request is required by a primary authentication provider. | |
const | REQUIRED = 1 |
Indicates that the request is required for authentication to proceed. | |
This is a value object for authentication requests.
An AuthenticationRequest represents a set of form fields that are needed on and provided from a login, account creation, password change or similar form. Form fields can be shared by multiple AuthenticationRequests (see {
Authentication providers that expect user input need to implement one or more subclasses of this class and return them from AuthenticationProvider::getAuthenticationRequests(). A typical subclass would override getFieldInfo() and set $required.
Definition at line 45 of file AuthenticationRequest.php.
|
static |
Implementing this mainly for use from the unit tests.
array | $data |
Reimplemented in MediaWiki\Auth\ButtonAuthenticationRequest, MediaWiki\Auth\ConfirmLinkAuthenticationRequest, and MediaWiki\Auth\PasswordDomainAuthenticationRequest.
Definition at line 434 of file AuthenticationRequest.php.
MediaWiki\Auth\AuthenticationRequest::describeCredentials | ( | ) |
Describe the credentials represented by this request.
This is used on requests returned by AuthenticationProvider::getAuthenticationRequests() for ACTION_LINK and ACTION_REMOVE and for requests returned in AuthenticationResponse::$linkRequest to create useful user interfaces.
Reimplemented in MediaWiki\Auth\PasswordAuthenticationRequest, MediaWiki\Auth\PasswordDomainAuthenticationRequest, and MediaWiki\Auth\TemporaryPasswordAuthenticationRequest.
Definition at line 269 of file AuthenticationRequest.php.
References MediaWiki\Auth\AuthenticationRequest\getUniqueId().
Referenced by MediaWiki\Specials\SpecialChangeCredentials\showSubpageList().
|
abstract |
Fetch input field info.
This will be used in the AuthManager APIs and web UIs to define API input parameters / form fields and to process the submitted data.
The field info is an associative array mapping field names to info arrays. The info arrays have the following keys:
All AuthenticationRequests are populated from the same data, so most of the time you'll want to prefix fields names with something unique to the extension/provider (although in some cases sharing the field with other requests is the right thing to do, e.g. for a 'password' field). When multiple fields have the same name, they will be merged (see AuthenticationRequests::mergeFieldInfo). Typically, AuthenticationRequest subclasses define public properties with names matching the field info keys, and those fields will be populated from the submitted data. More complex behavior can be implemented by overriding {
Reimplemented in MediaWiki\Auth\ButtonAuthenticationRequest, MediaWiki\Auth\ConfirmLinkAuthenticationRequest, MediaWiki\Auth\CreatedAccountAuthenticationRequest, MediaWiki\Auth\CreateFromLoginAuthenticationRequest, MediaWiki\Auth\CreationReasonAuthenticationRequest, MediaWiki\Auth\PasswordAuthenticationRequest, MediaWiki\Auth\PasswordDomainAuthenticationRequest, MediaWiki\Auth\RememberMeAuthenticationRequest, MediaWiki\Auth\TemporaryPasswordAuthenticationRequest, MediaWiki\Auth\UserDataAuthenticationRequest, and MediaWiki\Auth\UsernameAuthenticationRequest.
Referenced by MediaWiki\SpecialPage\AuthManagerSpecialPage\hasOwnSubmitButton(), and MediaWiki\Auth\AuthenticationRequest\loadFromSubmission().
MediaWiki\Auth\AuthenticationRequest::getMetadata | ( | ) |
Returns metadata about this request.
This is mainly for the benefit of API clients which need more detailed render hints than what's available through getFieldInfo(). Semantics are unspecified and left to the individual subclasses, but the contents of the array should be primitive types so that they can be transformed into JSON or similar formats.
Definition at line 175 of file AuthenticationRequest.php.
|
static |
Select a request by class name.
AuthenticationRequest[] | $reqs | |
string | $class | Class name |
bool | $allowSubclasses | If true, also returns any request that's a subclass of the given class. |
Definition at line 306 of file AuthenticationRequest.php.
Referenced by MediaWiki\Auth\AuthManager\beginAuthentication(), MediaWiki\Auth\AbstractTemporaryPasswordPrimaryAuthenticationProvider\beginPrimaryAccountCreation(), MediaWiki\Auth\LocalPasswordPrimaryAuthenticationProvider\beginPrimaryAccountCreation(), MediaWiki\Auth\AbstractTemporaryPasswordPrimaryAuthenticationProvider\beginPrimaryAuthentication(), MediaWiki\Auth\LocalPasswordPrimaryAuthenticationProvider\beginPrimaryAuthentication(), MediaWiki\Auth\AuthManager\continueAuthentication(), MediaWiki\Auth\ConfirmLinkSecondaryAuthenticationProvider\continueLinkAttempt(), MediaWiki\Auth\AbstractTemporaryPasswordPrimaryAuthenticationProvider\testForAccountCreation(), MediaWiki\Auth\LocalPasswordPrimaryAuthenticationProvider\testForAccountCreation(), and MediaWiki\Auth\ResetPasswordSecondaryAuthenticationProvider\tryReset().
MediaWiki\Auth\AuthenticationRequest::getUniqueId | ( | ) |
Supply a unique key for deduplication.
When the AuthenticationRequests instances returned by the providers are merged, the value returned here is used for keeping only one copy of duplicate requests.
Subclasses should override this if multiple distinct instances would make sense, i.e. the request class has internal state of some sort.
This value might be exposed to the user in web forms so it should not contain private information.
Reimplemented in MediaWiki\Auth\ButtonAuthenticationRequest, and MediaWiki\Auth\ConfirmLinkAuthenticationRequest.
Definition at line 117 of file AuthenticationRequest.php.
Referenced by MediaWiki\Auth\AuthenticationRequest\describeCredentials(), MediaWiki\Api\ApiRemoveAuthenticationData\execute(), and MediaWiki\Api\ApiAuthManagerHelper\loadAuthenticationRequests().
|
static |
Get the username from the set of requests.
Only considers requests that have a "username" field.
AuthenticationRequest[] | $reqs |
UnexpectedValueException | If multiple different usernames are present. |
Definition at line 327 of file AuthenticationRequest.php.
References MediaWiki\Auth\AuthenticationRequest\$username.
Referenced by MediaWiki\Auth\ThrottlePreAuthenticationProvider\testForAuthentication().
MediaWiki\Auth\AuthenticationRequest::loadFromSubmission | ( | array | $data | ) |
Initialize form submitted form data.
The default behavior is to check for each key of self::getFieldInfo() in the submitted data, and copy the value - after type-appropriate transformations - to $this->$key. Most subclasses won't need to override this; if you do override it, make sure to always return false if self::getFieldInfo() returns an empty array.
array | $data | Submitted data as an associative array (keys will correspond to getFieldInfo()) |
Reimplemented in MediaWiki\Auth\CreateFromLoginAuthenticationRequest.
Definition at line 192 of file AuthenticationRequest.php.
References MediaWiki\Auth\AuthenticationRequest\getFieldInfo().
|
static |
Update a set of requests with form submit data, discarding ones that fail.
AuthenticationRequest[] | $reqs | |
array | $data |
Definition at line 283 of file AuthenticationRequest.php.
|
static |
Merge the output of multiple AuthenticationRequest::getFieldInfo() calls.
AuthenticationRequest[] | $reqs |
UnexpectedValueException | If the requests include fields with the same name but incompatible definitions (e.g. different field types). |
Definition at line 354 of file AuthenticationRequest.php.
References MediaWiki\Auth\AuthenticationRequest\$required.
string null MediaWiki\Auth\AuthenticationRequest::$action = null |
The AuthManager::ACTION_* constant this request was created to be used for.
Usually set by AuthManager. The *_CONTINUE constants are not used here, the corresponding "begin" constant is used instead.
Definition at line 71 of file AuthenticationRequest.php.
Referenced by MediaWiki\Auth\CreateFromLoginAuthenticationRequest\hasPrimaryStateForAction(), and MediaWiki\Auth\CreateFromLoginAuthenticationRequest\hasStateForAction().
int MediaWiki\Auth\AuthenticationRequest::$required = self::REQUIRED |
Whether the authentication request is required (for login, continue, and link actions).
Setting this to optional is roughly equivalent to setting the 'optional' flag for all fields in the field info.
Set this to self::OPTIONAL or self::REQUIRED. When coming from a primary provider, self::REQUIRED will be automatically modified to self::PRIMARY_REQUIRED.
Definition at line 83 of file AuthenticationRequest.php.
Referenced by MediaWiki\Auth\ButtonAuthenticationRequest\__construct(), and MediaWiki\Auth\AuthenticationRequest\mergeFieldInfo().
string null MediaWiki\Auth\AuthenticationRequest::$returnToUrl = null |
Return-to URL, in case of a REDIRECT AuthenticationResponse.
Set by AuthManager.
Definition at line 89 of file AuthenticationRequest.php.
string null MediaWiki\Auth\AuthenticationRequest::$username = null |
Username.
Usually set by AuthManager. See AuthenticationProvider::getAuthenticationRequests() for details of what this means and how it behaves.
Often this doubles as a normal field (ie. getFieldInfo() has a 'username' key).
Definition at line 99 of file AuthenticationRequest.php.
Referenced by MediaWiki\Auth\AuthenticationRequest\getUsernameFromRequests().
const MediaWiki\Auth\AuthenticationRequest::OPTIONAL = 0 |
Indicates that the request is not required for authentication to proceed.
Definition at line 48 of file AuthenticationRequest.php.
Referenced by MediaWiki\Auth\ButtonAuthenticationRequest\__construct(), and MediaWiki\Auth\ResetPasswordSecondaryAuthenticationProvider\tryReset().
const MediaWiki\Auth\AuthenticationRequest::PRIMARY_REQUIRED = 2 |
Indicates that the request is required by a primary authentication provider.
Since the user can choose which primary to authenticate with, the request might or might not end up being actually required.
Definition at line 62 of file AuthenticationRequest.php.
const MediaWiki\Auth\AuthenticationRequest::REQUIRED = 1 |
Indicates that the request is required for authentication to proceed.
This will only be used for UI purposes; it is the authentication providers' responsibility to verify that all required requests are present.
Definition at line 55 of file AuthenticationRequest.php.
Referenced by MediaWiki\Auth\ButtonAuthenticationRequest\__construct(), and MediaWiki\Auth\ResetPasswordSecondaryAuthenticationProvider\tryReset().