MediaWiki 1.39.10
SpecialPage Class Reference

Parent class for all special pages. More...

Inheritance diagram for SpecialPage:
Collaboration diagram for SpecialPage:

Public Member Functions

 __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.
 
 addHelpLink ( $to, $overrideBaseUrl=false)
 Adds help link with an icon via page indicators.
 
 checkPermissions ()
 Checks if userCanExecute, and if not throws a PermissionsError.
 
 checkReadOnly ()
 If the wiki is currently in readonly mode, throws a ReadOnlyError.
 
 doesWrites ()
 Indicates whether this special page may perform database writes.
 
 execute ( $subPage)
 Default execute method Checks user permissions.
 
 getAssociatedNavigationLinks ()
 Return an array of strings representing page titles that are discoverable to end users via UI.
 
 getAuthority ()
 Shortcut to get the Authority executing this instance.
 
 getConfig ()
 Shortcut to get main config object.
 
 getContentLanguage ()
 Shortcut to get content language.
 
 getContext ()
 Gets the context this SpecialPage is executed in.
 
 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.
 
 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.
 
 getFullTitle ()
 Return the full title, including $par.
 
 getLanguage ()
 Shortcut to get user's language.
 
 getLinkRenderer ()
 
 getLocalName ()
 Get the localised name of the special page.
 
 getName ()
 Get the name of this Special Page.
 
 getOutput ()
 Get the OutputPage being used for this instance.
 
 getPageTitle ( $subpage=false)
 Get a self-referential title object.
 
 getRequest ()
 Get the WebRequest being used for this instance.
 
 getRestriction ()
 Get the permission that a user must have to execute this page.
 
 getShortDescription (string $path='')
 Similar to getDescription but takes into account sub pages and designed for display in tabs.
 
 getSkin ()
 Shortcut to get the skin being used for this instance.
 
 getUser ()
 Shortcut to get the User executing this instance.
 
 including ( $x=null)
 Whether the special page is being evaluated via transclusion.
 
 isCached ()
 Is this page cached? Expensive pages are cached or disabled in miser mode.
 
 isExpensive ()
 Is this page expensive (for some definition of expensive)? Expensive pages are disabled or cached in miser mode.
 
 isIncludable ()
 Whether it's allowed to transclude the special page via {{Special:Foo/params}}.
 
 isListed ()
 Whether this special page is listed in Special:SpecialPages.
 
 isRestricted ()
 Can be overridden by subclasses with more complicated permissions schemes.
 
 listed ( $x=null)
 Get or set whether this special page is listed in Special:SpecialPages.
 
 maxIncludeCacheTime ()
 How long to cache page when it is being included.
 
 msg ( $key,... $params)
 Wrapper around wfMessage that sets the current context.
 
 prefixSearchSubpages ( $search, $limit, $offset)
 Return an array of subpages beginning with $search that this special page will accept.
 
 requireLogin ( $reasonMsg='exception-nologin-text', $titleMsg='exception-nologin')
 If the user is not logged in, throws UserNotLoggedIn error.
 
 requireNamedUser ( $reasonMsg='exception-nologin-text', $titleMsg='exception-nologin')
 If the user is not logged in or is a temporary user, throws UserNotLoggedIn.
 
 run ( $subPage)
 Entry point.
 
 setContentLanguage (Language $contentLanguage)
 Set content language.
 
 setContext ( $context)
 Sets the context this SpecialPage is executed in.
 
 setHookContainer (HookContainer $hookContainer)
 
 setLinkRenderer (LinkRenderer $linkRenderer)
 
 setListed ( $listed)
 Set whether this page is listed in Special:Specialpages, at run-time.
 
 setSpecialPageFactory (SpecialPageFactory $specialPageFactory)
 
 userCanExecute (User $user)
 Checks if the given user (identified by an object) can execute this special page (as defined by $mRestriction).
 

Static Public Member Functions

static getSafeTitleFor ( $name, $subpage=false)
 Get a localised Title object for a page name with a possibly unvalidated subpage.
 
static getTitleFor ( $name, $subpage=false, $fragment='')
 Get a localised Title object for a specified special page name If you don't need a full Title object, consider using TitleValue through getTitleValueFor() below.
 
static getTitleValueFor ( $name, $subpage=false, $fragment='')
 Get a localised TitleValue object for a specified special page name.
 
static newSearchPage (User $user)
 Get the users preferred search page.
 

Protected Member Functions

 addFeedLinks ( $params)
 Adds RSS/atom links.
 
 afterExecute ( $subPage)
 Gets called after.
 
 beforeExecute ( $subPage)
 Gets called before.
 
 buildPrevNextNavigation ( $offset, $limit, array $query=[], $atend=false, $subpage=false)
 Generate (prev x| next x) (20|50|100...) type links for paging.
 
 checkLoginSecurityLevel ( $level=null)
 Verifies that the user meets the security level, possibly reauthenticating them in the process.
 
 displayRestrictionError ()
 Output an error message telling the user what access level they have to have.
 
 getAuthManager ()
 
 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'.
 
 getHookContainer ()
 
 getHookRunner ()
 
 getLanguageConverter ()
 Shortcut to get language's converter.
 
 getLoginSecurityLevel ()
 Tells if the special page does something security-sensitive and needs extra defense against a stolen account (e.g.
 
 getRobotPolicy ()
 Return the robot policy.
 
 getSpecialPageFactory ()
 
 getSubpagesForPrefixSearch ()
 Return an array of subpages that this special page will accept for prefix searches.
 
 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.
 
 prefixSearchString ( $search, $limit, $offset, SearchEngineFactory $searchEngineFactory=null)
 Perform a regular substring search for prefixSearchSubpages.
 
 setAuthManager (AuthManager $authManager)
 Set the injected AuthManager from the special page constructor.
 
 setHeaders ()
 Sets headers - this should be called from the execute() method of all derived classes!
 
 setReauthPostData (array $data)
 Record preserved POST data after a reauthentication.
 
 useTransactionalTimeLimit ()
 Call wfTransactionalTimeLimit() if this request was POSTed.
 

Static Protected Member Functions

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).
 

Protected Attributes

IContextSource $mContext
 Current request context.
 
bool $mIncludable
 Whether the special page can be included in an article.
 
bool $mIncluding
 Whether or not this special page is being included from an article.
 
string $mName
 The canonical name of this special page Also used for the default.
 
string $mRestriction
 Minimum user level required to access this page, or "" for anyone.
 

Detailed Description

Parent class for all special pages.

Includes some static functions for handling the special page list deprecated in favor of SpecialPageFactory.

Stability: stable
to extend

Definition at line 44 of file SpecialPage.php.

Constructor & Destructor Documentation

◆ __construct()

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.

If you override execute(), you can recover the default behavior with userCanExecute() and displayRestrictionError()

Stability: stable
to call
Parameters
string$nameName of the special page, as seen in links and URLs
string$restrictionUser right required, e.g. "block" or "delete"
bool$listedWhether the page is listed in Special:Specialpages
callable | bool$functionUnused
string$fileUnused
bool$includableWhether the page can be included in normal pages

Definition at line 190 of file SpecialPage.php.

Member Function Documentation

◆ addFeedLinks()

SpecialPage::addFeedLinks ( $params)
protected

Adds RSS/atom links.

Parameters
array$params

Definition at line 1002 of file SpecialPage.php.

References wfAppendQuery(), and wfScript().

Referenced by SpecialContributions\execute(), and SpecialWatchlist\outputFeedLinks().

◆ addHelpLink()

SpecialPage::addHelpLink ( $to,
$overrideBaseUrl = false )

Adds help link with an icon via page indicators.

Link target can be overridden by a local message containing a wikilink: the message key is: lowercase special page name + '-helppage'.

Parameters
string$toTarget MediaWiki.org page title or encoded URL.
bool$overrideBaseUrlWhether $url is a full URL, to avoid MW.o.
Since
1.25

Definition at line 1020 of file SpecialPage.php.

References $title.

Referenced by SpecialBlock\alterForm(), SpecialChangeContentModel\alterForm(), SpecialAllMessages\execute(), SpecialApiSandbox\execute(), SpecialAutoblockList\execute(), SpecialBlockList\execute(), SpecialBotPasswords\execute(), SpecialBrokenRedirects\execute(), SpecialCategories\execute(), SpecialComparePages\execute(), SpecialContributions\execute(), SpecialDeletedContributions\execute(), SpecialDoubleRedirects\execute(), SpecialExport\execute(), SpecialLinkSearch\execute(), SpecialListDuplicatedFiles\execute(), SpecialListFiles\execute(), SpecialListGroupRights\execute(), SpecialListRedirects\execute(), SpecialLog\execute(), SpecialMIMESearch\execute(), SpecialMute\execute(), SpecialNewFiles\execute(), SpecialNewpages\execute(), SpecialPasswordPolicies\execute(), SpecialPreferences\execute(), SpecialProtectedpages\execute(), SpecialProtectedtitles\execute(), SpecialSpecialpages\execute(), SpecialTags\execute(), SpecialTrackingCategories\execute(), SpecialUnblock\execute(), SpecialUncategorizedImages\execute(), SpecialUncategorizedPages\execute(), SpecialUndelete\execute(), SpecialUnwatchedPages\execute(), SpecialUpload\execute(), UserrightsPage\execute(), SpecialWhatLinksHere\execute(), SpecialExpandTemplates\execute(), SpecialRecentChanges\execute(), SpecialWatchlist\execute(), SpecialRecentChangesLinked\getExtraOptions(), SpecialRandomInCategory\getFormFields(), SpecialSearch\setupPage(), MovePageForm\showForm(), SpecialEditTags\showForm(), SpecialRevisionDelete\showForm(), SpecialDiff\showNoRedirectPage(), SpecialNewSection\showNoRedirectPage(), and SpecialPermanentLink\showNoRedirectPage().

◆ afterExecute()

SpecialPage::afterExecute ( $subPage)
protected

Gets called after.

See also
SpecialPage::execute.
Stability: stable
to override
Since
1.20
Parameters
string | null$subPage

Definition at line 729 of file SpecialPage.php.

◆ beforeExecute()

SpecialPage::beforeExecute ( $subPage)
protected

Gets called before.

See also
SpecialPage::execute. Return false to prevent calling execute() (since 1.27+).
Stability: stable
to override
Since
1.20
Parameters
string | null$subPage
Returns
bool|void

Reimplemented in AuthManagerSpecialPage, LoginSignupSpecialPage, and SpecialUserLogin.

Definition at line 717 of file SpecialPage.php.

◆ buildPrevNextNavigation()

SpecialPage::buildPrevNextNavigation ( $offset,
$limit,
array $query = [],
$atend = false,
$subpage = false )
protected

Generate (prev x| next x) (20|50|100...) type links for paging.

Parameters
int$offset
int$limit
array$queryOptional URL query parameter string
bool$atendOptional param for specified if this is the last page
string | false$subpageOptional param for specifying subpage
Returns
string

Definition at line 1127 of file SpecialPage.php.

References $title.

◆ checkLoginSecurityLevel()

SpecialPage::checkLoginSecurityLevel ( $level = null)
protected

Verifies that the user meets the security level, possibly reauthenticating them in the process.

This should be used when the page does something security-sensitive and needs extra defense against a stolen account (e.g. a reauthentication). The authentication framework will make an extra effort to make sure the user account is not compromised. What that exactly means will depend on the system and user settings; e.g. the user might be required to log in again unless their last login happened recently, or they might be given a second-factor challenge.

Calling this method will result in one if these actions:

  • return true: all good.
  • return false and set a redirect: caller should abort; the redirect will take the user to the login page for reauthentication, and back.
  • throw an exception if there is no way for the user to meet the requirements without using a different access method (e.g. this functionality is only available from a specific IP).

Note that this does not in any way check that the user is authorized to use this special page (use checkPermissions() for that).

Parameters
string | null$levelA security level. Can be an arbitrary string, defaults to the page name.
Returns
bool False means a redirect to the reauthentication page has been set and processing of the special page should be aborted.
Exceptions
ErrorPageErrorIf the security level cannot be met, even with reauthentication.

Definition at line 496 of file SpecialPage.php.

References $title, getAuthManager(), getFullTitle(), getName(), getOutput(), getRequest(), getTitleFor(), PROTO_HTTPS, setReauthPostData(), wfArrayToCgi(), and wfMessage().

Referenced by FormSpecialPage\execute().

◆ checkPermissions()

◆ checkReadOnly()

◆ displayRestrictionError()

SpecialPage::displayRestrictionError ( )
protected

Output an error message telling the user what access level they have to have.

Stability: stable
to override
Exceptions
PermissionsError
Returns
never

Definition at line 371 of file SpecialPage.php.

Referenced by checkPermissions(), and SpecialUndelete\checkPermissions().

◆ doesWrites()

◆ execute()

SpecialPage::execute ( $subPage)

Default execute method Checks user permissions.

This must be overridden by subclasses; it will be made abstract in a future version

Stability: stable
to override
Parameters
string | null$subPage

Reimplemented in SpecialConfirmEmail, SpecialEmailInvalidate, SpecialBookSources, SpecialEditWatchlist, FormSpecialPage, QueryPage, SpecialActiveUsers, SpecialAllMessages, SpecialAllPages, SpecialApiHelp, SpecialApiSandbox, SpecialAutoblockList, SpecialBlankpage, SpecialBlockList, SpecialBotPasswords, SpecialBrokenRedirects, SpecialCategories, SpecialChangeEmail, SpecialComparePages, SpecialContributions, SpecialDeletedContributions, SpecialDoubleRedirects, SpecialEditTags, SpecialEmailUser, SpecialExport, SpecialFileDuplicateSearch, SpecialGoToInterwiki, SpecialImport, SpecialJavaScriptTest, SpecialLinkSearch, SpecialListDuplicatedFiles, SpecialListFiles, SpecialListGrants, SpecialListGroupRights, SpecialListRedirects, SpecialListUsers, SpecialLog, SpecialMergeHistory, SpecialMIMESearch, MovePageForm, SpecialMute, SpecialNewFiles, SpecialNewpages, SpecialPagesWithProp, SpecialPasswordPolicies, SpecialPasswordReset, SpecialPreferences, SpecialPrefixindex, SpecialProtectedpages, SpecialProtectedtitles, SpecialRandomPage, SpecialResetTokens, SpecialRevisionDelete, SpecialRunJobs, SpecialSearch, SpecialSpecialpages, SpecialStatistics, SpecialTags, SpecialTrackingCategories, SpecialUnblock, SpecialUncategorizedImages, SpecialUncategorizedPages, SpecialUndelete, SpecialUnwatchedPages, SpecialUpload, SpecialUserLogout, UserrightsPage, SpecialVersion, WantedPagesPage, SpecialWhatLinksHere, SpecialWithoutInterwiki, ChangesListSpecialPage, DisabledSpecialPage, LoginSignupSpecialPage, RedirectSpecialPage, SpecialChangeCredentials, SpecialExpandTemplates, SpecialLinkAccounts, SpecialPageData, SpecialRecentChanges, SpecialUnlinkAccounts, SpecialUploadStash, and SpecialWatchlist.

Definition at line 743 of file SpecialPage.php.

◆ getAssociatedNavigationLinks()

SpecialPage::getAssociatedNavigationLinks ( )

Return an array of strings representing page titles that are discoverable to end users via UI.

Since
1.39
Stability: stable
to call or override
Returns
string[] strings representing page titles that can be rendered by skins if required.

Definition at line 618 of file SpecialPage.php.

◆ getAuthManager()

◆ getAuthority()

◆ getCacheTTL()

SpecialPage::getCacheTTL ( )
protected
Stability: stable
to override
Returns
int Seconds that this page can be cached

Reimplemented in SpecialNewpages, and SpecialRecentChanges.

Definition at line 282 of file SpecialPage.php.

Referenced by maxIncludeCacheTime().

◆ getConfig()

SpecialPage::getConfig ( )

Shortcut to get main config object.

Returns
Config
Since
1.24

Definition at line 950 of file SpecialPage.php.

References getContext().

Referenced by SpecialRecentChanges\__construct(), SpecialPasswordReset\alterForm(), SpecialBotPasswords\checkExecutePermissions(), SpecialLockdb\checkExecutePermissions(), SpecialUnlockdb\checkExecutePermissions(), SpecialWatchlist\doMainQuery(), SpecialRecentChangesLinked\doMainQuery(), SpecialAllMessages\execute(), SpecialAllPages\execute(), SpecialContributions\execute(), SpecialDeletedContributions\execute(), SpecialEmailUser\execute(), SpecialExport\execute(), SpecialImport\execute(), SpecialLinkSearch\execute(), SpecialListGrants\execute(), SpecialListGroupRights\execute(), SpecialLog\execute(), SpecialPasswordPolicies\execute(), SpecialRunJobs\execute(), SpecialSearch\execute(), SpecialWhatLinksHere\execute(), ChangesListSpecialPage\execute(), LoginSignupSpecialPage\execute(), SpecialWatchlist\execute(), UserrightsPage\fetchUser(), ChangesListSpecialPage\filterOnUserExperienceLevel(), SpecialBlock\getFormFields(), SpecialPageLanguage\getFormFields(), SpecialPasswordReset\getFormFields(), SpecialActiveUsers\getIntroText(), SpecialProtectedpages\getLevelMenu(), ChangesListSpecialPage\getLinkDays(), SpecialUnusedImages\getPageHeader(), LoginSignupSpecialPage\getPageHtml(), SpecialExport\getPagesFromCategory(), SpecialExport\getPagesFromNamespace(), LoginSignupSpecialPage\getPreservedParams(), SpecialLinkSearch\getQueryInfo(), SpecialShortPages\getQueryInfo(), SpecialUnusedImages\getQueryInfo(), WantedPagesPage\getQueryInfo(), SpecialChangeCredentials\getRequestBlacklist(), SpecialLinkAccounts\getRequestBlacklist(), SpecialRemoveCredentials\getRequestBlacklist(), SpecialUnlinkAccounts\getRequestBlacklist(), SpecialResetTokens\getTokensList(), SpecialSearch\goResult(), ChangesListSpecialPage\includeRcFiltersApp(), SpecialBotPasswords\isListed(), SpecialLinkSearch\linkParameters(), LoginSignupSpecialPage\load(), maxIncludeCacheTime(), SpecialBlock\maybeAlterFormDefaults(), SpecialLockdb\onSubmit(), SpecialUnlockdb\onSubmit(), SpecialPasswordReset\onSuccess(), SpecialWatchlist\outputChangesList(), SpecialAllPages\outputHTMLForm(), SpecialBlock\preHtml(), SpecialUpload\processUpload(), SpecialUpload\processVerificationError(), ChangesListSpecialPage\registerFilters(), SpecialWatchlist\setTopText(), MovePageForm\showForm(), SpecialSearch\showResults(), SpecialUserLogin\successfulAction(), SpecialExport\validateLinkDepth(), and ChangesListSpecialPage\validateOptions().

◆ getContentLanguage()

◆ getContext()

SpecialPage::getContext ( )

Gets the context this SpecialPage is executed in.

Returns
IContextSource|RequestContext
Since
1.18

Definition at line 836 of file SpecialPage.php.

References wfDebug().

Referenced by MergeHistoryPager\__construct(), NewPagesPager\__construct(), ProtectedTitlesPager\__construct(), SpecialActiveUsers\buildForm(), UserrightsPage\changeableGroups(), SpecialActiveUsers\execute(), SpecialAllMessages\execute(), SpecialApiHelp\execute(), SpecialAutoblockList\execute(), SpecialBlockList\execute(), SpecialCategories\execute(), SpecialComparePages\execute(), SpecialDeletedContributions\execute(), SpecialExport\execute(), SpecialFileDuplicateSearch\execute(), SpecialLinkSearch\execute(), SpecialListFiles\execute(), SpecialListUsers\execute(), SpecialNewFiles\execute(), SpecialPagesWithProp\execute(), SpecialPreferences\execute(), SpecialProtectedpages\execute(), SpecialStatistics\execute(), SpecialUnblock\execute(), SpecialExpandTemplates\execute(), SpecialFewestRevisions\formatResult(), SpecialMostCategories\formatResult(), SpecialMostInterwikis\formatResult(), SpecialMostLinked\formatResult(), SpecialMostLinkedCategories\formatResult(), SpecialMostLinkedTemplates\formatResult(), SpecialShortPages\formatResult(), SpecialUnwatchedPages\formatResult(), SpecialProtectedtitles\formatRow(), AuthManagerSpecialPage\getAuthForm(), SpecialAutoblockList\getBlockListPager(), SpecialBlockList\getBlockListPager(), FormSpecialPage\getForm(), SpecialEditTags\getList(), SpecialRevisionDelete\getList(), SpecialMIMESearch\getPageHeader(), SpecialWithoutInterwiki\getPageHeader(), AuthManagerSpecialPage\getRequest(), ChangesListBooleanFilter\modifyQuery(), ChangesListStringOptionsFilterGroup\modifyQuery(), SpecialPrefixindex\namespacePrefixForm(), SpecialChangeContentModel\onSubmit(), SpecialPageLanguage\onSubmit(), SpecialWatchlist\outputChangesList(), SpecialAllPages\outputHTMLForm(), ImageQueryPage\outputResults(), SpecialEmailUser\sendEmailForm(), AuthManagerSpecialPage\setRequest(), LoginSignupSpecialPage\setSessionUserForCurrentRequest(), SpecialTags\showActivateDeactivateForm(), SpecialTags\showDeleteTagForm(), UserrightsPage\showEditUserGroupsForm(), SpecialProtectedpages\showOptions(), SpecialPreferences\showResetForm(), LoginSignupSpecialPage\showReturnToPage(), LoginSignupSpecialPage\showSuccessPage(), SpecialPreferences\submitReset(), SpecialUserLogin\successfulAction(), and SpecialEmailUser\userForm().

◆ getDescription()

SpecialPage::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.

Derived classes can override this, but usually it is easier to keep the default behavior.

Stability: stable
to override
Returns
string

Reimplemented in SpecialCreateAccount, SpecialDiff, SpecialEditTags, SpecialEmailUser, SpecialMute, and SpecialUserLogin.

Definition at line 786 of file SpecialPage.php.

◆ getFinalGroupName()

SpecialPage::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.

Returns
string Group of this special page
Since
1.21

Definition at line 1045 of file SpecialPage.php.

◆ getFullTitle()

SpecialPage::getFullTitle ( )

Return the full title, including $par.

Returns
Title
Since
1.18

Definition at line 960 of file SpecialPage.php.

References getContext().

Referenced by checkLoginSecurityLevel(), LoginSignupSpecialPage\execute(), AuthManagerSpecialPage\getAuthForm(), and AuthManagerSpecialPage\handleReauthBeforeExecute().

◆ getGroupName()

SpecialPage::getGroupName ( )
protected

Under which header this special page is listed in Special:SpecialPages See messages 'specialpages-group-*' for valid names This method defaults to group 'other'.

Stability: stable
to override
Returns
string
Since
1.21

Reimplemented in ChangesListSpecialPage, LoginSignupSpecialPage, SpecialRedirectWithAction, SpecialActiveUsers, SpecialAllMessages, SpecialAllPages, SpecialAncientPages, SpecialApiSandbox, SpecialAutoblockList, SpecialBlock, SpecialBlockList, SpecialBookSources, SpecialBotPasswords, SpecialBrokenRedirects, SpecialCategories, SpecialChangeContentModel, SpecialChangeCredentials, SpecialChangeEmail, SpecialComparePages, SpecialContributions, SpecialCreateAccount, SpecialDeadendPages, SpecialDeletedContributions, SpecialDiff, SpecialDoubleRedirects, SpecialEditTags, SpecialEmailUser, SpecialExpandTemplates, SpecialExport, SpecialFewestRevisions, SpecialFileDuplicateSearch, SpecialFilepath, SpecialGoToInterwiki, SpecialImport, SpecialJavaScriptTest, SpecialLinkAccounts, SpecialLinkSearch, SpecialListDuplicatedFiles, SpecialListFiles, SpecialListGrants, SpecialListGroupRights, SpecialListRedirects, SpecialListUsers, SpecialLockdb, SpecialLog, SpecialLonelyPages, SpecialLongPages, SpecialMediaStatistics, SpecialMergeHistory, SpecialMIMESearch, SpecialMostCategories, MostimagesPage, SpecialMostInterwikis, SpecialMostLinked, SpecialMostLinkedCategories, SpecialMostLinkedTemplates, SpecialMostRevisions, MovePageForm, SpecialNewFiles, SpecialNewpages, SpecialNewSection, SpecialPageLanguage, SpecialPagesWithProp, SpecialPasswordPolicies, SpecialPasswordReset, SpecialPermanentLink, SpecialPreferences, SpecialPrefixindex, SpecialProtectedpages, SpecialProtectedtitles, SpecialRandomInCategory, SpecialRandomPage, SpecialRedirect, SpecialResetTokens, SpecialRevisionDelete, SpecialSearch, SpecialShortPages, SpecialStatistics, SpecialTags, SpecialTrackingCategories, SpecialUnblock, SpecialUncategorizedImages, SpecialUncategorizedPages, SpecialUndelete, SpecialUnlinkAccounts, SpecialUnlockdb, SpecialUnusedCategories, SpecialUnusedImages, SpecialUnusedTemplates, SpecialUnwatchedPages, SpecialUpload, SpecialUserLogin, SpecialUserLogout, UserrightsPage, SpecialVersion, SpecialWantedCategories, WantedFilesPage, WantedPagesPage, SpecialWantedTemplates, SpecialWhatLinksHere, and SpecialWithoutInterwiki.

Definition at line 1082 of file SpecialPage.php.

◆ getHookContainer()

SpecialPage::getHookContainer ( )
protected

◆ getHookRunner()

SpecialPage::getHookRunner ( )
protected
Access: internal
This is for use by core only. Hook interfaces may be removed without notice.
Since
1.35
Returns
HookRunner

Definition at line 1167 of file SpecialPage.php.

Referenced by RedirectSpecialArticle\__construct(), ChangesListSpecialPage\__construct(), SpecialPageLanguage\alterForm(), UserrightsPage\doSaveUserGroups(), SpecialContributions\execute(), SpecialImport\execute(), SpecialLog\execute(), SpecialSearch\execute(), SpecialStatistics\execute(), SpecialTrackingCategories\execute(), SpecialUpload\execute(), AuthManagerSpecialPage\fieldInfoToFormDescriptor(), FormSpecialPage\getForm(), SpecialBlock\getFormFields(), SpecialRandomPage\getQueryInfo(), SpecialAncientPages\getQueryInfo(), SpecialLonelyPages\getQueryInfo(), SpecialShortPages\getQueryInfo(), WantedPagesPage\getQueryInfo(), SpecialRandomPage\getRandomTitle(), SpecialSearch\getSearchProfiles(), SpecialResetTokens\getTokensList(), SpecialSearch\goResult(), SpecialMute\onSubmit(), SpecialUserLogout\onSuccess(), AuthManagerSpecialPage\performAuthenticationStep(), SpecialBlock\preHtml(), SpecialUpload\processUpload(), ChangesListSpecialPage\registerFilters(), SpecialWatchlist\registerFilters(), ChangesListSpecialPage\runMainQueryHook(), SpecialEmailUser\sendEmailForm(), SpecialNewpages\setup(), SpecialSearch\showCreateLink(), SpecialUndelete\showHistory(), SpecialAutoblockList\showList(), SpecialBlockList\showList(), SpecialSearch\showResults(), SpecialCreateAccount\successfulAction(), SpecialUserLogin\successfulAction(), and AuthManagerSpecialPage\trySubmit().

◆ getLanguage()

SpecialPage::getLanguage ( )

Shortcut to get user's language.

Returns
Language
Since
1.19

Definition at line 902 of file SpecialPage.php.

References getContext().

Referenced by SpecialEditTags\buildCheckBoxes(), SpecialActiveUsers\buildForm(), FormSpecialPage\checkExecutePermissions(), SpecialWatchlist\doHeader(), SpecialAllMessages\execute(), SpecialAllPages\execute(), SpecialFileDuplicateSearch\execute(), SpecialLinkSearch\execute(), SpecialListGrants\execute(), SpecialListGroupRights\execute(), SpecialPasswordPolicies\execute(), SpecialTrackingCategories\execute(), UserrightsPage\execute(), SpecialNewpages\filterLinks(), WantedQueryPage\formatResult(), SpecialAncientPages\formatResult(), SpecialBrokenRedirects\formatResult(), SpecialDoubleRedirects\formatResult(), SpecialFewestRevisions\formatResult(), SpecialListRedirects\formatResult(), SpecialMIMESearch\formatResult(), SpecialMostCategories\formatResult(), SpecialMostInterwikis\formatResult(), SpecialMostLinked\formatResult(), SpecialMostLinkedCategories\formatResult(), SpecialMostLinkedTemplates\formatResult(), SpecialShortPages\formatResult(), SpecialUnusedTemplates\formatResult(), SpecialUnwatchedPages\formatResult(), SpecialWantedCategories\formatResult(), SpecialUndelete\formatRevisionRow(), SpecialProtectedtitles\formatRow(), SpecialBotPasswords\getFormFields(), SpecialPageLanguage\getFormFields(), SpecialEditWatchlist\outputSubtitle(), SpecialNewpages\parseParams(), SpecialBlock\postHtml(), SpecialUpload\processVerificationError(), SpecialEditTags\showConvenienceLinks(), SpecialRevisionDelete\showConvenienceLinks(), UserrightsPage\showEditUserGroupsForm(), MovePageForm\showForm(), SpecialEditTags\showForm(), SpecialRevisionDelete\showForm(), and SpecialRevisionDelete\tryShowFile().

◆ getLanguageConverter()

SpecialPage::getLanguageConverter ( )
protected

Shortcut to get language's converter.

Deprecated
since 1.36 Inject LanguageConverterFactory and store a ILanguageConverter instance
Returns
ILanguageConverter
Since
1.35

Reimplemented in PageQueryPage.

Definition at line 939 of file SpecialPage.php.

◆ getLinkRenderer()

SpecialPage::getLinkRenderer ( )
Since
1.28
Returns
LinkRenderer

Definition at line 1100 of file SpecialPage.php.

Referenced by SpecialWatchlist\doHeader(), SpecialAllMessages\execute(), SpecialCategories\execute(), SpecialDeletedContributions\execute(), SpecialListFiles\execute(), SpecialListGroupRights\execute(), SpecialNewFiles\execute(), SpecialPasswordPolicies\execute(), SpecialProtectedpages\execute(), SpecialTrackingCategories\execute(), SpecialNewpages\filterLinks(), WantedQueryPage\formatResult(), SpecialAncientPages\formatResult(), SpecialBrokenRedirects\formatResult(), SpecialDoubleRedirects\formatResult(), SpecialFewestRevisions\formatResult(), SpecialLinkSearch\formatResult(), SpecialListRedirects\formatResult(), SpecialMIMESearch\formatResult(), SpecialMostCategories\formatResult(), SpecialMostInterwikis\formatResult(), SpecialMostLinked\formatResult(), SpecialMostLinkedCategories\formatResult(), SpecialMostLinkedTemplates\formatResult(), SpecialPagesWithProp\formatResult(), SpecialShortPages\formatResult(), SpecialUncategorizedCategories\formatResult(), SpecialUnusedCategories\formatResult(), SpecialUnusedTemplates\formatResult(), SpecialUnwatchedPages\formatResult(), SpecialWantedCategories\formatResult(), SpecialMergeHistory\formatRevisionRow(), SpecialUndelete\formatRevisionRow(), SpecialProtectedtitles\formatRow(), SpecialAutoblockList\getBlockListPager(), SpecialBlockList\getBlockListPager(), SpecialBotPasswords\getFormFields(), SpecialEmailUser\getFormFields(), SpecialUpload\getUploadForm(), LoginSignupSpecialPage\load(), WantedQueryPage\makeWlhLink(), SpecialWatchlist\outputChangesList(), SpecialEditWatchlist\outputSubtitle(), SpecialMediaStatistics\outputTableRow(), SpecialBlock\postHtml(), SpecialEditTags\showConvenienceLinks(), SpecialRevisionDelete\showConvenienceLinks(), SpecialRevisionDelete\showForm(), SpecialPrefixindex\showPrefixChunk(), SpecialSearch\showResults(), SpecialChangeCredentials\showSubpageList(), SpecialUpload\showUploadWarning(), and SpecialUpload\showViewDeletedLinks().

◆ getLocalName()

SpecialPage::getLocalName ( )

Get the localised name of the special page.

Stability: stable
to override
Returns
string

Definition at line 300 of file SpecialPage.php.

References getSpecialPageFactory().

◆ getLoginSecurityLevel()

SpecialPage::getLoginSecurityLevel ( )
protected

Tells if the special page does something security-sensitive and needs extra defense against a stolen account (e.g.

a reauthentication). What exactly that will mean is decided by the authentication framework.

Stability: stable
to override
Returns
bool|string False or the argument for AuthManager::securitySensitiveOperationStatus(). Typically a special page needing elevated security would return its name here.

Reimplemented in AuthManagerSpecialPage, SpecialBotPasswords, SpecialChangeEmail, SpecialCreateAccount, SpecialUnlinkAccounts, and SpecialUserLogin.

Definition at line 447 of file SpecialPage.php.

Referenced by FormSpecialPage\execute().

◆ getName()

◆ getOutput()

SpecialPage::getOutput ( )

Get the OutputPage being used for this instance.

Returns
OutputPage
Since
1.18

Definition at line 862 of file SpecialPage.php.

References getContext().

Referenced by MediaWiki\Search\SearchWidgets\InterwikiSearchResultSetWidget\__construct(), SpecialLog\addHeader(), ChangesListSpecialPage\addModules(), SpecialRevisionDelete\addUsageText(), SpecialChangeContentModel\alterForm(), SpecialPageLanguage\alterForm(), AuthManagerSpecialPage\beforeExecute(), SpecialUserLogin\beforeExecute(), checkLoginSecurityLevel(), ChangesListSpecialPage\considerActionsForDefaultSavedQuery(), SpecialWatchlist\doHeader(), SpecialRecentChangesLinked\doMainQuery(), SpecialConfirmEmail\execute(), SpecialBookSources\execute(), SpecialEditWatchlist\execute(), SpecialActiveUsers\execute(), SpecialAllMessages\execute(), SpecialAllPages\execute(), SpecialApiHelp\execute(), SpecialApiSandbox\execute(), SpecialAutoblockList\execute(), SpecialBlankpage\execute(), SpecialBlockList\execute(), SpecialBotPasswords\execute(), SpecialCategories\execute(), SpecialChangeEmail\execute(), SpecialComparePages\execute(), SpecialContributions\execute(), SpecialDeletedContributions\execute(), SpecialEditTags\execute(), SpecialEmailUser\execute(), SpecialExport\execute(), SpecialFileDuplicateSearch\execute(), SpecialGoToInterwiki\execute(), SpecialImport\execute(), SpecialJavaScriptTest\execute(), SpecialLinkSearch\execute(), SpecialListFiles\execute(), SpecialListGrants\execute(), SpecialListGroupRights\execute(), SpecialListUsers\execute(), SpecialLog\execute(), SpecialMergeHistory\execute(), MovePageForm\execute(), SpecialMute\execute(), SpecialNewFiles\execute(), SpecialNewpages\execute(), SpecialPagesWithProp\execute(), SpecialPasswordPolicies\execute(), SpecialPasswordReset\execute(), SpecialPreferences\execute(), SpecialPrefixindex\execute(), SpecialProtectedpages\execute(), SpecialProtectedtitles\execute(), SpecialRandomPage\execute(), SpecialResetTokens\execute(), SpecialRevisionDelete\execute(), SpecialRunJobs\execute(), SpecialSearch\execute(), SpecialSpecialpages\execute(), SpecialStatistics\execute(), SpecialTrackingCategories\execute(), SpecialUnblock\execute(), SpecialUndelete\execute(), SpecialUnwatchedPages\execute(), UserrightsPage\execute(), SpecialWhatLinksHere\execute(), ChangesListSpecialPage\execute(), DisabledSpecialPage\execute(), LoginSignupSpecialPage\execute(), RedirectSpecialPage\execute(), SpecialChangeCredentials\execute(), SpecialExpandTemplates\execute(), SpecialLinkAccounts\execute(), SpecialPageData\execute(), SpecialRecentChanges\execute(), SpecialUnlinkAccounts\execute(), SpecialWatchlist\execute(), SpecialEditWatchlist\executeViewEditWatchlist(), SpecialEditTags\failure(), SpecialRevisionDelete\failure(), SpecialNewpages\form(), SpecialChangeCredentials\getAuthFormDescriptor(), SpecialBlock\getFormFields(), AuthManagerSpecialPage\handleReauthBeforeExecute(), AuthManagerSpecialPage\handleReturnBeforeExecute(), ChangesListSpecialPage\includeRcFiltersApp(), LoginSignupSpecialPage\mainLoginForm(), SpecialBlock\maybeAlterFormDefaults(), SpecialRedirectWithAction\onFormSubmit(), SpecialDiff\onFormSubmit(), SpecialNewSection\onFormSubmit(), SpecialPermanentLink\onFormSubmit(), SpecialBotPasswords\onSubmit(), SpecialChangeContentModel\onSubmit(), SpecialPageLanguage\onSubmit(), SpecialRandomInCategory\onSubmit(), SpecialBotPasswords\onSuccess(), SpecialChangeContentModel\onSuccess(), SpecialChangeEmail\onSuccess(), SpecialLockdb\onSuccess(), SpecialMute\onSuccess(), SpecialPageLanguage\onSuccess(), SpecialPasswordReset\onSuccess(), SpecialResetTokens\onSuccess(), SpecialUnlockdb\onSuccess(), SpecialUserLogout\onSuccess(), SpecialWatchlist\outputChangesList(), SpecialMediaStatistics\outputMediaType(), ChangesListSpecialPage\outputNoResults(), SpecialRecentChangesLinked\outputNoResults(), SpecialMediaStatistics\outputResults(), SpecialEditWatchlist\outputSubtitle(), SpecialMediaStatistics\outputTableEnd(), SpecialMediaStatistics\outputTableRow(), SpecialMediaStatistics\outputTableStart(), ChangesListSpecialPage\outputTimeout(), SpecialBlock\postHtml(), SpecialBlock\preHtml(), SpecialPageLanguage\preHtml(), SpecialUpload\processUpload(), SpecialEmailUser\sendEmailForm(), SpecialUserLogin\setHeaders(), SpecialNewFiles\setTopText(), SpecialRecentChangesLinked\setTopText(), SpecialWatchlist\setTopText(), SpecialSearch\setupPage(), SpecialTags\showActivateDeactivateForm(), SpecialEditTags\showConvenienceLinks(), SpecialRevisionDelete\showConvenienceLinks(), SpecialSearch\showCreateLink(), SpecialTags\showDeleteTagForm(), UserrightsPage\showEditUserGroupsForm(), MovePageForm\showForm(), SpecialEditTags\showForm(), SpecialPageData\showForm(), SpecialRevisionDelete\showForm(), SpecialUndelete\showHistory(), SpecialAutoblockList\showList(), SpecialBlockList\showList(), SpecialPrefixindex\showPrefixChunk(), SpecialPreferences\showResetForm(), SpecialSearch\showResults(), SpecialChangeCredentials\showSubpageList(), LoginSignupSpecialPage\showSuccessPage(), SpecialAutoblockList\showTotal(), SpecialUploadStash\showUpload(), SpecialUpload\showUploadForm(), SpecialUpload\showUploadWarning(), SpecialUpload\showViewDeletedLinks(), SpecialEditTags\submit(), SpecialRevisionDelete\submit(), SpecialPreferences\submitReset(), SpecialChangeCredentials\success(), SpecialEditTags\success(), SpecialRevisionDelete\success(), SpecialCreateAccount\successfulAction(), UserrightsPage\switchForm(), SpecialRevisionDelete\tryShowFile(), SpecialUpload\unsaveUploadedFile(), and ChangesListSpecialPage\validateOptions().

◆ getPageTitle()

SpecialPage::getPageTitle ( $subpage = false)

Get a self-referential title object.

Parameters
string | false$subpage
Returns
Title
Since
1.23

Definition at line 816 of file SpecialPage.php.

Referenced by SpecialActiveUsers\buildForm(), ChangesListSpecialPage\considerActionsForDefaultSavedQuery(), SpecialWatchlist\doHeader(), SpecialApiHelp\execute(), SpecialAutoblockList\execute(), SpecialBlockList\execute(), SpecialFileDuplicateSearch\execute(), SpecialLinkSearch\execute(), SpecialPagesWithProp\execute(), SpecialSearch\execute(), LoginSignupSpecialPage\execute(), SpecialChangeCredentials\execute(), SpecialExpandTemplates\execute(), SpecialLinkAccounts\execute(), SpecialUnlinkAccounts\execute(), SpecialWatchlist\execute(), SpecialNewpages\filterLinks(), SpecialUndelete\formatRevisionRow(), SpecialBotPasswords\getFormFields(), SpecialMIMESearch\getPageHeader(), SpecialUpload\getUploadForm(), AuthManagerSpecialPage\handleReturnBeforeExecute(), LoginSignupSpecialPage\load(), SpecialPrefixindex\namespacePrefixForm(), SpecialDiff\onFormSubmit(), SpecialPermanentLink\onFormSubmit(), SpecialBotPasswords\onSubmit(), SpecialBotPasswords\onSuccess(), SpecialAllPages\outputHTMLForm(), AuthManagerSpecialPage\performAuthenticationStep(), SpecialTags\processCreateTagForm(), SpecialTags\processTagForm(), SpecialEmailUser\sendEmailForm(), SpecialWatchlist\setTopText(), SpecialSearch\setupPage(), SpecialTags\showActivateDeactivateForm(), SpecialTags\showDeleteTagForm(), UserrightsPage\showEditUserGroupsForm(), MovePageForm\showForm(), SpecialEditTags\showForm(), SpecialRevisionDelete\showForm(), SpecialUndelete\showHistory(), SpecialPrefixindex\showPrefixChunk(), SpecialPreferences\showResetForm(), SpecialPreferences\submitReset(), SpecialCreateAccount\successfulAction(), UserrightsPage\switchForm(), SpecialRevisionDelete\tryShowFile(), SpecialEmailUser\userForm(), and ChangesListSpecialPage\validateOptions().

◆ getRequest()

SpecialPage::getRequest ( )

Get the WebRequest being used for this instance.

Returns
WebRequest
Since
1.18

Reimplemented in AuthManagerSpecialPage.

Definition at line 852 of file SpecialPage.php.

References getContext().

Referenced by SpecialBlock\alterForm(), SpecialChangeEmail\alterForm(), SpecialPasswordReset\alterForm(), SpecialUserLogout\alterForm(), SpecialRevisionDelete\buildCheckBoxes(), SpecialActiveUsers\buildForm(), FormSpecialPage\checkExecutePermissions(), checkLoginSecurityLevel(), ChangesListSpecialPage\considerActionsForDefaultSavedQuery(), SpecialRedirect\dispatchFile(), SpecialBookSources\execute(), SpecialEditWatchlist\execute(), SpecialActiveUsers\execute(), SpecialAllMessages\execute(), SpecialAllPages\execute(), SpecialApiHelp\execute(), SpecialBlockList\execute(), SpecialCategories\execute(), SpecialContributions\execute(), SpecialDeletedContributions\execute(), SpecialEditTags\execute(), SpecialEmailUser\execute(), SpecialExport\execute(), SpecialFileDuplicateSearch\execute(), SpecialImport\execute(), SpecialLinkSearch\execute(), SpecialListFiles\execute(), SpecialLog\execute(), SpecialMIMESearch\execute(), MovePageForm\execute(), SpecialNewFiles\execute(), SpecialPagesWithProp\execute(), SpecialPreferences\execute(), SpecialPrefixindex\execute(), SpecialProtectedpages\execute(), SpecialProtectedtitles\execute(), SpecialRandomPage\execute(), SpecialRevisionDelete\execute(), SpecialRunJobs\execute(), SpecialSearch\execute(), SpecialTags\execute(), SpecialUnblock\execute(), UserrightsPage\execute(), SpecialWhatLinksHere\execute(), SpecialWithoutInterwiki\execute(), ChangesListSpecialPage\execute(), SpecialExpandTemplates\execute(), SpecialPageData\execute(), SpecialRecentChanges\execute(), SpecialWatchlist\execute(), SpecialRevisionDelete\extractBitParams(), ChangesListSpecialPage\fetchOptionsFromRequest(), SpecialWatchlist\fetchOptionsFromRequest(), ChangesListSpecialPage\getDefaultOptions(), FormSpecialPage\getForm(), SpecialPasswordReset\getFormFields(), SpecialFilepath\getRedirect(), RedirectSpecialPage\getRedirectQuery(), ChangesListSpecialPage\isStructuredFilterUiEnabled(), SpecialSearch\load(), SpecialUpload\loadRequest(), ChangesListSpecialPage\makeLegend(), SpecialBlock\maybeAlterFormDefaults(), SpecialBotPasswords\onSubmit(), SpecialRandomInCategory\onSubmit(), SpecialChangeEmail\onSuccess(), SpecialPasswordReset\onSuccess(), SpecialUpload\processUpload(), SpecialSearch\saveNamespaces(), UserrightsPage\saveUserGroups(), SpecialBlock\setParameter(), SpecialChangeContentModel\setParameter(), SpecialNewpages\setup(), SpecialRevisionDelete\showForm(), SpecialEditTags\submit(), SpecialRevisionDelete\submit(), SpecialPreferences\submitReset(), and SpecialRevisionDelete\tryShowFile().

◆ getRestriction()

SpecialPage::getRestriction ( )

Get the permission that a user must have to execute this page.

Returns
string

Definition at line 212 of file SpecialPage.php.

References $mRestriction.

◆ getRobotPolicy()

SpecialPage::getRobotPolicy ( )
protected

Return the robot policy.

Derived classes that override this can change the robot policy set by setHeaders() from the default 'noindex,nofollow'.

Returns
string
Since
1.23

Definition at line 971 of file SpecialPage.php.

◆ getSafeTitleFor()

static SpecialPage::getSafeTitleFor ( $name,
$subpage = false )
static

Get a localised Title object for a page name with a possibly unvalidated subpage.

Parameters
string$name
string | false$subpageSubpage string, or false to not use a subpage
Returns
Title|null Title object or null if the page doesn't exist

Definition at line 161 of file SpecialPage.php.

References NS_SPECIAL.

Referenced by SpecialFilepath\getRedirect(), Skin\makeSpecialUrl(), and Skin\makeSpecialUrlSubpage().

◆ getShortDescription()

SpecialPage::getShortDescription ( string $path = '')

Similar to getDescription but takes into account sub pages and designed for display in tabs.

Since
1.39
Stability: stable
to override if special page has complex parameter handling. Use default message keys where possible.
Parameters
string$path(optional)
Returns
string

Definition at line 801 of file SpecialPage.php.

◆ getSkin()

◆ getSpecialPageFactory()

SpecialPage::getSpecialPageFactory ( )
finalprotected
Since
1.36
Returns
SpecialPageFactory

Definition at line 1187 of file SpecialPage.php.

Referenced by SpecialBlockList\execute(), SpecialAutoblockList\getBlockListPager(), SpecialBlockList\getBlockListPager(), and getLocalName().

◆ getSubpagesForPrefixSearch()

SpecialPage::getSubpagesForPrefixSearch ( )
protected

Return an array of subpages that this special page will accept for prefix searches.

If this method requires a query you might instead want to implement prefixSearchSubpages() directly so you can support $limit and $offset. This method is better for static-ish lists of things.

Stability: stable
to override
Returns
string[] subpages to search from

Reimplemented in SpecialEditWatchlist, SpecialListUsers, SpecialLog, SpecialRedirect, SpecialTags, and SpecialWatchlist.

Definition at line 607 of file SpecialPage.php.

◆ getTitleFor()

static SpecialPage::getTitleFor ( $name,
$subpage = false,
$fragment = '' )
static

Get a localised Title object for a specified special page name If you don't need a full Title object, consider using TitleValue through getTitleValueFor() below.

Since
1.9
1.21 $fragment parameter added
Parameters
string$name
string | false$subpageSubpage string, or false to not use a subpage
string$fragmentThe link fragment (after the "#")
Returns
Title
Exceptions
MWException

Definition at line 132 of file SpecialPage.php.

Referenced by ApiQuerySiteinfo\appendExtensions(), MediaWiki\Preferences\SignatureValidator\applyPreSaveTransform(), SpecialUserLogin\beforeExecute(), Linker\blockLink(), Skin\buildNavUrls(), SpecialEditWatchlist\buildTools(), checkLoginSecurityLevel(), ApiFormatBase\closePrinter(), DifferenceEngine\deletedLink(), Linker\emailLink(), SpecialEditWatchlist\execute(), SpecialListGroupRights\execute(), SpecialPasswordPolicies\execute(), SpecialResetTokens\execute(), SpecialWatchlist\execute(), ApiFeedContributions\execute(), ApiFeedWatchlist\execute(), ApiHelp\execute(), TidyUpT39714\execute(), SpecialEditWatchlist\executeViewEditWatchlist(), LogFormatter\formatParameterValueForApi(), SpecialListDuplicatedFiles\formatResult(), SpecialUnusedTemplates\formatResult(), BlockLogFormatter\getActionLinks(), ContentModelLogFormatter\getActionLinks(), DeleteLogFormatter\getActionLinks(), MergeLogFormatter\getActionLinks(), MoveLogFormatter\getActionLinks(), RevDelArchivedFileItem\getApiData(), RevDelFileItem\getApiData(), HistoryAction\getDescription(), RevDelArchiveItem\getDiffLink(), LoginSignupSpecialPage\getFieldDefinitions(), Title\getFullUrlForRedirect(), OutputPage\getHeadLinksArray(), ChangeTagsLogItem\getHTML(), RevDelLogItem\getHTML(), RevDelArchivedFileItem\getLink(), RevDelFileItem\getLink(), BlockLogFormatter\getMessageParameters(), SearchNearMatcher\getNearMatchInternal(), ChangesListSpecialPage\getRcFiltersConfigSummary(), ChangesListSpecialPage\getRcFiltersConfigVars(), ManualLogEntry\getRecentChange(), SpecialRedirectToSpecial\getRedirect(), SpecialAllMyUploads\getRedirect(), SpecialMycontributions\getRedirect(), SpecialMyuploads\getRedirect(), RevDelArchiveItem\getRevisionLink(), MediaWiki\getTitle(), AllMessagesTablePager\getTitle(), ImageListPager\getTitle(), MediaWiki\SpecialPage\SpecialPageFactory\getTitleForAlias(), Skin\getUndeleteLink(), Linker\getUploadUrl(), ImagePage\getUploadUrl(), SpecialContributions\getUserLinks(), ExternalUserNames\getUserLinkTitle(), AuthManagerSpecialPage\handleReauthBeforeExecute(), ImageHistoryList\imageHistoryLine(), EnhancedChangesList\makeCacheGroupingKey(), WantedQueryPage\makeWlhLink(), RecentChangesUpdateJob\newCacheUpdateJob(), RecentChangesUpdateJob\newPurgeJob(), newSearchPage(), MarkpatrolledAction\onSubmit(), ImagePage\openShowImage(), SpecialMediaStatistics\outputTableRow(), InfoAction\pageInfo(), SpecialBlock\postHtml(), MediaWiki\Preferences\DefaultPreferencesFactory\profilePreferences(), EnhancedChangesList\recentChangesBlockLine(), UserNotLoggedIn\report(), Linker\revDeleteLink(), LogPage\saveContent(), UserMailer\sendInternal(), MediaWiki\Auth\TemporaryPasswordPrimaryAuthenticationProvider\sendPasswordResetEmail(), McrUndoAction\show(), SpecialEditTags\showConvenienceLinks(), SpecialRevisionDelete\showConvenienceLinks(), LogEventsList\showOptions(), OutputPage\showPermissionsErrorPage(), SpecialUpload\showUploadWarning(), SpecialUpload\showViewDeletedLinks(), CoreParserFunctions\special(), Linker\specialLink(), SpecialEmailUser\submit(), RevDelLogList\suggestTarget(), ChangeTags\updateTagsWithChecks(), Linker\userToolLinks(), MediaWiki\Preferences\DefaultPreferencesFactory\watchlistPreferences(), and wfOpenSearchDescMain().

◆ getTitleValueFor()

static SpecialPage::getTitleValueFor ( $name,
$subpage = false,
$fragment = '' )
static

Get a localised TitleValue object for a specified special page name.

Since
1.28
Parameters
string$name
string | false$subpageSubpage string, or false to not use a subpage
string$fragmentThe link fragment (after the "#")
Returns
TitleValue

Definition at line 147 of file SpecialPage.php.

References NS_SPECIAL.

Referenced by TagLogFormatter\getMessageParameters(), LogEventsList\logLine(), and InfoAction\pageInfo().

◆ getUser()

SpecialPage::getUser ( )

Shortcut to get the User executing this instance.

Returns
User
Since
1.18

Definition at line 872 of file SpecialPage.php.

References getContext().

Referenced by UserrightsPage\addLogEntry(), SpecialUserLogout\alterForm(), SpecialNewFiles\buildForm(), SpecialBotPasswords\checkExecutePermissions(), checkPermissions(), SpecialUndelete\checkPermissions(), SpecialWatchlist\countItems(), SpecialWatchlist\doHeader(), SpecialWatchlist\doMainQuery(), UserrightsPage\doSaveUserGroups(), SpecialConfirmEmail\execute(), FormSpecialPage\execute(), SpecialEditTags\execute(), SpecialEmailUser\execute(), SpecialImport\execute(), SpecialPreferences\execute(), SpecialRevisionDelete\execute(), SpecialUndelete\execute(), SpecialUserLogout\execute(), UserrightsPage\execute(), LoginSignupSpecialPage\execute(), SpecialUnlinkAccounts\execute(), SpecialUploadStash\execute(), SpecialWatchlist\execute(), SpecialMergeHistory\formatRevisionRow(), SpecialUndelete\formatRevisionRow(), SpecialProtectedtitles\formatRow(), SpecialEmailUser\getDescription(), SpecialBotPasswords\getFormFields(), SpecialChangeEmail\getFormFields(), SpecialEmailUser\getFormFields(), SpecialPasswordReset\getFormFields(), SpecialResetTokens\getFormFields(), SpecialAllMyUploads\getRedirect(), SpecialMycontributions\getRedirect(), SpecialMyuploads\getRedirect(), SpecialUndelete\isAllowed(), AuthManagerSpecialPage\loadAuth(), LoginSignupSpecialPage\mainLoginForm(), SpecialBotPasswords\onSubmit(), SpecialChangeEmail\onSubmit(), SpecialLockdb\onSubmit(), SpecialUserLogout\onSubmit(), SpecialResetTokens\onSubmit(), SpecialBotPasswords\onSuccess(), SpecialUserLogout\onSuccess(), SpecialWatchlist\outputChangesList(), SpecialWatchlist\outputFeedLinks(), SpecialEditWatchlist\outputSubtitle(), AuthManagerSpecialPage\performAuthenticationStep(), SpecialWatchlist\registerFilters(), requireLogin(), requireNamedUser(), SpecialUserLogin\setHeaders(), SpecialWatchlist\setTopText(), UserrightsPage\showEditUserGroupsForm(), SpecialEditTags\showForm(), SpecialRevisionDelete\showForm(), SpecialUndelete\showHistory(), LoginSignupSpecialPage\showSuccessPage(), SpecialEditTags\submit(), SpecialRevisionDelete\submit(), SpecialEditWatchlist\submitRaw(), SpecialPreferences\submitReset(), SpecialConfirmEmail\submitSend(), SpecialChangeCredentials\success(), SpecialCreateAccount\successfulAction(), SpecialUserLogin\successfulAction(), SpecialRevisionDelete\tryShowFile(), and UserrightsPage\userCanChangeRights().

◆ including()

◆ isCached()

SpecialPage::isCached ( )

Is this page cached? Expensive pages are cached or disabled in miser mode.

Used by QueryPage and subclasses, moved here so that Special:SpecialPages can safely call it for all special pages.

Stability: stable
to override
Returns
bool
Since
1.21

Reimplemented in QueryPage.

Definition at line 331 of file SpecialPage.php.

◆ isExpensive()

SpecialPage::isExpensive ( )

Is this page expensive (for some definition of expensive)? Expensive pages are disabled or cached in miser mode.

Originally used (and still overridden) by QueryPage and subclasses, moved here so that Special:SpecialPages can safely call it for all special pages.

Stability: stable
to override
Returns
bool

Reimplemented in QueryPage, WantedQueryPage, SpecialAncientPages, SpecialBrokenRedirects, SpecialDeadendPages, SpecialDoubleRedirects, SpecialFewestRevisions, SpecialListDuplicatedFiles, SpecialListRedirects, SpecialLonelyPages, SpecialMediaStatistics, SpecialMIMESearch, SpecialMostCategories, MostimagesPage, SpecialMostInterwikis, SpecialMostLinked, SpecialMostLinkedTemplates, SpecialUncategorizedImages, SpecialUncategorizedPages, SpecialUnusedCategories, SpecialUnusedImages, SpecialUnusedTemplates, SpecialUnwatchedPages, and SpecialWithoutInterwiki.

Definition at line 317 of file SpecialPage.php.

◆ isIncludable()

SpecialPage::isIncludable ( )

Whether it's allowed to transclude the special page via {{Special:Foo/params}}.

Stability: stable
to override
Returns
bool

Reimplemented in IncludableSpecialPage, SpecialApiHelp, SpecialRecentChanges, and WantedPagesPage.

Definition at line 259 of file SpecialPage.php.

References $mIncludable.

◆ isListed()

SpecialPage::isListed ( )

Whether this special page is listed in Special:SpecialPages.

Stability: stable
to override
Since
1.3 (r3583)
Returns
bool

Reimplemented in SpecialRedirectWithAction, UnlistedSpecialPage, SpecialBotPasswords, SpecialChangeCredentials, SpecialChangeEmail, SpecialDiff, SpecialLinkAccounts, SpecialNewSection, SpecialPageData, SpecialPasswordReset, SpecialPermanentLink, SpecialResetTokens, SpecialUnlinkAccounts, and SpecialUserLogout.

Definition at line 224 of file SpecialPage.php.

◆ isRestricted()

SpecialPage::isRestricted ( )

Can be overridden by subclasses with more complicated permissions schemes.

Stability: stable
to override
Returns
bool Should the page be displayed with the restricted-access pages?

Definition at line 343 of file SpecialPage.php.

◆ listed()

SpecialPage::listed ( $x = null)

Get or set whether this special page is listed in Special:SpecialPages.

Since
1.6
Deprecated
since 1.35 Set via subclassing UnlistedSpecialPage, get via isListed()
Parameters
bool | null$x
Returns
bool

Definition at line 249 of file SpecialPage.php.

References wfDeprecated(), and wfSetVar().

◆ maxIncludeCacheTime()

SpecialPage::maxIncludeCacheTime ( )

How long to cache page when it is being included.

Note
If cache time is not 0, then the current user becomes an anon if you want to do any per-user customizations, than this method must be overridden to return 0.
Since
1.26
Stability: stable
to override
Returns
int Time in seconds, 0 to disable caching altogether, false to use the parent page's cache settings

Definition at line 274 of file SpecialPage.php.

References getCacheTTL(), and getConfig().

◆ msg()

SpecialPage::msg ( $key,
$params )

Wrapper around wfMessage that sets the current context.

Since
1.16
Parameters
string | string[] | MessageSpecifier$key
mixed...$params
Returns
Message
See also
wfMessage

Implements MessageLocalizer.

Definition at line 984 of file SpecialPage.php.

References getContext().

Referenced by SpecialBlock\alterForm(), SpecialBotPasswords\alterForm(), SpecialChangeEmail\alterForm(), SpecialLockdb\alterForm(), SpecialPasswordReset\alterForm(), SpecialUnlockdb\alterForm(), SpecialUserLogout\alterForm(), SpecialEditTags\buildCheckBoxes(), SpecialRevisionDelete\buildCheckBoxes(), SpecialNewFiles\buildForm(), SpecialComparePages\checkExistingRevision(), SpecialWatchlist\doHeader(), SpecialRecentChangesLinked\doMainQuery(), SpecialEditWatchlist\execute(), SpecialAllMessages\execute(), SpecialAllPages\execute(), SpecialApiHelp\execute(), SpecialAutoblockList\execute(), SpecialBlockList\execute(), SpecialCategories\execute(), SpecialContributions\execute(), SpecialDeletedContributions\execute(), SpecialExport\execute(), SpecialFileDuplicateSearch\execute(), SpecialListFiles\execute(), SpecialListGrants\execute(), SpecialListGroupRights\execute(), SpecialListUsers\execute(), SpecialMergeHistory\execute(), SpecialPagesWithProp\execute(), SpecialPasswordPolicies\execute(), SpecialPreferences\execute(), SpecialPrefixindex\execute(), SpecialStatistics\execute(), SpecialTrackingCategories\execute(), SpecialUnblock\execute(), SpecialUndelete\execute(), UserrightsPage\execute(), SpecialWhatLinksHere\execute(), DisabledSpecialPage\execute(), SpecialChangeCredentials\execute(), SpecialLinkAccounts\execute(), SpecialUnlinkAccounts\execute(), SpecialEditWatchlist\executeViewEditWatchlist(), SpecialEditTags\failure(), SpecialRevisionDelete\failure(), SpecialNewpages\filterLinks(), WantedQueryPage\formatResult(), SpecialBrokenRedirects\formatResult(), SpecialDoubleRedirects\formatResult(), SpecialFewestRevisions\formatResult(), SpecialLinkSearch\formatResult(), SpecialListDuplicatedFiles\formatResult(), SpecialMIMESearch\formatResult(), SpecialMostCategories\formatResult(), SpecialMostInterwikis\formatResult(), SpecialMostLinked\formatResult(), SpecialMostLinkedCategories\formatResult(), SpecialPagesWithProp\formatResult(), SpecialShortPages\formatResult(), SpecialUnwatchedPages\formatResult(), SpecialWantedCategories\formatResult(), SpecialMergeHistory\formatRevisionRow(), SpecialUndelete\formatRevisionRow(), SpecialProtectedtitles\formatRow(), SpecialChangeCredentials\getAuthForm(), LoginSignupSpecialPage\getBenefitsContainerHtml(), MostimagesPage\getCellHtml(), SpecialCreateAccount\getDescription(), SpecialDiff\getDescription(), SpecialEditTags\getDescription(), SpecialEmailUser\getDescription(), SpecialMute\getDescription(), SpecialUserLogin\getDescription(), SpecialUpload\getDupeWarning(), SpecialRecentChangesLinked\getExtraOptions(), FormSpecialPage\getForm(), SpecialBlock\getFormFields(), SpecialBotPasswords\getFormFields(), SpecialChangeContentModel\getFormFields(), SpecialChangeEmail\getFormFields(), SpecialEmailUser\getFormFields(), SpecialPageLanguage\getFormFields(), SpecialRedirect\getFormFields(), SpecialResetTokens\getFormFields(), SpecialActiveUsers\getIntroText(), SpecialProtectedpages\getLevelMenu(), SpecialBrokenRedirects\getPageHeader(), SpecialDeadendPages\getPageHeader(), SpecialDoubleRedirects\getPageHeader(), SpecialLonelyPages\getPageHeader(), SpecialUnusedCategories\getPageHeader(), SpecialUnusedImages\getPageHeader(), SpecialUnusedTemplates\getPageHeader(), WantedFilesPage\getPageHeader(), LoginSignupSpecialPage\getPageHtml(), SpecialMediaStatistics\getTableHeaderRow(), SpecialProtectedpages\getTypeMenu(), SpecialUpload\getUploadForm(), ChangesListSpecialPage\includeRcFiltersApp(), LoginSignupSpecialPage\load(), SpecialUpload\loadRequest(), LoginSignupSpecialPage\mainLoginForm(), UserrightsPage\makeGroupNameList(), WantedQueryPage\makeWlhLink(), SpecialLockdb\onSubmit(), SpecialRandomInCategory\onSubmit(), SpecialBotPasswords\onSuccess(), SpecialChangeContentModel\onSuccess(), SpecialLockdb\onSuccess(), SpecialPasswordReset\onSuccess(), SpecialUnlockdb\onSuccess(), SpecialWatchlist\outputChangesList(), SpecialMediaStatistics\outputMediaType(), ChangesListSpecialPage\outputNoResults(), SpecialRecentChangesLinked\outputNoResults(), SpecialMediaStatistics\outputResults(), SpecialEditWatchlist\outputSubtitle(), SpecialMediaStatistics\outputTableEnd(), SpecialMediaStatistics\outputTableRow(), ChangesListSpecialPage\outputTimeout(), SpecialBlock\postHtml(), SpecialBlock\preHtml(), SpecialTags\processCreateTagForm(), SpecialTags\processTagForm(), SpecialUpload\processUpload(), SpecialUpload\processVerificationError(), SpecialEmailUser\sendEmailForm(), SpecialUserLogin\setHeaders(), SpecialNewFiles\setTopText(), SpecialWatchlist\setTopText(), SpecialSearch\setupPage(), SpecialTags\showActivateDeactivateForm(), SpecialEditTags\showConvenienceLinks(), SpecialRevisionDelete\showConvenienceLinks(), SpecialTags\showDeleteTagForm(), UserrightsPage\showEditUserGroupsForm(), MovePageForm\showForm(), SpecialEditTags\showForm(), SpecialRevisionDelete\showForm(), SpecialWatchlist\showHideCheck(), SpecialUndelete\showHistory(), SpecialAutoblockList\showList(), SpecialBlockList\showList(), SpecialProtectedpages\showOptions(), SpecialPrefixindex\showPrefixChunk(), SpecialUpload\showRecoverableUploadError(), SpecialAutoblockList\showTotal(), SpecialUpload\showUploadError(), SpecialUpload\showUploadWarning(), SpecialUpload\showViewDeletedLinks(), SpecialRevisionDelete\submit(), SpecialEditWatchlist\submitRaw(), SpecialConfirmEmail\submitSend(), SpecialEditTags\success(), SpecialLinkAccounts\success(), SpecialRevisionDelete\success(), SpecialCreateAccount\successfulAction(), SpecialUserLogin\successfulAction(), UserrightsPage\switchForm(), SpecialUpload\unsaveUploadedFile(), SpecialEmailUser\userForm(), and SpecialChangeContentModel\validateTitle().

◆ newSearchPage()

static SpecialPage::newSearchPage ( User $user)
static

Get the users preferred search page.

It will fall back to Special:Search if the preference points to a page that doesn't exist or is not defined.

Since
1.38
Parameters
User$userSearch page can be customized by user preference.
Returns
Title

Definition at line 104 of file SpecialPage.php.

References $title, and getTitleFor().

Referenced by MediaWiki\Skin\SkinComponentSearch\__construct(), and SkinTemplate\prepareQuickTemplate().

◆ outputHeader()

SpecialPage::outputHeader ( $summaryMessageKey = '')
protected

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.

by extensions to stick with the naming conventions for message keys: 'extensionname-xxx'

Stability: stable
to override
Parameters
string$summaryMessageKeyMessage key of the summary

Definition at line 763 of file SpecialPage.php.

Referenced by SpecialRedirect\alterForm(), SpecialBookSources\execute(), SpecialEditWatchlist\execute(), SpecialActiveUsers\execute(), SpecialAllPages\execute(), SpecialAutoblockList\execute(), SpecialBlockList\execute(), SpecialCategories\execute(), SpecialComparePages\execute(), SpecialContributions\execute(), SpecialDeletedContributions\execute(), SpecialEditTags\execute(), SpecialEmailUser\execute(), SpecialExport\execute(), SpecialFileDuplicateSearch\execute(), SpecialImport\execute(), SpecialLinkSearch\execute(), SpecialListFiles\execute(), SpecialListGrants\execute(), SpecialListGroupRights\execute(), SpecialListUsers\execute(), SpecialLog\execute(), SpecialMergeHistory\execute(), SpecialMIMESearch\execute(), MovePageForm\execute(), SpecialNewFiles\execute(), SpecialNewpages\execute(), SpecialPagesWithProp\execute(), SpecialPasswordPolicies\execute(), SpecialPreferences\execute(), SpecialPrefixindex\execute(), SpecialProtectedpages\execute(), SpecialProtectedtitles\execute(), SpecialRevisionDelete\execute(), SpecialSpecialpages\execute(), SpecialStatistics\execute(), SpecialTags\execute(), SpecialTrackingCategories\execute(), SpecialUnblock\execute(), SpecialUndelete\execute(), SpecialUpload\execute(), UserrightsPage\execute(), SpecialWhatLinksHere\execute(), ChangesListSpecialPage\execute(), DisabledSpecialPage\execute(), SpecialChangeCredentials\execute(), SpecialLinkAccounts\execute(), SpecialUnlinkAccounts\execute(), SpecialSearch\setupPage(), SpecialRedirectWithAction\showNoRedirectPage(), SpecialDiff\showNoRedirectPage(), SpecialNewSection\showNoRedirectPage(), and SpecialPermanentLink\showNoRedirectPage().

◆ prefixSearchArray()

static SpecialPage::prefixSearchArray ( $search,
$limit,
array $subpages,
$offset )
staticprotected

Helper function for implementations of prefixSearchSubpages() that filter the values in memory (as opposed to making a query).

Since
1.24
Parameters
string$search
int$limit
array$subpages
int$offset
Returns
string[]

Definition at line 662 of file SpecialPage.php.

Referenced by SpecialPagesWithProp\prefixSearchSubpages().

◆ prefixSearchString()

SpecialPage::prefixSearchString ( $search,
$limit,
$offset,
SearchEngineFactory $searchEngineFactory = null )
protected

Perform a regular substring search for prefixSearchSubpages.

Since
1.36 Added $searchEngineFactory parameter
Parameters
string$searchPrefix to search for
int$limitMaximum number of results to return (usually 10)
int$offsetNumber of results to skip (usually 0)
SearchEngineFactory | null$searchEngineFactoryProvide the service
Returns
string[] Matching subpages

Definition at line 631 of file SpecialPage.php.

References $t, $title, and SearchEngineFactory\create().

Referenced by SpecialRedirectWithAction\prefixSearchSubpages(), SpecialAllPages\prefixSearchSubpages(), SpecialChangeContentModel\prefixSearchSubpages(), SpecialNewSection\prefixSearchSubpages(), SpecialPageLanguage\prefixSearchSubpages(), SpecialRecentChangesLinked\prefixSearchSubpages(), and SpecialUndelete\prefixSearchSubpages().

◆ prefixSearchSubpages()

SpecialPage::prefixSearchSubpages ( $search,
$limit,
$offset )

Return an array of subpages beginning with $search that this special page will accept.

For example, if a page supports subpages "foo", "bar" and "baz" (as in Special:PageName/foo, etc.):

  • prefixSearchSubpages( "ba" ) should return [ "bar", "baz" ]
  • prefixSearchSubpages( "f" ) should return [ "foo" ]
  • prefixSearchSubpages( "z" ) should return []
  • prefixSearchSubpages( "" ) should return [ foo", "bar", "baz" ]</tt> \par "Stability: stable" to override
    Parameters
    string$searchPrefix to search for
    int$limitMaximum number of results to return (usually 10)
    int$offsetNumber of results to skip (usually 0)
    Returns
    string[] Matching subpages

Reimplemented in SpecialRedirectWithAction, SpecialAllPages, SpecialBlock, SpecialChangeContentModel, SpecialContributions, SpecialDeletedContributions, SpecialEmailUser, SpecialFileDuplicateSearch, SpecialFilepath, SpecialListFiles, MovePageForm, SpecialNewSection, SpecialPageLanguage, SpecialPagesWithProp, SpecialRecentChangesLinked, SpecialUnblock, SpecialUndelete, UserrightsPage, and SpecialWhatLinksHere.

Definition at line 589 of file SpecialPage.php.

◆ requireLogin()

SpecialPage::requireLogin ( $reasonMsg = 'exception-nologin-text',
$titleMsg = 'exception-nologin' )

If the user is not logged in, throws UserNotLoggedIn error.

The user will be redirected to Special:Userlogin with the given message as an error on the form.

Since
1.23
Parameters
string$reasonMsg[optional] Message key to be displayed on login page
string$titleMsg[optional] Passed on to UserNotLoggedIn constructor
Exceptions
UserNotLoggedIn

Definition at line 415 of file SpecialPage.php.

References getUser().

Referenced by SpecialConfirmEmail\execute(), and SpecialMute\execute().

◆ requireNamedUser()

SpecialPage::requireNamedUser ( $reasonMsg = 'exception-nologin-text',
$titleMsg = 'exception-nologin' )

If the user is not logged in or is a temporary user, throws UserNotLoggedIn.

Since
1.39
Parameters
string$reasonMsg[optional] Message key to be displayed on login page
string$titleMsg[optional] Passed on to UserNotLoggedIn constructor
Exceptions
UserNotLoggedIn

Definition at line 431 of file SpecialPage.php.

References getUser().

Referenced by SpecialChangeEmail\checkExecutePermissions(), SpecialEditWatchlist\execute(), SpecialBotPasswords\execute(), SpecialPreferences\execute(), SpecialResetTokens\execute(), and SpecialWatchlist\execute().

◆ run()

SpecialPage::run ( $subPage)
final

Entry point.

Since
1.20
Parameters
string | null$subPage

Definition at line 693 of file SpecialPage.php.

◆ setAuthManager()

SpecialPage::setAuthManager ( AuthManager $authManager)
finalprotected

Set the injected AuthManager from the special page constructor.

Since
1.36
Parameters
AuthManager$authManager

Definition at line 553 of file SpecialPage.php.

Referenced by SpecialChangeCredentials\__construct(), SpecialChangeEmail\__construct(), SpecialCreateAccount\__construct(), SpecialLinkAccounts\__construct(), SpecialUnlinkAccounts\__construct(), SpecialUserLogin\__construct(), and SpecialBotPasswords\__construct().

◆ setContentLanguage()

SpecialPage::setContentLanguage ( Language $contentLanguage)
final

Set content language.

Access: internal
For factory only
Parameters
Language$contentLanguage
Since
1.36

Definition at line 928 of file SpecialPage.php.

◆ setContext()

SpecialPage::setContext ( $context)

Sets the context this SpecialPage is executed in.

Parameters
IContextSource$context
Since
1.18

Definition at line 826 of file SpecialPage.php.

Referenced by Skin\buildNavUrls(), ApiQueryUsers\execute(), and LoginSignupSpecialPage\setSessionUserForCurrentRequest().

◆ setHeaders()

SpecialPage::setHeaders ( )
protected

Sets headers - this should be called from the execute() method of all derived classes!

Stability: stable
to override

Reimplemented in SpecialUserLogin.

Definition at line 672 of file SpecialPage.php.

Referenced by SpecialConfirmEmail\execute(), SpecialEmailInvalidate\execute(), SpecialBookSources\execute(), SpecialEditWatchlist\execute(), FormSpecialPage\execute(), SpecialActiveUsers\execute(), SpecialAllMessages\execute(), SpecialAllPages\execute(), SpecialApiSandbox\execute(), SpecialAutoblockList\execute(), SpecialBlankpage\execute(), SpecialBlockList\execute(), SpecialCategories\execute(), SpecialComparePages\execute(), SpecialContributions\execute(), SpecialDeletedContributions\execute(), SpecialEditTags\execute(), SpecialEmailUser\execute(), SpecialExport\execute(), SpecialFileDuplicateSearch\execute(), SpecialGoToInterwiki\execute(), SpecialImport\execute(), SpecialLinkSearch\execute(), SpecialListFiles\execute(), SpecialListGrants\execute(), SpecialListGroupRights\execute(), SpecialListUsers\execute(), SpecialLog\execute(), SpecialMergeHistory\execute(), SpecialMIMESearch\execute(), MovePageForm\execute(), SpecialNewFiles\execute(), SpecialNewpages\execute(), SpecialPagesWithProp\execute(), SpecialPasswordPolicies\execute(), SpecialPreferences\execute(), SpecialPrefixindex\execute(), SpecialProtectedpages\execute(), SpecialProtectedtitles\execute(), SpecialRandomPage\execute(), SpecialRevisionDelete\execute(), SpecialSpecialpages\execute(), SpecialStatistics\execute(), SpecialTags\execute(), SpecialTrackingCategories\execute(), SpecialUnblock\execute(), SpecialUndelete\execute(), SpecialUpload\execute(), SpecialUserLogout\execute(), UserrightsPage\execute(), SpecialWhatLinksHere\execute(), ChangesListSpecialPage\execute(), DisabledSpecialPage\execute(), LoginSignupSpecialPage\execute(), SpecialChangeCredentials\execute(), SpecialExpandTemplates\execute(), SpecialLinkAccounts\execute(), SpecialUnlinkAccounts\execute(), SpecialSearch\setupPage(), SpecialRedirectWithAction\showNoRedirectPage(), SpecialDiff\showNoRedirectPage(), SpecialNewSection\showNoRedirectPage(), and SpecialPermanentLink\showNoRedirectPage().

◆ setHookContainer()

SpecialPage::setHookContainer ( HookContainer $hookContainer)
Since
1.35
Access: internal
Parameters
HookContainer$hookContainer

Definition at line 1145 of file SpecialPage.php.

◆ setLinkRenderer()

SpecialPage::setLinkRenderer ( LinkRenderer $linkRenderer)
Since
1.28
Parameters
LinkRenderer$linkRenderer

Definition at line 1113 of file SpecialPage.php.

◆ setListed()

SpecialPage::setListed ( $listed)

Set whether this page is listed in Special:Specialpages, at run-time.

Since
1.3
Deprecated
since 1.35
Parameters
bool$listedSet via subclassing UnlistedSpecialPage, get via isListed()
Returns
bool

Definition at line 236 of file SpecialPage.php.

References wfDeprecated(), and wfSetVar().

◆ setReauthPostData()

SpecialPage::setReauthPostData ( array $data)
protected

Record preserved POST data after a reauthentication.

This is called from checkLoginSecurityLevel() when returning from the redirect for reauthentication, if the redirect had been served in response to a POST request.

The base SpecialPage implementation does nothing. If your subclass uses getLoginSecurityLevel() or checkLoginSecurityLevel(), it should probably implement this to do something with the data.

Note
Call self::setAuthManager from special page constructor when overriding
Stability: stable
to override
Since
1.32
Parameters
array$data

Reimplemented in FormSpecialPage.

Definition at line 468 of file SpecialPage.php.

Referenced by checkLoginSecurityLevel().

◆ setSpecialPageFactory()

SpecialPage::setSpecialPageFactory ( SpecialPageFactory $specialPageFactory)
final
Access: internal
For factory only
Since
1.36
Parameters
SpecialPageFactory$specialPageFactory

Definition at line 1179 of file SpecialPage.php.

◆ userCanExecute()

SpecialPage::userCanExecute ( User $user)

Checks if the given user (identified by an object) can execute this special page (as defined by $mRestriction).

Can be overridden by sub- classes with more complicated permissions schemes.

Stability: stable
to override
Parameters
User$userThe user to check
Returns
bool Does the user have permission to view the page?

Reimplemented in SpecialPasswordReset, SpecialUndelete, and SpecialUpload.

Definition at line 359 of file SpecialPage.php.

Referenced by checkPermissions().

◆ useTransactionalTimeLimit()

SpecialPage::useTransactionalTimeLimit ( )
protected

Member Data Documentation

◆ $mContext

IContextSource SpecialPage::$mContext
protected

Current request context.

Definition at line 73 of file SpecialPage.php.

◆ $mIncludable

bool SpecialPage::$mIncludable
protected

Whether the special page can be included in an article.

Definition at line 67 of file SpecialPage.php.

Referenced by isIncludable().

◆ $mIncluding

bool SpecialPage::$mIncluding
protected

Whether or not this special page is being included from an article.

Definition at line 64 of file SpecialPage.php.

◆ $mName

string SpecialPage::$mName
protected

The canonical name of this special page Also used for the default.

heading, @see getDescription()

Definition at line 49 of file SpecialPage.php.

Referenced by getName().

◆ $mRestriction

string SpecialPage::$mRestriction
protected

Minimum user level required to access this page, or "" for anyone.

Also used to categorise the pages in Special:Specialpages

Definition at line 58 of file SpecialPage.php.

Referenced by getRestriction().


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