(bug 43518) API action=unblock should return the user name, not the full user object
[lhc/web/wiklou.git] / RELEASE-NOTES-1.21
1 Security reminder: MediaWiki does not require PHP's register_globals. If you
2 have it on, turn it '''off''' if you can.
3
4 == MediaWiki 1.21 ==
5
6 THIS IS NOT A RELEASE YET
7
8 MediaWiki 1.21 is an alpha-quality branch and is not recommended for use in
9 production.
10
11 === Configuration changes in 1.21 ===
12 * (bug 29374) $wgVectorUseSimpleSearch is now enabled by default.
13 * Deprecated $wgAllowRealName is removed. Use $wgHiddenPrefs[] = 'realname'
14 instead.
15 * (bug 39957) Added $wgUnwatchedPageThreshold, specifying minimum count
16 of page watchers required for the number to be accessible to users
17 without the unwatchedpages permission.
18 * $wgBug34832TransitionalRollback has been removed.
19 * (bug 29472) $wgUseDynamicDates has been removed and its functionality
20 disabled.
21
22 === New features in 1.21 ===
23 * (bug 38110) Schema changes (adding or dropping tables, indicies and
24 fields) can be now be done separately from from other changes that
25 update.php makes. This is useful in environments that use database
26 permissions to restrict schema changes but allow the DB user that
27 MediaWiki normally runs as to perform other changes that update.php
28 makes. Schema changes can be run seperately. See the file UPGRADE
29 for more information.
30 * (bug 34876) jquery.makeCollapsible has been improved in performance.
31 * Added ContentHandler facility to allow extensions to support other content
32 than wikitext. See docs/contenthandler.txt for details.
33 * New feature was developed for showing high-DPI thumbnails for high-DPI mobile
34 and desktop displays (configurable with $wgResponsiveImages).
35 * Added new backend to represent and store information about sites and site
36 specific configuration.
37 * jQuery upgraded from 1.8.2 to 1.8.3.
38 * jQuery UI upgraded from 1.8.23 to 1.8.24.
39 * Added separate fa_sha1 field to filearchive table. This allows sha1
40 searches with the api in miser mode for deleted files.
41 * Add initial and programmatic sorting for tablesorter.
42 * Add the event "sortEnd.tablesorter", triggered after sorting has completed.
43 * The Job system was refactored to allow for different backing stores for
44 queues as well as cross-wiki access to queues, among other things. The schema
45 for the DB queue was changed to support better concurrency and reduce
46 deadlock errors.
47 * Added ApiQueryORM class to facilitate creation of query API modules based on
48 tables that have a corresponding ORMTable class.
49 * (bug 40876) Icon for PSD (Adobe Photoshop) file types.
50 * (bug 40641) Implemented Special:Version/Credits with a list of contributors.
51 * (bug 7851) Implemented one-click AJAX patrolling.
52 * The <data>, <time>, <meta>, and <link> elements are allowed within WikiText
53 for use with Microdata.
54 * The HTML5 <mark> tag has been whitelisted.
55 * Added ParserCloned hook for when the Parser object is cloned.
56 * Added AlternateEditPreview hook to allow extensions to replace the page
57 preview from the edit page.
58 * Added EditPage::showStandardInputs:options hook to allow extensions to add
59 new fields to the "editOptions" area of the edit form.
60 * Upload stash DB schema altered to improve upload performance.
61 * The following global functions are now reporting deprecated warnings in
62 debug mode: wfMsg, wfMsgNoTrans, wfMsgForContent, wfMsgForContentNoTrans,
63 wfMsgReal, wfMsgGetKey, wfMsgHtml, wfMsgWikiHtml, wfMsgExt, wfEmptyMsg. Use
64 the Message class, or the global method wfMessage.
65 * Added $wgEnableCanonicalServerLink, off by default. If enabled, a
66 <link rel=canonical> tag is added to every page indicating the correct server
67 to use.
68 * Debug message emitted by wfDebugLog() will now be prefixed with the group
69 name when its logged to the default log file. That is the case whenever the
70 group has no key in wgDebugLogGroups, that will help triage the default log.
71 * (bug 24620) Add types to LogFormatter.
72 * jQuery JSON upgraded from 2.3 to 2.4.0.
73 * Added GetDoubleUnderscoreIDs hook, for modifying the list of magic words.
74 * DatabaseUpdater class has two new methods to ease extensions schema changes:
75 dropExtensionIndex and renameExtensionIndex.
76 * New preference type - 'api'. Preferences of this type are not shown on
77 Special:Preferences, but are still available via the action=options API.
78 * (bug 39397) Hide rollback link if a user is the only contributor of the page.
79 * $wgPageInfoTransclusionLimit limits the list size of transcluded articles
80 on the info action. Default is 50.
81 * Added action=createaccount to allow user account creation.
82 * (bug 40124) action=options API also allows for setting of arbitrary
83 preferences, provided that their names are prefixed with 'userjs-'. This
84 officially reenables the feature that was undocumented and defective
85 in MW 1.20 (saving preferences using Special:Preferences cleared any
86 additional fields) and which has been disabled in 1.20.1 as a part of
87 a security fix (bug 42202).
88 * Added option to specify "others" as author in extension credits using
89 "..." as author name.
90 * Added the ability to limit the wall clock time used by shell processes,
91 as well as the CPU time. Configurable with $wgMaxShellWallClockTime.
92 * Allow memory of shell subprocesses to be limited using Linux cgroups
93 instead of ulimit -v, which tends to cause deadlocks in recent versions
94 of ImageMagick. Configurable with $wgShellCgroup.
95 * Added $wgWhitelistReadRegexp for regex whitelisting.
96 * (bug 5346) Categories that are redirects will be displayed italic in
97 the category links section at the bottom of a page.
98 * (bug 43915) New maintenance script deleteEqualMessages.php.
99 * WikiText now permits the use of WAI-ARIA's role="presentation" inside of
100 html elements and tables. This allows presentational markup, especially
101 tables. To be marked up as such.
102 * maintenance/sql.php learned the --cluster option. Let you run the script
103 on some external cluster instead of the primary cluster for a given wiki.
104 * (bug 20281) test the parsing of inline URLs.
105 * Added Special:PagesWithProp, which lists pages using a particular page property.
106 * Implemented language-specific collations for category sorting for 67 languages
107 based in latin, greek and cyrillic alphabets. This allows one to *finally* get
108 articles to be correctly sorted on category pages. They are named
109 'uca-<langcode>', where <langcode> is one of: af, ast, az, be, bg, br, bs, ca,
110 co, cs, cy, da, de, dsb, el, en, eo, es, et, eu, fi, fo, fr, fur, fy, ga, gd,
111 gl, hr, hsb, hu, is, it, kk, kl, ku, ky, la, lb, lt, lv, mk, mo, mt, nl, no,
112 oc, pl, pt, rm, ro, ru, rup, sco, sk, sl, smn, sq, sr, sv, tk, tl, tr, tt, uk,
113 uz, vi.
114
115 === Bug fixes in 1.21 ===
116 * (bug 40353) SpecialDoubleRedirect should support interwiki redirects.
117 * (bug 40352) fixDoubleRedirects.php should support interwiki redirects.
118 * (bug 9237) SpecialBrokenRedirect should not list interwiki redirects.
119 * (bug 34960) Drop unused fields rc_moved_to_ns and rc_moved_to_title from
120 recentchanges table.
121 * (bug 32951) Do not register internal externals with absolute protocol,
122 when server has relative protocol.
123 * (bug 39005) When purging proxies listed in $wgSquidServers using HTTP PURGE
124 method requests, we now send a Host header by default, for Varnish
125 compatibility. This also works with Squid in reverse-proxy mode. If you wish
126 to support Squid configured in forward-proxy mode, set
127 $wgSquidPurgeUseHostHeader to false.
128 * (bug 37020) sql.php with readline eats semicolon.
129 * (bug 11748) Properly handle optionally-closed HTML tags when Tidy is
130 disabled, and don't wrap HTML-syntax definition lists in paragraphs.
131 * (bug 41409) Diffs while editing an old revision should again diff against the
132 current revision.
133 * (bug 41494) Honor $wgLogExceptionBacktrace when logging non-API exceptions
134 caught during API execution.
135 * (bug 37963) Fixed loading process for user options.
136 * (bug 26995) Update filename field on Upload page after having sanitized it.
137 * (bug 41793) Contribution links to users with 0 edits on Special:ListUsers
138 didn't show up red.
139 * (bug 41899) A PHP notice no longer occurs when using the "rvcontinue" API
140 parameter.
141 * (bug 42036) Account creation emails now contain canonical (not
142 protocol-relative) URLs.
143 * (bug 41990) Fix regression: API edit with redirect=true and lacking
144 starttimestamp and basetimestamp should not cause an edit conflict.
145 * (bug 41706) EditPage: Preloaded page should be converted if possible and
146 needed.
147 * (bug 41886) Rowspans are no longer exploded by tablesorter until the table is
148 actually sorted.
149 * (bug 2865) User interface HTML elements don't use lang attribute.
150 (completed the fix by adding the lang attribute to firstHeading).
151 * (bug 42173) Removed namespace prefixes on Special:UncategorizedCategories.
152 * (bug 36053) Log in "returnto" feature forgets query parameters if no
153 title parameter was specified.
154 * (bug 42410) API action=edit now returns correct timestamp for the new edit.
155 * (bug 14901) Email notification mistakes log action for new page creation.
156 Enotif no longer sends "page has been created" notifications for some log
157 actions. The following events now have a correct message: page creation,
158 deletion, move, restore (undeletion), change (edit). Parameter
159 $CHANGEDORCREATED is deprecated in 'enotif_body' and scheduled for removal in
160 MediaWiki 1.23.
161 * (bug 457) In the sidebar of Vector, CologneBlue, Monobook, and Monobook-based
162 skins, the heading levels have been changed from (variously per skin)
163 <h4>, <h5> or <h6> to only <h3>s, with a <h2> hidden heading above them.
164 If you are styling or scripting the headings in a custom way, this change
165 will require updates to your site's CSS or JS.
166 * (bug 41342) jquery.suggestions should cancel any active (async) fetches
167 before it triggers another fetch.
168 * (bug 42184) $wgUploadSizeWarning missing second variable.
169 * (bug 34581) removeUnusedAccounts.php maintenance script now ignores newuser
170 log when determining whether an account is used.
171 * (bug 43379) Gracefully fail if rev_len is unavailable for a revision on the
172 History page.
173 * (bug 42949) API no longer assumes all exceptions are MWException.
174 * (bug 41733) Hide "New user message" (.usermessage) element from printable view.
175 * (bug 39062) Special:Contributions will display changes that don't have
176 a parent id instead of just an empty bullet item.
177 * (bug 37209) "LinkCache doesn't currently know about this title" error fixed.
178 * wfMerge() now works if $wgDiff3 contains spaces
179 * (bug 43052) mediawiki.action.view.dblClickEdit.dblClickEdit should trigger
180 ca-edit click instead opening URL directly.
181 * (bug 43964) Invalid value of "link" parameter in <gallery> no longer produces
182 a fatal error.
183 * (bug 44775) The username field is not pre-filled when creating an account.
184 * (bug 45069) wfParseUrl() no longer produces a PHP notice if passed a "mailto:"
185 URL without address
186 * (bug 45012) Creating an account by e-mail can no longer show a
187 "password mismatch" error.
188 * (bug 44599) On Special:Version, HEADs for submodule checkouts (e.g. for
189 extensions) performed using Git 1.7.8+ should now appear.
190
191 === API changes in 1.21 ===
192 * prop=revisions can now report the contentmodel and contentformat.
193 See docs/contenthandler.txt.
194 * action=edit and action=parse now support contentmodel and contentformat
195 parameters to control the interpretation of page content.
196 See docs/contenthandler.txt for details.
197 * (bug 35693) ApiQueryImageInfo now suppresses errors when unserializing metadata.
198 * (bug 40111) Disable minor edit for page/section creation by API.
199 * (bug 41042) Revert change to action=parse&page=... behavior when the page
200 does not exist.
201 * (bug 27202) Add timestamp sort to list=allimages.
202 * (bug 43137) Don't return the sha1 of revisions through the API if the content is
203 revision-deleted.
204 * ApiQueryImageInfo now also returns imageinfo for redirects.
205 * list=alltransclusions added to enumerate every instance of page embedding
206 * list=alllinks & alltransclusions now allow both 'from' and 'continue' in
207 the same query. When both are present, 'from' is simply ignored.
208 * list=alllinks & alltransclusions now allow 'unique' in generators, to yield
209 a list of all link/template target pages instead of source pages.
210 * BREAKING CHANGE: list=logevents output format changed for details of some log
211 types. Specifically, details that were formerly reported under a key like
212 "4::foo" will now be reported under a key of simply "foo".
213 * BREAKING CHANGE: '??_badcontinue' error code was changed to '??badcontinue'
214 for all query modules.
215 * ApiQueryBase adds 'badcontinue' error code if module has 'continue' parameter.
216 * (bug 35885) Removed version parameter and all getVersion() methods.
217 * action=options now takes a "resetkinds" option, which allows only resetting
218 certain types of preferences when the "reset" option is set.
219 * (bug 36751) ApiQueryImageInfo now returns imageinfo for the redirect target
220 when queried with &redirects=.
221 * (bug 31849) ApiQueryImageInfo no longer gets confused when asked for info on
222 a redirect and its target.
223 * (bug 43849) ApiQueryImageInfo no longer throws exceptions with ForeignDBRepo
224 redirects.
225 * On error, any warnings generated before that error will be shown in the result.
226 * action=help suports generalized submodules (modules=query+value), querymodules obsolete
227 * ApiQueryImageInfo continuation is more reliable. The only major change is
228 that the imagerepository property will no longer be set on page objects not
229 processed in the current query (i.e. non-images or those skipped due to
230 iicontinue).
231 * Add supports for all pageset capabilities - generators, redirects, converttitles to
232 action=purge and action=setnotificationtimestamp.
233 * (bug 43251) prop=pageprops&ppprop= now accepts multiple props to query.
234 * ApiQueryImageInfo will now limit the number of calls to File::transform made
235 in any one query. If there are too many, iicontinue will be returned.
236 * action=query&meta=siteinfo&siprop=general will now return the regexes used for
237 link trails and link prefices. Added for Parsoid support.
238 * Added an API query module list=pageswithprop, which lists pages using a
239 particular page property.
240 * Added an API query module list=pagepropnames, which lists all page prop names
241 currently in use on the wiki.
242 * (bug 44921) ApiMain::execute() will now return after the CORS check for an
243 HTTP OPTIONS request.
244 * (bug 44923) action=upload works correctly if the entire file is uploaded in
245 the first chunk.
246 * Added 'continue=' parameter to streamline client iteration over complex query results
247 * (bug 44909) API parameters may now be marked as type "upload", which is now
248 used for action=upload's 'file' and 'chunk' parameters. This type will raise
249 an error during parameter validation if the parameter is given but not
250 recognized as an uploaded file.
251 * (bug 44244) prop=info may now return the number of people watching each page.
252
253 === API internal changes in 1.21 ===
254 * For debugging only, a new global $wgDebugAPI removes many API restrictions when true.
255 Never use on the production servers, as this flag introduces security holes.
256 Whenever enabled, a warning will also be added to all output.
257 * ApiModuleManager now handles all submodules (actions,props,lists) and instantiation
258 * Query stores prop/list/meta as submodules
259 * ApiPageSet can now be used in any action to process titles/pageids/revids or any generator.
260 * BREAKING CHANGE: ApiPageSet constructor now has two params instead of three, with only the
261 first one keeping its meaning. ApiPageSet is now derived from ApiBase.
262 * BREAKING CHANGE: ApiQuery::newGenerator() and executeGeneratorModule() were deleted.
263 * ApiQueryGeneratorBase::setGeneratorMode() now requires a pageset param.
264 * $wgAPIGeneratorModules is now obsolete and will be ignored.
265 * Added flags ApiResult::OVERRIDE and ADD_ON_TOP to setElement() and addValue()
266 * Internal API calls will now include <warnings> in case of unused parameters
267
268 === Languages updated in 1.21 ===
269
270 MediaWiki supports over 350 languages. Many localisations are updated
271 regularly. Below only new and removed languages are listed, as well as
272 changes to languages because of Bugzilla reports.
273
274 * South Azerbaijani (azb) added.
275 * (bug 30040) Autonym for nds-nl is now 'Nedersaksies' (was 'Nedersaksisch').
276 * (bug 34977) Now formatted numbers in Spanish use space as separator
277 for thousands, as mandated by the Real Academia EspaƱola.
278 * (bug 35031) Kurdish formatted numbers now use period and comma
279 as separators for thousands and decimals respectively.
280
281 === Other changes in 1.21 ===
282 * BREAKING CHANGE: (bug 44385) Removed the jquery.collapsibleTabs module and
283 moved it to the Vector extension. It was entirely Vector-extension-specific,
284 deeply interconnected with the extension, and this functionality really
285 belongs to the extension instead of the skin anyway. In the unlikely case you
286 were using it, you have to either copy it to your extension, or install the
287 Vector extension (and possibly disable its features using config settings if
288 you don't want them).
289 * Experimental IBM DB2 support was removed due to lack of interest and maintainership
290
291 == Compatibility ==
292
293 MediaWiki 1.21 requires PHP 5.3.2 or later.
294
295 MySQL is the recommended DBMS. PostgreSQL or SQLite can also be used, but
296 support for them is somewhat less mature. There is experimental support for
297 Oracle.
298
299 The supported versions are:
300
301 * MySQL 5.0.2 or later
302 * PostgreSQL 8.3 or later
303 * SQLite 3.3.7 or later
304 * Oracle 9.0.1 or later
305
306 == Upgrading ==
307
308 1.21 has several database changes since 1.20, and will not work without schema
309 updates. Note that due to changes to some very large tables like the revision
310 table, the schema update may take quite long (minutes on a medium sized site,
311 many hours on a large site).
312
313 If upgrading from before 1.11, and you are using a wiki as a commons
314 repository, make sure that it is updated as well. Otherwise, errors may arise
315 due to database schema changes.
316
317 If upgrading from before 1.7, you may want to run refreshLinks.php to ensure
318 new database fields are filled with data.
319
320 If you are upgrading from MediaWiki 1.4.x or earlier, you should upgrade to
321 1.5 first. The upgrade script maintenance/upgrade1_5.php has been removed
322 with MediaWiki 1.21.
323
324 Don't forget to always back up your database before upgrading!
325
326 See the file UPGRADE for more detailed upgrade instructions.
327
328 For notes on 1.19.x and older releases, see HISTORY.
329
330 == Online documentation ==
331
332 Documentation for both end-users and site administrators is available on
333 MediaWiki.org, and is covered under the GNU Free Documentation License (except
334 for pages that explicitly state that their contents are in the public domain):
335
336 https://www.mediawiki.org/wiki/Documentation
337
338 == Mailing list ==
339
340 A mailing list is available for MediaWiki user support and discussion:
341
342 https://lists.wikimedia.org/mailman/listinfo/mediawiki-l
343
344 A low-traffic announcements-only list is also available:
345
346 https://lists.wikimedia.org/mailman/listinfo/mediawiki-announce
347
348 It's highly recommended that you sign up for one of these lists if you're
349 going to run a public MediaWiki, so you can be notified of security fixes.
350
351 == IRC help ==
352
353 There's usually someone online in #mediawiki on irc.freenode.net.