Fix up interwiki search results in API
[mediawiki.git] / RELEASE-NOTES-1.24
blob03cf27708eecd8216fa46b8cc1b16c1a6f16a357
1 Security reminder: If you have PHP's register_globals option set, you must
2 turn it off. MediaWiki will no longer work with it enabled.
4 == MediaWiki 1.24 ==
6 THIS IS NOT A RELEASE YET
8 MediaWiki 1.24 is an alpha-quality branch and is not recommended for use in
9 production.
11 === Configuration changes in 1.24 ===
12 * MediaWiki will no longer run if register_globals is enabled. It has been
13   deprecated for 5 years now, and was removed in PHP 5.4. For more information
14   about why, see <https://www.mediawiki.org/wiki/register_globals>.
15 * MediaWiki now requires PHP's iconv extension. openSUSE users may need to
16   install the php5-iconv package. Users of other systems may need to add
17   extension=iconv.so to php.ini or recompile PHP without --without-iconv.
18 * MediaWiki will no longer function if magic quotes are enabled. It has
19   been deprecated for 5 years now, and was removed in PHP 5.4.
20 * The server's canonical hostname is available as $wgServerName, which is
21   exposed in both mw.config and ApiQuerySiteInfo.
22 * Introduced $wgPagePropsHaveSortkey as a backwards-compatibility switch,
23   for using the old schema of the page_props table, in case the respective
24   schema update was not applied.
25 * $wgSearchEverythingOnlyLoggedIn was removed as the 'searcheverything'
26   user option was removed. Use $wgNamespacesToBeSearchedDefault instead or
27   if you used to have $wgDefaultUserOptions['searcheverything'] = 1.
28 * $wgMasterWaitTimeout has been deprecated.
29 * $wgDBClusterTimeout has been removed.
30 * $wgProxyKey has been removed. It is no longer used by MediaWiki core.
31   Ensure $wgSecretKey is set in LocalSettings.php.
32 * $wgExtraInterlanguageLinkPrefixes is a new configuration variable that
33   contains an array of interwiki prefixes that should be treated as language
34   prefixes (i.e. turned into interlanguage links when $wgInterwikiMagic is set
35   to true).
36 * $wgParserTestRemote has been removed.
37 * $wgCountTotalSearchHits has been removed. If you're concerned about efficiency
38   of search, you should use something like CirrusSearch instead of built in
39   search.
40 * Users in the 'sysop' group have access to Special:MergeHistory by default.
41 * $wgFileStore was removed after having been deprecated in 1.17. Alternative
42   configurations are $wgDeletedDirectory and $wgHashedUploadDirectory.
43 * The deprecated $wgUseCommaCount variable has been removed.
44 * $wgEnableSorbs and $wgSorbsUrl have been removed.
45 * The UserCryptPassword and UserComparePassword hooks are no longer called.
46   Any extensions using them must be updated to use the Password Hashing API.
47 * $wgCompiledFiles has been removed.
48 * $wgSortSpecialPages was removed, the listing on Special:SpecialPages is
49   now always sorted.
50 * $wgSpecialPages may now use callback functions as an alternative to plain class names.
51   This allows more control over constructor parameters.
52 * $wgHTCPMulticastAddress, $wgHTCPMulticastRouting and $wgHTCPPort were removed.
53 * $wgRC2UDPAddress, $wgRC2UDPInterwikiPrefix, $wgRC2UDPOmitBots, $wgRC2UDPPort
54   and $wgRC2UDPPrefix have been removed.
55 * The default password type for MediaWiki has been changed from MD5 to PBKDF2.
56   Password hashes will automatically be updated as users log in. If necessary, the
57   old MD5 hashing can be restored by changing $wgPasswordDefault to 'B'. In addition,
58   there is a maintenance script wrapOldPassword.php that can wrap all passwords in
59   PBKDF2 (or the hashing algorithm of your choice) if you don't want to wait for your
60   users to log in.
61 * $wgImportSources can now either be a regular array, or an associative map
62   specifying subprojects on the interwiki map of the target wiki, or a mix of
63   the two. Existing configurations will still work.
64 * Users must be able to edit through a page's protection to be able to delete it.
65 * The default thumb size ($wgDefaultUserOptions['thumbsize']) is now 300px, up from
66   180px. If you have altered the number of entries in $wgThumbLimits for your wiki, you
67   may need to adjust your default user settings to compensate for the index change.
68 * $wgDeferredUpdateList is now deprecated, you should use DeferredUpdates::addUpdate()
69   instead.
70 * $wgCanonicalLanguageLinks has been removed. Per Google recommendations, we
71   will not send a rel=canonical pointing to a variant-neutral page, however
72   we will send rel=alternate.
73 * $wgResourceLoaderLESSFunctions has been deprecated and will be removed in the future.
74 * $wgGoToEdit has been removed. Use the SpecialSearchNogomatch hook for similar
75   functionality.
77 === New features in 1.24 ===
78 * Added new hook WatchlistEditorBeforeFormRender, allowing subscribers to
79   manipulate the list of pages and/or preload lots of data at once.
80 * Added new argument &$link in hook WatchlistEditorBuildRemoveLine, allowing the
81   link to the title to be changed.
82 * Added a new hook, "WhatLinksHereProps", to allow extensions to annotate
83   WhatLinksHere entries.
84 * Added a new hook, "ContentGetParserOutput", to customize parser output for
85   a given content object.
86 * Deprecated the hook "ShowRawCssJs", use "ContentGetParserOutput" instead.
87 * HTMLForm's HTMLTextField now supports the 'url' type.
88 * HTMLForm fields may now be dynamically hidden based on the values of other
89   fields in the form.
90 * HTMLForm now supports multiple copies of an input field or set of input
91   fields, e.g. the form may request "one or more usernames" without having to
92   have the user enter delimited list of names into a text field.
93 * Added a new hook, "SidebarBeforeOutput", to allow to edit the structure of
94   the sidebar just before its display.
95 * (bug 49156) Added the mediawiki.cookie ResourceLoader module, which wraps
96   jquery.cookie so that getting/setting a cookie is syntactically and
97   functionally similar to using the WebRequest::getCookie() and
98   WebResponse::setcookie() methods.
99 * (bug 44740) jQuery upgraded from 1.8.3 to 1.11.1. A new configuration option,
100   $wgIncludejQueryMigrate, also loads the jQuery Migrate hack to let extensions
101   and gadgets use the long-deprecated functions that were removed in jQuery 1.9.
102   This option is turned off by default, and will be removed in MediaWiki 1.25.
103 * (bug 47076) jQuery UI upgraded from 1.8.24 to 1.9.2.
104 * Changes to content typography (fonts, etc.). See
105   https://www.mediawiki.org/wiki/Typography_refresh for further information.
106 * WikitextContent will now render redirects with the expected "redirect"
107   header, rather than as an ordered list. Code calling Article::viewRedirect
108   can probably be changed to no longer special-case redirects.
109 * Header font set to a serif font stack. See
110   https://www.mediawiki.org/wiki/Typography_refresh for further information.
111 * (bug 65567) Added a new hook, "BeforeHttpsRedirect", to allow cancellation of
112   the HTTP to HTTPS redirect due to forceHTTPS cookie, userRequires, etc. This
113   is only for page views, since this hook doesn't affect UserLogin, OAuth,
114   CentralAuth, etc. ATTENTION: This hook is likely to be removed soon due to
115   overall design of the system.
116 * (bug 17367) It is now possible to add pages to your watchlist from
117   Special:UnwatchedPages without reloading the special page.
118 * New methods setVolatile and isVolatile are added to PPFrame, so that
119   extensions such as Cite.php can mark that their output is volatile and
120   shouldn't be cached.
121 * (bug 52817) Advanced search options are now saved on the search page itself,
122   rather than in a dedicated pane in the preferences panel.
123 * (bug 44591) The dropdown actions menu (little triangle next to page tabs) in
124   the Vector skin has gained a label that should make it more discoverable.
125 * MWCryptHKDF added for fast, cryptographically secure random number generation
126   that won't deplete openssl's entropy pool.
127 * ResourceLoader: File modules can now provide a skip function that uses an
128   inline feature test to bypass loading of the module.
129 * (bug 20210) Special pages may now provide autocompletion of their subpage
130   names in search suggestions. Right now the only useful implementation is in
131   Special:Log, but more are to come.
132 * Special:MostLinkedTemplates is no longer limited to transclusions from the
133   Template namespace.
134 * Skins can now use 'remoteSkinPath' when defining ResourceLoader modules.
135   This works the same as 'remoteExtPath' but is relative to the skins/ folder
136   instead of the extensions/ folder.
137 * Added the json2.js polyfill for the ES5 JSON.stringify and JSON.parse methods.
138   Exposed as module "json" with a skip function to optimise loading.
139 * Extensions and skins may now use 'namemsg' in $wgExtensionCredits in addition
140   to 'name', to allow for the name to be localizable. 'name' should still be
141   specified for backwards-compatibility and to define the path Special:Version
142   uses to find extension license information.
143 * Browser tests are now included to verify basic wiki functionality in developer
144   environments. For details on running tests, see tests/browser/README.mediawiki.
145 * Upgrade jStorage to v0.4.10.
146 * {{!}} is now a magic word that produces the | character. This removes the need
147   for Template:! for purposes such as passing pipes inside of parameters.
148 * (bug 20790) The block log snippet on Special:Contributions and while
149   editing user and user talk pages now works for IP range blocks.
150 * (bug 9360) Added ability to change the page language for MediaWiki pages using
151   Special:PageLanguage. All pages are set to wiki language by default.
152   The feature needs to be enabled with $wgPageLanguageUseDB=true and
153   permission needs to be set for 'pagelang'.
154 * Upgrade Moment.js to v2.8.3.
155 * (bug 67042) Added support for the HTML5 <rtc> tag for East Asian typography.
156 * Upgrade Sinon.JS to 1.10.3.
157 * Added the es5-shim polyfill for older or non-compliant javascript engines.
158 * Upgrade jQuery Cookie to v1.3.1.
159 * (bug 20476) Add a "viewsuppressed" user right to be able to view
160   suppressed content but not suppress it ("suppressrevision" right).
161 * (bug 66440) The MediaWiki web installer will now allow you to choose the skins
162   to enable (from the ones included in download tarball) and decide which one
163   should be the default.
164 * (bug 68085, 68802) Links like [[localInterwikiPrefix:languageCode:pageTitle]],
165   where localInterwikiPrefix is a member of the $wgLocalInterwikis array, will
166   no longer be displayed in the sidebar when $wgInterwikiMagic is true. In a
167   similar way, links like [[localInterwikiPrefix:File:Image.png]] and
168   [[localInterwikiPrefix:Category:Hello]] will now render as regular links, and
169   will not include the file or add the page to the category.
170 * New special page, MyLanguage, to redirect users to subpages with localised
171   versions of a page. (Integrated from Extension:Translate)
172 * MediaWiki now supports multiple password types, including bcrypt and PBKDF2.
173   The default type can be changed with $wgPasswordDefault and the type
174   configurations can be changed with $wgPasswordConfig.
175 * Skins can now define custom styles for default ResourceLoader modules using
176   the $wgResourceModuleSkinStyles global. See the Vector skin for examples.
177 * (bug 4488) There is now a preference to watch pages where the user has
178   rollbacked an edit by default.
179 * (bug 15484) Users will now be redirected to the login page when they need to
180   log in, rather than being shown a page asking them to log in and having to click
181   another link to actually get to the login page.
182 * A JsonContent and JsonContentHandler were added for extensions to extend.
183 * (bug 35045) Redirects to sections will now update the URL in browser's address
184   bar using the HTML5 History API. When [[Dog]] redirects to [[Animals#Dog]],
185   the user will now see "Animals#Dog" in their browser instead of "Dog#Dog".
186 * API token handling has been rewritten. Any API module using tokens will need
187   to be updated. See the entry below under "Action API internal changes".
188 * Added HTMLAutoCompleteSelectField.
189 * Added a new hook, "SkinPreloadExistence", to allow extensions to add titles to
190   link existence cache before the page is rendered.
191 * Config::set() was moved to its own interface, MutableConfig. GlobalVarConfig::set()
192   is now deprecated, does not implement MutableConfig.
193 * A MutableConfig named HashConfig was added, that stores an array of configuration
194   settings.
195 * (bug 69418) A MultiConfig implementation was added that supports fallback
196   to multiple Config instances.
197 * Update CSSJanus to v1.1.0.
198 * Added FormatJson::parse() returning status with result or localized error message
200 === Bug fixes in 1.24 ===
201 * (bug 50572) MediaWiki:Blockip should support gender
202 * (bug 49116) Footer copyright notice is now always displayed in user language
203   rather than content language (same as copyright notice for editing interface).
204 * (bug 62258) A bug was fixed in File::getUnscaledThumb when a height
205   restriction was present in the parameters. Images with both the "frame"
206   option and a size specification set will now always ignore the provided
207   size and display an unscaled image, as the documentation has always
208   claimed it would.
209 * (bug 39035) Improved Vector skin performance by removing collapsibleNav,
210   which used to collapse some sidebar elements by default.
211   This removes -list id suffixes like p-lang-list: instead of using things like
212   #p-lang-list, you can do #p-lang .body ul.
213 * (bug 890) Links in Special:RecentChanges and Special:Watchlist no longer
214   follow redirects to their target pages.
215 * Parser now dies early if called recursively, instead of producing subtle bugs.
216 * (bug 14323) Redirect pages, when viewed with redirect=no, no longer hide the
217   remaining page content.
218 * (bug 52587) Maintenance script deleteBatch.php no longer follows redirects
219   in the file namespace and delete the file on the target page. It will still
220   however delete the redirect page.
221 * (bug 22683) {{msgnw:}} and other uses of PPFrame::RECOVER_ORIG will correctly
222   recover the original code of extension tags.
223 * (bug 65757) MSSQL: Update script drops unnamed constraints to be prepared
224   for future updates. Because it's doing so heuristically, it may fail or drop
225   wrong constraints.
226 * (bug 67870) wfShellExec() cuts off stdout at multiples of 8192 bytes.
227 * $wgRunJobsAsync now works with private wikis (e.g. read requires login).
228 * (bugs 57238, 65206) Blank pages can now be directly created.
229 * (bug 69789) Title::getContentModel() now loads from the database when
230   necessary instead of incorrectly returning the default content model.
231 * (bug 69249) wfBaseConvert() now works around PHP Bug #50175 when using GMP.
232 * (bug 57909) URLs in the externallinks table will no longer have certain
233   characters decoded in the query string.
234 * (bug 67368) LESS mixins like .background-image() correctly flip image
235   references for RTL stylesheets now.
237 === Action API changes in 1.24 ===
238 * action=parse API now supports prop=modules, which provides the list of
239   ResourceLoader modules that should be used to enhance the parsed content.
240 * action=query&meta=siteinfo&siprop=interwikimap returns a new "protorel"
241   field which is true if protocol-relative urls can be used to access
242   a particular interwiki map entry.
243 * list=logevents now provides logpage, which is the page ID from the
244   logging table, if ids are requested and the user has the permissions.
245 * action=edit now requires that appendtext, prependtext, or section=new be used
246   when using the 'redirect' parameter, to prevent clients accidentally
247   overwriting the target page with the content of the redirect.
248 * list=logevents will now return an error if both letitle and leprefix are
249   specified.
250 * list=logevents has a new parameter, lenamespace, to allow filtering by
251   namespace.
252 * action=expandtemplates has a new parameter, prop, and a new output format.
253   The old format is still used if prop isn't provided, but this is deprecated.
254 * meta=userinfo can now return the count of unread pages on the watchlist.
255 * list=watchlist can now filter by unread status.
256 * The deprecated action=parse&prop=languageshtml has been removed.
257 * (bug 48071) action=setnotificationtimestamp no longer throws PHP or database
258   errors when no pages are given.
259 * (bug 60734) Actions that use ApiPageSet (e.g. purge, watch,
260   setnotificationtimestamp) will now include continuation information when
261   using a generator.
262 * Removed 'props' and 'errors' from action=paraminfo, as they have extremely
263   limited use and are generally inaccurate, unmaintained, and impossible to
264   properly maintain.
265 * Formats dbg, dump, txt, wddx, and yaml are now deprecated.
266 * action=paraminfo now indicates when a parameter is specifying a submodule.
267 * The iwurl parameter to prop=iwlinks is deprecated in favor of iwprop=url, for
268   parallelism with prop=langlinks.
269 * All tokens should be fetched from action=query&meta=tokens; all other methods
270   of fetching tokens are deprecated. The value needed for meta=tokens's 'type'
271   parameter for each module is documented in the action=help output and is
272   returned from action=paraminfo.
273 * New action ClearHasMsg that can be used to clear HasMsg flag.
274 * The cmstartsortkey and cmendsortkey parameters to list=categorymembers are
275   deprecated in favor of cmstarthexsortkey and cmendhexsortkey.
276 * (bug 63326) Add blockedtimestamp field to output of blockinfo property for
277   the list=allusers and list=users modules.
278 * prop=imageinfo no longer requires iiurlwidth to be set when using iiurlparam.
279 * Added prop=linkshere, prop=fileusage, and prop=transcludedin, which are
280   roughly equivalent to list=backlinks, list=imageusage, and list=embeddedin
281   but can work on a list of titles (including titles from a generator).
282 * prop=redirects can now filter returned redirects by namespace.
284 === Action API internal changes in 1.24 ===
285 * Methods for handling continuation are added to ApiResult, so actions other
286   than query that use generators can easily support continuation.
287 * $wgAPIModules (and the related $wgAPIFormatModules, $wgAPIMetaModules,
288   $wgAPIPropModules, and $wgAPIListModules settings) now allow API modules
289   to be specified using a "module spec" array instead of a plain class name.
290   A "module spec" is an associative array containing at least the 'class' key
291   for the module's class, and optionally a 'factory' key for the factory function
292   to use for the module. This is intended for extensions that want control over
293   the instantiation of their API modules, to allow for proper dependency
294   injection.
295 * A new param type 'submodule' is available. Parameters of this type will take
296   the list of valid values from the module's ApiModuleManager for the group
297   corresponding to the parameter name.
298 * The 'APIGetPossibleErrors' and 'APIGetResultProperties' hooks are no longer used.
299 * API token handling has been rewritten. Any API module using tokens will need
300   to be updated:
301   * ApiBase::needsToken now returns a token type instead of boolean true when a
302     token is needed. Returning true will throw an exception. See documentation
303     of that method for details.
304   * Information for the 'token' parameter is automatically set by ApiBase
305     getFinalParams and getFinalParamDescription.
306   * ApiBase::getTokenSalt has been removed.
307   * The hooks APIQueryInfoTokens, APIQueryRevisionsTokens,
308     APIQueryRecentChangesTokens, APIQueryUsersTokens, and
309     ApiTokensGetTokenTypes are deprecated, but are still called to support
310     backwards-compatible token access.
311 * ApiBase::validateLimit and ApiBase::validateTimestamp are now protected.
312 * ApiQueryRedirects was removed; prop=redirects is now implemented by
313   ApiQueryBacklinksProp along with the newly-added prop modules.
314 * The following methods have been deprecated and may be removed in a future
315   release:
316   * ApiBase::getResultProperties
317   * ApiBase::getFinalResultProperties
318   * ApiBase::addTokenProperties
319   * ApiBase::getRequireOnlyOneParameterErrorMessages
320   * ApiBase::getRequireMaxOneParameterErrorMessages
321   * ApiBase::getRequireAtLeastOneParameterErrorMessages
322   * ApiBase::getTitleOrPageIdErrorMessage
323   * ApiBase::getPossibleErrors
324   * ApiBase::getFinalPossibleErrors
325   * ApiBase::parseErrors
326   * ApiQuery::setGeneratorContinue
327   * ApiQueryBase::checkRowCount
328   * ApiQueryBase::titleToKey
329   * ApiQueryBase::keyToTitle
330   * ApiQueryBase::keyPartToTitle
331   * ApiQueryInfo::getTokenFunctions
332   * ApiQueryInfo::resetTokenCache
333   * ApiQueryInfo::getEditToken
334   * ApiQueryInfo::getDeleteToken
335   * ApiQueryInfo::getProtectToken
336   * ApiQueryInfo::getMoveToken
337   * ApiQueryInfo::getBlockToken
338   * ApiQueryInfo::getUnblockToken
339   * ApiQueryInfo::getEmailToken
340   * ApiQueryInfo::getImportToken
341   * ApiQueryInfo::getWatchToken
342   * ApiQueryInfo::getOptionsToken
343   * ApiQueryRecentChanges::getTokenFunctions
344   * ApiQueryRecentChanges::getPatrolToken
345   * ApiQueryRevisions::getTokenFunctions
346   * ApiQueryRevisions::getRollbackToken
347   * ApiQueryUsers::getTokenFunctions
348   * ApiQueryUsers::getUserrightsToken
349 * The following classes have been deprecated and may be removed in a future
350   release:
351   * ApiFormatDbg
352   * ApiFormatDump
353   * ApiFormatTxt
354   * ApiFormatWddx
355   * ApiFormatYaml
356   * ApiTokens
357 * The following class constants have been deprecated and may be removed in a
358   future release:
359   * ApiBase::PROP_ROOT
360   * ApiBase::PROP_LIST
361   * ApiBase::PROP_TYPE
362   * ApiBase::PROP_NULLABLE
364 === Languages updated in 1.24 ===
366 MediaWiki supports over 350 languages. Many localisations are updated
367 regularly. Below only new and removed languages are listed, as well as
368 changes to languages because of Bugzilla reports.
370 === Other changes in 1.24 ===
371 * The deprecated jquery.delayedBind ResourceLoader module was removed.
372 * The deprecated function mw.util.toggleToc was removed.
373 * The Special:Search hooks SpecialSearchGo and SpecialSearchResultsAppend
374   were removed as they were unused.
375 * (bug 65477) User::pingLimiter() now has an additional profile point varying
376   by action being used.
377 * mediawiki.util.$content no longer supports old versions of the Vector,
378   Monobook, Modern and CologneBlue skins that don't yet implement the "mw-body"
379   and/or "mw-body-primary" class name in their html.
380 * Added pp_sortkey column to page_props table, so pages can be efficiently
381   queried and sorted by property value (bug 58032).
382   See $wgPagePropsHaveSortkey if you want to postpone the schema change.
383 * BREAKING CHANGE: All four built-in MediaWiki skins (Vector, MonoBook, Modern
384   and Cologne Blue) were moved out of MediaWiki core to their own respective
385   repositories. They will be installed with the release tarball, but you must
386   install them separately if installing MediaWiki from source code. A warning
387   message displayed until you do it should guide you through the process. See
388   also <https://www.mediawiki.org/wiki/Manual:Skin_configuration>.
389 * BREAKING CHANGE: Skins built for MediaWiki 1.15 and earlier that do not use
390   the "headelement" template key are no longer supported. Setting
391   $useHeadElement = false; is no longer supported and will not cause old keys
392   like "headlinks", "skinnameclass", etc. to be defined.
393 * BREAKING CHANGE: The files commonElements.css, commonContent.css and
394   commonInterface.css (in skins/common/) have been removed. Skins may no longer
395   rely on their presence and include them in their style modules. ResourceLoader
396   modules introduced in MediaWiki 1.23 should be loaded instead:
397   - skins/common/commonElements.css  â†’ 'mediawiki.skinning.elements' module
398   - skins/common/commonContent.css   â†’ 'mediawiki.skinning.content' module
399   - skins/common/commonInterface.css â†’ 'mediawiki.skinning.interface' module
400 * The deprecated 'SpecialVersionExtensionTypes' hook was removed.
401 * (bug 63891) Add 'X-Robots-Tag: noindex' header in action=render pages.
402 * SpecialPage no longer supports the syntax for invoking wfSpecial*() functions.
403   Special pages should subclass SpecialPage and implement the execute() method.
404 * (bug 63755) The deprecated constants RC_MOVE and RC_MOVE_OVER_REDIRECT were
405   removed.
406 * Special:MostLinkedTemplates has been renamed to Special:MostTranscludedPages.
407 * The skin autodiscovery mechanism has been deprecated and will be removed in
408   MediaWiki 1.25. See https://www.mediawiki.org/wiki/Manual:Skin_autodiscovery
409   for migration guide for creators and users of custom skins that relied on it.
410 * ResourceLoaderFileModule#getAllStyleFiles now returns all style files and all
411   skin style files used by the module.
412 * Removed getLang() from IContextSource and subclasses. (deprecated since 1.19)
413 * Removed setLang() from subclasses of IContextSource. (deprecated since 1.19)
414 * Removed WebRequest::escapeAppendQuery(). (deprecated since 1.20)
415 * Removed info(), purge(), revert() and rollback() from the Article class; they
416   have since become subclasses of the Action class. (deprecated since 1.19)
417 * SearchEngineReplacePrefixesComplete hook was removed.
418 * The "jquery.json" module has been deprecated. Use the "json" module instead.
419 * Removed HTMLForm::addJS(). (deprecated since 1.18)
420 * Removed LogEventsList::showHeader(). (deprecated since 1.19)
421 * Removed ImageGalleryBase::useSkin(). (deprecated since 1.18)
422 * Removed DatabaseMysqlBase::getLagFromProcesslist(). (deprecated since 1.19)
423 * Removed LoadBalancer::closeConnecton(). (deprecated since 1.18)
424 * Removed ApiBase::createContext(). (deprecated since 1.19)
425 * BREAKING CHANGE: The undocumented Special{$this->getName()}BeforeFormDisplay
426   set of hooks has been removed and replaced by a single new hook
427   SpecialPageBeforeFormDisplay.
428 * (bug 65781) Removed block warning on included {{Special:Contributions}}
429 * Removed Skin::makeGlobalVariablesScript(). (deprecated since 1.19)
430 * Removed MWNamespace::isMain(). (deprecated since 1.19)
431 * Removed Preferences::loadOldSearchNs(). (deprecated since 1.19)
432 * Removed OutputPage::getStatusMessage(). (deprecated since 1.18)
433 * Removed OutputPage::isUserJsAllowed(). (deprecated since 1.18)
434 * Removed Title::updateTitleProtection(). (deprecated since 1.19)
435 * Removed ParserOptions::setSkin(). (deprecated since 1.19)
436 * Removed Title::escapeCanonicalURL(). (deprecated since 1.19)
437 * Removed Title::escapeLocalURL(). (deprecated since 1.19)
438 * Removed Title::escapeFullURL(). (deprecated since 1.19)
439 * Removed User::isValidEmailAddr(). (deprecated since 1.18)
440 * Removed Title::getEscapedText(). (deprecated since 1.19)
441 * Removed Language::getFallbackLanguageCode(). (deprecated since 1.19)
442 * Removed WikiPage::isBigDeletion(). (deprecated since 1.19)
443 * Removed MWInit class which contained functions related to a now discontinued
444   PHP compiler called hphpc. (deprecated since 1.22)
445 * ApiResult::enableSizeCheck() and disableSizeCheck() are now obsolete.
446 * Removed ResourceLoaderGetStartupModules hook. (deprecated since 1.23)
447 * Removed getFormFields(), onSubmit() and onSuccess() from FormlessAction, as
448   these were meant specifically for FormAction instead.
449 * Removed Action::execute().
450 * Removed AjaxAddScript which has been obsolete since ResourceLoader and
451   is unused by any modern extension.
452 * Removed maintenance/nextJobDB.php; no longer in use.
453 * Removed global function wfViewPrevNext(). (deprecated since 1.19)
454 * Removed global function xmlsafe() from Export.php. (moved to OAIRepo extension)
455 * Removed Title::userCanRead(). (deprecated since 1.19)
456 * Removed maintenance script importTextFile.php. Use edit.php script instead.
457 * A _from_namespace field has been added to the templatelinks, pagelinks,
458   and filelinks tables. Run update.php to apply this change to the schema.
459 * Removed File::sha1Base36(). (deprecated since 1.19)
460 * Removed File::getPropsFromPath(). (deprecated since 1.19)
461 * Removed functions blockedPage(), noCreatePermission(), readOnlyPage() and
462   userNotLoggedInPage() from EditPage.php. (deprecated since 1.19)
463 * Removed functions getContent(), getPreloadedText(), mergeChangesInto() and
464   setPreloadedText() from EditPage.php. (deprecated since 1.21)
465 * Removed global functions wfArrayLookup(), wfArrayMerge(), wfDebugDieBacktrace()
466   and wfTime(). (deprecated since 1.22)
467 * Browser support for Internet Explorer 6 and 7 lowered from Grade A to Grade C,
468   meaning that JavaScript is no longer executed in these browser versions.
469 * Browser support for Opera 11 lowered from Grade A to Grade C.
470 * Removed IEFixes module which existed purely to provide support for MSIE versions
471 * Deprecated SpecialPageFactory::getList() in favor of
472   SpecialPageFactory::getNames()
473   below 7 (conditionally loaded only for those browsers).
474 * Action::checkCanExecute() no longer has a return value.
475 * Removed cleanupForIRC(), loadFromCurRow(), newFromCurRow(), notifyRC2UDP()
476   and sendToUDP() from RecentChange.php. (deprecated since 1.22)
477 * Removed EnhancedChangesList::arrow(), sideArrow(), downArrow(), spacerArrow().
478 * Removed Xml::namespaceSelector(). (deprecated since 1.19)
479 * Removed WikiPage::estimateRevisionCount(). (deprecated since 1.19)
480 * MYSQL: Enum item added to "major MIME type" columns.
481   Running update.php on MySQL < v5.1 may result in heavy processing.
482 * RSS and Atom feeds generated by MediaWiki no longer include a fallback
483   stylesheet. It was ignored by most browsers these days anyway.
484 * SpecialSearchNoResults hook has been removed. SpecialSearchResults is now
485   called unconditionally.
486 * TablePager::getBody() is now 'final' and can't be overridden in subclasses.
487 * TablePager::getBody() is deprecated, use getBodyOutput() or getFullOutput().
488 * Added $outputPage parameter to the SkinTemplateGetLanguageLink hook.
489 * log_page for move log entries store the original page ID, rather than that
490   of the new redirect page. This is not retroactive.
491 * LCStoreAccel was removed. $wgLocalisationCacheConf can no longer be set to
492   use this store class.
493 * Html::infoBox() no longer accepts paths relative to skins/common/images/.
494 * Deprecated defunct Skin::getCommonStylePath().
495 * Some extensions had their ResourceLoader modules depend on the "mediawiki"
496   and "jquery" modules. In the past, this behavior was undefined, now it will
497   throw an error.
498 * Removed BagOStuff::replace(). (deprecated since 1.23)
499 * In Linker.php, link(), linkText() and makeBrokenImageLinkObj() now display
500   warnings if their first parameter is not a Title object. Also makeImageLink()
501   now requires a Parser as its first parameter.
502 * (bug 67368) LESS functions embed() and embeddable(), added in MediaWiki 1.23
503   and broken by design, have been removed. Use appropriate LESS mixins instead.
504 * Removed cssjanus.py from maintenance directory as it was unused.
505 * Removed maintenance/purgeOldText.inc and the PurgeRedundantText() function
506   it contained (superseded by Maintenance::purgeRedundantText() in 1.16).
507   The purgeOldText.php maintenance script has been retained.
508 * PHPUnit tests can be found by directory discovery, by adding the directory
509   path from your UnitTestsList callback. Older versions of MediaWiki core will
510   barf at this usage.
512 ==== Renamed classes ====
513 * CLDRPluralRuleConverter_Expression to CLDRPluralRuleConverterExpression
514 * CLDRPluralRuleConverter_Fragment to CLDRPluralRuleConverterFragment
515 * CLDRPluralRuleConverter_Operator to CLDRPluralRuleConverterOperator
516 * CLDRPluralRuleEvaluator_Range to CLDRPluralRuleEvaluatorRange
517 * CSSJanus_Tokenizer to CSSJanusTokenizer
518 * MediaWiki_I18N to MediaWikiI18N
519 * Parser_DiffTest to ParserDiffTest
520 * RevDel_ArchiveItem to RevDelArchiveItem
521 * RevDel_ArchiveList to RevDelArchiveList
522 * RevDel_ArchivedFileItem to RevDelArchivedFileItem
523 * RevDel_ArchivedFileList to RevDelArchivedFileList
524 * RevDel_ArchivedRevisionItem to RevDelArchivedRevisionItem
525 * RevDel_FileItem to RevDelFileItem
526 * RevDel_FileList to RevDelFileList
527 * RevDel_Item to RevDelItem
528 * RevDel_List to RevDelList
529 * RevDel_LogItem to RevDelLogItem
530 * RevDel_LogList to RevDelLogList
531 * RevDel_RevisionItem to RevDelRevisionItem
532 * RevDel_RevisionList to RevDelRevisionList
533 * WebInstaller_Complete to WebInstallerComplete
534 * WebInstaller_Copying to WebInstallerCopying
535 * WebInstaller_DBConnect to WebInstallerDBConnect
536 * WebInstaller_DBSettings to WebInstallerDBSettings
537 * WebInstaller_Document to WebInstallerDocument
538 * WebInstaller_ExistingWiki to WebInstallerExistingWiki
539 * WebInstaller_Install to WebInstallerInstall
540 * WebInstaller_Language to WebInstallerLanguage
541 * WebInstaller_Name to WebInstallerName
542 * WebInstaller_Options to WebInstallerOptions
543 * WebInstaller_Readme to WebInstallerReadme
544 * WebInstaller_ReleaseNotes to WebInstallerReleaseNotes
545 * WebInstaller_Restart to WebInstallerRestart
546 * WebInstaller_Upgrade to WebInstallerUpgrade
547 * WebInstaller_UpgradeDoc to WebInstallerUpgradeDoc
548 * WebInstaller_Welcome to WebInstallerWelcome
550 ==== Removed classes ====
551 * IPBlockForm - Use SpecialBlock directly
552 * WatchlistEditor - Use SpecialEditWatchlist directly
553 * FormatExif - Use FormatMetadata directly
554 * RevertFileAction - Use RevertAction directly
555 * HistoryPage - Use HistoryAction directly
556 * RawPage - Use RawAction directly
557 * StubContLang - Use Language::factory() instead
558 * XMLReader2 - Use XMLReader directly
559 * ResourceLoaderLESSFunctions - No longer in use, not intended for public usage
561 ==== Removed files ====
562 The skins/common/ directory, previously containing some assets intended to be
563 used by skins and a number of legacy styles and scripts, has been removed. Its
564 contents have been deleted or relocated into the resources/ directory. Full list
565 of files that are no longer available follows.
567 * skins/common/ajax.js
568 * skins/common/commonContent.css
569 * skins/common/commonElements.css
570 * skins/common/commonInterface.css
571 * skins/common/commonPrint.css
572 * skins/common/config-cc.css
573 * skins/common/config.css
574 * skins/common/config.js
575 * skins/common/feed.css
576 * skins/common/IEFixes.js
577 * skins/common/oldshared.css
578 * skins/common/protect.js
579 * skins/common/shared.css
580 * skins/common/upload.js
581 * skins/common/wikibits.js
582 * skins/common/images/add.png
583 * skins/common/images/ajax-loader.gif
584 * skins/common/images/arrow_disabled_first_25.png
585 * skins/common/images/arrow_disabled_last_25.png
586 * skins/common/images/arrow_disabled_left_25.png
587 * skins/common/images/arrow_disabled_right_25.png
588 * skins/common/images/arrow_first_25.png
589 * skins/common/images/arrow_last_25.png
590 * skins/common/images/arrow_left_25.png
591 * skins/common/images/arrow_right_25.png
592 * skins/common/images/Arr_.png
593 * skins/common/images/Arr_d.png
594 * skins/common/images/Arr_l.png
595 * skins/common/images/Arr_r.png
596 * skins/common/images/Arr_u.png
597 * skins/common/images/bullet.gif
598 * skins/common/images/button_bold.png
599 * skins/common/images/button_extlink.png
600 * skins/common/images/button_headline.png
601 * skins/common/images/button_hr.png
602 * skins/common/images/button_image.png
603 * skins/common/images/button_italic.png
604 * skins/common/images/button_link.png
605 * skins/common/images/button_media.png
606 * skins/common/images/button_nowiki.png
607 * skins/common/images/button_sig.png
608 * skins/common/images/button_template.png
609 * skins/common/images/cc-0.png
610 * skins/common/images/cc-by-nc-sa.png
611 * skins/common/images/cc-by-sa.png
612 * skins/common/images/cc-by.png
613 * skins/common/images/Checker-16x16.png
614 * skins/common/images/closewindow.png
615 * skins/common/images/closewindow19x19.png
616 * skins/common/images/critical-32.png
617 * skins/common/images/diffunderline.gif
618 * skins/common/images/download-32.png
619 * skins/common/images/feed-icon.png
620 * skins/common/images/feed-icon.svg
621 * skins/common/images/gnu-fdl.png
622 * skins/common/images/help-question-hover.gif
623 * skins/common/images/help-question.gif
624 * skins/common/images/info-32.png
625 * skins/common/images/link_icon.gif
626 * skins/common/images/magnify-clip-rtl.png
627 * skins/common/images/magnify-clip.png
628 * skins/common/images/mediawiki.png
629 * skins/common/images/nextredirectltr.png
630 * skins/common/images/nextredirectrtl.png
631 * skins/common/images/poweredby_mediawiki_88x31.png
632 * skins/common/images/public-domain.png
633 * skins/common/images/question-small.png
634 * skins/common/images/question.svg
635 * skins/common/images/redirectltr.png
636 * skins/common/images/redirectrtl.png
637 * skins/common/images/remove.png
638 * skins/common/images/spinner.gif
639 * skins/common/images/tick-32.png
640 * skins/common/images/tipsy-arrow.gif
641 * skins/common/images/tooltip_icon.png
642 * skins/common/images/warning-32.png
643 * skins/common/images/wiki.png
644 * skins/common/images/Zoom_sans.gif
645 * skins/common/images/ar/button_bold.png
646 * skins/common/images/ar/button_headline.png
647 * skins/common/images/ar/button_italic.png
648 * skins/common/images/ar/button_link.png
649 * skins/common/images/ar/button_nowiki.png
650 * skins/common/images/be-tarask/button_bold.png
651 * skins/common/images/be-tarask/button_italic.png
652 * skins/common/images/be-tarask/button_link.png
653 * skins/common/images/cyrl/button_bold.png
654 * skins/common/images/cyrl/button_italic.png
655 * skins/common/images/cyrl/button_link.png
656 * skins/common/images/de/button_bold.png
657 * skins/common/images/de/button_italic.png
658 * skins/common/images/fa/button_bold.png
659 * skins/common/images/fa/button_headline.png
660 * skins/common/images/fa/button_italic.png
661 * skins/common/images/fa/button_link.png
662 * skins/common/images/fa/button_nowiki.png
663 * skins/common/images/icons/fileicon-c.png
664 * skins/common/images/icons/fileicon-cpp.png
665 * skins/common/images/icons/fileicon-deb.png
666 * skins/common/images/icons/fileicon-djvu.png
667 * skins/common/images/icons/fileicon-djvu.xcf
668 * skins/common/images/icons/fileicon-dvi.png
669 * skins/common/images/icons/fileicon-exe.png
670 * skins/common/images/icons/fileicon-h.png
671 * skins/common/images/icons/fileicon-html.png
672 * skins/common/images/icons/fileicon-iso.png
673 * skins/common/images/icons/fileicon-java.png
674 * skins/common/images/icons/fileicon-mid.png
675 * skins/common/images/icons/fileicon-mov.png
676 * skins/common/images/icons/fileicon-o.png
677 * skins/common/images/icons/fileicon-ogg.png
678 * skins/common/images/icons/fileicon-ogg.xcf
679 * skins/common/images/icons/fileicon-pdf.png
680 * skins/common/images/icons/fileicon-ps.png
681 * skins/common/images/icons/fileicon-psd.png
682 * skins/common/images/icons/fileicon-rm.png
683 * skins/common/images/icons/fileicon-rpm.png
684 * skins/common/images/icons/fileicon-svg.png
685 * skins/common/images/icons/fileicon-tar.png
686 * skins/common/images/icons/fileicon-tex.png
687 * skins/common/images/icons/fileicon-ttf.png
688 * skins/common/images/icons/fileicon-txt.png
689 * skins/common/images/icons/fileicon.png
690 * skins/common/images/ksh/button_S_italic.png
692 == Compatibility ==
694 MediaWiki 1.24 requires PHP 5.3.2 or later. There is experimental support for
695 HHVM 3.3.0.
697 MySQL is the recommended DBMS. PostgreSQL or SQLite can also be used, but
698 support for them is somewhat less mature. There is experimental support for
699 Oracle and Microsoft SQL Server.
701 The supported versions are:
703 * MySQL 5.0.2 or later
704 * PostgreSQL 8.3 or later
705 * SQLite 3.3.7 or later
706 * Oracle 9.0.1 or later
707 * Microsoft SQL Server 2005 (9.00.1399)
709 == Upgrading ==
711 1.24 has several database changes since 1.23, and will not work without schema
712 updates. Note that due to changes to some very large tables like the revision
713 table, the schema update may take quite long (minutes on a medium sized site,
714 many hours on a large site).
716 If upgrading from before 1.11, and you are using a wiki as a commons
717 repository, make sure that it is updated as well. Otherwise, errors may arise
718 due to database schema changes.
720 If upgrading from before 1.7, you may want to run refreshLinks.php to ensure
721 new database fields are filled with data.
723 If you are upgrading from MediaWiki 1.4.x or earlier, you should upgrade to
724 1.5 first. The upgrade script maintenance/upgrade1_5.php has been removed
725 with MediaWiki 1.21.
727 Don't forget to always back up your database before upgrading!
729 See the file UPGRADE for more detailed upgrade instructions.
731 For notes on 1.23.x and older releases, see HISTORY.
733 == Online documentation ==
735 Documentation for both end-users and site administrators is available on
736 MediaWiki.org, and is covered under the GNU Free Documentation License (except
737 for pages that explicitly state that their contents are in the public domain):
739         https://www.mediawiki.org/wiki/Documentation
741 == Mailing list ==
743 A mailing list is available for MediaWiki user support and discussion:
745         https://lists.wikimedia.org/mailman/listinfo/mediawiki-l
747 A low-traffic announcements-only list is also available:
749         https://lists.wikimedia.org/mailman/listinfo/mediawiki-announce
751 It's highly recommended that you sign up for one of these lists if you're
752 going to run a public MediaWiki, so you can be notified of security fixes.
754 == IRC help ==
756 There's usually someone online in #mediawiki on irc.freenode.net.