MediaWiki  master
LoginSignupSpecialPage Class Reference

Holds shared logic for login and account creation pages. More...

Inheritance diagram for LoginSignupSpecialPage:
Collaboration diagram for LoginSignupSpecialPage:

Public Member Functions

 __construct ($name)
 
 execute ($subPage)
 
 onAuthChangeFormFields (array $requests, array $fieldInfo, array &$formDescriptor, $action)
 
 showReturnToPage ($type, $returnTo= '', $returnToQuery= '', $stickHTTPS=false)
 Add a "return to" link or redirect to it. More...
 
- Public Member Functions inherited from AuthManagerSpecialPage
 getRequest ()
 
 handleFormSubmit ($data)
 Submit handler callback for HTMLForm. More...
 
 onAuthChangeFormFields (array $requests, array $fieldInfo, array &$formDescriptor, $action)
 Change the form descriptor that determines how a field will look in the authentication form. More...
 
- Public Member Functions inherited from SpecialPage
 __construct ($name= '', $restriction= '', $listed=true, $function=false, $file= '', $includable=false)
 Default constructor for special pages Derivative classes should call this from their constructor Note that if the user does not have the required level, an error message will be displayed by the default execute() method, without the global function ever being called. More...
 
 addHelpLink ($to, $overrideBaseUrl=false)
 Adds help link with an icon via page indicators. More...
 
 checkPermissions ()
 Checks if userCanExecute, and if not throws a PermissionsError. More...
 
 checkReadOnly ()
 If the wiki is currently in readonly mode, throws a ReadOnlyError. More...
 
 displayRestrictionError ()
 Output an error message telling the user what access level they have to have. More...
 
 doesWrites ()
 Indicates whether this special page may perform database writes. More...
 
 execute ($subPage)
 Default execute method Checks user permissions. More...
 
 getConfig ()
 Shortcut to get main config object. More...
 
 getContext ()
 Gets the context this SpecialPage is executed in. More...
 
 getDescription ()
 Returns the name that goes in the \<h1\> in the special page itself, and also the name that will be listed in Special:Specialpages. More...
 
 getFinalGroupName ()
 Get the group that the special page belongs in on Special:SpecialPage Use this method, instead of getGroupName to allow customization of the group name from the wiki side. More...
 
 getFullTitle ()
 Return the full title, including $par. More...
 
 getLanguage ()
 Shortcut to get user's language. More...
 
 getLocalName ()
 Get the localised name of the special page. More...
 
 getName ()
 Get the name of this Special Page. More...
 
 getOutput ()
 Get the OutputPage being used for this instance. More...
 
 getPageTitle ($subpage=false)
 Get a self-referential title object. More...
 
 getRequest ()
 Get the WebRequest being used for this instance. More...
 
 getRestriction ()
 Get the permission that a user must have to execute this page. More...
 
 getSkin ()
 Shortcut to get the skin being used for this instance. More...
 
 getTitle ($subpage=false)
 Get a self-referential title object. More...
 
 getUser ()
 Shortcut to get the User executing this instance. More...
 
 including ($x=null)
 Whether the special page is being evaluated via transclusion. More...
 
 isCached ()
 Is this page cached? Expensive pages are cached or disabled in miser mode. More...
 
 isExpensive ()
 Is this page expensive (for some definition of expensive)? Expensive pages are disabled or cached in miser mode. More...
 
 isIncludable ()
 Whether it's allowed to transclude the special page via {{Special:Foo/params}}. More...
 
 isListed ()
 Whether this special page is listed in Special:SpecialPages. More...
 
 isRestricted ()
 Can be overridden by subclasses with more complicated permissions schemes. More...
 
 listed ($x=null)
 Get or set whether this special page is listed in Special:SpecialPages. More...
 
 maxIncludeCacheTime ()
 How long to cache page when it is being included. More...
 
 msg ()
 Wrapper around wfMessage that sets the current context. More...
 
 outputHeader ($summaryMessageKey= '')
 Outputs a summary message on top of special pages Per default the message key is the canonical name of the special page May be overridden, i.e. More...
 
 prefixSearchSubpages ($search, $limit, $offset)
 Return an array of subpages beginning with $search that this special page will accept. More...
 
 requireLogin ($reasonMsg= 'exception-nologin-text', $titleMsg= 'exception-nologin')
 If the user is not logged in, throws UserNotLoggedIn error. More...
 
 run ($subPage)
 Entry point. More...
 
 setContext ($context)
 Sets the context this SpecialPage is executed in. More...
 
 setHeaders ()
 Sets headers - this should be called from the execute() method of all derived classes! More...
 
 setLinkRenderer (LinkRenderer $linkRenderer)
 
 setListed ($listed)
 Set whether this page is listed in Special:Specialpages, at run-time. More...
 
 userCanExecute (User $user)
 Checks if the given user (identified by an object) can execute this special page (as defined by $mRestriction). More...
 

Protected Member Functions

 beforeExecute ($subPage)
 
 getAuthForm (array $requests, $action, $msg= '', $msgType= 'error')
 Generates a form from the given request. More...
 
 getBCFieldDefinitions ($fieldDefinitions, $template)
 Adds fields provided via the deprecated UserLoginForm / UserCreateForm hooks. More...
 
 getFakeTemplate ($msg, $msgType)
 Temporary B/C method to handle extensions using the UserLoginForm/UserCreateForm hooks. More...
 
 getFieldDefinitions ($template)
 Create a HTMLForm descriptor for the core login fields. More...
 
 getGroupName ()
 
 getPageHtml ($formHtml)
 Add page elements which are outside the form. More...
 
 getPreservedParams ($withToken=false)
 
 getReturnToQueryStringFragment ()
 Returns a string that can be appended to the URL (without encoding) to preserve the return target. More...
 
 getTokenName ()
 
 hasSessionCookie ()
 Check if a session cookie is present. More...
 
 isSignup ()
 
 load ($subPage)
 Load data from request. More...
 
 logAuthResult ($success, $status=null)
 Logs to the authmanager-stats channel. More...
 
 mainLoginForm (array $requests, $msg= '', $msgtype= 'error')
 
 makeLanguageSelector ()
 Produce a bar of links which allow the user to select another language during login/registration but retain "returnto". More...
 
 makeLanguageSelectorLink ($text, $lang)
 Create a language selector link for a particular language Links back to this page preserving type and returnto. More...
 
 postProcessFormDescriptor (&$formDescriptor)
 
 setRequest (array $data, $wasPosted=null)
 
 setSessionUserForCurrentRequest ()
 Replace some globals to make sure the fact that the user has just been logged in is reflected in the current request. More...
 
 showExtraInformation ()
 Show extra information such as password recovery information, link from login to signup, CTA etc? Such information should only be shown on the "landing page", ie. More...
 
 showSuccessPage ($type, $title, $msgname, $injected_html, $extraMessages)
 Show the success page. More...
 
 successfulAction ($direct=false, $extraMessages=null)
 
- Protected Member Functions inherited from AuthManagerSpecialPage
 addTabIndex (&$formDescriptor)
 Adds a sequential tabindex starting from 1 to all form elements. More...
 
 beforeExecute ($subPage)
 
 displayForm ($status)
 Display the form. More...
 
 fieldInfoToFormDescriptor (array $requests, array $fieldInfo, $action)
 Turns a field info array into a form descriptor. More...
 
 getAuthForm (array $requests, $action)
 
 getAuthFormDescriptor ($requests, $action)
 Generates a HTMLForm descriptor array from a set of authentication requests. More...
 
 getContinueAction ($action)
 Gets the _CONTINUE version of an action. More...
 
 getDefaultAction ($subPage)
 Get the default action for this special page, if none is given via URL/POST data. More...
 
 getLoginSecurityLevel ()
 
 getPreservedParams ($withToken=false)
 Returns URL query parameters which can be used to reload the page (or leave and return) while preserving all information that is necessary for authentication to continue. More...
 
 getRequestBlacklist ()
 Allows blacklisting certain request types. More...
 
 getToken ()
 Returns the CSRF token. More...
 
 getTokenName ()
 Returns the name of the CSRF token (under which it should be found in the POST or GET data). More...
 
 handleReauthBeforeExecute ($subPage)
 Handle redirection when the user needs to (re)authenticate. More...
 
 handleReturnBeforeExecute ($subPage)
 Handle redirection from the /return subpage. More...
 
 isActionAllowed ($action)
 Checks whether AuthManager is ready to perform the action. More...
 
 isContinued ()
 Returns true if this is not the first step of the authentication. More...
 
 loadAuth ($subPage, $authAction=null, $reset=false)
 Load or initialize $authAction, $authRequests and $subPage. More...
 
 messageKey ($defaultKey)
 Return custom message key. More...
 
 needsSubmitButton ($formDescriptor)
 Returns true if the form has fields which take values. More...
 
 performAuthenticationStep ($action, array $requests)
 
 setRequest (array $data, $wasPosted=null)
 Override the POST data, GET data from the real request is preserved. More...
 
 trySubmit ()
 Attempts to do an authentication step with the submitted data. More...
 
- Protected Member Functions inherited from SpecialPage
 addFeedLinks ($params)
 Adds RSS/atom links. More...
 
 afterExecute ($subPage)
 Gets called after. More...
 
 beforeExecute ($subPage)
 Gets called before. More...
 
 checkLoginSecurityLevel ($level=null)
 Verifies that the user meets the security level, possibly reauthenticating them in the process. More...
 
 getCacheTTL ()
 
 getGroupName ()
 Under which header this special page is listed in Special:SpecialPages See messages 'specialpages-group-*' for valid names This method defaults to group 'other'. More...
 
 getLinkRenderer ()
 
 getLoginSecurityLevel ()
 Tells if the special page does something security-sensitive and needs extra defense against a stolen account (e.g. More...
 
 getRobotPolicy ()
 Return the robot policy. More...
 
 getSubpagesForPrefixSearch ()
 Return an array of subpages that this special page will accept for prefix searches. More...
 
 prefixSearchString ($search, $limit, $offset)
 Perform a regular substring search for prefixSearchSubpages. More...
 
 useTransactionalTimeLimit ()
 Call wfTransactionalTimeLimit() if this request was POSTed. More...
 

Protected Attributes

HTMLForm $authForm
 
FakeAuthTemplate $fakeTemplate
 
 $mAction
 
 $mEntryError = ''
 
 $mEntryErrorType = 'error'
 
 $mFromHTTP
 
 $mLanguage
 
 $mLoaded = false
 
 $mLoadedRequest = false
 
 $mPosted
 
 $mReturnTo
 
 $mReturnToQuery
 
 $mSecureLoginUrl
 
 $mStickHTTPS
 
 $mToken
 
bool $proxyAccountCreation
 True if the user if creating an account for someone else. More...
 
string $securityLevel
 
User $targetUser
 FIXME another flag for passing data. More...
 
- Protected Attributes inherited from AuthManagerSpecialPage
string $authAction
 one of the AuthManager::ACTION_* constants. More...
 
AuthenticationRequest[] $authRequests
 
bool $isReturn
 True if the current request is a result of returning from a redirect flow. More...
 
WebRequest null $savedRequest
 If set, will be used instead of the real request. More...
 
string $subPage
 Subpage of the special page. More...
 
- Protected Attributes inherited from SpecialPage
IContextSource $mContext
 Current request context. More...
 
 $mIncludable
 
 $mIncluding
 
 $mName
 
 $mRestriction
 

Private Member Functions

 loadRequestParameters ($subPage)
 Load basic request parameters for this Special page. More...
 
 showCreateAccountLink ()
 Whether the login/create account form should display a link to the other form (in addition to whatever the skin provides). More...
 

Additional Inherited Members

- Static Public Member Functions inherited from SpecialPage
static getSafeTitleFor ($name, $subpage=false)
 Get a localised Title object for a page name with a possibly unvalidated subpage. More...
 
static getTitleFor ($name, $subpage=false, $fragment= '')
 Get a localised Title object for a specified special page name. More...
 
- Static Protected Member Functions inherited from AuthManagerSpecialPage
static getField (array $array, $fieldName, $default=null)
 Get an array value, or a default if it does not exist. More...
 
static mapFieldInfoTypeToFormDescriptorType ($type)
 Maps AuthenticationRequest::getFieldInfo() types to HTMLForm types. More...
 
static mapSingleFieldInfo ($singleFieldInfo, $fieldName)
 Maps an authentication field configuration for a single field (as returned by AuthenticationRequest::getFieldInfo()) to a HTMLForm field descriptor. More...
 
static sortFormDescriptorFields (array &$formDescriptor)
 Sort the fields of a form descriptor by their 'weight' property. More...
 
- Static Protected Member Functions inherited from SpecialPage
static prefixSearchArray ($search, $limit, array $subpages, $offset)
 Helper function for implementations of prefixSearchSubpages() that filter the values in memory (as opposed to making a query). More...
 
- Static Protected Attributes inherited from AuthManagerSpecialPage
static string[] $allowedActions
 The list of actions this special page deals with. More...
 
static array $messages = []
 Customized messages. More...
 

Detailed Description

Holds shared logic for login and account creation pages.

Definition at line 36 of file LoginSignupSpecialPage.php.

Constructor & Destructor Documentation

LoginSignupSpecialPage::__construct (   $name)

Definition at line 84 of file LoginSignupSpecialPage.php.

References $name, $wgUseMediaWikiUIEverywhere, and global.

Member Function Documentation

LoginSignupSpecialPage::beforeExecute (   $subPage)
protected
LoginSignupSpecialPage::getBCFieldDefinitions (   $fieldDefinitions,
  $template 
)
protected

Adds fields provided via the deprecated UserLoginForm / UserCreateForm hooks.

Parameters
$fieldDefinitionsarray
FakeAuthTemplate$template
Returns
array

Definition at line 1102 of file LoginSignupSpecialPage.php.

References $template.

Referenced by getFieldDefinitions().

LoginSignupSpecialPage::getFakeTemplate (   $msg,
  $msgType 
)
protected
LoginSignupSpecialPage::getFieldDefinitions (   $template)
protected
LoginSignupSpecialPage::getGroupName ( )
protected

Definition at line 1233 of file LoginSignupSpecialPage.php.

LoginSignupSpecialPage::getPageHtml (   $formHtml)
protected

Add page elements which are outside the form.

FIXME this should probably be a template, but use a sane language (handlebars?)

Parameters
string$formHtml
Returns
string

Definition at line 508 of file LoginSignupSpecialPage.php.

References $html, $wgLoginLanguageSelector, global, isSignup(), makeLanguageSelector(), SpecialPage\msg(), Html\rawElement(), and showExtraInformation().

Referenced by mainLoginForm().

LoginSignupSpecialPage::getPreservedParams (   $withToken = false)
protected

Definition at line 191 of file LoginSignupSpecialPage.php.

References $params, $wgSecureLogin, global, and isSignup().

Referenced by execute().

LoginSignupSpecialPage::getReturnToQueryStringFragment ( )
protected

Returns a string that can be appended to the URL (without encoding) to preserve the return target.

Does not include leading '?'/'&'.

Definition at line 1147 of file LoginSignupSpecialPage.php.

References wfUrlencode().

Referenced by getAuthForm().

LoginSignupSpecialPage::getTokenName ( )
protected

Definition at line 1173 of file LoginSignupSpecialPage.php.

References isSignup().

Referenced by getAuthForm(), and load().

LoginSignupSpecialPage::hasSessionCookie ( )
protected

Check if a session cookie is present.

This will not pick up a cookie set during this request, but is meant to ensure that the client is returning the cookie which was set on a previous pass through the system.

Returns
bool

Definition at line 1134 of file LoginSignupSpecialPage.php.

References $wgDisableCookieCheck, $wgInitialSessionId, AuthManagerSpecialPage\getRequest(), global, and string.

Referenced by SpecialCreateAccount\successfulAction(), and SpecialUserLogin\successfulAction().

LoginSignupSpecialPage::load (   $subPage)
protected
LoginSignupSpecialPage::loadRequestParameters (   $subPage)
private

Load basic request parameters for this Special page.

Parameters
$subPage

Definition at line 101 of file LoginSignupSpecialPage.php.

References $request, AuthManagerSpecialPage\$subPage, and AuthManagerSpecialPage\getRequest().

Referenced by beforeExecute(), and load().

LoginSignupSpecialPage::logAuthResult (   $success,
  $status = null 
)
abstractprotected

Logs to the authmanager-stats channel.

Parameters
bool$success
string | null$statusError message key

Referenced by execute().

LoginSignupSpecialPage::mainLoginForm ( array  $requests,
  $msg = '',
  $msgtype = 'error' 
)
protected
Parameters
AuthenticationRequest[]$requests A list of AuthorizationRequest objects, used to generate the form fields. An empty array means a fatal error (authentication cannot continue).
string | Message$msg
string$msgtype
Exceptions
ErrorPageError
Exception
FatalError
MWException
PermissionsError
ReadOnlyError
Access:
private

Definition at line 454 of file LoginSignupSpecialPage.php.

References $out, $user, getAuthForm(), AuthManagerSpecialPage\getDefaultAction(), SpecialPage\getOutput(), getPageHtml(), SpecialPage\getPageTitle(), SpecialPage\getUser(), isSignup(), SpecialPage\msg(), and Status\newFatal().

Referenced by execute(), SpecialCreateAccount\successfulAction(), and SpecialUserLogin\successfulAction().

LoginSignupSpecialPage::makeLanguageSelector ( )
protected

Produce a bar of links which allow the user to select another language during login/registration but retain "returnto".

Returns
string

Definition at line 1183 of file LoginSignupSpecialPage.php.

References $lang, as, SpecialPage\getLanguage(), makeLanguageSelectorLink(), and SpecialPage\msg().

Referenced by getPageHtml().

LoginSignupSpecialPage::makeLanguageSelectorLink (   $text,
  $lang 
)
protected

Create a language selector link for a particular language Links back to this page preserving type and returnto.

Parameters
string$textLink text
string$langLanguage code
Returns
string

Definition at line 1210 of file LoginSignupSpecialPage.php.

References $lang, $mReturnTo, $mReturnToQuery, $query, Language\factory(), SpecialPage\getLanguage(), SpecialPage\getPageTitle(), and Linker\linkKnown().

Referenced by makeLanguageSelector().

LoginSignupSpecialPage::onAuthChangeFormFields ( array  $requests,
array  $fieldInfo,
array $formDescriptor,
  $action 
)

Definition at line 836 of file LoginSignupSpecialPage.php.

References as, and getFieldDefinitions().

LoginSignupSpecialPage::postProcessFormDescriptor ( $formDescriptor)
protected
LoginSignupSpecialPage::setRequest ( array  $data,
  $wasPosted = null 
)
protected

Definition at line 92 of file LoginSignupSpecialPage.php.

LoginSignupSpecialPage::setSessionUserForCurrentRequest ( )
protected

Replace some globals to make sure the fact that the user has just been logged in is reflected in the current request.

Parameters
User$user

Definition at line 419 of file LoginSignupSpecialPage.php.

References $code, $context, $user, $wgLang, $wgUser, Language\factory(), SpecialPage\getContext(), RequestContext\getMain(), AuthManagerSpecialPage\getRequest(), global, and SpecialPage\setContext().

Referenced by execute().

LoginSignupSpecialPage::showCreateAccountLink ( )
private

Whether the login/create account form should display a link to the other form (in addition to whatever the skin provides).

Returns
bool

Definition at line 1163 of file LoginSignupSpecialPage.php.

References SpecialPage\getUser(), and isSignup().

Referenced by getAuthForm(), and getFakeTemplate().

LoginSignupSpecialPage::showExtraInformation ( )
protected

Show extra information such as password recovery information, link from login to signup, CTA etc? Such information should only be shown on the "landing page", ie.

when the user is at the first step of the authentication process.

Returns
bool

Definition at line 884 of file LoginSignupSpecialPage.php.

References $securityLevel, and AuthManagerSpecialPage\getContinueAction().

Referenced by getAuthForm(), getFieldDefinitions(), and getPageHtml().

LoginSignupSpecialPage::showReturnToPage (   $type,
  $returnTo = '',
  $returnToQuery = '',
  $stickHTTPS = false 
)

Add a "return to" link or redirect to it.

Extensions can use this to reuse the "return to" logic after inject steps (such as redirection) into the login process.

Parameters
string$typeOne of the following:
  • error: display a return to link ignoring $wgRedirectOnLogin
  • signup: display a return to link using $wgRedirectOnLogin if needed
  • success: display a return to link using $wgRedirectOnLogin if needed
  • successredirect: send an HTTP redirect using $wgRedirectOnLogin if needed
string$returnTo
array | string$returnToQuery
bool$stickHTTPSKeep redirect link on HTTPS
Since
1.22

Definition at line 407 of file LoginSignupSpecialPage.php.

References $returnTo, $returnToQuery, $type, and SpecialPage\getContext().

LoginSignupSpecialPage::showSuccessPage (   $type,
  $title,
  $msgname,
  $injected_html,
  $extraMessages 
)
protected

Show the success page.

Parameters
string$typeCondition of return to; see executeReturnTo
string | Message$titlePage's title
string$msgname
string$injected_html
StatusValue | null$extraMessages

Definition at line 373 of file LoginSignupSpecialPage.php.

References $out, $title, $type, SpecialPage\getContext(), SpecialPage\getName(), SpecialPage\getOutput(), SpecialPage\getUser(), wfEscapeWikiText(), and Status\wrap().

Referenced by SpecialCreateAccount\successfulAction(), and SpecialUserLogin\successfulAction().

LoginSignupSpecialPage::successfulAction (   $direct = false,
  $extraMessages = null 
)
abstractprotected
Parameters
bool$directTrue if the action was successful just now; false if that happened pre-redirection (so this handler was called already)
StatusValue | null$extraMessages
Returns
void

Referenced by execute().

Member Data Documentation

HTMLForm LoginSignupSpecialPage::$authForm
protected

Definition at line 62 of file LoginSignupSpecialPage.php.

Referenced by getAuthForm().

FakeAuthTemplate LoginSignupSpecialPage::$fakeTemplate
protected

Definition at line 65 of file LoginSignupSpecialPage.php.

Referenced by getAuthForm().

LoginSignupSpecialPage::$mAction
protected

Definition at line 39 of file LoginSignupSpecialPage.php.

LoginSignupSpecialPage::$mEntryError = ''
protected

Definition at line 45 of file LoginSignupSpecialPage.php.

LoginSignupSpecialPage::$mEntryErrorType = 'error'
protected

Definition at line 46 of file LoginSignupSpecialPage.php.

LoginSignupSpecialPage::$mFromHTTP
protected

Definition at line 44 of file LoginSignupSpecialPage.php.

LoginSignupSpecialPage::$mLanguage
protected

Definition at line 40 of file LoginSignupSpecialPage.php.

Referenced by getAuthForm(), and getFakeTemplate().

LoginSignupSpecialPage::$mLoaded = false
protected

Definition at line 48 of file LoginSignupSpecialPage.php.

LoginSignupSpecialPage::$mLoadedRequest = false
protected

Definition at line 49 of file LoginSignupSpecialPage.php.

LoginSignupSpecialPage::$mPosted
protected

Definition at line 38 of file LoginSignupSpecialPage.php.

LoginSignupSpecialPage::$mReturnTo
protected

Definition at line 37 of file LoginSignupSpecialPage.php.

Referenced by makeLanguageSelectorLink().

LoginSignupSpecialPage::$mReturnToQuery
protected

Definition at line 41 of file LoginSignupSpecialPage.php.

Referenced by makeLanguageSelectorLink().

LoginSignupSpecialPage::$mSecureLoginUrl
protected

Definition at line 50 of file LoginSignupSpecialPage.php.

LoginSignupSpecialPage::$mStickHTTPS
protected

Definition at line 43 of file LoginSignupSpecialPage.php.

LoginSignupSpecialPage::$mToken
protected

Definition at line 42 of file LoginSignupSpecialPage.php.

bool LoginSignupSpecialPage::$proxyAccountCreation
protected

True if the user if creating an account for someone else.

Flag used for internal communication, only set at the very end.

Definition at line 57 of file LoginSignupSpecialPage.php.

string LoginSignupSpecialPage::$securityLevel
protected

Definition at line 53 of file LoginSignupSpecialPage.php.

Referenced by load(), and showExtraInformation().

User LoginSignupSpecialPage::$targetUser
protected

FIXME another flag for passing data.

Definition at line 59 of file LoginSignupSpecialPage.php.


The documentation for this class was generated from the following file: