Added ApiResult::NO_SIZE_CHECK flag for addValue()
[lhc/web/wiklou.git] / RELEASE-NOTES-1.24
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.
3
4 == MediaWiki 1.24 ==
5
6 THIS IS NOT A RELEASE YET
7
8 MediaWiki 1.24 is an alpha-quality branch and is not recommended for use in
9 production.
10
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 * The server's canonical hostname is available as $wgServerName, which is
16 exposed in both mw.config and ApiQuerySiteInfo.
17 * Introduced $wgPagePropsHaveSortkey as a backwards-compatibility switch,
18 for using the old schema of the page_props table, in case the respective
19 schema update was not applied.
20 * $wgSearchEverythingOnlyLoggedIn was removed as the 'searcheverything'
21 user option was removed. Use $wgNamespacesToBeSearchedDefault instead or
22 if you used to have $wgDefaultUserOptions['searcheverything'] = 1.
23 * $wgMasterWaitTimeout has been deprecated.
24 * $wgDBClusterTimeout has been removed.
25 * $wgProxyKey has been removed. It is no longer used by MediaWiki core.
26 Ensure $wgSecretKey is set in LocalSettings.php.
27 * $wgExtraInterlanguageLinkPrefixes is a new configuration variable that
28 contains an array of interwiki prefixes that should be treated as language
29 prefixes (i.e. turned into interlanguage links when $wgInterwikiMagic is set
30 to true).
31 * $wgParserTestRemote has been removed.
32 * $wgCountTotalSearchHits has been removed. If you're concerned about efficiency
33 of search, you should use something like CirrusSearch instead of built in
34 search.
35 * Users in the 'sysop' group have access to Special:MergeHistory by default.
36 * $wgFileStore was removed after having been deprecated in 1.17. Alternative
37 configurations are $wgDeletedDirectory and $wgHashedUploadDirectory.
38 * The deprecated $wgUseCommaCount variable has been removed.
39
40 === New features in 1.24 ===
41 * Added a new hook, "WhatLinksHereProps", to allow extensions to annotate
42 WhatLinksHere entries.
43 * Added a new hook, "ContentGetParserOutput", to customize parser output for
44 a given content object.
45 * Deprecated the hook "ShowRawCssJs", use "ContentGetParserOutput" instead.
46 * HTMLForm's HTMLTextField now supports the 'url' type.
47 * HTMLForm fields may now be dynamically hidden based on the values of other
48 fields in the form.
49 * HTMLForm now supports multiple copies of an input field or set of input
50 fields, e.g. the form may request "one or more usernames" without having to
51 have the user enter delimited list of names into a text field.
52 * Added a new hook, "SidebarBeforeOutput", to allow to edit the structure of
53 the sidebar just before its display.
54 * (bug 49156) Added the mediawiki.cookie ResourceLoader module, which wraps
55 jquery.cookie so that getting/setting a cookie is syntactically and
56 functionally similar to using the WebRequest::getCookie() and
57 WebResponse::setcookie() methods.
58 * (bug 44740) jQuery upgraded from 1.8.3 to 1.11.1. A new configuration option,
59 $wgIncludejQueryMigrate, also loads the jQuery Migrate hack to let extensions
60 and gadgets use the long-deprecated functions that were removed in jQuery 1.9.
61 This option is turned off by default, and will be removed in MediaWiki 1.25.
62 * (bug 47076) jQuery UI upgraded from 1.8.24 to 1.9.2.
63 * Changes to content typography (fonts, etc.). See
64 https://www.mediawiki.org/wiki/Typography_refresh for further information.
65 * WikitextContent will now render redirects with the expected "redirect"
66 header, rather than as an ordered list. Code calling Article::viewRedirect
67 can probably be changed to no longer special-case redirects.
68 * Header font set to a serif font stack. See
69 https://www.mediawiki.org/wiki/Typography_refresh for further information.
70 * (bug 65567) Added a new hook, "BeforeHttpsRedirect", to allow cancellation of
71 the HTTP to HTTPS redirect due to forceHTTPS cookie, userRequires, etc. This
72 is only for page views, since this hook doesn't affect UserLogin, OAuth,
73 CentralAuth, etc. ATTENTION: This hook is likely to be removed soon due to
74 overall design of the system.
75 * (bug 17367) It is now possible to add pages to your watchlist from
76 Special:UnwatchedPages without reloading the special page.
77 * New methods setVolatile and isVolatile are added to PPFrame, so that
78 extensions such as Cite.php can mark that their output is volatile and
79 shouldn't be cached.
80 * (bug 52817) Advanced search options are now saved on the search page itself,
81 rather than in a dedicated pane in the preferences panel.
82 * (bug 44591) The dropdown actions menu (little triangle next to page tabs) in
83 the Vector skin has gained a label that should make it more discoverable.
84 * MWCryptHKDF added for fast, cryptographically secure random number generation
85 that won't deplete openssl's entropy pool.
86 * ResourceLoader: File modules can now provide a skip function that uses an
87 inline feature test to bypass loading of the module.
88 * (bug 20210) Special pages may now provide autocompletion of their subpage
89 names in search suggestions. Right now the only useful implementation is in
90 Special:Log, but more are to come.
91 * Special:MostLinkedTemplates is no longer limited to transclusions from the
92 Template namespace.
93 * Skins can now use 'remoteSkinPath' when defining ResourceLoader modules.
94 This works the same as 'remoteExtPath' but is relative to the skins/ folder
95 instead of the extensions/ folder.
96 * Added the json2.js polyfill for the ES5 JSON.stringify and JSON.parse methods.
97 Exposed as module "json" with a skip function to optimise loading.
98 * Extensions and skins may now use 'namemsg' in $wgExtensionCredits in addition
99 to 'name', to allow for the name to be localizable. 'name' should still be
100 specified for backwards-compatibility and to define the path Special:Version
101 uses to find extension license information.
102 * Browser tests are now included to verify basic wiki functionality in developer
103 environments. For details on running tests, see tests/browser/README.mediawiki.
104 * Upgrade jStorage to v0.4.10.
105 * {{!}} is now a magic word that produces the | character. This removes the need
106 for Template:! for purposes such as passing pipes inside of parameters.
107 * (bug 20790) The block log snippet on Special:Contributions and while
108 editing user and user talk pages now works for IP range blocks.
109 * (bug 9360) Added ability to change the page language for MediaWiki pages using
110 Special:PageLanguage. All pages are set to wiki language by default.
111 The feature needs to be enabled with $wgPageLanguageUseDB=true and
112 permission needs to be set for 'pagelang'.
113 * Upgrade Moment.js to v2.7.0.
114 * (bug 67042) Added support for the HTML5 <rtc> tag for East Asian typography.
115 * Upgrade Sinon.JS to 1.10.3.
116 * Added the es5-shim polyfill for older or non-compliant javascript engines.
117
118 === Bug fixes in 1.24 ===
119 * (bug 49116) Footer copyright notice is now always displayed in user language
120 rather than content language (same as copyright notice for editing interface).
121 * (bug 62258) A bug was fixed in File::getUnscaledThumb when a height
122 restriction was present in the parameters. Images with both the "frame"
123 option and a size specification set will now always ignore the provided
124 size and display an unscaled image, as the documentation has always
125 claimed it would.
126 * (bug 39035) Improved Vector skin performance by removing collapsibleNav,
127 which used to collapse some sidebar elements by default.
128 This removes -list id suffixes like p-lang-list: instead of using things like
129 #p-lang-list, you can do #p-lang .body ul.
130 * (bug 890) Links in Special:RecentChanges and Special:Watchlist no longer
131 follow redirects to their target pages.
132 * Parser now dies early if called recursively, instead of producing subtle bugs.
133 * (bug 14323) Redirect pages, when viewed with redirect=no, no longer hide the
134 remaining page content.
135 * (bug 52587) Maintenance script deleteBatch.php no longer follows redirects
136 in the file namespace and delete the file on the target page. It will still
137 however delete the redirect page.
138 * (bug 22683) {{msgnw:}} and other uses of PPFrame::RECOVER_ORIG will correctly
139 recover the original code of extension tags.
140 * (bug 65757) MSSQL: Update script drops unnamed constraints to be prepared
141 for future updates. Because it's doing so heuristically, it may fail or drop
142 wrong constraints.
143
144 === Web API changes in 1.24 ===
145 * action=parse API now supports prop=modules, which provides the list of
146 ResourceLoader modules that should be used to enhance the parsed content.
147 * action=query&meta=siteinfo&siprop=interwikimap returns a new "protorel"
148 field which is true iff protocol-relative urls can be used to access
149 a particular interwiki map entry.
150 * ApiQueryLogEvents now provides logpage, which is the page ID from the
151 logging table, if ids are requested and the user has the permissions.
152 * action=edit now requires that appendtext, prependtext, or section=new be used
153 when using the 'redirect' parameter, to prevent clients accidentally
154 overwriting the target page with the content of the redirect.
155 * action=logevents will now return an error if both letitle and leprefix are
156 specified.
157 * action=logevents has a new parameter, lenamespace, to allow filtering by
158 namespace.
159 * action=expandtemplates has a new parameter, prop, and a new output format.
160 The old format is still used if prop isn't provided, but this is deprecated.
161 * meta=userinfo can now return the count of unread pages on the watchlist.
162 * list=watchlist can now filter by unread status.
163 * The deprecated action=parse&prop=languageshtml has been removed.
164 * (bug 48071) action=setnotificationtimestamp no longer throws PHP or database
165 errors when no pages are given.
166 * (bug 60734) Actions that use ApiPageSet (e.g. purge, watch,
167 setnotificationtimestamp) will now include continuation information when
168 using a generator.
169
170 === Languages updated in 1.24 ===
171
172 MediaWiki supports over 350 languages. Many localisations are updated
173 regularly. Below only new and removed languages are listed, as well as
174 changes to languages because of Bugzilla reports.
175
176 === Other changes in 1.24 ===
177 * The deprecated jquery.delayedBind ResourceLoader module was removed.
178 * The deprecated function mw.util.toggleToc was removed.
179 * The Special:Search hooks SpecialSearchGo and SpecialSearchResultsAppend
180 were removed as they were unused.
181 * (bug 65477) User::pingLimiter() now has an additional profile point varying
182 by action being used.
183 * mediawiki.util.$content no longer supports old versions of the Vector,
184 Monobook, Modern and CologneBlue skins that don't yet implement the "mw-body"
185 and/or "mw-body-primary" class name in their html.
186 * Added pp_sortkey column to page_props table, so pages can be efficiently
187 queried and sorted by property value (bug 58032).
188 See $wgPagePropsHaveSortkey if you want to postpone the schema change.
189 * BREAKING CHANGE: The Modern and Cologne Blue skins were moved out of MediaWiki
190 core to their own respective repositories. See also
191 https://www.mediawiki.org/wiki/Skin:Modern and
192 https://www.mediawiki.org/wiki/Skin:CologneBlue.
193 * BREAKING CHANGE: Skins built for MediaWiki 1.15 and earlier that do not use
194 the "headelement" template key are no longer supported. Setting
195 $useHeadElement = false; is no longer supported and will not cause old keys
196 like "headlinks", "skinnameclass", etc. to be defined.
197 * The deprecated 'SpecialVersionExtensionTypes' hook was removed.
198 * (bug 63891) Add 'X-Robots-Tag: noindex' header in action=render pages.
199 * SpecialPage no longer supports the syntax for invoking wfSpecial*() functions.
200 Special pages should subclass SpecialPage and implement the execute() method.
201 * (bug 63755) The deprecated constants RC_MOVE and RC_MOVE_OVER_REDIRECT were
202 removed.
203 * Special:MostLinkedTemplates has been renamed to Special:MostTranscludedPages.
204 * The skin autodiscovery mechanism has been deprecated and will be removed in
205 MediaWiki 1.25. See https://www.mediawiki.org/wiki/Manual:Skin_autodiscovery
206 for migration guide for creators and users of custom skins that relied on it.
207 * ResourceLoaderFileModule#getAllStyleFiles now returns all style files and all
208 skin style files used by the module.
209 * Removed getLang() from IContextSource and subclasses. (deprecated since 1.19)
210 * Removed setLang() from subclasses of IContextSource. (deprecated since 1.19)
211 * Removed WebRequest::escapeAppendQuery(). (deprecated since 1.20)
212 * Removed info(), purge(), revert() and rollback() from the Article class; they
213 have since become subclasses of the Action class. (deprecated since 1.19)
214 * SearchEngineReplacePrefixesComplete hook was removed.
215 * The "jquery.json" module has been deprecated. Use the "json" module instead.
216 * Removed HTMLForm::addJS(). (deprecated since 1.18)
217 * Removed LogEventsList::showHeader(). (deprecated since 1.19)
218 * Removed ImageGalleryBase::useSkin(). (deprecated since 1.18)
219 * Removed DatabaseMysqlBase::getLagFromProcesslist(). (deprecated since 1.19)
220 * Removed LoadBalancer::closeConnecton(). (deprecated since 1.18)
221 * Removed ApiBase::createContext(). (deprecated since 1.19)
222 * BREAKING CHANGE: The undocumented Special{$this->getName()}BeforeFormDisplay
223 set of hooks has been removed and replaced by a single new hook
224 SpecialPageBeforeFormDisplay.
225 * (bug 65781) Removed block warning on included {{Special:Contributions}}
226 * Removed Skin::makeGlobalVariablesScript. (deprecated since 1.19)
227 * Removed MWNamespace::isMain(). (deprecated since 1.19)
228 * Removed Preferences::loadOldSearchNs(). (deprecated since 1.19)
229 * Removed OutputPage::getStatusMessage(). (deprecated since 1.18)
230 * Removed OutputPage::isUserJsAllowed(). (deprecated since 1.18)
231 * Removed Title::updateTitleProtection(). (deprecated since 1.19)
232 * Removed ParserOptions::setSkin(). (deprecated since 1.19)
233 * Removed Title::escapeCanonicalURL(). (deprecated since 1.19)
234 * Removed Title::escapeLocalURL(). (deprecated since 1.19)
235 * Removed Title::escapeFullURL(). (deprecated since 1.19)
236 * Removed User::isValidEmailAddr(). (deprecated since 1.18)
237 * Removed Title::getEscapedText(). (deprecated since 1.19)
238 * Removed Language::getFallbackLanguageCode(). (deprecated since 1.19)
239 * Removed WikiPage::isBigDeletion(). (deprecated since 1.19)
240 * Removed MWInit class which contained functions related to a now discontinued
241 PHP compiler called hphpc. (deprecated since 1.22)
242 * ApiResult::enableSizeCheck() and disableSizeCheck() are now obsolete.
243
244 ==== Renamed classes ====
245 * CLDRPluralRuleConverter_Expression to CLDRPluralRuleConverterExpression
246 * CLDRPluralRuleConverter_Fragment to CLDRPluralRuleConverterFragment
247 * CLDRPluralRuleConverter_Operator to CLDRPluralRuleConverterOperator
248 * CLDRPluralRuleEvaluator_Range to CLDRPluralRuleEvaluatorRange
249 * CSSJanus_Tokenizer to CSSJanusTokenizer
250 * MediaWiki_I18N to MediaWikiI18N
251 * Parser_DiffTest to ParserDiffTest
252 * RevDel_ArchiveItem to RevDelArchiveItem
253 * RevDel_ArchiveList to RevDelArchiveList
254 * RevDel_ArchivedFileItem to RevDelArchivedFileItem
255 * RevDel_ArchivedFileList to RevDelArchivedFileList
256 * RevDel_ArchivedRevisionItem to RevDelArchivedRevisionItem
257 * RevDel_FileItem to RevDelFileItem
258 * RevDel_FileList to RevDelFileList
259 * RevDel_Item to RevDelItem
260 * RevDel_List to RevDelList
261 * RevDel_LogItem to RevDelLogItem
262 * RevDel_LogList to RevDelLogList
263 * RevDel_RevisionItem to RevDelRevisionItem
264 * RevDel_RevisionList to RevDelRevisionList
265 * WebInstaller_Complete to WebInstallerComplete
266 * WebInstaller_Copying to WebInstallerCopying
267 * WebInstaller_DBConnect to WebInstallerDBConnect
268 * WebInstaller_DBSettings to WebInstallerDBSettings
269 * WebInstaller_Document to WebInstallerDocument
270 * WebInstaller_ExistingWiki to WebInstallerExistingWiki
271 * WebInstaller_Install to WebInstallerInstall
272 * WebInstaller_Language to WebInstallerLanguage
273 * WebInstaller_Name to WebInstallerName
274 * WebInstaller_Options to WebInstallerOptions
275 * WebInstaller_Readme to WebInstallerReadme
276 * WebInstaller_ReleaseNotes to WebInstallerReleaseNotes
277 * WebInstaller_Restart to WebInstallerRestart
278 * WebInstaller_Upgrade to WebInstallerUpgrade
279 * WebInstaller_UpgradeDoc to WebInstallerUpgradeDoc
280 * WebInstaller_Welcome to WebInstallerWelcome
281
282 ==== Removed classes ====
283 * IPBlockForm - Use SpecialBlock directly
284 * WatchlistEditor - Use SpecialEditWatchlist directly
285 * FormatExif - Use FormatMetadata directly
286
287 == Compatibility ==
288
289 MediaWiki 1.24 requires PHP 5.3.2 or later.
290
291 MySQL is the recommended DBMS. PostgreSQL or SQLite can also be used, but
292 support for them is somewhat less mature. There is experimental support for
293 Oracle and Microsoft SQL Server.
294
295 The supported versions are:
296
297 * MySQL 5.0.2 or later
298 * PostgreSQL 8.3 or later
299 * SQLite 3.3.7 or later
300 * Oracle 9.0.1 or later
301 * Microsoft SQL Server 2005 (9.00.1399)
302
303 == Upgrading ==
304
305 1.24 has several database changes since 1.23, and will not work without schema
306 updates. Note that due to changes to some very large tables like the revision
307 table, the schema update may take quite long (minutes on a medium sized site,
308 many hours on a large site).
309
310 If upgrading from before 1.11, and you are using a wiki as a commons
311 repository, make sure that it is updated as well. Otherwise, errors may arise
312 due to database schema changes.
313
314 If upgrading from before 1.7, you may want to run refreshLinks.php to ensure
315 new database fields are filled with data.
316
317 If you are upgrading from MediaWiki 1.4.x or earlier, you should upgrade to
318 1.5 first. The upgrade script maintenance/upgrade1_5.php has been removed
319 with MediaWiki 1.21.
320
321 Don't forget to always back up your database before upgrading!
322
323 See the file UPGRADE for more detailed upgrade instructions.
324
325 For notes on 1.23.x and older releases, see HISTORY.
326
327 == Online documentation ==
328
329 Documentation for both end-users and site administrators is available on
330 MediaWiki.org, and is covered under the GNU Free Documentation License (except
331 for pages that explicitly state that their contents are in the public domain):
332
333 https://www.mediawiki.org/wiki/Documentation
334
335 == Mailing list ==
336
337 A mailing list is available for MediaWiki user support and discussion:
338
339 https://lists.wikimedia.org/mailman/listinfo/mediawiki-l
340
341 A low-traffic announcements-only list is also available:
342
343 https://lists.wikimedia.org/mailman/listinfo/mediawiki-announce
344
345 It's highly recommended that you sign up for one of these lists if you're
346 going to run a public MediaWiki, so you can be notified of security fixes.
347
348 == IRC help ==
349
350 There's usually someone online in #mediawiki on irc.freenode.net.