Followup 248ac9e: set $wgAutoloadClasses to an array after declaring
[mediawiki.git] / RELEASE-NOTES-1.24
blob5d4fc074ed72b7dd95ee329946a72645ee067232
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. Any extensions
46   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.
51 === New features in 1.24 ===
52 * Added a new hook, "WhatLinksHereProps", to allow extensions to annotate
53   WhatLinksHere entries.
54 * Added a new hook, "ContentGetParserOutput", to customize parser output for
55   a given content object.
56 * Deprecated the hook "ShowRawCssJs", use "ContentGetParserOutput" instead.
57 * HTMLForm's HTMLTextField now supports the 'url' type.
58 * HTMLForm fields may now be dynamically hidden based on the values of other
59   fields in the form.
60 * HTMLForm now supports multiple copies of an input field or set of input
61   fields, e.g. the form may request "one or more usernames" without having to
62   have the user enter delimited list of names into a text field.
63 * Added a new hook, "SidebarBeforeOutput", to allow to edit the structure of
64   the sidebar just before its display.
65 * (bug 49156) Added the mediawiki.cookie ResourceLoader module, which wraps
66   jquery.cookie so that getting/setting a cookie is syntactically and
67   functionally similar to using the WebRequest::getCookie() and
68   WebResponse::setcookie() methods.
69 * (bug 44740) jQuery upgraded from 1.8.3 to 1.11.1. A new configuration option,
70   $wgIncludejQueryMigrate, also loads the jQuery Migrate hack to let extensions
71   and gadgets use the long-deprecated functions that were removed in jQuery 1.9.
72   This option is turned off by default, and will be removed in MediaWiki 1.25.
73 * (bug 47076) jQuery UI upgraded from 1.8.24 to 1.9.2.
74 * Changes to content typography (fonts, etc.). See
75   https://www.mediawiki.org/wiki/Typography_refresh for further information.
76 * WikitextContent will now render redirects with the expected "redirect"
77   header, rather than as an ordered list. Code calling Article::viewRedirect
78   can probably be changed to no longer special-case redirects.
79 * Header font set to a serif font stack. See
80   https://www.mediawiki.org/wiki/Typography_refresh for further information.
81 * (bug 65567) Added a new hook, "BeforeHttpsRedirect", to allow cancellation of
82   the HTTP to HTTPS redirect due to forceHTTPS cookie, userRequires, etc. This
83   is only for page views, since this hook doesn't affect UserLogin, OAuth,
84   CentralAuth, etc. ATTENTION: This hook is likely to be removed soon due to
85   overall design of the system.
86 * (bug 17367) It is now possible to add pages to your watchlist from
87   Special:UnwatchedPages without reloading the special page.
88 * New methods setVolatile and isVolatile are added to PPFrame, so that
89   extensions such as Cite.php can mark that their output is volatile and
90   shouldn't be cached.
91 * (bug 52817) Advanced search options are now saved on the search page itself,
92   rather than in a dedicated pane in the preferences panel.
93 * (bug 44591) The dropdown actions menu (little triangle next to page tabs) in
94   the Vector skin has gained a label that should make it more discoverable.
95 * MWCryptHKDF added for fast, cryptographically secure random number generation
96   that won't deplete openssl's entropy pool.
97 * ResourceLoader: File modules can now provide a skip function that uses an
98   inline feature test to bypass loading of the module.
99 * (bug 20210) Special pages may now provide autocompletion of their subpage
100   names in search suggestions. Right now the only useful implementation is in
101   Special:Log, but more are to come.
102 * Special:MostLinkedTemplates is no longer limited to transclusions from the
103   Template namespace.
104 * Skins can now use 'remoteSkinPath' when defining ResourceLoader modules.
105   This works the same as 'remoteExtPath' but is relative to the skins/ folder
106   instead of the extensions/ folder.
107 * Added the json2.js polyfill for the ES5 JSON.stringify and JSON.parse methods.
108   Exposed as module "json" with a skip function to optimise loading.
109 * Extensions and skins may now use 'namemsg' in $wgExtensionCredits in addition
110   to 'name', to allow for the name to be localizable. 'name' should still be
111   specified for backwards-compatibility and to define the path Special:Version
112   uses to find extension license information.
113 * Browser tests are now included to verify basic wiki functionality in developer
114   environments. For details on running tests, see tests/browser/README.mediawiki.
115 * Upgrade jStorage to v0.4.10.
116 * {{!}} is now a magic word that produces the | character. This removes the need
117   for Template:! for purposes such as passing pipes inside of parameters.
118 * (bug 20790) The block log snippet on Special:Contributions and while
119   editing user and user talk pages now works for IP range blocks.
120 * (bug 9360) Added ability to change the page language for MediaWiki pages using
121   Special:PageLanguage. All pages are set to wiki language by default.
122   The feature needs to be enabled with $wgPageLanguageUseDB=true and
123   permission needs to be set for 'pagelang'.
124 * Upgrade Moment.js to v2.7.0.
125 * (bug 67042) Added support for the HTML5 <rtc> tag for East Asian typography.
126 * Upgrade Sinon.JS to 1.10.3.
127 * Added the es5-shim polyfill for older or non-compliant javascript engines.
128 * Upgrade jQuery Cookie to v1.3.1.
129 * (bug 20476) Add a "viewsuppressed" user right to be able to view
130   suppressed content but not suppress it ("suppressrevision" right).
131 * (bug 66440) The MediaWiki web installer will now allow you to choose the skins
132   to enable (from the ones included in download tarball) and decide which one
133   should be the default.
134 * (bug 68085, 68802) Links like [[localInterwikiPrefix:languageCode:pageTitle]],
135   where localInterwikiPrefix is a member of the $wgLocalInterwikis array, will
136   no longer be displayed in the sidebar when $wgInterwikiMagic is true. In a
137   similar way, links like [[localInterwikiPrefix:File:Image.png]] and
138   [[localInterwikiPrefix:Category:Hello]] will now render as regular links, and
139   will not include the file or add the page to the category.
140 * New special page, MyLanguages, to redirect users to subpages with localised
141   versions of a page. (Integrated from Extension:Translate)
142 * MediaWiki now supports multiple password types, including bcrypt and PBKDF2.
143   The default type can be changed with $wgPasswordDefault and the type
144   configurations can be changed with $wgPasswordConfig.
145 * Skins can now define custom styles for default ResourceLoader modules using
146   the $wgResourceModuleSkinStyles global. See the Vector skin for examples.
147 * (bug 4488) There is now a preference to watch pages where the user has
148   rollbacked an edit by default.
149 * (bug 15484) Users will now be redirected to the login page when they need to
150   log in, rather than being shown a page asking them to log in and having to click
151   another link to actually get to the login page.
152 * A JSONContent and JSONContentHandler were added for extensions to extend.
154 === Bug fixes in 1.24 ===
155 * (bug 50572) MediaWiki:Blockip should support gender
156 * (bug 49116) Footer copyright notice is now always displayed in user language
157   rather than content language (same as copyright notice for editing interface).
158 * (bug 62258) A bug was fixed in File::getUnscaledThumb when a height
159   restriction was present in the parameters. Images with both the "frame"
160   option and a size specification set will now always ignore the provided
161   size and display an unscaled image, as the documentation has always
162   claimed it would.
163 * (bug 39035) Improved Vector skin performance by removing collapsibleNav,
164   which used to collapse some sidebar elements by default.
165   This removes -list id suffixes like p-lang-list: instead of using things like
166   #p-lang-list, you can do #p-lang .body ul.
167 * (bug 890) Links in Special:RecentChanges and Special:Watchlist no longer
168   follow redirects to their target pages.
169 * Parser now dies early if called recursively, instead of producing subtle bugs.
170 * (bug 14323) Redirect pages, when viewed with redirect=no, no longer hide the
171   remaining page content.
172 * (bug 52587) Maintenance script deleteBatch.php no longer follows redirects
173   in the file namespace and delete the file on the target page. It will still
174   however delete the redirect page.
175 * (bug 22683) {{msgnw:}} and other uses of PPFrame::RECOVER_ORIG will correctly
176   recover the original code of extension tags.
177 * (bug 65757) MSSQL: Update script drops unnamed constraints to be prepared
178   for future updates. Because it's doing so heuristically, it may fail or drop
179   wrong constraints.
180 * (bug 67870) wfShellExec() cuts off stdout at multiples of 8192 bytes.
181 * $wgRunJobsAsync now works with private wikis (e.g. read requires login).
182 * (bugs 57238, 65206) Blank pages can now be directly created.
184 === Web API changes in 1.24 ===
185 * action=parse API now supports prop=modules, which provides the list of
186   ResourceLoader modules that should be used to enhance the parsed content.
187 * action=query&meta=siteinfo&siprop=interwikimap returns a new "protorel"
188   field which is true iff protocol-relative urls can be used to access
189   a particular interwiki map entry.
190 * ApiQueryLogEvents now provides logpage, which is the page ID from the
191   logging table, if ids are requested and the user has the permissions.
192 * action=edit now requires that appendtext, prependtext, or section=new be used
193   when using the 'redirect' parameter, to prevent clients accidentally
194   overwriting the target page with the content of the redirect.
195 * action=logevents will now return an error if both letitle and leprefix are
196   specified.
197 * action=logevents has a new parameter, lenamespace, to allow filtering by
198   namespace.
199 * action=expandtemplates has a new parameter, prop, and a new output format.
200   The old format is still used if prop isn't provided, but this is deprecated.
201 * meta=userinfo can now return the count of unread pages on the watchlist.
202 * list=watchlist can now filter by unread status.
203 * The deprecated action=parse&prop=languageshtml has been removed.
204 * (bug 48071) action=setnotificationtimestamp no longer throws PHP or database
205   errors when no pages are given.
206 * (bug 60734) Actions that use ApiPageSet (e.g. purge, watch,
207   setnotificationtimestamp) will now include continuation information when
208   using a generator.
209 * $wgAPIModules (and the related $wgAPIFormatModules, $wgAPIMetaModules,
210   $wgAPIPropModules, and $wgAPIListModules settings) now allow API modules
211   to be specified using a "module spec" array instead of a plain class name.
212   A "module spec" is an associative array containing at least the 'class' key
213   for the module's class, and optionally a 'factory' key for the factory function
214   to use for the module. This is intended for extensions that want control over
215   the instantiation of their API modules, to allow for proper dependency
216   injection.
218 === Languages updated in 1.24 ===
220 MediaWiki supports over 350 languages. Many localisations are updated
221 regularly. Below only new and removed languages are listed, as well as
222 changes to languages because of Bugzilla reports.
224 === Other changes in 1.24 ===
225 * The deprecated jquery.delayedBind ResourceLoader module was removed.
226 * The deprecated function mw.util.toggleToc was removed.
227 * The Special:Search hooks SpecialSearchGo and SpecialSearchResultsAppend
228   were removed as they were unused.
229 * (bug 65477) User::pingLimiter() now has an additional profile point varying
230   by action being used.
231 * mediawiki.util.$content no longer supports old versions of the Vector,
232   Monobook, Modern and CologneBlue skins that don't yet implement the "mw-body"
233   and/or "mw-body-primary" class name in their html.
234 * Added pp_sortkey column to page_props table, so pages can be efficiently
235   queried and sorted by property value (bug 58032).
236   See $wgPagePropsHaveSortkey if you want to postpone the schema change.
237 * BREAKING CHANGE: The Modern and Cologne Blue skins were moved out of MediaWiki
238   core to their own respective repositories. See also
239   https://www.mediawiki.org/wiki/Skin:Modern and
240   https://www.mediawiki.org/wiki/Skin:CologneBlue.
241 * BREAKING CHANGE: Skins built for MediaWiki 1.15 and earlier that do not use
242   the "headelement" template key are no longer supported. Setting
243   $useHeadElement = false; is no longer supported and will not cause old keys
244   like "headlinks", "skinnameclass", etc. to be defined.
245 * The deprecated 'SpecialVersionExtensionTypes' hook was removed.
246 * (bug 63891) Add 'X-Robots-Tag: noindex' header in action=render pages.
247 * SpecialPage no longer supports the syntax for invoking wfSpecial*() functions.
248   Special pages should subclass SpecialPage and implement the execute() method.
249 * (bug 63755) The deprecated constants RC_MOVE and RC_MOVE_OVER_REDIRECT were
250   removed.
251 * Special:MostLinkedTemplates has been renamed to Special:MostTranscludedPages.
252 * The skin autodiscovery mechanism has been deprecated and will be removed in
253   MediaWiki 1.25. See https://www.mediawiki.org/wiki/Manual:Skin_autodiscovery
254   for migration guide for creators and users of custom skins that relied on it.
255 * ResourceLoaderFileModule#getAllStyleFiles now returns all style files and all
256   skin style files used by the module.
257 * Removed getLang() from IContextSource and subclasses. (deprecated since 1.19)
258 * Removed setLang() from subclasses of IContextSource. (deprecated since 1.19)
259 * Removed WebRequest::escapeAppendQuery(). (deprecated since 1.20)
260 * Removed info(), purge(), revert() and rollback() from the Article class; they
261   have since become subclasses of the Action class. (deprecated since 1.19)
262 * SearchEngineReplacePrefixesComplete hook was removed.
263 * The "jquery.json" module has been deprecated. Use the "json" module instead.
264 * Removed HTMLForm::addJS(). (deprecated since 1.18)
265 * Removed LogEventsList::showHeader(). (deprecated since 1.19)
266 * Removed ImageGalleryBase::useSkin(). (deprecated since 1.18)
267 * Removed DatabaseMysqlBase::getLagFromProcesslist(). (deprecated since 1.19)
268 * Removed LoadBalancer::closeConnecton(). (deprecated since 1.18)
269 * Removed ApiBase::createContext(). (deprecated since 1.19)
270 * BREAKING CHANGE: The undocumented Special{$this->getName()}BeforeFormDisplay
271   set of hooks has been removed and replaced by a single new hook
272   SpecialPageBeforeFormDisplay.
273 * (bug 65781) Removed block warning on included {{Special:Contributions}}
274 * Removed Skin::makeGlobalVariablesScript. (deprecated since 1.19)
275 * Removed MWNamespace::isMain(). (deprecated since 1.19)
276 * Removed Preferences::loadOldSearchNs(). (deprecated since 1.19)
277 * Removed OutputPage::getStatusMessage(). (deprecated since 1.18)
278 * Removed OutputPage::isUserJsAllowed(). (deprecated since 1.18)
279 * Removed Title::updateTitleProtection(). (deprecated since 1.19)
280 * Removed ParserOptions::setSkin(). (deprecated since 1.19)
281 * Removed Title::escapeCanonicalURL(). (deprecated since 1.19)
282 * Removed Title::escapeLocalURL(). (deprecated since 1.19)
283 * Removed Title::escapeFullURL(). (deprecated since 1.19)
284 * Removed User::isValidEmailAddr(). (deprecated since 1.18)
285 * Removed Title::getEscapedText(). (deprecated since 1.19)
286 * Removed Language::getFallbackLanguageCode(). (deprecated since 1.19)
287 * Removed WikiPage::isBigDeletion(). (deprecated since 1.19)
288 * Removed MWInit class which contained functions related to a now discontinued
289   PHP compiler called hphpc. (deprecated since 1.22)
290 * ApiResult::enableSizeCheck() and disableSizeCheck() are now obsolete.
291 * Removed ResourceLoaderGetStartupModules hook. (deprecated since 1.23)
292 * Removed getFormFields(), onSubmit() and onSuccess() from FormlessAction, as
293   these were meant specifically for FormAction instead.
294 * Removed Action::execute().
295 * Removed AjaxAddScript which has been obsolete since ResourceLoader and
296   is unused by any modern extension.
297 * Removed maintenance/nextJobDB.php; no longer in use.
298 * Removed global function wfViewPrevNext(). (deprecated since 1.19)
299 * Removed global function xmlsafe() from Export.php. (moved to OAIRepo extension)
300 * Removed Title::userCanRead(). (deprecated since 1.19)
301 * Removed maintenance script importTextFile.php. Use edit.php script instead.
302 * A _from_namespace field has been added to the templatelinks, pagelinks,
303   and filelinks tables. Run update.php to apply this change to the schema.
304 * Removed File::sha1Base36(). (deprecated since 1.19)
305 * Removed File::getPropsFromPath(). (deprecated since 1.19)
306 * Removed functions blockedPage(), noCreatePermission(), readOnlyPage() and
307   userNotLoggedInPage() from EditPage.php. (deprecated since 1.19)
308 * Removed functions getContent(), getPreloadedText(), mergeChangesInto() and
309   setPreloadedText() from EditPage.php. (deprecated since 1.21)
310 * Removed global functions wfArrayLookup(), wfArrayMerge(), wfDebugDieBacktrace()
311   and wfTime(). (deprecated since 1.22)
312 * Microsoft Internet Explorer 6 is now a "grade C" browser, meaning that
313   JavaScript is no longer executed in this browser. The IEFixes script, which
314   existed purely to provide support for MSIE versions below 7 and which was
315   conditionally loaded for those browsers, was also removed.
317 ==== Renamed classes ====
318 * CLDRPluralRuleConverter_Expression to CLDRPluralRuleConverterExpression
319 * CLDRPluralRuleConverter_Fragment to CLDRPluralRuleConverterFragment
320 * CLDRPluralRuleConverter_Operator to CLDRPluralRuleConverterOperator
321 * CLDRPluralRuleEvaluator_Range to CLDRPluralRuleEvaluatorRange
322 * CSSJanus_Tokenizer to CSSJanusTokenizer
323 * MediaWiki_I18N to MediaWikiI18N
324 * Parser_DiffTest to ParserDiffTest
325 * RevDel_ArchiveItem to RevDelArchiveItem
326 * RevDel_ArchiveList to RevDelArchiveList
327 * RevDel_ArchivedFileItem to RevDelArchivedFileItem
328 * RevDel_ArchivedFileList to RevDelArchivedFileList
329 * RevDel_ArchivedRevisionItem to RevDelArchivedRevisionItem
330 * RevDel_FileItem to RevDelFileItem
331 * RevDel_FileList to RevDelFileList
332 * RevDel_Item to RevDelItem
333 * RevDel_List to RevDelList
334 * RevDel_LogItem to RevDelLogItem
335 * RevDel_LogList to RevDelLogList
336 * RevDel_RevisionItem to RevDelRevisionItem
337 * RevDel_RevisionList to RevDelRevisionList
338 * WebInstaller_Complete to WebInstallerComplete
339 * WebInstaller_Copying to WebInstallerCopying
340 * WebInstaller_DBConnect to WebInstallerDBConnect
341 * WebInstaller_DBSettings to WebInstallerDBSettings
342 * WebInstaller_Document to WebInstallerDocument
343 * WebInstaller_ExistingWiki to WebInstallerExistingWiki
344 * WebInstaller_Install to WebInstallerInstall
345 * WebInstaller_Language to WebInstallerLanguage
346 * WebInstaller_Name to WebInstallerName
347 * WebInstaller_Options to WebInstallerOptions
348 * WebInstaller_Readme to WebInstallerReadme
349 * WebInstaller_ReleaseNotes to WebInstallerReleaseNotes
350 * WebInstaller_Restart to WebInstallerRestart
351 * WebInstaller_Upgrade to WebInstallerUpgrade
352 * WebInstaller_UpgradeDoc to WebInstallerUpgradeDoc
353 * WebInstaller_Welcome to WebInstallerWelcome
355 ==== Removed classes ====
356 * IPBlockForm - Use SpecialBlock directly
357 * WatchlistEditor - Use SpecialEditWatchlist directly
358 * FormatExif - Use FormatMetadata directly
359 * RevertFileAction - Use RevertAction directly
360 * HistoryPage - Use HistoryAction directly
361 * RawPage - Use RawAction directly
362 * StubContLang - Use Language::factory() instead
363 * XMLReader2 - Use XMLReader directly
365 == Compatibility ==
367 MediaWiki 1.24 requires PHP 5.3.2 or later.
369 MySQL is the recommended DBMS. PostgreSQL or SQLite can also be used, but
370 support for them is somewhat less mature. There is experimental support for
371 Oracle and Microsoft SQL Server.
373 The supported versions are:
375 * MySQL 5.0.2 or later
376 * PostgreSQL 8.3 or later
377 * SQLite 3.3.7 or later
378 * Oracle 9.0.1 or later
379 * Microsoft SQL Server 2005 (9.00.1399)
381 == Upgrading ==
383 1.24 has several database changes since 1.23, and will not work without schema
384 updates. Note that due to changes to some very large tables like the revision
385 table, the schema update may take quite long (minutes on a medium sized site,
386 many hours on a large site).
388 If upgrading from before 1.11, and you are using a wiki as a commons
389 repository, make sure that it is updated as well. Otherwise, errors may arise
390 due to database schema changes.
392 If upgrading from before 1.7, you may want to run refreshLinks.php to ensure
393 new database fields are filled with data.
395 If you are upgrading from MediaWiki 1.4.x or earlier, you should upgrade to
396 1.5 first. The upgrade script maintenance/upgrade1_5.php has been removed
397 with MediaWiki 1.21.
399 Don't forget to always back up your database before upgrading!
401 See the file UPGRADE for more detailed upgrade instructions.
403 For notes on 1.23.x and older releases, see HISTORY.
405 == Online documentation ==
407 Documentation for both end-users and site administrators is available on
408 MediaWiki.org, and is covered under the GNU Free Documentation License (except
409 for pages that explicitly state that their contents are in the public domain):
411         https://www.mediawiki.org/wiki/Documentation
413 == Mailing list ==
415 A mailing list is available for MediaWiki user support and discussion:
417         https://lists.wikimedia.org/mailman/listinfo/mediawiki-l
419 A low-traffic announcements-only list is also available:
421         https://lists.wikimedia.org/mailman/listinfo/mediawiki-announce
423 It's highly recommended that you sign up for one of these lists if you're
424 going to run a public MediaWiki, so you can be notified of security fixes.
426 == IRC help ==
428 There's usually someone online in #mediawiki on irc.freenode.net.