Merge "Fix partially blocked admin undelete permissions"
[lhc/web/wiklou.git] / HISTORY
1 Change notes from older releases. For current info see RELEASE-NOTES-1.33.
2
3 = MediaWiki 1.32 =
4
5 == MediaWiki 1.32.1 ==
6
7 === Changes since MediaWiki 1.32.0 ===
8 * (T213577) rdbms: avoid transaction status errors from ping() in rollback().
9 * rdbms: Pass required parameter.
10 * rdbms: do not treat SAVEPOINT and RELEASE SAVEPOINT as write queries.
11 * (T204531) rdbms: reduce LoadBalancer replication log spam.
12 * (T213489) Avoid session double-start in Setup.php.
13 * (T213717) Correct namespace 'Template' for gom-deva
14 * (T198054) Fix login page crash caused by unknown language via ?uselang
15 * (T215324) (T210937) list=users mistakenly reports user as missing.
16 * (T209483) Add ILBFactory::redefineLocalDomain method. This is intended for
17 use with scripts like addWiki.php to avoid mismatched domain errors.
18 * (T208871) The hard-coded Google search form on the database error page was
19 removed.
20 * (T204800) Fix Title::getFragmentForURL for bad interwiki prefix
21 * (T215566) Fix installer being unable to determine if the database exists
22 during a fresh installation.
23
24 == MediaWiki 1.32.0 ==
25
26 === Changes since MediaWiki 1.32.0-rc.2 ===
27 * (T188327) Fix slow queries in migrateActors.php.
28 * (T102320) Fix $magicWords for the Sanskrit language.
29
30 === Changes since MediaWiki 1.32.0-rc.1 ===
31 * Fix addition of ug_expiry column to user_groups table on MSSQL.
32 * (T210307) Fix the cache timestamp for forced updates.
33 * (T210621) User: Bypass repeatable-read when creating an actor_id.
34 * (T197535) Extensions can now specify PHP versions and PHP extensions they
35 depend on.
36 * Updated wikimedia/ip-set from v1.2.0 to v1.3.0.
37 * (T212356) When using action=delete on pages with many revisions, the module
38 may return a boolean-true 'scheduled' and no 'logid'. This signifies that the
39 deletion will be processed via the job queue.
40 * (T64103) Dropped columns category.cat_hidden, site_stats.ss_admins, and
41 recentchanges.rc_cur_time from the PostgreSQL schema.
42
43 === Changes since MediaWiki 1.32.0-rc.0 ===
44 * (T209885) Prevent populateSearchIndex.php from breaking once actor migration
45 has been started.
46 * (T210998) Properly set $wgLanguageCode in the generated LocalSettings.php
47 if --lang is used with the command-line installer (install.php).
48
49 === Configuration changes in 1.32 ===
50
51 ==== New configuration ====
52 * $wgJpegQuality – The quality of JPEG thumbnails is now configurable through
53 this setting. The default is 80, which matches the quality of JPEG thumbnails
54 previously generated by ImageMagick. The quality of JPEG thumbnails generated
55 by GD was previously 95, but now uses the $wgJpegQuality setting as well.
56 * $wgCookieSetOnIpBlock - This determines whether to set a cookie when an IP
57 user is blocked. Doing so means that a blocked user, even after moving to a
58 new IP address, will still be blocked.
59 * $wgRawHtmlMessages – This new configuration setting is added for listing
60 messages which are displayed as raw HTML.
61 * $wgCSPHeader and $wgCSPReportOnlyHeader – You can now define a
62 "Content Security Policy" for your wiki. This adds a defense-in-depth feature
63 to stop an attacker who has found a bug in the parser allowing them to insert
64 malicious attributes. Disabled by default. (T135963)
65 * $wgGroupPermissions – A new user group, 'interface-admin', is added for
66 controlling access to sitewide CSS/JS (and editing other users' CSS/JS). No
67 other group has 'editsitecss', 'editusercss', 'editsitejs' or 'edituserjs'
68 by default.
69 * $wgGrantPermissions – A new grant group, 'editsiteconfig', is added for
70 granting the above rights.
71 * $wgDBDefaultGroup – A default database group for use by maintenance scripts.
72 * $wgResourceLoaderEnableJSProfiler – This new configuration setting lets you
73 enable client-side profiling of JavaScript modules; it is off by default.
74 * (T193868) $wgChangeTagsSchemaMigrationStage — This temporary configuration
75 setting allows sysadmins to gradually migrate the database table schema for
76 how change tags are stored.
77 * (T199334) $wgTagStatisticsNewTable — This temporary configuration setting
78 allows sysadmins to enable the caching of Special:Tags via the new
79 change_tag_def table.
80
81 ==== Changed configuration ====
82 * $wgUseAjax – This setting, deprecated in 1.31, is now ignored.
83 * $wgDefaultUserOptions – The default watchlist view time (watchlistdays) has
84 been increased from 3 to 7 days. (T194414)
85 * $wgGroupPermissions – The right to edit sitewide Javascript
86 (e.g. MediaWiki:Common.js), CSS or JSON was separated from 'editinterface'
87 and is available under 'editsitejs'/'editsitecss'/'editsitejson'. Having
88 'editinterface' is still necessary to edit such pages.
89 * $wgMultiContentRevisionSchemaMigrationStage now defaults to writing both the
90 old and the new schema, but reading the new schema, so Multi-Content Revisions
91 (MCR) are now functional per default. The new default value of the setting is
92 SCHEMA_COMPAT_WRITE_BOTH | SCHEMA_COMPAT_READ_NEW.
93 * $wgActorTableSchemaMigrationStage no longer accepts MIGRATION_WRITE_BOTH or
94 MIGRATION_WRITE_NEW. It instead uses SCHEMA_COMPAT_WRITE_BOTH |
95 SCHEMA_COMPAT_READ_OLD and SCHEMA_COMPAT_WRITE_BOTH | SCHEMA_COMPAT_READ_NEW
96 for intermediate stages of migration.
97 * $wgDBTableOptions – The default table options now use the binary charset. The
98 default was already overridden in the installer-generated LocalSettings.php,
99 and so is always set to binary after the installer UI option was removed. The
100 default value is only used when the installer installs an extension.
101 * $wgPopularPasswordFile — The location of the default popular passwords file
102 has been moved to be in line with other non-PHP files used by libraries and
103 classes.
104 * $wgEnableImageWhitelist is now disabled by default, as it opens up a hole for
105 potential privacy leaks by administrators. You can check
106 "MediaWiki:External image whitelist" on your wiki to see whether the feature
107 was ever used, and whether it needs to be re-enabled.
108
109 ==== Removed configuration ====
110 * $wgEnableAPI and $wgEnableWriteAPI – These settings, deprecated in 1.31,
111 have been removed. (T115414)
112 * $wgSiteSupportPage – This setting, unused since 1.5, was removed.
113 * $wgBrowserBlacklist – This setting, deprecated in 1.30, was removed.
114 * $wgExperimentalHtmlIds – This setting, deprecated since 1.30, was removed.
115 The 'html5-legacy' value for $wgFragmentMode is no longer accepted.
116 * $wgPasswordSenderName - This setting, ignored since 1.23 by MediaWiki and
117 most extensions, is no longer set. Instead, you can modify the system
118 message `emailsender`.
119 * $wgTidyConfig – The experimental Html5Internal and Html5Depurate tidy drivers
120 were removed. RemexHtml, which is the default, should be used instead.
121 * (T181318) The $wgStyleVersion setting and its appendage to various script and
122 style URLs in OutputPage, deprecated in 1.31, was removed.
123 * (T140807) The wgResourceLoaderLESSImportPaths configuration option was removed
124 from ResourceLoader. Instead, use `@import` statements in LESS to import
125 files directly from nearby directories within the same project.
126 * (T140804) The wgResourceLoaderLESSVars configuration option, deprecated
127 since 1.30, was removed. Instead, to expose variables from PHP to LESS, use
128 the ResourceLoaderModule::getLessVars() method.
129 * $wgResourceLoaderValidateStaticJS – This setting, unused since MediaWiki 1.18,
130 was removed.
131 * Two temporary variables for deploying the feature of filters on change lists,
132 $wgStructuredChangeFiltersShowPreference introduced in MediaWiki 1.30 and
133 $wgStructuredChangeFiltersOnWatchlist in 1.31, were removed.
134
135 === New features in 1.32 ===
136 * (T112474) Generalized the ResourceLoader mechanism for overriding modules
137 using a particular page during edit previews.
138 * (T12331) You can now log page creation events by setting $wgPageCreationLog
139 to true.
140 * Added 'ApiParseMakeOutputPage' hook.
141 * (T174313) Added checkbox on Special:ListUsers to display only users in
142 temporary user groups.
143 * (T152462) A cookie can now be set when an IP user is blocked to track that
144 user if they move to a new IP address. This is disabled by default.
145 * (T194950) Added 'ApiMaxLagInfo' hook.
146 * SpecialPage::checkLoginSecurityLevel() will now preserve POST data when
147 reauthenticating.
148 * FormSpecialPage::execute() will now call checkLoginSecurityLevel() if
149 getLoginSecurityLevel() returns non-false.
150 * The 'ImageBeforeProduceHTML' hook is now passed three new parameters, $parser,
151 &$query and &$widthOption, allowing extensions even finer control over the
152 resulting HTML code.
153 * Added new 'ArticleShowPatrolFooter' hook, which allows extensions to determine
154 if the [mark as patrolled] link should be shown at the footer of patrollable
155 pages.
156 * The array of hidden options ($opts) passed to the 'SpecialSearchPowerBox' hook
157 is now passed by reference, allowing extensions to modify or even unset it.
158 * Added new 'OutputPageAfterGetHeadLinksArray' hook, allowing extensions to
159 modify the return value of OutputPage#getHeadLinksArray in order to add,
160 remove or otherwise alter the elements to be output in the page <head>.
161 * (T28934) The 'HistoryPageToolLinks' hook allows extensions to append
162 additional links to the subtitle of a history page.
163 * The 'GetLinkColours' hook now receives an additional $title parameter,
164 the Title object of the page being parsed, on which the links will be shown.
165 * (T194731) DifferenceEngine supports multiple slots. Added SlotDiffRenderer to
166 render diffs between two Content objects, and DifferenceEngine::setRevisions()
167 to render diffs between two custom (potentially multi-content) revisions.
168 Added GetSlotDiffRenderer hook which works like GetDifferenceEngine for slots.
169 * Added a temporary action=mcrundo to the web UI, as the normal undo logic
170 can't yet handle MCR and deadlines are forcing is to put off fixing that.
171 This action should be considered deprecated and should not be used directly.
172 * Extensions overriding ContentHandler::getUndoContent() will need to be
173 updated for the changed method signature.
174 * Added a new hook, 'UserGetRightsRemove', which can be used to remove rights
175 from user. Unlike the 'UserGetRights' it will ensure that removed rights
176 will not be reinserted.
177 * (T197535) Extensions can now specify PHP versions and PHP extensions they
178 depend on.
179
180 === External library changes in 1.32 ===
181
182 ==== New external libraries ====
183 * Added pear/Net_SMTP v1.8.0.
184 * Added wikimedia/xmp-reader v0.6.0.
185
186 * Added cache/integration-tests v0.16.0 (dev-only).
187 * Added giorgiosironi/eris v0.10.0 (dev-only).
188 * Added seld/jsonlint v1.7.1 (dev-only).
189
190 * Added EasyDeflate (unversioned).
191
192 ==== Changed external libraries ====
193 * Updated OOUI from v0.26.3 to v0.29.2.
194 * Updated wikimedia/base-convert from v1.0.1 to v2.0.0.
195 * Updated wikimedia/remex-html from v1.0.3 to v2.0.1.
196 * Updated wikimedia/scoped-callback from v1.0.0 to v2.0.0.
197 ** ScopedCallback objects can no longer be serialized.
198 * Updated wikimedia/timestamp from v1.0.0 to v2.2.0.
199 * Updated wikimedia/wrappedstring from v2.3.0 to v3.0.1.
200 * oyejorge/less.php replaced with our fork wikimedia/less.php
201 * Updated wikimedia/ip-set from v1.2.0 to v1.3.0.
202
203 * Updated composer/spdx-licenses from v1.3.0 to v1.4.0 (dev-only).
204 * Updated mediawiki/mediawiki-codesniffer from v18.0.0 to v22.0.0 (dev-only).
205 * Updated psy/psysh from v0.8.11 to v0.9.6 (dev-only).
206
207 * Updated CLDRPluralRuleParser from v0.1.0 to v1.3.2-pre.
208 * Updated jquery from v3.2.1 to v3.3.1.
209 * Updated jquery.client from v2.0.0 to v2.0.1.
210 * Updated jquery.i18n from v1.0.4 to v1.0.5.
211 * Updated mustache.js from v0.8.2-d9aa703 to v1.0.0.
212 * Updated OOjs from v2.2.0 to v2.2.2.
213 * Updated qunitjs from v2.4.0 to v2.6.2.
214 * Updated sinonjs from v1.17.3 to v1.17.7.
215
216 ==== Removed external libraries ====
217 * pear/mail_mime-decode was removed.
218
219 === Bug fixes in 1.32 ===
220 * SpecialPage::execute() will now only call checkLoginSecurityLevel() if
221 getLoginSecurityLevel() returns non-false.
222 * (T43720, T46197) Improved page display title handling for category pages
223 * (T65080) Fixed resetting options of some types via API action=options.
224
225 === Action API changes in 1.32 ===
226 * Added templated parameters.
227 * A module can define a templated parameter like "{fruit}-quantity", where
228 the actual parameters recognized correspond to the values of a multi-valued
229 parameter. Then clients can make requests like
230 "fruits=apples|bananas&apples-quantity=1&bananas-quantity=5".
231 * action=paraminfo will return templated parameter definitions separately
232 from normal parameters. All parameter definitions now include an "index"
233 key to allow clients to maintain parameter ordering when merging normal and
234 templated parameters.
235 * It is now an error to submit too many values for a multi-valued parameter.
236 This has generated a warning since MediaWiki 1.14.
237 * Assertion failures from the 'assert' and 'assertuser' parameters will no
238 longer use the action module's custom response format, for the few modules
239 that use custom formatters that handle errors.
240 * (T198935) User list preferences such as `email-blacklist` and similar
241 extension preferences are no longer represented as arrays when returned by
242 action=query&meta=userinfo&uiprop=options.
243 * 'missingparam' errors will now use the prefixed parameter name in the code
244 and error text, e.g. "noxxfoo" and "The 'xxfoo' parameter must be set" rather
245 than "nofoo" and "The 'foo' parameter must be set".
246 * action=query&prop=revisions now takes a 'rvslots' parameter to indicate the
247 multi-content revision slots for which content should be returned. It also
248 has a new rvprop, 'roles', to indicate which roles have slots. A deprecation
249 warning will be issued if rvprop=content or rvprop=contentmodel are used
250 without rvslots.
251 * The rvcontentformat parameter to action=query&prop=revisions has been
252 deprecated. Clients should be prepared to deal with the default format for
253 relevant models.
254 * Use of the deprecated parameters rvexpandtemplates, rvgeneratexml, rvparse,
255 rvdiffto, rvdifftotext, rvdifftotextpst, rvcontentformat, or the deprecated
256 rvprop=parsetree is forbidden with the new 'rvslots' parameter.
257 * action=query&prop=deletedrevisions, action=query&list=allrevisions, and
258 action=query&list=alldeletedrevisions are changed similarly to
259 &prop=revisions (see the three previous items).
260 * (T174032) action=compare now supports multi-content revisions.
261 * It has a 'slots' parameter to select diffing of individual slots. The
262 default behavior is to return one combined diff.
263 * The 'fromtext', 'fromsection', 'fromcontentmodel', 'fromcontentformat',
264 'totext', 'tosection', 'tocontentmodel', and 'tocontentformat' parameters
265 are deprecated. Specify the new 'fromslots' and 'toslots' to identify which
266 slots have text supplied and the corresponding templated parameters for
267 each slot.
268 * The behavior of 'fromsection' and 'tosection' of extracting one section's
269 content is not being preserved. 'fromsection-{slot}' and 'tosection-{slot}'
270 instead expand the given text as if for a section edit. This effectively
271 declines T183823 in favor of T185723.
272 * (T198214) The 'disabletidy' parameter to action=parse has been
273 deprecated; untidy output will not be supported by future wikitext
274 parsers.
275 * Added intestactionsdetail to action=query&prop=info to allow retrieving the
276 reasons an action is not allowed.
277 * Deprecated action=query&prop=info inprop=readable in favor of
278 intestactions=read.
279 * (T212356) When using action=delete on pages with many revisions, the module
280 may return a boolean-true 'scheduled' and no 'logid'. This signifies that the
281 deletion will be processed via the job queue.
282
283 === Action API internal changes in 1.32 ===
284 * Added 'ApiParseMakeOutputPage' hook.
285 * Parameter names may no longer contain '{' or '}', as these are now used for
286 templated parameters.
287 * (T194950) Added 'ApiMaxLagInfo' hook.
288 * The following methods now take a RevisionRecord rather than a Revision. No
289 external callers are known.
290 * ApiFeedContributions::feedItemAuthor()
291 * ApiFeedContributions::feedItemDesc()
292 * ApiQueryRevisionsBase::extractRevisionInfo()
293 * The following deprecated methods have been removed:
294 * ApiBase::profileIn() (deprecated in 1.25)
295 * ApiBase::profileOut() (deprecated in 1.25)
296 * ApiBase::safeProfileOut() (deprecated in 1.25)
297 * ApiBase::profileDBIn() (deprecated in 1.25)
298 * ApiBase::profileDBOut() (deprecated in 1.25)
299 * ApiBase::dieUsage() (deprecated in 1.29)
300 * ApiBase::dieUsageMsg() (deprecated in 1.29)
301 * ApiBase::dieUsageMsgOrDebug() (deprecated in 1.29)
302 * ApiBase::getErrorFromStatus() (deprecated in 1.29)
303 * ApiBase::parseMsg() (deprecated in 1.29)
304 * ApiBase::setWarning() (deprecated in 1.29)
305 * ApiPageSet::getInvalidTitles() (deprecated in 1.26)
306 * ApiQueryLogEvents::addLogParams() (deprecated in 1.25)
307 * ApiUsageException::getCodeString() (deprecated in 1.29)
308 * ApiUsageException::getMessageArray() (deprecated in 1.29)
309 * Class UsageException, deprecated in 1.29, has been removed.
310 * ApiErrorFormatter: Added getFormat() and newWithFormat(). In particular, you
311 can now easily test $formatter->getFormat() === 'bc', and then call
312 $formatter->newWithFormat( 'plaintext' ) to get a non-BC formatter.
313
314 === Languages updated in 1.32 ===
315 MediaWiki supports over 350 languages. Many localisations are updated regularly.
316 Below only new and removed languages are listed, as well as changes to languages
317 because of Phabricator reports.
318
319 * (T193566) Added language support for Ambonese Malay (abs).
320 * (T194047) Added language support for Shawiya, Latin script (shy-latn).
321 * (T195940) Added language support for Batak Mandailing (btm).
322 * (T137491) Added language support for Standard Moroccan Amazigh (zgh).
323 * (T198132) Added language support for Manipuri (mni).
324 * (T201276) Added language support for Western Armenian (hyw).
325 * (T201583) Added language support for Mon (mnw).
326
327 === Breaking changes in 1.32 ===
328 * $wgRequestTime, deprecated in 1.25, was removed. Use
329 $_SERVER['REQUEST_TIME_FLOAT'] or WebRequest::getElapsedTime() instead.
330 * The MediaWikiI18N class, deprecated in 1.31, was removed.
331 * QuickTemplate::setTranslator(), deprecated in 1.31, was removed. Use
332 Skin::msg() instead.
333 * wfInitShellLocale(), deprecated in 1.30, was removed.
334 * wfShellExecDisabled(), deprecated in 1.30, was removed.
335 * The type string for the parameter $lang of DateFormatter::getInstance,
336 deprecated in 1.31, was removed.
337 * The EDIT_TOKEN_SUFFIX constant deprecated in 1.27, was removed. Use
338 MediaWiki\Session\Token::SUFFIX instead.
339 * EditPage::isOouiEnabled() deprecated in 1.30, was removed.
340 * mw.util.wikiGetlink(), deprecated in 1.23, was removed. Use mw.util.getUrl()
341 instead.
342 * (T61113) The following methods and constants from the Revision class, which
343 were deprecated in 1.25, have now been removed:
344 * Revision::getRawUser()
345 * Revision::getRawUserText()
346 * Revision::getRawComment()
347 * window.gM() from mediawiki.jqueryMsg, deprecated in 1.23, was removed. Use
348 mw.msg() or mw.message() instead.
349 * mw.util.escapeId(), deprecated in 1.30, was removed. Use
350 mw.util.escapeIdForAttribute or mw.util.escapeIdForLink instead.
351 * mw.util.updateTooltipAccessKeys(), deprecated in 1.24, was removed. Use
352 jquery.accessKeyLabel instead.
353 * The SqlDataUpdate class, deprecated in 1.28, has been removed.
354 * The Html5Internal and Html5Depurate tidy driver classes were removed, along
355 with the Balancer tidy implementation. Both implementations were experimental,
356 and were replaced by RemexHtml.
357 * (T179624) Job::insert() and ::batchInsert(), deprecated in 1.21, were both
358 removed. Use JobQueueGroup::singleton()->push() instead.
359 * The jquery.footHovzer module, for mediawiki.debug, was removed.
360 * The es5-shim module, empty and deprecated since 1.29, was removed.
361 * the dom-level2-shim module, empty and deprecated since 1.29, was removed.
362 * the json module, empty and deprecated since 1.29, was removed.
363 * The mediawiki.widgets.visibleByteLimit module alias, deprecated in 1.32, was
364 removed. Use mediawiki.widgets.visibleLengthLimit instead.
365 * The jquery.farbtastic module, unused since 1.18, was removed.
366 * The 'jquery.expandableField' module, unused since 1.22, was removed.
367 * The hooks 'PreferencesFormPreSave' and 'PreferencesGetLegend' may provide
368 any HTMLForm object rather than PreferencesForm.
369 * The non namespaced TimestampException class, deprecated in 1.29, was removed.
370 Use Wikimedia\Timestamp\TimestampException instead.
371 * The global functions codepointToUtf8, hexSequenceToUtf8, utf8ToHexSequence,
372 utf8ToCodepoint, and escapeSingleString (deprecated in 1.25) were removed.
373 The UtfNormal\Utils class from the utfnormal library should be used instead.
374 * The deprecated UTF8_ and UNICODE_ constants were removed. The class constants
375 from the UtfNormal\Constants class from the utfnormal library should be used
376 * The protected methods PHPSessionHandler::returnSuccess() and returnFailure(),
377 only needed for PHP5 compatibility, have been removed. It now uses the boolean
378 values `true` and `false` respectively.
379 * The $parserMemc global and wfGetParserCacheStorage(), deprecated since 1.30,
380 were removed. Use the ParserCache class instead.
381 * ScopedCallback (deprecated in 1.28) was removed. Use Wikimedia\ScopedCallback
382 instead.
383 * Support for ResourceLoaderModule::getModifiedTime() and getModifiedHash(),
384 deprecated since 1.26, was removed. Use getDefinitionSummary() instead.
385 * (T195256) Skins are recommended not to rely on JavaScript for the "mw-jump"
386 and "jump-to-nav" accessibility links. To this end, the "jquery.mw-jump"
387 is no longer loaded by default. The Vector and MonoBook skins have made a
388 minor change to implement the toggle feature with CSS instead. To restore
389 prior functionality, either explicitly load "jquery.mw-jump" in your skin
390 or refer to T195256 for details on how to make the same change.
391 * Hook 'EditPageBeforeEditChecks' was removed;
392 use 'EditPageGetCheckboxesDefinition' instead.
393 * Linker::getLinkColour() and DummyLinker::getLinkColour(), deprecated since
394 1.28, were removed. LinkRenderer::getLinkClasses() should be used instead.
395 * Wikimedia\Rdbms\LoadBalancer::getLaggedSlaveMode(), deprecated in 1.28, has
396 been removed. Use Wikimedia\Rdbms\LoadBalancer::getLaggedReplicaMode()
397 instead.
398 * mw.widgets.CategoryMultiselectWidget now uses TagMultiselectWidget instead of
399 CapsuleMultiselectWidget. The following methods may no longer be used:
400 * setItemsFromData: Use setValue instead
401 * getItemsData: Use getItems instead and get the data property
402 * Two OutputPage methods, addMetadataLink() and getMetadataAttribute(), were
403 removed. Use addLink() instead.
404 * Another two OutputPage methods, setPageTitleActionText() and
405 getPageTitleActionText(), were removed. They did nothing since 1.15 (almost
406 ten years). Use setHTMLTitle() directly.
407 * The return value of OutputPage::adaptCdnTTL() has been removed. The
408 value returned was misleading and probably not what any caller would
409 have wanted.
410 * All MagicWord static member variables have been removed. Use appropriate
411 hooks or MagicWordFactory methods instead.
412 * MagicWord::clearCache() has been removed. Instead, create a new
413 MagicWordFactory, such as by calling
414 resetServiceForTesting( 'MagicWordFactory' ) on a MediaWikiServices.
415 * mw.util.init() has been removed. This function is not needed anymore and was
416 a no-op function since 1.30.
417 * SpecialPageFactory::resetList() is a no-op. Call overrideMwServices()
418 instead.
419 * MediaWiki no longer supports a StartProfiler.php file. Instead, you can set
420 $wgProfiler and $wgEnableProfileInfo.
421 * The mw.loader.addSource() is now considered a private method, and no longer
422 supports the `id, url` signature. Use the `Object` parameter instead.
423 * The backwards-compatibility code in HTMLForm to add a drop-down control to an
424 option that is not set to be a drop-down if the "mw-chosen" class is present,
425 is now removed.
426 * Several collations were removed. They were workarounds for bugs in the ICU
427 library and they are no longer needed (as of ICU 57.1):
428 * 'uppercase-se' (NorthernSamiUppercaseCollation) - use 'uca-se' instead
429 * 'xx-uca-et' (CollationEt) - use 'uca-et' instead
430 * 'xx-uca-fa' (CollationFa) - use 'uca-fa' instead
431 * LanguageCode::bcp47() now always returns a valid BCP 47 code. This means
432 that some MediaWiki-specific language codes, such as `simple`, are mapped
433 into valid BCP 47 codes (eg `en-simple`).
434 * The hooks 'SpecialRecentChangesFilters' & 'SpecialWatchlistFilters' deprecated
435 in 1.23 were removed. Instead, use 'ChangesListSpecialPageStructuredFilters'.
436 The ChangesListSpecialPage code for these legacy hooks, and their use in
437 SpecialRecentchanges.php and SpecialWatchlist, was also removed:
438 * ChangesListSpecialPage->getCustomFilters()
439 * ChangesListSpecialPage->getFilterGroupDefinitionFromLegacyCustomFilters()
440 * ChangesListSpecialPage::customFilters
441 * The global function wfUseMW, deprecated since 1.26, has now been removed. Use
442 the "requires" property of static extension registration instead.
443 * $wgSpecialPages no longer accepts array syntax, deprecated since 1.18.
444 * The MailAddress constructor can no longer be called with a User object,
445 behaviour which has been deprecated since 1.24.
446 * LBFactory, deprecated since 1.28, has been removed. Instead, use
447 Wikimedia\Rdbms\LBFactory.
448 * The MimeMagic class, deprecated since 1.28 has been removed. Get a
449 MimeAnalyzer instance from MediaWikiServices instead.
450 * The '--tidy' option to maintenance/parse.php has been removed. Tidying
451 the output is now the default. Use '--no-tidy' to bypass the tidy
452 phase.
453 * The global function wfErrorLog, deprecated since 1.25, has now been removed.
454 Use MWLoggerLegacyLogger::emit or UDPTransport.
455 * The hooks 'SpecialRecentChangesQuery' & 'SpecialWatchlistQuery', deprecated in
456 1.23, were removed. Instead, use ChangesListSpecialPageStructuredFilters or
457 ChangesListSpecialPageQuery.
458 * The global function wfUsePHP, deprecated since 1.30, has now been removed. To
459 assert a newer version of PHP than MediaWiki does, use extension registration.
460 * The hook 'ChangesListSpecialPageFilters', deprecated in 1.29, has now been
461 removed. Use the 'ChangesListSpecialPageStructuredFilters' hook instead.
462 * DeferredUpdates::setImmediateMode(), deprecated since 1.29, has been removed.
463 * File / MediaHandler::getStreamHeaders(), deprecated since 1.30, was removed.
464 * The hook 'DoEditSectionLink', deprecated since 1.25, has been removed. Use
465 the hook 'SkinEditSectionLinks' instead.
466 * The hook 'UserGetImplicitGroups', deprecated since 1.25, has been removed.
467 * The global function wfRunHooks, deprecated since 1.25, has now been removed.
468 Use Hooks::run().
469 * The hook 'UnknownAction', deprecated since 1.19, has now been removed.
470 * The hook 'ParserLimitReport', deprecated since 1.22, has been removed. Use
471 the hooks 'ParserLimitReportPrepare' and 'ParserLimitReportFormat' instead.
472 * The following deprecated API methods have been removed:
473 * ApiBase::profileIn() (deprecated in 1.25)
474 * ApiBase::profileOut() (deprecated in 1.25)
475 * ApiBase::safeProfileOut() (deprecated in 1.25)
476 * ApiBase::profileDBIn() (deprecated in 1.25)
477 * ApiBase::profileDBOut() (deprecated in 1.25)
478 * ApiBase::dieUsage() (deprecated in 1.29)
479 * ApiBase::dieUsageMsg() (deprecated in 1.29)
480 * ApiBase::dieUsageMsgOrDebug() (deprecated in 1.29)
481 * ApiBase::getErrorFromStatus() (deprecated in 1.29)
482 * ApiBase::parseMsg() (deprecated in 1.29)
483 * ApiBase::setWarning() (deprecated in 1.29)
484 * ApiPageSet::getInvalidTitles() (deprecated in 1.26)
485 * ApiQueryLogEvents::addLogParams() (deprecated in 1.25)
486 * ApiUsageException::getCodeString() (deprecated in 1.29)
487 * ApiUsageException::getMessageArray() (deprecated in 1.29)
488 * Class UsageException, deprecated in 1.29, has been removed.
489 * MediaWiki no longer has a 'JavaScript-powered' wikitext toolbar built in. The
490 old "bulletin board style toolbar", known as "the 2006 wikitext editor", has
491 been removed, and instead sysadmins will be required to choose one (or more)
492 of the several extensions available for this purpose if they need the
493 functionality. The MediaWiki "tarball" releases have included the replacement
494 extension for this, the WikiEditor extension aka "the 2010 wikitext editor",
495 for many years now. As part of this, several parts of MediaWiki have been
496 removed or simplified:
497 * The user option 'showtoolbar' (shown as "Show edit toolbar") is no longer
498 available; if an extension adds a toolbar via the EditPageBeforeEditToolbar
499 hook, it will be shown; extensions should provide a specific user preference
500 to disable themselves as needed.
501 * The public methods Language::getImageFile() and ::getImageFiles(), and the
502 related specification of $imageFiles within individual languages' code file,
503 as well as the referenced static media assets, all of which were only used
504 inside MediaWiki itself for providing the icons for the old toolbar, have
505 been removed without explicit deprecation.
506 * The internal ResourceLoader module "mediawiki.toolbar", which is unused
507 except by MediaWiki itself and back-compatibility code, has been removed.
508 * The internal ResourceLoaderEditToolbarModule class has been removed.
509
510 === Deprecations in 1.32 ===
511 * HTMLForm::setSubmitProgressive() is deprecated. No need to call it. Submit
512 button is already marked as progressive.
513 * Skin::setupSkinUserCss() is deprecated. Adding of modules to load
514 has been centralised to Skin::getDefaultModules(), which is now capable
515 of queueing style modules as well.
516 * OutputPage::addModuleScripts() and ParserOutput::addModuleScripts are
517 deprecated. Use addModules() instead.
518 * Overriding SearchEngine::{searchText,searchTitle,searchArchiveTitle}
519 in extending classes is deprecated. Extend related doSearch* methods
520 instead.
521 * The following 'mediawiki.api' plugin modules were merged into mediawiki.api
522 and deprecated: mediawiki.api.category, mediawiki.api.edit,
523 mediawiki.api.login, mediawiki.api.options, mediawiki.api.parse,
524 mediawiki.api.upload, mediawiki.api.user, mediawiki.api.watch,
525 mediawiki.api.messages, and mediawiki.api.rollback.
526 * ApiBase::truncateArray() is deprecated. No replacement, as nothing is known
527 to use it.
528 * WatchAction::getUnwatchToken is deprecated. Use WatchAction::getWatchToken
529 with the 'unwatch' action parameter instead.
530 * IcuCollation::getICUVersion() is deprecated, as you can just use the PHP
531 constant INTL_ICU_VERSION directly in all versions that MediaWiki supports.
532 * Parser::fetchFile() is deprecated. Use ::fetchFileAndTitle() instead.
533 * The ApiQueryContributions class has been renamed to ApiQueryUserContribs.
534 * The XMPInfo, XMPReader, and XMPValidate classes have been deprecated in favor
535 of the namespaced classes provided by the wikimedia/xmp-reader library.
536 * SearchResultSet::{next,rewind} are deprecated. Calling code should
537 use foreach on the SearchResultSet, or the extractResults method. Extending
538 code should override extractResults.
539 * Instantiating SearchResultSet directly is deprecated. SearchEngine
540 implementations must subclass SearchResultSet for their purposes.
541 * SearchResult::setExtensionData argument has been changed from accepting an
542 array to accepting a Closure that returns the array when called.
543 * Class CryptRand, everything in MWCryptRand except generateHex() and function
544 MediaWikiServices::getInstance()->getCryptRand() are deprecated, use
545 random_bytes() to generate cryptographically secure random byte sequences.
546 * Parser::getConverterLanguage() is deprecated. Use ::getTargetLanguage()
547 instead.
548 * Language::markNoConversion() is deprecated. It confused readers because
549 it had unexpected behavior (only marking text if it looked like a URL)
550 and was only used in a single place in the code. Use
551 LanguageConverter::markNoConversion() instead.
552 * (T197492) Language::truncate() was soft deprecated in 1.31 and is
553 hard deprecated in this release. It has been split into two similar
554 methods, Language::truncateForVisual() and Language::truncateForDatabase(),
555 which measure length in characters and bytes, respectively. Use
556 Language::truncateForVisual() when possible to provide equity to users
557 of multibyte scripts.
558 * (T176526) EditPage::getContextTitle() falling back to $wgTitle when the
559 context title is unset is now deprecated; anything creating an EditPage
560 instance should set the context title via ::setContextTitle().
561 * The 'jquery.hidpi' module (polyfill for IMG srcset) is deprecated.
562 * ResourceLoaderStartUpModule::getStartupModules() and ::getLegacyModules()
563 are deprecated. These concepts are obsolete and have no replacement.
564 * String type for $lang of DifferenceEngine::setTextLanguage is deprecated.
565 * The following methods of OutputPage are now deprecated in favour
566 of using showFatalError directly: OutputPage::showFileDeleteError()
567 OutputPage::showFileNotFoundError(), OutputPage::showFileRenameError()
568 OutputPage::showFileCopyError() and OutputPage::showUnexpectedValueError().
569 * The Replacer, DoubleReplacer, HashtableReplacer, and RegexlikeReplacer
570 classes are now deprecated. Use a Closure instead.
571 * (T194263) ContentHandler::makeParserOptions() is deprecated. Use
572 WikiPage::makeParserOptions() or ParserOptions::newCanonical() instead.
573 * (T100681) Use of the Parsoid v1 API with the VirtualRESTService, deprecated in
574 MediaWiki 1.26, is now hard-deprecated. All known clients were converted to
575 the Parsoid v3 API in May 2015.
576 * $input is deprecated in hook 'LogEventsListGetExtraInputs'. Use
577 $formDescriptor instead.
578 * SearchEngine::transformSearchTerm( $term ) should no longer be called prior
579 to running searchText. This method was mainly implemented to support the
580 'prefix' URI param in SpecialSearch, but there are no reasons to expose this
581 logic as it should be handled internally by SearchEngine implementations
582 supporting this feature. SearchEngine implementations should no longer
583 override this methods.
584 * SearchEngine::replacePrefixes( $query ) should no longer be called prior
585 to running searchText/searchTitle.
586 * (T199657) Messages for $wgFilterLogTypes labels should be no longer be in the
587 'log-show-hide-[type]' format. Instead use 'logeventslist-[type]-log'.
588 * Global functions wfArrayFilter() and wfArrayFilterByKey() are deprecated.
589 use array_filter() directly.
590 * The $wgShowSQLErrors global is deprecated and nonfunctional.
591 Set $wgShowExceptionDetails and/or $wgShowHostnames instead.
592 * The $wgShowDBErrorBacktrace global is deprecated and nonfunctional.
593 Set $wgShowExceptionDetails instead.
594 * Public access to the DifferenceEngine properties mOldid, mNewid, mOldRev,
595 mNewRev, mOldPage, mNewPage, mOldContent, mNewContent, mRevisionsLoaded,
596 mTextLoaded and mCacheHit is deprecated. Use getOldid() / getNewid() /
597 getOldRevision() / getNewRevision() for the first four (note that the
598 revision ones return a RevisionRecord, not a Revision), do your own lookup
599 for page/content.
600 * The $wgExternalDiffEngine value 'wikidiff2' is deprecated. To use wikidiff2
601 just enable the PHP extension, and it will be autodetected.
602 * (T194731) DifferenceEngine properties mOldContent and mNewContent and methods
603 setContent(), generateContentDiffBody(), generateTextDiffBody() and textDiff()
604 are deprecated. To interact with a single slot, use a SlotDiffRenderer (and
605 subclass it to customize diff rendering); to diff custom (e.g. unsaved)
606 content, use setRevisions(). Subclassing DifferenceEngine should only be done
607 to customize page-level diff properties (such as the navigation header).
608 * The wfUseMW function, soft-deprecated in 1.26, is now hard deprecated.
609 * All MagicWord static methods are now deprecated. Use the MagicWordFactory
610 methods instead.
611 * PasswordFactory::init is deprecated. To get a password factory with the
612 standard configuration, use
613 MediaWikiServices::getInstance()->getPasswordFactory.
614 * $wgContLang is deprecated, use
615 MediaWikiServices::getInstance()->getContentLanguage() instead.
616 * $wgParser is deprecated, use MediaWikiServices::getInstance()->getParser()
617 instead.
618 * wfGetMainCache() is deprecated, use ObjectCache::getLocalClusterInstance()
619 instead.
620 * wfGetCache() is deprecated, use ObjectCache::getInstance() instead.
621 * All SpecialPageFactory static methods are deprecated. Instead, call the
622 methods on a SpecialPageFactory instance, which may be obtained from
623 MediaWikiServices.
624 * mw.user.stickyRandomId was renamed to the more explicit
625 mw.user.getPageviewToken to better capture its function.
626 * Passing Revision objects to ContentHandler::getUndoContent() is deprecated,
627 Content object should be passed instead.
628 * (T197179) Parameters 'notice', 'notice-messages', 'notice-message',
629 previously used by OOUI HTMLForm fields, are now deprecated. Use
630 'help', 'help-message', 'help-messages' instead.
631 * (T197179) HTMLFormField::getNotices() is now deprecated.
632 * The jquery.localize module is now deprecated. Use jquery.i18n instead.
633 * The SecondaryDataUpdates hook was deprecated in favor of RevisionDataUpdates,
634 or overriding ContentHandler::getSecondaryDataUpdates (T194038).
635 * The WikiPageDeletionUpdates hook was deprecated in favor of
636 PageDeletionDataUpdates, or overriding ContentHandler::getDeletionDataUpdates
637 (T194038).
638 * Content::getSecondaryDataUpdates has been deprecated in favor of
639 ContentHandler::getSecondaryDataUpdates() for overriding by extensions
640 (T194038).
641 Application logic should call WikiPage::doSecondaryDataUpdates() (T194037).
642 * Content::getDeletionUpdates has been deprecated in favor of
643 ContentHandler::getDeletionUpdates() for overriding by extensions (T194038).
644 Application logic should call WikiPage::doSecondaryDataUpdates() (T194037).
645 * (T198214) Old Tidy-related configuration settings, which were soft-deprecated
646 in MediaWiki 1.26, have now been hard deprecated. This affects $wgUseTidy,
647 $wgTidyBin, $wgTidyConf, $wgTidyOpts, $wgTidyInternal, and $wgDebugTidy. Use
648 $wgTidyConfig instead.
649 * All Tidy configurations other than Remex have been hard deprecated;
650 future parsers will not emit compatible output for these configurations.
651 In particular, running MediaWiki with tidy disabled has been deprecated.
652 * (T198214) OutputPage::addWikiText(), OutputPage::addWikiTextWithTitle(),
653 and OutputPage::addWikiTextTitle() have been deprecated, since they
654 can result in untidy output. In addition OutputPage::addWikiTextTidy()
655 and OutputPage::addWikiTextTitleTidy() was deprecated to make naming new
656 methods consistent. Use OutputPage::addWikiTextAsInterface() or
657 OutputPage::addWikiTextAsContent() instead, which ensures the output is
658 tidy and clarifies whether content-language specific postprocessing should
659 be done on the text.
660 * OutputPage::parse() and OutputPage::parseInline() have been deprecated
661 due to untidy output and inconsistent handling of wrapper divs and
662 interface/content language defaults. Use OutputPage::parseAsContent(),
663 OutputPage::parseAsInterface(), or OutputPage::parseInlineAsInterface()
664 as appropriate.
665 * QuickTemplate::msgHtml() and BaseTemplate::msgHtml() have been deprecated
666 as they promote bad practises. I18n messages should always be properly
667 escaped.
668 * Skin::getDynamicStylesheetQuery() has been deprecated. It always
669 returns action=raw&ctype=text/css which callers should use directly.
670 * Class LegacyFormatter is deprecated.
671 * Use of CommentStore::insertWithTempTable() with 'img_description' is
672 deprecated. Use CommentStore::insert() instead.
673 * Language::setCode is deprecated as public function. Use Language::factory
674 to create a new Language object with a different language code.
675 * Several classes have been moved from the MediaWiki\Storage\ namespace to the
676 MediaWiki\Revision\ namespace. The old class names are aliased for
677 compatibility, but are deprecated. Classes are IncompleteRevisionException,
678 MutableRevisionRecord, MutableRevisionSlots, RevisionAccessException,
679 RevisionArchiveRecord, RevisionFactory, RevisionLookup, RevisionRecord,
680 RevisionSlots, RevisionStore, RevisionStoreRecord, SlotRecord, and
681 SuppressedDataException.
682 * When using OOUI HTMLForm containing an 'info' field which uses the 'rawrow'
683 option, it is now deprecated to give its contents (the 'default' option)
684 as a string. They should be given as a OOUI\FieldLayout object instead.
685 Notably, this affects fields defined in the 'GetPreferences' hook, because
686 Special:Preferences uses an OOUI form now. (If possible, don't use 'rawrow'.)
687 * In Skin::doEditSectionLink omitting the parameters $tooltip and $lang is
688 deprecated. For the $lang parameter, types other than Language are
689 deprecated.
690 * The $wgUseKeyHeader configuration option and the
691 OutputPage::getKeyHeader() method have been deprecated; the relevant
692 draft IETF spec expired without becoming a standard.
693 * Deprecated API action=query&prop=info inprop=readable in favor of
694 intestactions=read.
695
696 === Other changes in 1.32 ===
697 * (T198811) The following tables have had their UNIQUE indexes turned into
698 proper PRIMARY KEYs for increased maintainability: interwiki, page_props,
699 protected_titles and site_identifiers.
700 * OOUI HTMLForm will now display help text inline after the input field,
701 rather than in a popup. Previous behavior can be restored by using
702 `'help-inline' => false`.
703 * The archive table's ar_rev_id field is now unique.
704 * Special:BotPasswords now requires reauthentication.
705 * (T174023) Multi-Content Revision (MCR) capabilities were introduced into the
706 storage layer and have basic support for display. No user interface exists
707 yet for creating or managing content in slots beides the main slot. See
708 <https://www.mediawiki.org/wiki/Multi-Content_Revisions> for more
709 information.
710 * The image_comment_temp database table has been removed. Since all access
711 should be mediated by the CommentStore class, this change shouldn't affect
712 external code.
713 * (T206147) Database::close() will no longer commit any open transactions.
714 * (T64103) Dropped columns category.cat_hidden, site_stats.ss_admins, and
715 recentchanges.rc_cur_time from the PostgreSQL schema.
716
717 = MediaWiki 1.31 =
718
719 == MediaWiki 1.31.1 ==
720
721 This is a security and maintenance release of the MediaWiki 1.31 branch.
722
723 === Changes since MediaWiki 1.31.0 ===
724 * (T169545, CVE-2018-0503) SECURITY: $wgRateLimits entry for 'user' overrides
725 'newbie'.
726 * (T194605, CVE-2018-0505) SECURITY: BotPasswords can bypass CentralAuth's
727 account lock.
728 * (T199029, CVE-2018-13258) SECURITY: Tarball was missing .htaccess files.
729 * (T197229) Bundle Nuke extension, it was accidentally omitted.
730 * (T193995) Fix undefined patchPath() method call in parser tests.
731 * (T198687) Fix various selectFields methods to use the string 'NULL', not null.
732 * Special:BotPasswords now requires reauthentication.
733 * (T191608, T187638) Add 'logid' parameter to Special:Log.
734 * (T193829) Indicate when a Bot Password needs reset.
735 * (T198037) GitInfo: Don't try shelling out if it's disabled.
736 * (T151415) Log email changes.
737 * (T197206) Fix performance regression when multiple DB used without caching.
738 * (T197030) PHPSessionHandler: Suppress headers warnings in initialize().
739 * (T182377, T196793) Exif: Guard against uncountable tag values.
740 * (T200861) Fix total breakage of SQLite web upgrade.
741 * (T200864) Fix pingback over-reporting on non-MySQL databases
742 * (T202550) Unbreak SpecialListusersHeaderForm and SpecialListusersHeader
743 hooks.
744
745 == MediaWiki 1.31.0 ==
746
747 === Changes since MediaWiki 1.31.0-rc.2 ===
748 * (T195783) Initialize PSR-4 namespaces at same stage as normal autoloader.
749 * (T196092) Hide MySQL binary/utf-8 charset option in the installer.
750 * (T196185) Don't allow setting $wgDBmysql5 in the installer.
751 * (T196125) php-memcached 3.0 (provided with PHP 7.0) is now supported.
752 * (T182366) UploadBase::checkXMLEncodingMissmatch() now works on PHP 7.1+
753 * (T118683) Fix exception from &$user deref on HHVM in the TitleMoveComplete hook.
754 * (T196672) The mtime of extension.json files is now able to be zero
755 * (T180403) Validate $length in padleft/padright parser functions.
756 * (T143790) Make $wgEmailConfirmToEdit only affect edit actions.
757
758 === Changes since MediaWiki 1.31.0-rc.0 ===
759 * (T33223) Drop archive.ar_text and ar_flags.
760 * Add default edit rate limit of 90 edits/minute for all users.
761 * (T187645) Use codepoint as tiebreaker when getting first-letters in
762 IcuCollation.
763 * (T191947) Don't shell during the installer if shelling out is disabled.
764 * (T194319) Improve duplicate config setting exception as part of extension
765 registration.
766 * (T195211) Don't require trailing slash in PSR-4 autoloader directory.
767 * (T186565) Fix PHP Notice from `ob_end_flush()` in `FileRepo::streamFile()`.
768 * Do not incorrectly hide namespace input field in the installer.
769 * (T186456) Refactor checks looking for PEAR maik libraries to be clearer.
770
771 === Important pre-upgrade notes for 1.31 ===
772 * If you're using MySQL, SQLite, or MSSQL, are not using update.php to apply
773 schema changes, and cannot have downtime to run migrateArchiveText.php and
774 apply patch-drop-ar_text.sql manually, you'll have to apply a default value
775 to the ar_text and ar_flags columns of the archive table or make those
776 columns nullable before upgrading to MediaWiki 1.31.
777 maintenance/archives/patch-nullable-ar_text.sql shows how to do this for MySQL.
778
779 === Configuration changes in 1.31 ===
780 * $wgEnableAPI and $wgEnableWriteAPI are now deprecated and will be removed in
781 a future version. The API is now considered to be stable, secure and
782 essential.
783 * $wgUsejQueryThree was removed, as it is now the default. This was documented
784 as a temporary variable during the migration period, deprecated since 1.29.
785 * $wgLogoHD has been updated to support svg images and uses $wgLogo where
786 possible for fallback images such as png.
787 * (T44246) $wgFilterLogTypes will no longer ignore 'patrol' when user does not
788 have the right to mark things patrolled.
789 * Wikis that contain imported revisions or CentralAuth global blocks should run
790 maintenance/cleanupUsersWithNoId.php.
791 * The configuration settings $wgResourceLoaderMinifierStatementsOnOwnLine and
792 $wgResourceLoaderMinifierMaxLineLength, deprecated since 1.27, were removed.
793 * (T180921) $wgReferrerPolicy now supports having fallbacks for browsers that
794 are not using the latest version of the Referrer Policy specification.
795 * $wgFragmentMode is now set to [ 'legacy', 'html5' ] by default. This is a
796 first step of migration to human-readable section IDs that will later result
797 in 'html5' being the default mode.
798 * CACHE_ACCEL now only supports APC(u) or WinCache. XCache support was removed
799 as upstream is inactive and has no plans to move to PHP 7.
800 * The old CategorizedRecentChanges feature, including its related configuration
801 option $wgAllowCategorizedRecentChanges, has been removed.
802 * (T188472) The 'comma' value for $wgArticleCountMethod is no longer supported
803 for performance reasons, and installations with this setting will now work as
804 if it was configured with 'any'.
805 * (T185753) MediaWiki now defaults to using RemexHtml to tidy up user input,
806 rather than being off by default. If you wish to disable HTML tidying
807 entirely, set $wgTidyConfig to null; if you wish to use the old, deprecated
808 Tidy external binary, both set $wgTidyConfig to null and $wgUseTidy to true.
809 * $wgLogAutopatrol now defaults to false instead of true.
810 * $wgValidateAllHtml was removed and will be ignored.
811 * $wgScriptExtension, deprecated and ignored since 1.25, was removed. See the
812 1.25 release notes for more information.
813 * $wgUseAjax is now marked as deprecated, just like the deprecated AJAX
814 framework that it enables. Some extensions mistakenly used this to check
815 whether any AJAX functionality at all should be enabled, further making this
816 problematic to retain.
817 * $wgDBmysql5 is now deprecated, and will be removed in a future version. It
818 has been marked as experimental ever since it was introduced.
819
820 === New features in 1.31 ===
821 * (T76554) User sub-pages named ….json are now protected in the same way that
822 ….js and ….css pages are, so that configuration options can safely be placed
823 there.
824 * Wikimedia\Rdbms\IDatabase->select() and similar methods now support joins
825 with parentheses for grouping.
826 * As a first pass in standardizing dialog boxes across the MediaWiki product,
827 Html class now provides helper methods for messageBox, successBox, errorBox
828 and warningBox generation.
829 * (T9240) Imports will now record unknown (and, optionally, known) usernames in
830 a format like "iw>Example".
831 * (T20209) Linker (used on history pages, log pages, and so on) will display
832 usernames formed like "iw>Example" as interwiki links, as if by wikitext like
833 [[iw:User:Example|iw>Example]].
834 * (T111605) The 'ImportHandleUnknownUser' hook allows extensions to auto-create
835 users during an import.
836 * Added a hook, ParserOutputPostCacheTransform, to allow extensions to affect
837 the ParserOutput::getText() post-cache transformations.
838 * Added a hook, UploadForm:getInitialPageText, to allow extensions to alter the
839 initial page text for file uploads.
840 * (T181651) The info page for File pages now displays the file's base-16 SHA1
841 hash value in the table of basic information.
842 * Style tags with a 'data-mw-deduplicate' attribute will be deduplicated as a
843 ParserOutput::getText() post-cache transformation. This may be disabled by
844 passing 'deduplicateStyles' => false to that method.
845 * The identity of the logged-in or IP "actor" for logged actions is being moved
846 into a new actor table, with the rows in tables such as revision and logging
847 referring to the actor ID instead of storing the user ID and name/IP in
848 every row.
849 * This is currently gated by $wgActorTableSchemaMigrationStage. Most wikis
850 can set this to MIGRATION_NEW and run maintenance/migrateActors.php as
851 soon as any necessary extensions are updated.
852 * Most code accessing rows for logged actions from the database should use
853 the relevant getQueryInfo() methods to get the information needed to build
854 the SQL query. The ActorMigration class may also be used to get feature
855 -flagged information needed to access actor-related fields during the
856 migration period.
857 * Added Wikimedia\Rdbms\IDatabase::cancelAtomic(), to roll back an atomic
858 section without having to roll back the whole transaction.
859 * Wikimedia\Rdbms\IDatabase::doAtomicSection(), non-native ::insertSelect(),
860 and non-MySQL ::replace() and ::upsert() no longer roll back the whole
861 transaction on failure.
862 * (T189785) Added a monthly heartbeat ping to the pingback feature.
863 * The CLI installer (maintenance/install.php) learned to detect and include
864 extensions. Pass --with-extensions to enable that feature.
865 * (T184791) rc_patrolled now has three states: "0" for unpatrolled,
866 "1" for manually patrolled and "2" for autopatrolled actions.
867 * Extensions can now set their type to "editor" if they provide an editor or
868 enhance the editing experience.
869 * Extensions can use a PSR-4 autoloader by setting an "AutoloadNamespaces"
870 property in extension.json. See the documentation at
871 <https://mediawiki.org/wiki/Manual:Extension.json/Schema#AutoloadNamespaces>
872 for more details and an example.
873 * (T19099) Tabs which link to pages that don't exist (like those to uncreated
874 discussion pages) now have a tooltip to indicate state, not just colour.
875
876 === External library changes in 1.31 ===
877 * pear/mail, pear/mail_mime and pear/mail_mime-decode have been moved from
878 suggested to required. These packages now must be installed via composer
879 and not via PEAR itself.
880
881 ==== Upgraded external libraries ====
882 * Updated jquery.chosen from v0.9.14 to v1.8.2.
883 * Updated composer/spdx-licenses from 1.1.4 to 1.3.0 (development dependency).
884 * Updated nikic/php-parser from 2.1.0 to 3.1.3 (development dependency).
885 * Updated wikimedia/ip-set from 1.1.0 to 1.2.0.
886 * Updated wikimedia/relpath from 2.0.0 to 2.1.1.
887 * Updated wikimedia/running-stat from 1.1.0 to 1.2.0.
888 * Updated wikimedia/wrappedstring from 2.2.0 to 2.3.0.
889 * Updated mediawiki/at-ease from 1.1.0 to 1.2.0.
890 * Updated wikimedia/php-session-serializer from 1.0.4 to 1.0.6.
891 * Updated wikimedia/remex-html from 1.0.2 to 1.0.3.
892 * Updated wikimedia/html-formatter from 1.0.1 to 1.0.2.
893
894 ==== New external libraries ====
895 * Added wikimedia/object-factory 1.0.0
896
897 ==== Removed and replaced external libraries ====
898 * (T17845) The deprecated 'jquery.badge' module was removed.
899 * The deprecated 'jquery.autoEllipsis' module was removed. Use the CSS
900 text-overflow property instead.
901 * The deprecated 'jquery.placeholder' module was removed.
902 * The deprecated 'jquery.appear' module was removed. Use the
903 'mediawiki.viewport' module instead.
904 * mediawiki/at-ease was replaced with wikimedia/at-ease.
905
906 === Bug fixes in 1.31 ===
907 * (T90902) Non-breaking space in header ID breaks anchor.
908 * (T189375) CSSMin now allows quoted urls in `url()` syntax to start with a
909 space.
910 * (T2087, T10897, T87753, T174639) Whitespace created by category and language
911 links is now stripped rather than leaving blank lines in odd places.
912 * (T3780) Uploads with UTF-8 names now work on PHP7.1+ on Windows servers.
913 * (T182366) UploadBase::checkXMLEncodingMissmatch() now works on PHP 7.1+
914
915 === Action API changes in 1.31 ===
916 * (T185058) The 'name' value to tgprop for action=query&list=tags has been
917 removed. It has never made a difference in the output, the name was always
918 returned regardless.
919 * The 'watch' and 'unwatch' parameters for action=move have been removed. They
920 were deprecated and also accidentally nonfunctional since 1.17 in 2010. Use
921 'watchlist' instead.
922
923 === Action API internal changes in 1.31 ===
924 * ApiBase::getProfileDBTime, deprecated since 1.25, was removed.
925 * ApiBase::getModuleProfileName, deprecated since 1.25, was removed.
926 * ApiBase::getProfileTime, deprecated since 1.25, was removed.
927
928 === Languages updated in 1.31 ===
929 MediaWiki supports over 350 languages. Many localisations are updated
930 regularly. Below only new and removed languages are listed, as well as
931 changes to languages because of Phabricator reports.
932
933 * (T180052) Mirandese (mwl) now supports gendered NS_USER/NS_USER_TALK.
934 * (T182305) New language support: Nyungar (nys).
935 * (T186359) New language support: Siberian Tatar [cебертатар] (sty).
936 * (T186635) New language support: Guianan Creole (gcr).
937 * (T186647) New language support: Kumyk [къумукъ] (kum).
938 * (T187750) New language support: Spanish formal address (es-formal).
939 * (T187824) New language support: Hungarian formal address (hu-formal).
940 * (T189127) New language support: Gorontalo (gor).
941
942 === Breaking changes in 1.31 ===
943 * MessageBlobStore::insertMessageBlob(), deprecated in 1.27, was removed.
944 * The OutputPage class constructor now requires a context parameter.
945 Instantiating without context was deprecated in 1.18.
946 * The mw.page JavaScript singleton, deprecated in 1.30, was removed.
947 * Article::getLastPurgeTimestamp(), WikiPage::getLastPurgeTimestamp(), and the
948 related WikiPage::PURGE_* constants, deprecated in 1.29, were removed.
949 * The Article::selectFields(), ::onArticleCreate(), ::onArticleDelete(), and
950 ::onArticleEdit() methods, deprecated in 1.24, were removed.
951 * Installer::locateExecutable() and ::locateExecutableInDefaultPaths() were
952 removed. Use ExecutableFinder::findInDefaultPaths() instead.
953 * The deprecated MW_DIFF_VERSION constant was removed.
954 DifferenceEngine::MW_DIFF_VERSION should be used instead.
955 * Due to significant refactoring, method ContribsPager::getUserCond() that had
956 no access restriction has been removed.
957 * The Block class will no longer accept usable-but-missing usernames for
958 'byText' or ->setBlocker(). Callers should either ensure the blocker exists
959 locally or use a new interwiki-format username like "iw>Example".
960 * The following methods and constants from the WatchedItem class, which were
961 deprecated in 1.27, have been removed:
962 * WatchedItem::getTitle()
963 * WatchedItem::fromUserTitle()
964 * WatchedItem::addWatch()
965 * WatchedItem::removeWatch()
966 * WatchedItem::isWatched()
967 * WatchedItem::duplicateEntries()
968 * WatchedItem::IGNORE_USER_RIGHTS
969 * WatchedItem::CHECK_USER_RIGHTS
970 * WatchedItem::DEPRECATED_USAGE_TIMESTAMP
971 * The $statementsOnOwnLine parameter of JavaScriptMinifier::minify was removed.
972 $wgResourceLoaderMinifierStatementsOnOwnLine, the corresponding configuration
973 variable, has been deprecated since 1.27 and was removed as well.
974 * The $maxLineLength parameter of JavaScriptMinifier::minify was removed.
975 $wgResourceLoaderMinifierMaxLineLength, the corresponding configuration
976 variable, has been deprecated since 1.27 and was removed as well.
977 * The HtmlFormatter class, deprecated in 1.27, was removed. The namespaced
978 HtmlFormatter\HtmlFormatter class should be used instead.
979 * The driver 'mysql' for MySQL, deprecated in MediaWiki 1.30, has been removed.
980 The driver has been deprecated since PHP 5.5 and was removed in PHP 7.0. The
981 default driver for MySQL has been 'mysqli' since MediaWiki 1.22.
982 * The following properties of PreparedEdit were deprecated in 1.21 and have
983 been removed:
984 * PreparedEdit->newText
985 * PreparedEdit->oldText
986 * PreparedEdit->pst
987 * ParserOutput objects which are generated using a non-default value for
988 ParserOptions::setWrapOutputClass() can no longer be added to the parser
989 cache.
990 * The following deprecated methods from the OutputPage class have been removed:
991 * OutputPage::addExtensionStyle(); deprecated in 1.27
992 * OutputPage::getExtStyle(); deprecated in 1.27
993 * OutputPage::setETag(); deprecated in 1.28 (obsolete no-op)
994 * OutputPage::setSquidMaxage(); deprecated in 1.27
995 * OutputPage::readOnlyPage(); deprecated in 1.25
996 * OutputPage::rateLimited(); deprecated in 1.25
997 * Additionally, the protected OutputPage::$mExtStyles array, only accessed
998 through the above and with no known uses, was removed.
999 * The no-op method Skin::showIPinHeader(), deprecated in 1.27, was removed.
1000 * The following variables and methods in EditPage, deprecated in MediaWiki 1.30,
1001 were removed:
1002 * $isCssJsSubpage — use ::isUserConfigPage()
1003 * $isCssSubpage — use ::isUserCssConfigPage()
1004 * $isJsSubpage — use ::isUserJsConfigPage()
1005 * $isWrongCaseCssJsPage – use ::isWrongCaseUserConfigPage()
1006 * ::getSummaryInput() – use ::getSummaryInputWidget()
1007 * ::getSummaryInputOOUI() – use ::getSummaryInputWidget()
1008 * ::getCheckboxes() – use ::getCheckboxesWidget() or
1009 ::getCheckboxesDefinition()
1010 * ::getCheckboxesOOUI() – use ::getCheckboxesWidget() or
1011 ::getCheckboxesDefinition()
1012 * ResourceLoaderModule::getPosition(), deprecated in 1.29, has been removed.
1013 * In User, the cookie-related methods which were wrappers for the functions on
1014 the response object, and were deprecated in 1.27, have been removed:
1015 * ::setCookie()
1016 * ::clearCookie()
1017 * ::setExtendedLoginCookie()
1018 Note that User::setCookies() remains, and is not deprecated.
1019 * Also in User, some auth-related methods which were deprecated in 1.27 have
1020 been removed:
1021 * ::getEditTokenTimestamp() – use MediaWiki\Session\Token::getTimestamp()
1022 * ::getPasswordFactory() – create a PasswordFactory directly
1023 * ::passwordChangeInputAttribs()
1024 * The global functions wfProfileIn and wfProfileOut, deprecated in 1.25, have
1025 been removed.
1026 * SpecialPageFactory::getList(), deprecated in 1.24, has been removed. You can
1027 use ::getNames() instead.
1028 * OpenSearch::getOpenSearchTemplate(), deprecated in 1.25, has been removed. You
1029 can use ApiOpenSearch::getOpenSearchTemplate() instead.
1030 * The global function wfBaseConvert, deprecated in 1.27, has been removed. Use
1031 Wikimedia\base_convert() directly.
1032 * Calling Database::begin() explicitly during an implicit transaction or when
1033 DBO_TRX is set results in an exception. Calling Database::commit() explicitly
1034 for an implicit transaction also results in an exception. Previously these
1035 were logged as errors. The startAtomic() and endAtomic() methods, or
1036 AtomicSectionUpdate should be used instead.
1037 * The global function wfOutputHandler() was removed, use the its replacement
1038 MediaWiki\OutputHandler::handle() instead. The global function was only
1039 sometimes defined. Its replacement is always available via the autoloader.
1040 * ChangeTags::listExtensionActivatedTags and ::listExtensionDefinedTags,
1041 deprecated in 1.28, have been removed. Use ::listSoftwareActivatedTags() and
1042 ::listSoftwareDefinedTags() instead.
1043 * Title::getTitleInvalidRegex(), deprecated in 1.25, has been removed. You can
1044 use MediaWikiTitleCodec::getTitleInvalidRegex() instead.
1045 * HTMLForm & VFormHTMLForm::isVForm(), deprecated in 1.25, have been removed.
1046 * The ProfileSection class, deprecated in 1.25 and unused, has been removed.
1047 * The ResourceLoaderGetLessVars hook, deprecated in 1.30, has been removed. Use
1048 ResourceLoaderModule::getLessVars() to expose local variables instead of
1049 global ones.
1050 * As part of work to modernise user-generated content clean-up, a config option
1051 and some methods related to HTML validity were removed without deprecation.
1052 The public methods MWTidy::checkErrors() and the path through which it was
1053 called, TidyDriverBase::validate(), are removed, as are the testing methods
1054 MediaWikiTestCase::assertValidHtmlSnippet() and ::assertValidHtmlDocument().
1055 The $wgValidateAllHtml configuration option is removed and will be ignored.
1056 * Execution of external programs using MediaWiki\Shell\Command now applies
1057 the RESTRICT_DEFAULT Firejail restriction by default.
1058 * The ResourceLoaderModule::getHashMtime() and ::getDefinitionMtime() methods,
1059 deprecated in 1.26, were removed.
1060 * The deprecated 'mediawiki.widgets.CategorySelector' module alias was removed.
1061 Use the 'mediawiki.widgets.CategoryMultiselectWidget' module directly.
1062
1063 === Deprecations in 1.31 ===
1064 * The Revision class was deprecated in favor of RevisionStore, BlobStore, and
1065 RevisionRecord and its subclasses.
1066 * The global function wfBCP47 is deprecated in favour of LanguageCode::bcp47.
1067 * The global function wfCountDown is now deprecated in favor of
1068 Maintenance::countDown.
1069 * Several methods for returning lists of fields to select from the database
1070 have been deprecated in favor of similar methods that also return the tables
1071 to select from and the join conditions for those tables.
1072 * Block::selectFields() → Block::getQueryInfo()
1073 * RecentChange::selectFields() → RecentChange::getQueryInfo()
1074 * ArchivedFile::selectFields() → ArchivedFile::getQueryInfo()
1075 * LocalFile::selectFields() → LocalFile::getQueryInfo()
1076 * LocalFile::getCacheFields() with a prefix no longer works
1077 * LocalFile::getLazyCacheFields() with a prefix no longer works
1078 * OldLocalFile::selectFields() → OldLocalFile::getQueryInfo()
1079 * RecentChange::selectFields() → RecentChange::getQueryInfo()
1080 * Revision::userJoinCond() → Revision::getQueryInfo( [ 'user' ] )
1081 * Revision::selectUserFields() → Revision::getQueryInfo( [ 'user' ] )
1082 * Revision::pageJoinCond() → Revision::getQueryInfo( [ 'page' ] )
1083 * Revision::selectPageFields() → Revision::getQueryInfo( [ 'page' ] )
1084 * Revision::selectTextFields() → Revision::getQueryInfo( [ 'text' ] )
1085 * Revision::selectFields() → Revision::getQueryInfo()
1086 * Revision::selectArchiveFields() → Revision::getArchiveQueryInfo()
1087 * User::selectFields() → User::getQueryInfo()
1088 * WikiPage::selectFields() → WikiPage::getQueryInfo()
1089 * Revision::setUserIdAndName() was deprecated.
1090 * Access to TitleValue class properties was deprecated, the relevant getters
1091 should be used instead.
1092 * DifferenceEngine::getDiffBodyCacheKey() is deprecated. Subclasses should
1093 override DifferenceEngine::getDiffBodyCacheKeyParams() instead.
1094 * Use of Maintenance::error( $err, $die ) to exit script was deprecated. Use
1095 Maintenance::fatalError() instead.
1096 * Passing a ParserOptions object to OutputPage::parserOptions() is deprecated.
1097 * The RevisionInsertComplete hook is now deprecated; use instead the hook
1098 RevisionRecordInserted. RevisionInsertComplete is still called, but the second
1099 and third parameter will always be null. Hard deprecation is scheduled for 1.32.
1100 * The following methods that get and set ParserOutput state are deprecated.
1101 Callers should use the new stateless $options parameter to
1102 ParserOutput::getText() instead.
1103 * ParserOptions::getEditSection()
1104 * ParserOptions::setEditSection()
1105 * ParserOutput::getEditSectionTokens()
1106 * ParserOutput::setEditSectionTokens()
1107 * ParserOutput::getTOCEnabled()
1108 * ParserOutput::setTOCEnabled()
1109 * OutputPage::enableSectionEditLinks()
1110 * OutputPage::sectionEditLinksEnabled()
1111 * The public ParserOutput state fields $mTOCEnabled and $mEditSectionTokens
1112 are also deprecated.
1113 * License::getLicenses has been deprecated; use License::getLines instead.
1114 * QuickTemplate::setRef() was deprecated in favour of QuickTemplate::set().
1115 Setting template variables by reference allowed violating the principle of
1116 data being immutable once added to the skin template. In practice, this method
1117 was not being used for that. Rather, setRef() existed as memory optimisation
1118 for PHP 4.
1119 * QuickTemplate::setTranslator() and MediaWikiI18N::set() were deprecated in
1120 favour of Skin::msg() parameters.
1121 * MediaWikiI18N::translate() was deprecated in favour of Skin::msg() or
1122 wfMessage().
1123 * Passing false to ParserOptions::setWrapOutputClass() is deprecated. Use the
1124 'unwrap' transform to ParserOutput::getText() instead.
1125 * \ObjectFactory (no namespace) is deprecated, the namespaced class
1126 \Wikimedia\ObjectFactory from the wikimedia/object-factory library should be
1127 used instead.
1128 * CommentStore::newKey is deprecated. Instead, get an instance from
1129 MediaWikiServices.
1130 * The following CommentStore methods have had their signatures changed to
1131 introduce a $key parameter, usage of the methods on instances retrieved from
1132 CommentStore::newKey will remain unchanged but deprecated:
1133 * CommentStore::getFields
1134 * CommentStore::getJoin
1135 * CommentStore::getComment
1136 * CommentStore::getCommentLegacy
1137 * CommentStore::insert
1138 * CommentStore::insertWithTemplate
1139 * The following methods in Title have been renamed, and the old ones are
1140 deprecated:
1141 * Title::getSkinFromCssJsSubpage – use ::getSkinFromConfigSubpage
1142 * Title::isCssOrJsPage – use ::isSiteConfigPage
1143 * Title::isCssJsSubpage – use ::isUserConfigPage
1144 * Title::isCssSubpage – use ::isUserCssConfigPage
1145 * Title::isJsSubpage – use ::isUserJsConfigPage
1146 * The following methods related to caching of half-parsed HTML were deprecated:
1147 * Parser::serializeHalfParsedText()
1148 * Parser::unserializeHalfParsedText()
1149 * Parser::isValidHalfParsedText()
1150 * StripState::getSubState()
1151 * StripState::merge()
1152 * The DeferredStringifier class is deprecated, use Message::listParam() instead.
1153 * The type string for the parameter $lang of DateFormatter::getInstance is
1154 deprecated.
1155 * Wikimedia\Rdbms\SavepointPostgres is deprecated.
1156 * The DO_MAINTENANCE constant is deprecated. RUN_MAINTENANCE_IF_MAIN should be
1157 used instead.
1158 * The function wfShellWikiCmd() has been deprecated, use
1159 MediaWiki\Shell::makeScriptCommand().
1160 * In the future, the hooks 'PreferencesFormPreSave' and 'PreferencesGetLegend'
1161 will be allowed to provide any HTMLForm object rather than PreferencesForm.
1162
1163 === Other changes in 1.31 ===
1164 * Browser support for Internet Explorer 10 was lowered from Grade A to Grade C.
1165 * Browser support for Opera 12 and older was dropped entirely. Opera 15+
1166 continues at Grade A.
1167 * Multi-content-revision capability was introduced into the storage layer. See
1168 <https://mediawiki.org/wiki/Requests_for_comment/Multi-Content_Revisions>.
1169 * The "free" CSS class is now only applied to unbracketed URLs in wikitext.
1170 Links written using square brackets will get the class "text" not "free".
1171 * RFC 157418: Whitespace is trimmed from wikitext headings, wikitext list items,
1172 wikitext table captions, wikitext table headings, wikitext table cells. HTML
1173 headings, HTML list items, HTML table captions, HTML table headings, HTML
1174 table cells will not have this trimming behavior.
1175
1176 == Compatibility ==
1177 MediaWiki 1.31 requires PHP 7.0.0 or later. Although HHVM 3.18.5 or later is
1178 supported, it is generally advised to use PHP 7.0.0 or later for long term
1179 support.
1180
1181 MySQL/MariaDB is the recommended DBMS. PostgreSQL or SQLite can also be used,
1182 but support for them is somewhat less mature. There is experimental support for
1183 Oracle and Microsoft SQL Server.
1184
1185 The supported versions are:
1186
1187 * MySQL 5.5.8 or later
1188 * PostgreSQL 9.2 or later
1189 * SQLite 3.3.7 or later
1190 * Oracle 9.0.1 or later
1191 * Microsoft SQL Server 2005 (9.00.1399)
1192
1193 == Upgrading ==
1194 1.31 has several database changes since 1.30, and will not work without schema
1195 updates. Note that due to changes to some very large tables like the revision
1196 table, the schema update may take quite long (minutes on a medium sized site,
1197 many hours on a large site).
1198
1199 Don't forget to always back up your database before upgrading!
1200
1201 See the file UPGRADE for more detailed upgrade instructions, including
1202 important information when upgrading from versions prior to 1.11.
1203
1204 For notes on 1.30.x and older releases, see HISTORY.
1205
1206 == Online documentation ==
1207 Documentation for both end-users and site administrators is available on
1208 MediaWiki.org, and is covered under the GNU Free Documentation License (except
1209 for pages that explicitly state that their contents are in the public domain):
1210
1211 https://www.mediawiki.org/wiki/Special:MyLanguage/Documentation
1212
1213 == Mailing list ==
1214 A mailing list is available for MediaWiki user support and discussion:
1215
1216 https://lists.wikimedia.org/mailman/listinfo/mediawiki-l
1217
1218 A low-traffic announcements-only list is also available:
1219
1220 https://lists.wikimedia.org/mailman/listinfo/mediawiki-announce
1221
1222 It's highly recommended that you sign up for one of these lists if you're
1223 going to run a public MediaWiki, so you can be notified of security fixes.
1224
1225 == IRC help ==
1226 There's usually someone online in #mediawiki on irc.freenode.net.
1227
1228
1229 = MediaWiki 1.30 =
1230
1231 == MediaWiki 1.30.1 ==
1232
1233 This is a security and maintenance release of the MediaWiki 1.30 branch.
1234
1235 === Changes since MediaWiki 1.30.0 ===
1236 * (T169545, CVE-2018-0503) SECURITY: $wgRateLimits entry for 'user' overrides
1237 'newbie'.
1238 * (T194605, CVE-2018-0505) SECURITY: BotPasswords can bypass CentralAuth's
1239 account lock.
1240 * (T87572) Make FormatMetadata::flattenArrayReal() work for an associative array.
1241 * Updated composer/spdx-licenses from 1.1.4 to 1.3.0 (development dependency).
1242 * (T189567) the CLI installer (maintenance/install.php) learned to detect and
1243 include extensions. Pass --with-extensions to enable that feature.
1244 * (T190503) Let built-in web server (maintenance/dev) handle .php requests.
1245 * (T167507) selenium: Run Chrome headlessly.
1246 * selenium: Pass -no-sandbox to Chrome under Docker.
1247 * (T179190) selenium: Move logic for running tests from package.json to selenium.sh
1248 * (T192584) Stop incorrectly passing USE INDEX to RecentChange::newFromConds().
1249 * Add default edit rate limit of 90 edits/minute for all users.
1250 * (T186565) Fix PHP Notice from `ob_end_flush()` in `FileRepo::streamFile()`.
1251 * oojs/oojs-ui updated to remove an unnecessary dependancy.
1252 * (T196125) php-memcached 3.0 (provided with PHP 7.0) is now supported.
1253 * (T118683) Fix exception from &$user deref on HHVM in the TitleMoveComplete hook.
1254 * (T196672) The mtime of extension.json files is now able to be zero
1255 * (T180403) Validate $length in padleft/padright parser functions.
1256 * (T143790) Make $wgEmailConfirmToEdit only affect edit actions.
1257 * (T193995) Fix undefined patchPath() method call in parser tests.
1258 * Special:BotPasswords now requires reauthentication.
1259 * (T191608, T187638) Add 'logid' parameter to Special:Log.
1260 * (T193829) Indicate when a Bot Password needs reset.
1261 * (T151415) Log email changes.
1262 * (T200861) Fix total breakage of SQLite web upgrade.
1263 * (T202550) Unbreak SpecialListusersHeaderForm and SpecialListusersHeader
1264 hooks.
1265 * (T190539) Explicitly require Postgres 9.1.
1266 * (T118420) Unbreak Oracle installer.
1267
1268 == MediaWiki 1.30.0 ==
1269
1270 === Changes since MediaWiki 1.30.0-rc.0 ===
1271 * Upgraded Moment.js from v2.15.0 to v2.19.3.
1272 * Add ip_changes to postgres/tables.sql.
1273 * Skip null shell parameters.
1274 * Add wfWaitForSlaves() to maintenance/migrateComments.php.
1275 * (T182245) Fix join conditions in ImageListPager.
1276 * (T178626) Revert #contentSub and #jump-to-nav margin changes.
1277
1278 === MySQL version requirement in 1.30 ===
1279 As of 1.30, MediaWiki now requires MySQL 5.5.8 or higher (see Compatibility
1280 section).
1281
1282 === Configuration changes in 1.30 ===
1283 * The "C.UTF-8" locale should be used for $wgShellLocale, if available, to avoid
1284 unexpected behavior when code uses locale-sensitive string comparisons. For
1285 example, the Scribunto extension considers "bar" < "Foo" in most locales
1286 since it ignores case.
1287 * $wgShellLocale now affects LC_ALL rather than only LC_CTYPE. See
1288 documentation of $wgShellLocale for details.
1289 * $wgShellLocale is now applied for all requests. wfInitShellLocale() is
1290 deprecated and a no-op, as it is no longer needed.
1291 * $wgJobClasses may now specify callback functions as an alternative to plain
1292 class names. This is intended for extensions that want control over the
1293 instantiation of their jobs, to allow for proper dependency injection.
1294 * $wgResourceModules may now specify callback functions as an alternative
1295 to plain class names, using the 'factory' key in the module description
1296 array. This allows dependency injection to be used for ResourceLoader modules.
1297 * $wgExceptionHooks has been removed.
1298 * (T163562) $wgRangeContributionsCIDRLimit was introduced to control the size
1299 of IP ranges that can be queried at Special:Contributions.
1300 * (T45547) $wgUsePigLatinVariant added (off by default).
1301 * (T152540) MediaWiki now supports a section ID escaping style that allows to display
1302 non-Latin characters verbatim on many modern browsers. This is controlled by the
1303 new configuration setting, $wgFragmentMode.
1304 * $wgExperimentalHtmlIds is now deprecated and will be removed in a future version,
1305 use $wgFragmentMode to migrate off it to a modern alternative.
1306 * $wgExternalInterwikiFragmentMode was introduced to control how fragments in
1307 sinterwikis going outside of current wiki farm are encoded.
1308 * (T120333) Soft-deprecated the use of PHP extension 'mysql' in favor of 'mysqli'.
1309 This PHP extension was deprecated in PHP 5.5 and removed in PHP 7.0. MediaWiki
1310 auto-selects the 'mysqli' driver since MediaWiki 1.22, except if explicitly
1311 requested through the configuration parameter $wgDBservers.
1312 * $wgOOUIEditPage was removed, as it is now the default. This was documented as a
1313 temporary variable during the migration period.
1314
1315 === New features in 1.30 ===
1316 * (T37247) Output from Parser::parse() will now be wrapped in a div with
1317 class="mw-parser-output" by default. This may be changed or disabled using
1318 ParserOptions::setWrapOutputClass().
1319 * (T163562) Added ability to search for contributions within an IP ranges
1320 at Special:Contributions.
1321 * Added 'ChangeTagsAllowedAdd' hook, enabling extensions to allow software-
1322 specific tags to be added by users.
1323 * Added a 'ParserOptionsRegister' hook to allow extensions to register
1324 additional parser options.
1325 * (T45547) Included Pig Latin, a language game in English, as a
1326 LanguageConverter variant. This allows English-speaking developers
1327 to develop and test LanguageConverter more easily. Pig Latin can be
1328 enabled by setting $wgUsePigLatinVariant to true.
1329 * Added RecentChangesPurgeRows hook to allow extensions to purge data that
1330 depends on the recentchanges table.
1331 * Added JS config values wgDiffOldId/wgDiffNewId to the output of diff pages.
1332 * (T2424) Added direct unwatch links to entries in Special:Watchlist (if the
1333 'watchlistunwatchlinks' preference option is enabled). With JavaScript
1334 enabled, these links toggle so the user can also re-watch pages that have
1335 just been unwatched.
1336 * Added $wgParserTestMediaHandlers, where mock media handlers can be passed to
1337 MediaHandlerFactory for parser tests.
1338 * Edit summaries, block reasons, and other "comments" are now stored in a
1339 separate database table. Use the CommentFormatter class to access them.
1340 ** This is currently gated by $wgCommentTableSchemaMigrationStage. Most wikis
1341 can set this to MIGRATION_NEW and run maintenance/migrateComments.php as
1342 soon as any necessary extensions are updated.
1343 * (T138166) Added ability for users to prohibit other users from sending them
1344 emails with Special:Emailuser. Can be enabled by setting
1345 $wgEnableUserEmailBlacklist to true.
1346 * (T67297) $wgBrowserBlacklist is deprecated, and changing it will have no effect.
1347 Instead, users using browsers that do not support Unicode will be unable to edit
1348 and should upgrade to a modern browser instead.
1349
1350 === External library changes in 1.30 ===
1351
1352 ==== Upgraded external libraries ====
1353 * Updated justinrainbow/json-schema from v3.0 to v5.2.
1354 * Updated mediawiki/mediawiki-codesniffer from v0.7.2 to v0.12.0.
1355 * Updated wikimedia/composer-merge-plugin from v1.4.0 to v1.4.1.
1356 * Updated wikimedia/relpath from v1.0.3 to v2.0.0.
1357 * Updated OOjs from v2.0.0 to v2.1.0.
1358 * Updated OOUI from v0.21.1 to v0.23.0.
1359 * Updated QUnit from v1.23.1 to v2.4.0.
1360 * Updated phpunit/phpunit from v4.8.35 to v4.8.36.
1361 * Upgraded Moment.js from v2.15.0 to v2.19.3.
1362
1363 ==== New external libraries ====
1364 * The class \TestingAccessWrapper has been moved to the external library
1365 wikimedia/testing-access-wrapper and renamed \Wikimedia\TestingAccessWrapper.
1366 * Purtle, a fast, lightweight RDF generator.
1367
1368 ==== Removed and replaced external libraries ====
1369 * …
1370
1371 === Bug fixes in 1.30 ===
1372 * (T151633) Ordered list items use now Devanagari digits in Nepalese
1373 (thanks to Sfic)
1374
1375 === Action API changes in 1.30 ===
1376 * (T37247) action=parse output will be wrapped in a div with
1377 class="mw-parser-output" by default. This may be changed or disabled using
1378 the new 'wrapoutputclass' parameter.
1379 * When errorformat is not 'bc', abort reasons from action=login will be
1380 formatted as specified by the error formatter parameters.
1381 * action=compare can now handle arbitrary text, deleted revisions, and
1382 returning users and edit comments.
1383 * (T164106) The 'rvdifftotext', 'rvdifftotextpst', 'rvdiffto',
1384 'rvexpandtemplates', 'rvgeneratexml', 'rvparse', and 'rvprop=parsetree'
1385 parameters to prop=revisions are deprecated, as are the similarly named
1386 parameters to prop=deletedrevisions, list=allrevisions, and
1387 list=alldeletedrevisions. Use action=compare, action=parse, or
1388 action=expandtemplates instead.
1389
1390 === Action API internal changes in 1.30 ===
1391 * ApiBase::getDescriptionMessage() and the "apihelp-*-description" messages are
1392 deprecated. The existing message should be split between "apihelp-*-summary"
1393 and "apihelp-*-extended-description".
1394 * (T123931) Individual values of multi-valued parameters can now be marked as
1395 deprecated.
1396
1397 === Languages updated in 1.30 ===
1398 MediaWiki supports over 350 languages. Many localisations are updated
1399 regularly. Below only new and removed languages are listed, as well as
1400 changes to languages because of Phabricator reports.
1401
1402 * Added: kbp (Kabɩyɛ / Kabiyè)
1403 * Added: skr (Saraiki, سرائیکی)
1404 * Added: tay (Tayal / Atayal)
1405 * Removed: tokipona (Toki Pona)
1406
1407 ==== Pig Latin added ====
1408 * (T45547) Added Pig Latin, a made-up English variant (en-x-piglatin),
1409 for easier variant development and testing. Disabled by default. It can be
1410 enabled by setting $wgUsePigLatinVariant to true.
1411
1412 === Other changes in 1.30 ===
1413 * The use of an associative array for $wgProxyList, where the IP address is in
1414 the key instead of the value, is deprecated (e.g. [ '127.0.0.1' => 'value' ]).
1415 Please convert these arrays to indexed/sequential ones (e.g. [ '127.0.0.1' ]).
1416 * mw.user.bucket (deprecated in 1.23) was removed.
1417 * LoadBalancer::getServerInfo() and LoadBalancer::setServerInfo() are
1418 deprecated. There are no known callers.
1419 * File::getStreamHeaders() was deprecated.
1420 * MediaHandler::getStreamHeaders() was deprecated.
1421 * Title::canTalk() was deprecated. The new Title::canHaveTalkPage() should be
1422 used instead.
1423 * MWNamespace::canTalk() was deprecated. The new MWNamespace::hasTalkNamespace()
1424 should be used instead.
1425 * The ExtractThumbParameters hook (deprecated in 1.21) was removed.
1426 * The OutputPage::addParserOutputNoText and ::getHeadLinks methods (both
1427 deprecated in 1.24) were removed.
1428 * wfMemcKey() and wfGlobalCacheKey() were deprecated. BagOStuff::makeKey() and
1429 BagOStuff::makeGlobalKey() should be used instead.
1430 * (T146304) Preprocessor handling of LanguageConverter markup has been improved.
1431 As a result of the new uniform handling, '-{' may need to be escaped
1432 (for example, as '-<nowiki/>{') where it occurs inside template arguments
1433 or wikilinks.
1434 * (T163966) Page moves are now counted as edits for the purposes of
1435 autopromotion, i.e., they increment the user_editcount field in the database.
1436 * Two new hooks, LogEventsListLineEnding and NewPagesLineEnding, were added for
1437 manipulating Special:Log and Special:NewPages lines.
1438 * The OldChangesListRecentChangesLine, EnhancedChangesListModifyLineData,
1439 PageHistoryLineEnding, ContributionsLineEnding and DeletedContributionsLineEnding
1440 hooks have an additional parameter, for manipulating HTML data attributes of
1441 RC/history lines. EnhancedChangesListModifyBlockLineData can do that via the
1442 $data['attribs'] subarray.
1443 * (T130632) The OutputPage::enableTOC() method was removed.
1444 * WikiPage::getParserOutput() will now throw an exception if passed
1445 ParserOptions that would pollute the parser cache. Callers should use
1446 WikiPage::makeParserOptions() to create the ParserOptions object and only
1447 change options that affect the parser cache key.
1448 * Article::viewRedirect() is deprecated.
1449 * IP::isValidBlock() was deprecated. Use the equivalent IP::isValidRange().
1450 * DeprecatedGlobal no longer supports passing in a direct value, it requires a
1451 callable factory function or a class name.
1452 * The $parserMemc global, wfGetParserCacheStorage(), and ParserCache::singleton()
1453 are all deprecated. The main ParserCache instance should be obtained from
1454 MediaWikiServices instead. Access to the underlying BagOStuff is possible
1455 through the new ParserCache::getCacheStorage() method.
1456 * .mw-ui-constructive CSS class (deprecated in 1.27) was removed.
1457 * Sanitizer::escapeId() was deprecated, use escapeIdForAttribute(),
1458 escapeIdForLink() or escapeIdForExternalInterwiki() instead.
1459 * Title::escapeFragmentForURL() was deprecated, use one of the aforementioned
1460 Sanitizer functions or, if possible, Title::getFragmentForURL().
1461 * Second parameter to Sanitizer::escapeIdReferenceList() ($options) now does
1462 nothing and is deprecated.
1463 * mw.util.escapeId() was deprecated, use escapeIdForAttribute() or
1464 escapeIdForLink().
1465 * MagicWord::replaceMultiple() (deprecated in 1.25) was removed.
1466 * WikiImporter now requires the second parameter to be an instance of the Config,
1467 class. Prior to that, the Config parameter was optional (a behavior deprecated in
1468 1.25).
1469 * Removed 'jquery.mwExtension' module. (deprecated since 1.26)
1470 * mediawiki.ui: Deprecate greys, which are not part of WikimediaUI color palette
1471 any more.
1472 * CdbReader, CdbWriter, CdbException classes (deprecated in 1.25) were removed.
1473 The namespaced classes in the Cdb namespace should be used instead.
1474 * IPSet class (deprecated in 1.26) was removed. The namespaced IPSet\IPSet
1475 should be used instead.
1476 * RunningStat class (deprecated in 1.27) was removed. The namespaced
1477 RunningStat\RunningStat should be used instead.
1478 * MWMemcached and MemCachedClientforWiki classes (deprecated in 1.27) were removed.
1479 The MemcachedClient class should be used instead.
1480 * EditPage underwent some refactoring and deprecations:
1481 * EditPage::isOouiEnabled() is deprecated and will always return true.
1482 * EditPage::getSummaryInput() and ::getSummaryInputOOUI() are deprecated. Please
1483 use ::getSummaryInputWidget() instead.
1484 * EditPage::getCheckboxes() and ::getCheckboxesOOUI() are deprecated. Please
1485 use ::getCheckboxesWidget() instead.
1486 * Creating an EditPage instance without calling EditPage::setContextTitle() should
1487 be avoided and will be deprecated in a future release.
1488 * EditPage::safeUnicodeInput() and ::safeUnicodeOutput() are deprecated and no-ops.
1489 * EditPage::$isCssJsSubpage, ::$isCssSubpage, and ::$isJsSubpage are deprecated. The
1490 corresponding methods from Title should be used instead.
1491 * EditPage::$isWrongCaseCssJsPage is deprecated. There is no replacement.
1492 * EditPage::$mArticle and ::$mTitle are deprecated for public usage. The getters
1493 ::getArticle() and ::getTitle() should be used instead.
1494 * Trying to control or fake EditPage context by overriding $wgUser, $wgRequest, $wgOut,
1495 and $wgLang is no longer supported and won't work. The IContextSource returned from
1496 EditPage::getContext() must be modified instead.
1497 * Parser::getRandomString() (deprecated in 1.26) was removed.
1498 * Parser::uniqPrefix() (deprecated in 1.26) was removed.
1499 * Parser::extractTagsAndParams() now only accepts three arguments. The fourth,
1500 $uniq_prefix was deprecated in 1.26 and has now been removed.
1501 * (T172514) The following tables have had their UNIQUE indexes turned into proper
1502 PRIMARY KEYs for increased maintainability: categorylinks, imagelinks, iwlinks,
1503 langlinks, log_search, module_deps, objectcache, pagelinks, query_cache, site_stats,
1504 templatelinks, text, transcache, user_former_groups, user_properties.
1505 * IDatabase::nextSequenceValue() is no longer needed by any database backends
1506 (formerly it was needed by PostgreSQL and Oracle), and is now deprecated.
1507 * (T146591) The lc_lang_key index on the l10n_cache table has been changed into a
1508 PRIMARY KEY.
1509 * (T157227) bot_password.bp_user, change_tag.ct_log_id, change_tag.ct_rev_id,
1510 page_restrictions.pr_user, tag_summary.ts_log_id, tag_summary.ts_rev_id and
1511 user_properties.up_user have all been made unsigned on MySQL.
1512 * DB_SLAVE is deprecated. DB_REPLICA should be used instead.
1513 * wfUsePHP() is deprecated.
1514 * wfFixSessionID() was removed.
1515 * wfShellExec() and related functions are deprecated, use Shell::command(). This also
1516 slightly changes the behavior of how execution time limits are calculated when only
1517 some of defaults are overridden per-call. When in doubt, always override both wall
1518 clock and CPU time.
1519 * (T138166) SpecialEmailUser::getTarget() now requires a second argument, the sending
1520 user object. Using the method without the second argument is deprecated.
1521 * (T67297) Browsers that don't support Unicode will have their edits rejected.
1522 * (T178450) The module 'jquery.badge' is deprecated and will be removed in a future
1523 release. For notifying the user of an event, the Notifications ("Echo") system
1524 should be used instead.
1525 * (T178451) SECURITY: Potential XSS when $wgShowExceptionDetails = false and browser
1526 sends non-standard url escaping.
1527 * (T165846) SECURITY: BotPassword login attempts weren't throttled.
1528
1529 = MediaWiki 1.29 =
1530
1531 == MediaWiki 1.29.3 ==
1532
1533 This is a security and maintenance release of the MediaWiki 1.29 branch.
1534
1535 === Changes since 1.29.2 ===
1536 * (T169545, CVE-2018-0503) SECURITY: $wgRateLimits entry for 'user' overrides
1537 'newbie'.
1538 * (T194605, CVE-2018-0505) SECURITY: BotPasswords can bypass CentralAuth's
1539 account lock.
1540 * (T180551) Fix LanguageSrTest for language converter
1541 * (T180552) Fix langauge converter parser test with self-close tags
1542 * (T180537) Remove $wgAuth usage from wrapOldPasswords.php
1543 * (T180485) InputBox: Have inputbox langconvert certain attributes
1544 * (T161732, T181547) Upgraded Moment.js from v2.15.0 to v2.19.3.
1545 * (T172927) Drop vendor from MW release branch
1546 * (T87572) Make FormatMetadata::flattenArrayReal() work for an associative array
1547 * Updated composer/spdx-licenses from 1.1.4 to 1.3.0 (development dependency).
1548 * (T189567) the CLI installer (maintenance/install.php) learned to detect and
1549 include extensions. Pass --with-extensions to enable that feature.
1550 * (T182381) Mask deprecated call in WatchedItemUnitTest
1551 * (T190503) Let built-in web server (maintenance/dev) handle .php requests.
1552 * The karma qunit tests would fail on some configuration due to headers already
1553 sent. Check headers_sent() before sending cpPosTime headers
1554 * (T167507) selenium: Run Chrome headlessly.
1555 * selenium: Pass -no-sandbox to Chrome under Docker
1556 * (T191247) Use MediaWiki\SuppressWarnings around trigger_error('') instead @
1557 * (T75174, T161041) Unit test ChangesListSpecialPageTest::testFilterUserExpLevel
1558 fails under SQLite.
1559 * (T192584) Stop incorrectly passing USE INDEX to RecentChange::newFromConds().
1560 * (T179190) selenium: Move test running logic from package.json to selenium.sh.
1561 * (T117839, T193200) PDFHandler: Fix for pdfinfo changes in poppler-utils 0.48.
1562 * Add default edit rate limit of 90 edits/minute for all users.
1563 * (T196125) php-memcached 3.0 (provided with PHP 7.0) is now supported.
1564 * (T196672) The mtime of extension.json files is now able to be zero
1565 * (T180403) Validate $length in padleft/padright parser functions.
1566 * (T143790) Make $wgEmailConfirmToEdit only affect edit actions.
1567 * (T194237) Special:BotPasswords now requires reauthentication.
1568 * (T191608, T187638) Add 'logid' parameter to Special:Log.
1569 * (T176097) resourceloader: Disable a flaky MessageBlobStoreTest case
1570 * (T193829) Indicate when a Bot Password needs reset.
1571 * (T151415) Log email changes.
1572 * (T118420) Unbreak Oracle installer.
1573
1574 == MediaWiki 1.29.2 ==
1575
1576 This is a security and maintenance release of the MediaWiki 1.29 branch.
1577
1578 === Changes since 1.29.1 ===
1579 * (T166757) Avoid scoped lock errors in Category::refreshCounts() due to nesting.
1580 * (T175439) Unbreak Postgres Updater when setting defaults for a column.
1581 * (T160298) Remove use of implicitGroupBy() in ActiveUsersPager.
1582 * Fixed login button label to accept RawMessage.
1583 * Fixed case of SpecialRecentChanges class usage.
1584 * (T174255) Declare uploadCount property in importDump.php.
1585 * (T163646) Pass a string not an int to mysql_real_escape_string().
1586 * (T180143) Bump justinrainbow/json-schema development dependency to ~5.2.
1587 * Updated dev dependancy phpunit/phpunit from v4.8.35 to v4.8.36.
1588 * (T178451) SECURITY: Potential XSS when $wgShowExceptionDetails = false and browser
1589 sends non-standard url escaping.
1590 * (T165846) SECURITY: BotPassword login attempts weren't throttled.
1591 * (T128209) SECURITY: Reflected File Download from api.php.
1592 * (T134100) SECURITY: Do not reveal if user exists during login failure.
1593 * (T176247) SECURITY: Ensure Message::rawParams can't lead to XSS.
1594 * (T125163) SECURITY: Make anchor for headlines escape > and <.
1595 * (T180237) SECURITY: Protect vendor folder with .htaccess.
1596 * (T180231) SECURITY: Remove PHPUnit file with known RCE if exists in update.php.
1597 * (T124404) SECURITY: XSS in langconverter when regex hits pcre.backtrack_limit.
1598 * (T119158) SECURITY: Handle -{}- syntax in attributes safely.
1599 * (T180488) (T125177) "api.log contains passwords in plaintext" wasn't correctly fixed in all
1600 branches in the previous security release.
1601
1602 == MediaWiki 1.29.1 ==
1603
1604 This is a maintenance release of the MediaWiki 1.29 branch.
1605
1606 The SpamBlacklist and PdfHandler extensions were missing from the generated
1607 packages.
1608
1609 === Changes since 1.29.1 ===
1610 * (T164999) Define mw.Upload.Dialog.static.name in mediawiki.Upload.Dialog.js.
1611 * (T172061) Fix fatal when passing a category to refreshLinks.php.
1612
1613 == MediaWiki 1.29.0 ==
1614
1615 === Configuration changes in 1.29 ===
1616 * Default cookie expiration time has been reduced to 30 days. Login cookie
1617 expiration time is kept at 180 days.
1618 * A new configuration variable has been added: $wgCookieSetOnAutoblock. This
1619 determines whether to set a cookie when a user is autoblocked. Doing so means
1620 that a blocked user, even after logging out and moving to a new IP address,
1621 will still be blocked.
1622 * The resetpassword right and associated password reset capture feature has
1623 been removed.
1624 * The $error parameter to the EmailUser hook should be set to a Status object
1625 or boolean false. This should be compatible with at least MediaWiki 1.23 if
1626 not earlier. Returning a raw HTML string is now deprecated.
1627 * The $message parameter to the ApiCheckCanExecute hook should be set to an
1628 ApiMessage. This is compatible with MediaWiki 1.27 and later. Returning a
1629 code for ApiBase::parseMsg() will no longer work.
1630 * ApiBase::$messageMap is no longer public. Code attempting to access it will
1631 result in a PHP fatal error.
1632 * $wgUserEmailUseReplyTo is now true by default to work around restrictive DMARC
1633 policies.
1634 * Subpages are now enabled by default in the Template namespace. Set
1635 $wgNamespacesWithSubpages[NS_TEMPLATE] to false to keep the old behavior.
1636 * $wgRunJobsAsync is now false by default (T142751). This change only affects
1637 wikis with $wgJobRunRate > 0.
1638 * (T158474) "Unknown user" has been added to $wgReservedUsernames.
1639 * (T156983) $wgRateLimitsExcludedIPs now accepts CIDR ranges as well as single IPs.
1640 * $wgDummyLanguageCodes is deprecated. Additional language code mappings may be
1641 added to $wgExtraLanguageCodes instead.
1642 * (T161453) LocalisationCache will no longer use the temporary directory in it's
1643 fallback chain when trying to work out where to write the cache.
1644 * The user right 'editusercssjs' (deprecated in 1.16) was removed. Use
1645 'editusercss' and 'edituserjs' in $wgGroupPermissions and elsewhere instead.
1646
1647 === New features in 1.29 ===
1648 * (T5233) A cookie can now be set when a user is autoblocked, to track that user
1649 if they move to a new IP address. This is disabled by default.
1650 * Added ILocalizedException interface to standardize the use of localized
1651 exceptions, largely so the API can handle them more sensibly.
1652 * Blocks created automatically by MediaWiki, such as for configured proxies or
1653 dnsbls, are now indicated as such and use a new i18n message when displayed.
1654 * Added new $wgHTTPImportTimeout setting. Sets timeout for
1655 downloading the XML dump during a transwiki import in seconds.
1656 * Parser limit report is now available in machine-readable format to JavaScript
1657 via mw.config.get('wgPageParseReport').
1658 * Added $wgSoftBlockRanges, to allow for automatically blocking anonymous edits
1659 from certain IP ranges (e.g. private IPs).
1660 * (T59603) Added new magic word {{PAGELANGUAGE}} which returns the language code
1661 of the page being parsed.
1662 * HTML5 form validation attributes will no longer be suppressed. Originally
1663 browsers had poor support for them, but modern browsers handle them fine.
1664 This might affect some forms that used them and only worked because the
1665 attributes were not actually being set.
1666 * Expiry times can now be specified when users are added to user groups.
1667 * Completely new user interface for the RecentChanges page, which
1668 structures filters into user-friendly groups. This has corresponding
1669 changes to how filters are registered by core and extensions.
1670 * The edit form now uses pretty OOjs UI buttons, checkboxes and summary input.
1671 Because this change can cause problems for extensions and on-wiki
1672 scripts depending on the exact HTML, the old version is still available
1673 and can be used by setting $wgOOUIEditPage = false; in LocalSettings.php.
1674 This will be removed later and OOjs UI will become the only option.
1675 To make testing easier, users can also force either mode by adding
1676 &ooui=true or &ooui=false to the action=edit URL.
1677
1678 === External library changes in 1.29 ===
1679
1680 ==== Upgraded external libraries ====
1681 * Updated QUnit from v1.22.0 to v1.23.1.
1682 * Updated cssjanus from v1.1.2 to v1.2.0.
1683 * Updated psr/log from v1.0.0 to v1.0.2.
1684 * Update Moment.js from v2.8.4 to v2.15.0.
1685 * Updated oyejorge/less.php from v1.7.0.10 to v1.7.0.14.
1686 * Updated monolog from v1.18.2 to 1.22.1.
1687 * Updated wikimedia/composer-merge-plugin from v1.3.1 to v1.4.0.
1688 * Updated OOjs from v1.1.10 to v2.0.0.
1689 * Updated jQuery from v1.11.3 to v3.2.1 (including jQuery Migrate v3.0.0).
1690
1691 ==== New external libraries ====
1692 * Added wikimedia/timestamp v1.0.0.
1693 * Added wikimedia/remex-html v1.0.1.
1694
1695 ==== Removed and replaced external libraries ====
1696
1697 === Bug fixes in 1.29 ===
1698 * (T62604) Core parser functions returning a number now format the number according
1699 to the page content language, not wiki content language.
1700 * (T27187) Search suggestions based on jquery.suggestions will now correctly only
1701 highlight prefix matches in the results.
1702 * (T157035) "new mw.Uri()" was ignoring options when using default URI.
1703 * Special:Allpages can no longer be filtered by redirect in miser mode.
1704 * (T160519) CACHE_ANYTHING will not be CACHE_ACCEL if no accelerator is installed.
1705 * (T109140) (T122209) SECURITY: Special:UserLogin and Special:Search allow redirect
1706 to interwiki links.
1707 * (T144845) SECURITY: XSS in SearchHighlighter::highlightText() when
1708 $wgAdvancedSearchHighlighting is true.
1709 * (T125177) SECURITY: API parameters may now be marked as "sensitive" to keep
1710 their values out of the logs.
1711 * (T150044) SECURITY: "Mark all pages visited" on the watchlist now requires a CSRF
1712 token.
1713 * (T156184) SECURITY: Escape content model/format url parameter in message.
1714 * (T151735) SECURITY: SVG filter evasion using default attribute values in DTD
1715 declaration.
1716 * (T161453) SECURITY: LocalisationCache will no longer use the temporary directory
1717 in it's fallback chain when trying to work out where to write the cache.
1718 * (T48143) SECURITY: Spam blacklist ineffective on encoded URLs inside file inclusion
1719 syntax's link parameter.
1720 * (T108138) SECURITY: Sysops can undelete pages, although the page is protected against
1721 it.
1722
1723 === Action API changes in 1.29 ===
1724 * Submitting sensitive authentication request parameters to action=login,
1725 action=clientlogin, action=createaccount, action=linkaccount, and
1726 action=changeauthenticationdata in the query string is now an error. They
1727 should be submitted in the POST body instead.
1728 * The capture option for action=resetpassword has been removed
1729 * action=clearhasmsg now requires a POST.
1730 * (T47843) API errors and warnings may be requested in non-English languages
1731 using the new 'errorformat', 'errorlang', and 'errorsuselocal' parameters.
1732 * API error codes may have changed. Most notably, errors from modules using
1733 parameter prefixes (e.g. all query submodules) will no longer be prefixed.
1734 * ApiPageSet-using modules will report the 'invalidreason' using the specified
1735 'errorformat'.
1736 * action=emailuser may return a "Warnings" status, and now returns 'warnings' and
1737 'errors' subelements (as applicable) instead of 'message'.
1738 * action=imagerotate returns an 'errors' subelement rather than 'errormessage'.
1739 * action=move now reports errors when moving the talk page as an array under
1740 key 'talkmove-errors', rather than using 'talkmove-error-code' and
1741 'talkmove-error-info'. The format for subpage move errors has also changed.
1742 * action=revisiondelete no longer includes a "rendered" property on warnings
1743 and errors for each item. Use errorformat=wikitext if you're wanting parsed
1744 output.
1745 * action=rollback no longer returns a "messageHtml" property. Use
1746 errorformat=html if you're wanting HTML formatting of error messages.
1747 * action=upload now reports optional stash failures as an array under key
1748 'stasherrors' rather than a 'stashfailed' text string.
1749 * action=watch reports 'errors' and 'warnings' instead of a single 'error', and
1750 no longer returns a 'message' on success.
1751 * Added action=validatepassword to validate passwords for the account creation
1752 and password change forms.
1753 * action=purge now requires a POST.
1754 * There is a new `languagevariants` siprop for action=query&meta=siteinfo,
1755 which returns a list of languages with active LanguageConverter instances.
1756 * action=query&query=allpages will no longer filter redirects using a database
1757 query in miser mode. This may result in less results being returned than were
1758 requested.
1759
1760 === Action API internal changes in 1.29 ===
1761 * New methods were added to ApiBase to handle errors and warnings using i18n
1762 keys. Methods for using hard-coded English messages were deprecated:
1763 * ApiBase::dieUsage() was deprecated
1764 * ApiBase::dieUsageMsg() was deprecated
1765 * ApiBase::dieUsageMsgOrDebug() was deprecated
1766 * ApiBase::getErrorFromStatus() was deprecated
1767 * ApiBase::parseMsg() was deprecated
1768 * ApiBase::setWarning() was deprecated
1769 * ApiBase::$messageMap is no longer public. Code attempting to access it will
1770 result in a PHP fatal error.
1771 * The $message parameter to the ApiCheckCanExecute hook should be set to an
1772 ApiMessage. This is compatible with MediaWiki 1.27 and later. Returning a
1773 code for ApiBase::parseMsg() will no longer work.
1774 * UsageException is deprecated in favor of ApiUsageException. For the time
1775 being ApiUsageException is a subclass of UsageException to allow things that
1776 catch only UsageException to still function properly.
1777 * If, for some strange reason, code was using an ApiErrorFormatter instead of
1778 ApiErrorFormatter_BackCompat, note that the result format has changed and
1779 various methods now take a module path rather than a module name.
1780 * ApiMessageTrait::getApiCode() now strips 'apierror-' and 'apiwarn-' prefixes
1781 from the message key, and maps some message keys for backwards compatibility.
1782 * API parameters may now be marked as "sensitive" to keep their values out of
1783 the logs.
1784
1785 === Languages updated in 1.29 ===
1786
1787 MediaWiki supports over 350 languages. Many localisations are updated
1788 regularly. Below only new and removed languages are listed, as well as
1789 changes to languages because of Phabricator reports.
1790
1791 * Based as always on linguistic studies on intelligibility and language
1792 knowledge by geography, language fallbacks have been expanded. When a
1793 translation is missing in the user's preferred interface language, the
1794 corresponding translation for the fallback language will be used instead.
1795 English will only be used as last resort when there are no translations.
1796 Some configurations (such as date formats and gender namespaces) have also
1797 been updated when using the fallback language's configuration was inadequate.
1798 The new or reinstated language fallbacks are (after cs ↔ sk in 1.28):
1799 ca ↔ oc; hsb ↔ dsb; io → eo; mdf → ru; pnt → el; roa-tara → it; rup → ro;
1800 sh → bs, sr-el, hr.
1801 * (T137376) New language support: Atikamekw (atj).
1802 * (T163600) New language support: Dinka (din).
1803 * (T155957) Talk Namespaces for Javanese language (jv) have been updated.
1804
1805 ==== No fallback for Ukrainian ====
1806 * (T39314) The fallback from Ukrainian to Russian was removed. The Ukrainian
1807 language will now use the default fallback language: English. When a translation
1808 to Ukrainian is not available, an English string will be shown.
1809
1810 === Other changes in 1.29 ===
1811 * Database::getSearchEngine() (deprecated in 1.28) was removed. Use
1812 SearchEngineFactory::getSearchEngineClass() instead.
1813 * $wgSessionsInMemcached (deprecated in 1.20) was removed. No replacement is
1814 required as all sessions are stored in Object Cache now.
1815 * MWHttpRequest::execute() should be considered to return a StatusValue; the
1816 Status return type is deprecated.
1817 * User::edits() (deprecated in 1.21) was removed.
1818 * Xml::escapeJsString() (deprecated in 1.21) was removed.
1819 * Article::getText() and Article::prepareTextForEdit() (deprecated in 1.21)
1820 were removed.
1821 * Article::getAutosummary() and WikiPage::getAutosummary() (deprecated in 1.21)
1822 were removed.
1823 * Hook ArticleViewCustom (deprecated in 1.21) was removed. Use ArticleContentViewCustom
1824 instead.
1825 * Hooks EditPageGetDiffText and ShowRawCssJs (deprecated in 1.21) were removed.
1826 * Class RevisiondeleteAction (deprecated in 1.25) was removed.
1827 * WikiPage::prepareTextForEdit() (deprecated in 1.21) was removed.
1828 * WikiPage::getText() (deprecated in 1.21) was removed.
1829 * Article::fetchContent() (deprecated in 1.21) was removed.
1830 * User::getPassword() (deprecated in 1.27) was removed.
1831 * User::getTemporaryPassword() (deprecated in 1.27) was removed.
1832 * User::isPasswordReminderThrottled() (deprecated in 1.27) was removed.
1833 * Class FSRepo (deprecated in 1.19) was removed.
1834 * WebRequest::checkSessionCookie() (deprecated in 1.27) was removed. Use
1835 \MediaWiki\Session\SessionManager::singleton()->getPersistedSessionId() instead.
1836 * Class ImageGallery (deprecated in 1.22) was removed.
1837 Use ImageGalleryBase::factory instead.
1838 * Title::moveNoAuth() (deprecated in 1.25) was removed. Use MovePage class instead.
1839 * Hook UnknownAction (deprecated in 1.19) was actually deprecated (it will now
1840 emit warnings). Create a subclass of Action and add it to $wgActions instead.
1841 * WikiRevision::getText() (deprecated since 1.21) is no longer marked deprecated.
1842 * Linker::getInterwikiLinkAttributes() (deprecated since 1.25) was removed.
1843 * Linker::getInternalLinkAttributes() (deprecated since 1.25) was removed.
1844 * Linker::getInternalLinkAttributesObj() (deprecated since 1.25) was removed.
1845 * Linker::getLinkAttributesInternal() (deprecated since 1.25) was removed.
1846 * RedisConnectionPool::handleException (deprecated since 1.23) was removed.
1847 * The static properties mw.Api.errors and mw.Api.warnings, containing incomplete
1848 and outdated lists of errors/warnings returned by the API, are now deprecated.
1849 * wiki.phtml entry point was removed. Refer to index.php instead. If you want "wiki.phtml"
1850 URLs to continue to work, set up redirects. In Apache, this can be done by enabling
1851 mod_rewrite and adding the following rules to your configuration:
1852
1853 RewriteEngine On
1854 RewriteBase /
1855 RewriteRule ^/w/wiki\.phtml$ /w/index.php [R=301,L]
1856 * Hook ArticleAfterFetchContent (deprecated in 1.21) was removed.
1857 Use ArticleAfterFetchContentObject instead.
1858 * Hook ArticleInsertComplete (deprecated in 1.21) was removed.
1859 Use PageContentInsertComplete instead.
1860 * Hook ArticleSave (deprecated in 1.21) was removed.
1861 Use PageContentSave instead.
1862 * Hook ArticleSaveComplete (deprecated in 1.21) was removed.
1863 Use PageContentSaveComplete instead.
1864 * Hook EditFilterMerged (deprecated in 1.21) was removed.
1865 Use EditFilterMergedContent instead.
1866 * Hook EditPageGetPreviewText (deprecated in 1.21) was removed.
1867 Use EditPageGetPreviewContent instead.
1868 * Hook TitleIsCssOrJsPage (deprecated in 1.21) was removed.
1869 Use ContentHandlerDefaultModelFor instead.
1870 * Hook TitleIsWikitextPage (deprecated in 1.21) was removed.
1871 Use ContentHandlerDefaultModelFor instead.
1872 * Article::getContent() (deprecated in 1.21) was removed.
1873 * Revision::getText() (deprecated in 1.21) was removed.
1874 * Article::doEdit() and WikiPage::doEdit() (deprecated in 1.21) were removed.
1875 * Parser::replaceUnusualEscapes() (deprecated in 1.24) was removed.
1876 * Article::doEditContent() was marked as deprecated, to be removed in 1.30
1877 or later.
1878 * ContentHandler::runLegacyHooks() was removed.
1879 * refreshLinks.php now can be limited to a particular category with --category=...
1880 or a tracking category with --tracking-category=...
1881 * User-like objects that are passed to SpecialUserRights and its subclasses are
1882 now required to have a getGroupMemberships() method. See UserRightsProxy for
1883 an example.
1884 * User::$mGroups (instance variable) was marked private. Use User::getGroups()
1885 instead.
1886 * User::getGroupName(), User::getGroupMember(), User:getGroupPage(),
1887 User::makeGroupLinkHTML(), and User::makeGroupLinkWiki() were deprecated.
1888 Use equivalent methods on the UserGroupMembership class.
1889 * Maintenance scripts and tests that call User::addGroup() must now ensure that
1890 User objects have been added to the database prior to calling addGroup().
1891 * Protected function UsersPager::getGroups() was removed, and protected function
1892 UsersPager::buildGroupLink() was changed from a static to an instance method.
1893 * The third parameter ($cache) to the UsersPagerDoBatchLookups hook was changed;
1894 see docs/hooks.txt.
1895 * User::crypt() (deprecated in 1.24) was removed.
1896 * User::comparePasswords() (deprecated in 1.24) was removed.
1897 * ArchivedFile::getUserText() (deprecated in 1.23) was removed.
1898 * HTMLFileCache::newFromTitle() (deprecated in 1.24) was removed.
1899 * BREAKING CHANGE: Internal signature changes to ChangesListSpecialPage
1900 and subclasses. It should only break if you call buildMainQueryConds
1901 (changed to buildQuery with new signature) or doMainQuery (new
1902 signature). Subclasses are likely to call at least doMainQuery
1903 (possibly both), but other classes might too, because they were
1904 public.
1905 Also, some related hooks were deprecated, but this is not yet a
1906 breaking change.
1907 * Removed 'jquery.arrowSteps' module. (deprecated since 1.28)
1908 * The 'jquery.autoEllipsis' ResourceLoader module is now deprecated.
1909 * WikiRevision::$fileIsTemp was deprecated.
1910 * WikiRevision::$importer was deprecated.
1911 * WikiRevision::$user was deprecated.
1912 * Article::getLastPurgeTimestamp(), WikiPage::getLastPurgeTimestamp(), and the
1913 WikiPage::PURGE_* constants are deprecated, and the functions will always
1914 return false. They were a hack for an issue that has since been fixed.
1915 * Hook 'EditPageBeforeEditChecks' is now deprecated. Instead use the new hook
1916 'EditPageGetCheckboxesDefinition', or 'EditPage::showStandardInputs:options'
1917 if you don't actually care about checkboxes and just want to add some HTML
1918 to the page.
1919 * Selflinks are now rendered as href-less <a> tags with the class mw-selflink
1920 rather than <strong> tags. The old class name, "selflink", was deprecated
1921 and will be removed in a future release. (T160480)
1922 * (T156184) $wgRawHtml will no longer apply to internationalization messages.
1923 * Browser support for non-ES5 JavaScript browsers, including Android 2,
1924 Opera <12.10, and Internet Explorer 9, was lowered from Grade A to Grade C.
1925 * Removed wikibits global methods deprecated since MediaWiki 1.17 (T122755):
1926 is_gecko, is_chrome_mac, is_chrome, webkit_version, is_safari_win, is_safari,
1927 webkit_match, is_ff2, ff2_bugs, is_ff2_win, is_ff2_x11, opera95_bugs,
1928 opera7_bugs, opera6_bugs, is_opera_95, is_opera_preseven, is_opera,
1929 ie6_bugs, clientPC, changeText, killEvt, addHandler, hookEvent,
1930 addClickHandler, removeHandler, getElementsByClassName, getInnerText,
1931 setupCheckboxShiftClick, addCheckboxClickHandlers, mwEditButtons,
1932 mwCustomEditButtons, injectSpinner, removeSpinner, escapeQuotes,
1933 escapeQuotesHTML, jsMsg, addPortletLink, appendCSS, tooltipAccessKeyPrefix,
1934 tooltipAccessKeyRegexp, updateTooltipAccessKeys.
1935 * The ID of the <li> element containing the login link has changed from
1936 'pt-login' to 'pt-login-private' in private wikis.
1937 * The old, neglected "bulletin board style toolbar" in the edit form is now
1938 deprecated (T30856). This old code dates from 2006, and was replaced in the
1939 MediaWiki release tarball and in Wikimedia production by the WikiEditor
1940 extension in 2010. It is only shown to users if no other editor was
1941 installed, and leads to confusion.
1942 * (T92459) Loading ResourceLoader modules containing JavaScript through
1943 addModuleStyles() is deprecated and will log a warning server-side.
1944
1945 = MediaWiki 1.28 =
1946
1947 == MediaWiki 1.28.3 ==
1948
1949 This is a security and maintenance release of the MediaWiki 1.28 branch.
1950
1951 === Changes since 1.28.2 ==
1952 * (T168856) Allow SVGs created by Dia to be uploaded.
1953 * (T157545) Add missing doUpdates() call to refreshLinks.php.
1954 * (T165714) (T100085) Better handling of jobs execution in post-connection shutdown.
1955 * (T154425) (T154438) (T157679) Use AutoCommitUpdate instead of Database->onTransactionIdle.
1956 * (T154425) Make DeferredUpdates detect LBFactory transaction rounds.
1957 * (T149454) Restore erroneously removed realTableName call from DatabasePostgres.
1958 * (T167798) Fix phrase search and highlighting for phrase queries.
1959 * (T151136) Provide credits information to callbacks in extension registration.
1960 * (T160462) Allow namespaces defined in extension.json to be overwritten locally.
1961 * (T168337) Fix ErrorPageError to work from non-UI contexts.
1962 * (T143788) Backports for PHP 7.0 and 7.1 support.
1963 * (T175439) Unbreak Postgres Updater when setting defaults for a column.
1964 * (T160298) Remove use of implicitGroupBy() in ActiveUsersPager.
1965 * (T174255) Declare uploadCount property in importDump.php.
1966 * (T180231) SECURITY: Updated dev dependancy phpunit/phpunit from v4.8.24 to v4.8.36.
1967 * (T178451) SECURITY: Potential XSS when $wgShowExceptionDetails = false and browser
1968 sends non-standard url escaping.
1969 * (T165846) SECURITY: BotPassword login attempts weren't throttled.
1970 * (T128209) SECURITY: Reflected File Download from api.php.
1971 * (T134100) SECURITY: Do not reveal if user exists during login failure.
1972 * (T176247) SECURITY: Ensure Message::rawParams can't lead to XSS.
1973 * (T125163) SECURITY: Make anchor for headlines escape > and <.
1974 * (T180237) SECURITY: Protect vendor folder with .htaccess.
1975 * (T180231) SECURITY: Remove PHPUnit file with known RCE if exists in update.php.
1976 * (T124404) SECURITY: XSS in langconverter when regex hits pcre.backtrack_limit.
1977 * (T119158) SECURITY: Handle -{}- syntax in attributes safely.
1978
1979 == MediaWiki 1.28.2 ==
1980
1981 Due to a packaging error, the wrong version of the SyntaxHighlight extension was
1982 included in the tarball version of MediaWiki 1.28.1. The version included had a
1983 serious security issue in it (T158689). There was also some minor code fixes in
1984 MediaWiki itself since 1.28.1, but none of them were security relevant.
1985
1986 == MediaWiki 1.28.1 ==
1987
1988 This is a security and maintenance release of the MediaWiki 1.28 branch.
1989
1990 === Changes since 1.28.0 ===
1991
1992 * $wgRunJobsAsync is now false by default (T142751). This change only affects
1993 wikis with $wgJobRunRate > 0.
1994 * Fix fatal from "WaitConditionLoop" not being found, experienced when a wiki has
1995 more than one database server setup.
1996 * (T152717) Better escaping for PHP mail() command,
1997 * (T154670) A missing method causing the MySQL installer to fatal in rare
1998 circumstances was restored.
1999 * (T154672) Un-deprecate ArticleAfterFetchContentObject hook.
2000 * (T158766) Avoid SQL error on MSSQL when using selectRowCount().
2001 * (T145635) Fix too long index error when installing with MSSQL.
2002 * (T156184) $wgRawHtml will no longer apply to internationalization messages.
2003 * (T160519) CACHE_ANYTHING will not be CACHE_ACCEL if no accelerator is installed.
2004 * (T154872) Fix incorrect ar_usertext_timestamp index names in new 1.28 installs.
2005 * (T109140) (T122209) SECURITY: Special:UserLogin and Special:Search allow redirect
2006 to interwiki links.
2007 * (T144845) SECURITY: XSS in SearchHighlighter::highlightText() when
2008 $wgAdvancedSearchHighlighting is true.
2009 * (T125177) SECURITY: API parameters may now be marked as "sensitive" to keep
2010 their values out of the logs.
2011 * (T150044) SECURITY: "Mark all pages visited" on the watchlist now requires a CSRF
2012 token.
2013 * (T156184) SECURITY: Escape content model/format url parameter in message.
2014 * (T151735) SECURITY: SVG filter evasion using default attribute values in DTD
2015 declaration.
2016 * (T161453) SECURITY: LocalisationCache will no longer use the temporary directory
2017 in it's fallback chain when trying to work out where to write the cache.
2018 * (T48143) SECURITY: Spam blacklist ineffective on encoded URLs inside file inclusion
2019 syntax's link parameter.
2020 * (T108138) SECURITY: Sysops can undelete pages, although the page is protected against
2021 it.
2022
2023 == MediaWiki 1.28 ==
2024
2025 === Changes since 1.28.0-rc1 ===
2026 * (T148957) Replace wgShowExceptionDetails with wgShowDBErrorBacktrace on db
2027 errors.
2028 * (T148956) Only apply wgDBschema to postgres/mssql.
2029 * (T145991) Introduce separate log action for deleting pages on move.
2030 * (T141474) (T110464) Bypass login page if no user input is required.
2031
2032 === Changes since 1.28.0-rc0 ===
2033 * (T142210) The changes to move the parser "NewPP limit report" from a HTML
2034 comment to a machine-readable JavaScript config option 'wgPageParseReport'
2035 have been undone. They caused the human-readable limit report to be shown
2036 incompletely or not at all. ParserOutput::setLimitReportData() and
2037 getLimitReportData() behave as they did in MediaWiki 1.27 again.
2038 * (T149510) Value of {{DISPLAYTITLE:}} parser function will not be used for
2039 the text of subheadings on a category page when creating it. This wasn't
2040 working correctly.
2041 * (T106793) MediaWiki will no longer try to perform a HTTP redirect to the
2042 canonical pretty URL when a non-pretty URL is used. It resulted in redirect
2043 loops in some clients and in some server configurations. This undoes a change
2044 made in MediaWiki 1.26.
2045 * (T149759) manifest_version: 2 was removed.
2046
2047 === Configuration changes in 1.28 ===
2048 * $wgSend404Code now affects status code of action=history if the page is not there.
2049 * BREAKING CHANGE: $wgHTTPProxy is now *required* for all external requests
2050 made by MediaWiki via a proxy. Relying on the http_proxy environment
2051 variable is no longer supported.
2052 * The load.php entry point now enforces the existing policy of not allowing
2053 access to session data, which includes the session user and the session
2054 user's language. If such access is attempted, an exception will be thrown.
2055 * The number of internal PBKDF2 iterations used to derive the session secret
2056 is configurable via $wgSessionPbkdf2Iterations.
2057 * Upload dialog's file upload log comment can now be configured separately for
2058 local and foreign uploads.
2059 * $wgForeignUploadTargets now defaults to `[ 'local' ]`, where `'local'`
2060 signifies local uploads. A value of `[]` (empty array) now means that
2061 no upload targets are allowed, effectively disabling the upload dialog.
2062 * The deprecated $wgEditEncoding variable has been removed; it was only used
2063 for Esperanto language character conversion. You are now recommended to use
2064 input methods provided by the UniversalLanguageSelector extension.
2065 * When $wgPingback is true, MediaWiki will periodically ping
2066 https://www.mediawiki.org/beacon with basic information about the local
2067 MediaWiki installation. This data includes, for example, the type of system,
2068 PHP version, and chosen database backend. This behavior is off by default.
2069 * When $wgEditSubmitButtonLabelPublish is true, MediaWiki will label the button
2070 to store-to-database-and-show-to-others as "Publish page"/"Publish changes";
2071 if false, the default, they will be "Save page"/"Save changes".
2072 * The 'editcontentmodel' permission is now granted to all logged-in users ('user').
2073 instead of just administrators ('sysop'). Documentation for this feature is
2074 available at <https://www.mediawiki.org/wiki/Help:ChangeContentModel>.
2075 * $wgRevisionCacheExpiry is now set to one week by default instead of being disabled.
2076 * Magic links are now disabled by default, and can be re-enabled by modifying the value
2077 of $wgEnableMagicLinks. Their usage is discouraged, but if they are manually enabled,
2078 a tracking category will be added to help identify usage and make it easier to migrate
2079 away from. If you depend upon magic link functionality, it is requested that you comment
2080 on <https://www.mediawiki.org/wiki/Requests_for_comment/Future_of_magic_links> and
2081 explain your use case(s).
2082 * New config variable $wgCSPFalsePositiveUrls to control what URLs to ignore
2083 in upcoming Content-Security-Policy feature's reporting.
2084
2085 === New features in 1.28 ===
2086 * User::isBot() method for checking if an account is a bot role account.
2087 * Added a new 'slideshow' mode for galleries.
2088 * Added a new hook, 'UserIsBot', to aid in determining if a user is a bot.
2089 * Added a new hook, 'ApiMakeParserOptions', to allow extensions to better
2090 interact with API parsing.
2091 * Added a new hook, 'UploadVerifyUpload', which can be used to reject a file
2092 upload. Unlike 'UploadVerifyFile' it provides information about upload comment
2093 and the file description page, but does not run for uploads to stash.
2094 * (T141604) Extensions can now provide a better error message when their
2095 maintenance scripts are run without the extension being installed.
2096 * (T8948) Numeric sorting in categories is now supported by setting $wgCategoryCollation
2097 to 'uca-default-u-kn' or 'uca-<langcode>-u-kn'. If you can't use UCA collations,
2098 a 'numeric' collation is also available. If migrating from another
2099 collation, you will need to run the updateCollation.php maintenance script.
2100 * Two new codes have been added to #time parser function: "xit" for days in current
2101 month, and "xiz" for days passed in the year, both in Iranian calendar.
2102 * mw.Api has a new option, useUS, to use U+001F (Unit Separator) when
2103 appropriate for sending multi-valued parameters. This defaults to true when
2104 the mw.Api instance seems to be for the local wiki.
2105 * After a client performs an action which alters a database that has replica databases,
2106 MediaWiki will wait for the replica databases to synchronize with the master database
2107 while it renders the HTML output. However, if the output is a redirect to another wiki
2108 on the wiki farm with a different domain, MediaWiki will instead alter the redirect
2109 URL to include a ?cpPosTime parameter that triggers the database synchronization when
2110 the URL is followed by the client. The same-domain case uses a new cpPosTime cookie.
2111 * Added new hooks, 'ApiQueryBaseBeforeQuery', 'ApiQueryBaseAfterQuery', and
2112 'ApiQueryBaseProcessRow', to make it easier for extensions to add 'prop' and
2113 'show' parameters to existing API query modules.
2114
2115 === External library changes in 1.28 ===
2116
2117 ==== Upgraded external libraries ====
2118 * Updated es5-shim from v4.1.5 to v4.5.8
2119 * Updated composer/semver from v1.4.1 to v1.4.2
2120 * Updated wikimedia/php-session-serializer from v1.0.3 to v1.0.4
2121
2122 ==== New external libraries ====
2123 * Added wikimedia/scoped-callback v1.0.0
2124 * Added wikimedia/wait-condition-loop v1.0.1
2125
2126 === Bug fixes in 1.28 ===
2127 * (T146496) action=history pages should return 404 HTTP error code if the page does not exist
2128 * (T137264) SECURITY: XSS in unclosed internal links
2129 * (T133147) SECURITY: Escape '<' and ']]>' in inline <style> blocks
2130 * (T133147) SECURITY: Require login to preview user CSS pages
2131 * (T132926) SECURITY: Do not allow undeleting a revision deleted file if it is
2132 the top file
2133 * (T129738) SECURITY: Make $wgBlockDisablesLogin also restrict logged in
2134 permissions
2135 * (T129738) SECURITY: Make blocks log users out if $wgBlockDisablesLogin is true
2136 * (T139670) Move 'UserGetRights' call before application of
2137 Session::getAllowedUserRights()
2138
2139 === Action API changes in 1.28 ===
2140 * Added 'maxarticlesize' property to action=query&meta=siteinfo which contains
2141 the value of $wgMaxArticleSize.
2142 * Property 'modulemessages' from action=parse&prop=modules was removed
2143 (deprecated since 1.26).
2144 * The following response properties from action=login, deprecated in 1.27, are
2145 now removed: lgtoken, cookieprefix, sessionid. Clients should handle cookies
2146 to properly manage session state.
2147 * Submitting the lgtoken and lgpassword parameters in the query string to
2148 action=login is now deprecated and outputs a warning. They should be submitted
2149 in the POST body instead.
2150 * Submitting sensitive authentication request parameters to action=clientlogin,
2151 action=createaccount, action=linkaccount, and action=changeauthenticationdata
2152 in the query string is now deprecated and outputs a warning. They should be
2153 submitted in the POST body instead.
2154 * (T141960) Multi-valued parameters may now be separated using U+001F (Unit Separator)
2155 instead of the pipe character. This will be useful if some of the multiple
2156 values need to contain pipes, e.g. for action=options.
2157 * The API will now warn if input is not NFC-normalized Unicode or if it
2158 contains invalid characters.
2159 * The 'normalized' list output by action=query and other modules that use
2160 ApiPageSet may contain entries where the 'from' value is percent-encoded as
2161 the raw value cannot be represented in a valid API response. These are
2162 indicated by a 'fromencoded' boolean alongside the existing 'from' parameter.
2163 * (T28680) action=paraminfo can now return info about all submodules of a
2164 module without listing them all explicitly.
2165 * (T146770) It is now possible to assert that the current user is a specific
2166 named user, using the 'assertuser' parameter.
2167 * (T141963) Added a 'known' property when missing-but-known titles (e.g. from
2168 the 'TitleIsAlwaysKnown' hook) are output in various modules.
2169
2170 === Action API internal changes in 1.28 ===
2171 * Added a new hook, 'ApiMakeParserOptions', to allow extensions to better
2172 interact with ApiParse and ApiExpandTemplates.
2173 * (T139565) SECURITY: API: Generate head items in the context of the given title
2174 * (T115333) SECURITY: Check read permission when loading page content in ApiParse
2175 * ApiBase::getResultData() was removed (deprecated since 1.25)
2176 * ApiBase::makeHelpArrayToString() was removed (deprecated since 1.25)
2177 * ApiBase::makeHelpMsgParameters() was removed (deprecated since 1.25)
2178 * ApiBase::makeHelpMsg() was removed (deprecated since 1.25)
2179 * ApiFormatBase::formatHTML() was removed (deprecated since 1.25)
2180 * ApiFormatBase::getNeedsRawData() was removed (deprecated since 1.25)
2181 * ApiFormatBase::getWantsHelp() was removed (deprecated since 1.25)
2182 * ApiFormatBase::setBufferResult() was removed (deprecated since 1.25)
2183 * ApiFormatBase::setHelp() was removed (deprecated since 1.25)
2184 * ApiFormatBase::setUnescapeAmps() was removed (deprecated since 1.25)
2185 * ApiMain::makeHelpMsgHeader() was removed (deprecated since 1.25)
2186 * ApiMain::reallyMakeHelpMsg() was removed (deprecated since 1.25)
2187 * ApiMain::setHelp() was removed (deprecated since 1.25)
2188 * ApiResult::beginContinuation() was removed (deprecated since 1.25)
2189 * ApiResult::cleanUpUTF8() was removed (deprecated since 1.25)
2190 * ApiResult::convertStatusToArray() was removed (deprecated since 1.25)
2191 * ApiResult::disableSizeCheck() was removed (deprecated since 1.24)
2192 * ApiResult::enableSizeCheck() was removed (deprecated since 1.24)
2193 * ApiResult::endContinuation() was removed (deprecated since 1.25)
2194 * ApiResult::getData() was removed (deprecated since 1.25)
2195 * ApiResult::getIsRawMode() was removed (deprecated since 1.25)
2196 * ApiResult::setContent() was removed (deprecated since 1.25)
2197 * ApiResult::setContinueParam() was removed (deprecated since 1.25)
2198 * ApiResult::setElement() was removed (deprecated since 1.25)
2199 * ApiResult::setGeneratorContinueParam() was removed (deprecated since 1.25)
2200 * ApiResult::setIndexedTagName_internal() was removed (deprecated since 1.25)
2201 * ApiResult::setIndexedTagName_recursive() was removed (deprecated since 1.25)
2202 * ApiResult::setMainForContinuation() was removed (deprecated since 1.25)
2203 * ApiResult::setParsedLimit() was removed (deprecated since 1.25)
2204 * ApiResult::setRawMode() was removed (deprecated since 1.25)
2205 * ApiResult::size() was removed (deprecated since 1.25)
2206 * Added new hooks, 'ApiQueryBaseBeforeQuery', 'ApiQueryBaseAfterQuery', and
2207 'ApiQueryBaseProcessRow', to make it easier for extensions to add 'prop' and
2208 'show' parameters to existing API query modules. A query module can enable
2209 these hooks by passing an array for $hookData to ApiQueryBase::select() and
2210 by calling ApiQueryBase->processRow() before adding a row's data to the
2211 result.
2212
2213 === Languages updated in 1.28 ===
2214
2215 MediaWiki supports over 375 languages. Many localisations are updated
2216 regularly. Below only new and removed languages are listed, as well as
2217 changes to languages because of Phabricator reports.
2218
2219 * (T137411) ban (Balinese), thanks to translators Adi Mayndra, Andru,
2220 BASAbali, M. Adiputra, Naval Scene, Nemo bis, NoiX180, and 아라.
2221 * (T135867) shn (Shan), thanks to translators Khun Sar, Piangpha,
2222 Saiddzone Saimawnkham, Saosukham, and Sengwan.
2223 * Czech (cs) and Slovak (sk) set as reciprocal fallbacks.
2224 * (T146744) Livvi-Karelian (olo) namespace messages created thanks to translator Ilja.mos.
2225
2226 === Other changes in 1.28 ===
2227 * (T128697) Improved handling of large diffs.
2228 * [BREAKING CHANGE] $wgExtendedLoginCookies has been removed. You can
2229 use or update a custom session provider if needed.
2230 * Deprecated APIEditBeforeSave hook in favor of EditFilterMergedContent.
2231 * The 'UploadVerification' hook is deprecated. Use 'UploadVerifyFile' instead.
2232 * SiteConfiguration::isLocalVHost() was removed (deprecated since 1.25).
2233 * The 'UserLoginComplete' hook has a new parameter to differentiate between actual
2234 login and visiting the login page while already logged in.
2235 * ResourceLoader::makeLoaderURL() was removed (deprecated since 1.24).
2236 * $.fn.liveAndTestAtStart was removed (deprecated since 1.24).
2237 * mw.util.tooltipAccessKeyPrefix was removed (deprecated since 1.24).
2238 * mw.util.tooltipAccessKeyRegexp was removed (deprecated since 1.24).
2239 * Linker::link() and Linker::linkKnown() were deprecated; please instead use
2240 MediaWiki\Linker\LinkRenderer. In addition, the LinkBegin and LinkEnd hooks
2241 were replaced by HtmlPageLinkRendererBegin and HtmlPageLinkRendererEnd
2242 respectively. See docs/hooks.txt for the specific changes needed for those hooks.
2243 * Linker::formatSize() was deprecated. Use Language::formatSize() directly.
2244 * Aliases for Linker methods, deprecated since 1.21, were removed from Skin:
2245 * Skin::commentBlock() (use Linker::commentBlock() instead)
2246 * Skin::generateRollback() (use Linker::generateRollback() instead)
2247 * Skin::link() (use MediaWiki\Linker\LinkRenderer instead)
2248 * Skin::linkKnown() (use MediaWiki\Linker\LinkRenderer instead)
2249 * Skin::userLink() (use Linker::userLink() instead)
2250 * Skin::userToolLinks() (use Linker::userToolLinks() instead)
2251 * Disabled "bug 2702" HTML tidying of parsed UI messages on wikis where Tidy is
2252 disabled.
2253 * DifferenceEngine::generateDiffBody() was removed (deprecated since 1.21).
2254 * UploadBase::stashFileGetKey() and UploadBase::stashSession() were deprecated.
2255 Use ...->stashFile()->getFileKey() instead.
2256 * "Public domain" was removed as a wiki license option from the installer, in
2257 favour of CC-0.
2258 * AuthenticationRequest::$required is now changed from REQUIRED to PRIMARY_REQUIRED
2259 on requests needed by primary providers even if all primaries need them.
2260 Primary providers are discouraged from returning multiple REQUIRED requests.
2261 * OOjs UI PHP widgets constructed with the `'infusable' => true` config option
2262 will no longer be automatically infused. You should call `OO.ui.infuse()`
2263 on them yourself from your JavaScript code.
2264 * parserTests.php has moved to tests/parser/parserTests.php
2265 * The command line options specific to parser tests have been removed from
2266 phpunit.php: --regex and --keep-uploads. Instead of --regex, use --filter.
2267 Instead of --keep-uploads, use the same option to parserTests.php, but you
2268 must specify a directory with --upload-dir.
2269 * The 'jquery.arrowSteps' ResourceLoader module is now deprecated.
2270 * IP::isConfiguredProxy() and IP::isTrustedProxy() were removed. Callers should
2271 migrate to using the same functions on a ProxyLookup instance, obtainable from
2272 MediaWikiServices.
2273 * The ArticleAfterFetchContent, ArticleInsertComplete, ArticleSave, ArticleSaveComplete,
2274 ArticleViewCustom, EditFilterMerged, EditPageGetDiffText, EditPageGetPreviewText and
2275 ShowRawCssJs hooks will now emit deprecation warnings if used.
2276 * (T68404) CSS3 attr() function with url type is no longer allowed
2277 in inline styles.
2278 * Database::getSearchEngine() is deprecated, use SearchEngineFactory::getSearchEngineClass
2279 instead.
2280
2281 == Compatibility ==
2282
2283 MediaWiki 1.28 requires PHP 5.5.9 or later. There is experimental support for
2284 HHVM 3.6.5 or later.
2285
2286 MySQL is the recommended DBMS. PostgreSQL or SQLite can also be used, but
2287 support for them is somewhat less mature. There is experimental support for
2288 Oracle and Microsoft SQL Server.
2289
2290 The supported versions are:
2291
2292 * MySQL 5.0.3 or later
2293 * PostgreSQL 8.3 or later
2294 * SQLite 3.3.7 or later
2295 * Oracle 9.0.1 or later
2296 * Microsoft SQL Server 2005 (9.00.1399)
2297
2298 == Upgrading ==
2299
2300 1.28 has several database changes since 1.27, and will not work without schema
2301 updates. Note that due to changes to some very large tables like the revision
2302 table, the schema update may take quite long (minutes on a medium sized site,
2303 many hours on a large site).
2304
2305 If upgrading from before 1.11, and you are using a wiki as a commons
2306 repository, make sure that it is updated as well. Otherwise, errors may arise
2307 due to database schema changes.
2308
2309 If upgrading from before 1.7, you may want to run refreshLinks.php to ensure
2310 new database fields are filled with data.
2311
2312 If you are upgrading from MediaWiki 1.4.x or earlier, you should upgrade to
2313 1.5 first. The upgrade script maintenance/upgrade1_5.php has been removed
2314 with MediaWiki 1.21.
2315
2316 Don't forget to always back up your database before upgrading!
2317
2318 See the file UPGRADE for more detailed upgrade instructions.
2319
2320 For notes on 1.27.x and older releases, see HISTORY.
2321
2322 == Online documentation ==
2323
2324 Documentation for both end-users and site administrators is available on
2325 MediaWiki.org, and is covered under the GNU Free Documentation License (except
2326 for pages that explicitly state that their contents are in the public domain):
2327
2328 https://www.mediawiki.org/wiki/Special:MyLanguage/Documentation
2329
2330 == Mailing list ==
2331
2332 A mailing list is available for MediaWiki user support and discussion:
2333
2334 https://lists.wikimedia.org/mailman/listinfo/mediawiki-l
2335
2336 A low-traffic announcements-only list is also available:
2337
2338 https://lists.wikimedia.org/mailman/listinfo/mediawiki-announce
2339
2340 It's highly recommended that you sign up for one of these lists if you're
2341 going to run a public MediaWiki, so you can be notified of security fixes.
2342
2343 == IRC help ==
2344
2345 There's usually someone online in #mediawiki on irc.freenode.net.
2346
2347 = MediaWiki 1.27 =
2348
2349 == MediaWiki 1.27.5 ==
2350
2351 This is a security and maintenance release of the MediaWiki 1.27 branch.
2352
2353 === Changes since 1.27.4 ===
2354 * (T169545, CVE-2018-0503) SECURITY: $wgRateLimits entry for 'user' overrides
2355 'newbie'.
2356 * (T194605, CVE-2018-0505) SECURITY: BotPasswords can bypass CentralAuth's
2357 account lock.
2358 * Upgraded Moment.js from v2.8.4 to v2.19.3.
2359 * (T160298) Fixed Special:ActiveUsers due to bad backport.
2360 * (T87572) Make FormatMetadata::flattenArrayReal() work for an associative array.
2361 * Updated list of SPDX licenses for extensions.
2362 * (T189567) the CLI installer (maintenance/install.php) learned to detect and
2363 include extensions. Pass --with-extensions to enable that feature.
2364 * (T192584) Stop incorrectly passing USE INDEX to RecentChange::newFromConds().
2365 * Add default edit rate limit of 90 edits/minute for all users.
2366 * (T196125) php-memcached 3.0 (provided with PHP 7.0) is now supported.
2367 * (T196672) The mtime of extension.json files is now able to be zero.
2368 * (T118683) Fix exception from &$user deref on HHVM in the TitleMoveComplete hook.
2369 * (T180403) Validate $length in padleft/padright parser functions.
2370 * (T143790) Make $wgEmailConfirmToEdit only affect edit actions.
2371 * Special:BotPasswords now requires reauthentication.
2372 * (T191608, T187638) Add 'logid' parameter to Special:Log.
2373 * (T193829) Indicate when a Bot Password needs reset.
2374 * (T151415) Log email changes.
2375 * (T118420) Unbreak Oracle installer.
2376
2377 == MediaWiki 1.27.4 ==
2378 This is a security and maintenance release of the MediaWiki 1.27 branch.
2379
2380 === Changes since 1.27.3 ===
2381 * (T100085) Better handling of jobs execution in post-connection shutdown.
2382 * (T141604) Support conditionally registered namespaces.
2383 * (T167798) Fix highlighting for phrase queries and phrase search.
2384 * (T151136) Provide credits information to callbacks.
2385 * (T160462) Allow namespaces defined in extension.json to be overwritten locally.
2386 * (T168856) Allow SVGs created by Dia to be uploaded.
2387 * (T144705) (T148662) Password reset link is no longer shown when no reset options are
2388 available.
2389 * (T143788) (T174262) Various backports for PHP 7.0 and 7.1 support.
2390 * (T66795) $wgUserEmailUseReplyTo is now true by default to work around restrictive DMARC
2391 policies.
2392 * DB_REPLICA constant added from REL1_28+ to ease backports to extensions and core.
2393 * (T175439) Unbreak Postgres Updater when setting defaults for a column.
2394 * (T160298) Remove use of implicitGroupBy() in ActiveUsersPager.
2395 * (T142304) Allow putting the app ID in the password for bot passwords.
2396 * Updated dev dependancy phpunit/phpunit from v4.8.24 to v4.8.36.
2397 * (T178451) SECURITY: Potential XSS when $wgShowExceptionDetails = false and browser
2398 sends non-standard url escaping.
2399 * (T165846) SECURITY: BotPassword login attempts weren't throttled.
2400 * (T128209) SECURITY: Reflected File Download from api.php.
2401 * (T134100) SECURITY: Do not reveal if user exists during login failure.
2402 * (T176247) SECURITY: Ensure Message::rawParams can't lead to XSS.
2403 * (T125163) SECURITY: Make anchor for headlines escape > and <.
2404 * (T180237) SECURITY: Protect vendor folder with .htaccess.
2405 * (T180231) SECURITY: Remove PHPUnit file with known RCE if exists in update.php.
2406 * (T124404) SECURITY: XSS in langconverter when regex hits pcre.backtrack_limit.
2407 * (T119158) SECURITY: Handle -{}- syntax in attributes safely.
2408
2409 == MediaWiki 1.27.3 ==
2410 Due to a packaging error, the wrong version of the SyntaxHighlight extension was
2411 included in the tarball version of MediaWiki 1.27.2. The version included had a
2412 serious security issue in it (T158689). There was also some minor code fixes in
2413 MediaWiki itself since 1.27.2, but none of them were security relevant.
2414
2415 === Changes since 1.27.2 ===
2416 * (T145664) Fix broken wincache merge() implementation
2417 * (T163434) Add wikimedia/testing-access-wrapper for forwards compatibility
2418 * (T153505) Fix php warnings on php 7.1 due to use of &$this
2419
2420 == MediaWiki 1.27.2 ==
2421 This is a security and maintenance release of the MediaWiki 1.27 branch.
2422
2423 ApiCreateAccount was removed in 1.27.0. It was incorrectly still marked as
2424 deprecated (rather than already removed) in the RELEASE-NOTES at the point 1.27.0
2425 was released.
2426
2427 === Changes since 1.27.1 ===
2428
2429 * (T68404) CSS3 attr() function with url type argument is no longer allowed
2430 in inline styles.
2431 * $wgRunJobsAsync is now false by default (T142751). This change only affects
2432 wikis with $wgJobRunRate > 0.
2433 * (T152717) Better escaping for PHP mail() command
2434 * Submitting the lgtoken and lgpassword parameters in the query string to
2435 action=login is now deprecated and outputs a warning. They should be submitted
2436 in the POST body instead.
2437 * Submitting sensitive authentication request parameters to action=clientlogin,
2438 action=createaccount, action=linkaccount, and action=changeauthenticationdata
2439 in the query string is now deprecated and outputs a warning. They should be
2440 submitted in the POST body instead.
2441 * (T158766) Avoid SQL error on MSSQL when using selectRowCount()
2442 * (T145635) Fix too long index error when installing with MSSQL.
2443 * (T156184) $wgRawHtml will no longer apply to internationalization messages.
2444 * (T160519) CACHE_ANYTHING will not be CACHE_ACCEL if no accelerator is installed.
2445 * (T109140) (T122209) SECURITY: Special:UserLogin and Special:Search allow redirect
2446 to interwiki links.
2447 * (T144845) SECURITY: XSS in SearchHighlighter::highlightText() when
2448 $wgAdvancedSearchHighlighting is true.
2449 * (T125177) SECURITY: API parameters may now be marked as "sensitive" to keep
2450 their values out of the logs.
2451 * (T150044) SECURITY: "Mark all pages visited" on the watchlist now requires a CSRF
2452 token.
2453 * (T156184) SECURITY: Escape content model/format url parameter in message.
2454 * (T151735) SECURITY: SVG filter evasion using default attribute values in DTD
2455 declaration.
2456 * (T161453) SECURITY: LocalisationCache will no longer use the temporary directory
2457 in it's fallback chain when trying to work out where to write the cache.
2458 * (T48143) SECURITY: Spam blacklist ineffective on encoded URLs inside file inclusion
2459 syntax's link parameter.
2460 * (T108138) SECURITY: Sysops can undelete pages, although the page is protected against
2461 it.
2462
2463 == MediaWiki 1.27.1 ==
2464
2465 This is a maintenance release of the MediaWiki 1.27 branch.
2466
2467 === Changes since 1.27.0 ===
2468 * BREAKING CHANGE: $wgHTTPProxy is now *required* for all external requests
2469 made by MediaWiki via a proxy. Relying on the http_proxy environment
2470 variable is no longer supported.
2471 * (T139565) SECURITY: API: Generate head items in the context of the given title
2472 * (T137264) SECURITY: XSS in unclosed internal links
2473 * (T133147) SECURITY: Escape '<' and ']]>' in inline <style> blocks
2474 * (T133147) SECURITY: Require login to preview user CSS pages
2475 * (T132926) SECURITY: Do not allow undeleting a revision deleted file if it is
2476 the top file
2477 * (T129738) SECURITY: Make $wgBlockDisablesLogin also restrict logged in
2478 permissions
2479 * (T129738) SECURITY: Make blocks log users out if $wgBlockDisablesLogin is true
2480 * (T115333) SECURITY: Check read permission when loading page content in ApiParse
2481 * (T57548) Remove support for $wgWellFormedXml = false, all output is now well formed
2482 * (T139670) Move 'UserGetRights' call before application of Session::getAllowedUserRights()
2483
2484 == MediaWiki 1.27.0 ==
2485
2486 === PHP version requirement in 1.27 ===
2487 As of 1.27, MediaWiki now requires PHP 5.5.9 or higher (see Compatibility
2488 section). Additionally, the following PHP extensions are required:
2489 * ctype
2490 * iconv
2491 * json
2492 * mbstring (new requirement in 1.27)
2493 * xml
2494 The following PHP extensions are strongly recommended:
2495 * openssl
2496
2497 === Configuration changes in 1.27 ===
2498 * $wgAllowMicrodataAttributes and $wgAllowRdfaAttributes were removed,
2499 now always enabled. If you use RDFa on your wiki, you now have to explicitly
2500 set $wgHtml5Version to 'HTML+RDFa 1.0' or 'XHTML+RDFa 1.0'.
2501 * $wgUseLinkNamespaceDBFields was removed.
2502 * Deprecated $wgResourceLoaderMinifierStatementsOnOwnLine and
2503 $wgResourceLoaderMinifierMaxLineLength, because there was little value in
2504 making the behavior configurable. The default values (`false` for the former,
2505 1000 for the latter) are now hard-coded.
2506 * $wgDebugDumpSqlLength was removed (deprecated in 1.24).
2507 * $wgDebugDBTransactions was removed (deprecated in 1.20).
2508 * $wgUseXVO has been removed, as it provides functionality only used by
2509 custom Wikimedia patches against Squid 2.x that probably noone uses in
2510 production anymore. There is now $wgUseKeyHeader that provides similar
2511 functionality but instead of the MediaWiki-specific X-Vary-Options header,
2512 uses the draft Key header standard.
2513 * $wgScriptExtension (and support for '.php5' entry points) was removed. See the
2514 deprecation notice in the release notes for version 1.25 for advice on how to
2515 preserve support for '.php5' entry points via URL rewriting.
2516 * Password handling via the User object has been deprecated and partially
2517 removed, pending the future introduction of AuthManager. In particular:
2518 ** expirePassword(), getPasswordExpireDate(), resetPasswordExpiration(), and
2519 getPasswordExpired() have been removed. They were unused outside of core.
2520 ** The mPassword, mNewpassword, mNewpassTime, and mPasswordExpires fields are
2521 now private and will be removed in the future.
2522 ** The getPassword() and getTemporaryPassword() methods now throw
2523 BadMethodCallException and will be removed in the future.
2524 ** The ability to pass 'password' and 'newpassword' to createNew() has been
2525 removed. The only users of it seem to have been using it to set invalid
2526 passwords, and so shouldn't be greatly affected.
2527 ** setPassword(), setInternalPassword(), and setNewpassword() have been
2528 deprecated, pending the introduction of AuthManager.
2529 ** User::randomPassword() is deprecated in favor of a new method
2530 PasswordFactory::generateRandomPasswordString()
2531 ** User::getPasswordFactory() is deprecated, callers should just create a
2532 PasswordFactory themselves.
2533 ** A new constructor, User::newSystemUser(), has been added to simplify the
2534 creation of passwordless "system" users for logged actions.
2535 * $wgMaxSquidPurgeTitles was removed.
2536 * $wgAjaxWatch was removed. This is now enabled by default.
2537 * $wgUseInstantCommons now hotlinks Commons images by default instead of
2538 downloading originals and thumbnailing them locally. This allows wikis to save
2539 on CPU and bandwidth while reducing time to first byte for pages, even without
2540 a thumbnail handler. See $wgForeignFileRepos documentation for tweaks.
2541 * (T27397) WebP is enabled by default as an uploadable filetype.
2542 * (T48998) $wgArticlePath must now be either a full url, or start with a "/".
2543 * $wgRateLimitLog was removed; use $wgDebugLogGroups['ratelimit'] instead.
2544 * Deprecated API formats dbg, txt, and yaml have been removed.
2545 * CLDRPluralRule* classes have been replaced with
2546 wikimedia/cldr-plural-rule-parser.
2547 * Removed $wgProfilePerHost, $wgUDPProfilerHost, $wgUDPProfilerPort,
2548 $wgUDPProfilerFormatString, $wgStatsMethod, $wgAggregateStatsID,
2549 $wgStatsFormatString, and $wgProfileCallTree (deprecated since 1.20).
2550 * For proper operation of LocalIdLookup with shared user tables, ensure that
2551 $wgSharedDB and $wgSharedTables are properly set even on the "central" wiki
2552 that all others are sharing from and that $wgLocalDatabases is set to the
2553 full list of sharing wikis on all those wikis.
2554 * Massive overhaul to session handling:
2555 ** $wgSessionsInObjectCache is no longer supported and must be true, due to
2556 MediaWiki\Session\SessionManager. $wgSessionHandler is similarly no longer
2557 used.
2558 ** ObjectCacheSessionHandler is removed, replaced with
2559 MediaWiki\Session\PhpSessionHandler.
2560 ** PHP session handling in general ($_SESSION, session_id(), and so on) is
2561 deprecated. Use MediaWiki\Session\SessionManager instead. A new config
2562 variable, $wgPHPSessionHandling, is available to cause use of $_SESSION to
2563 issue a deprecation warning or to cause most PHP session handling to throw
2564 exceptions.
2565 ** Deprecated UserSetCookies hook. Session-handling extensions should generally
2566 be creating a custom subclass of CookieSessionProvider. Other extensions
2567 messing with cookies can no longer count on user data being saved in cookies
2568 versus other methods.
2569 ** Deprecated UserLoadFromSession hook, extensions should create a
2570 MediaWiki\Session\SessionProvider.
2571 ** The User cannot be loaded from session until after Setup.php completes.
2572 Attempts to do so will be ignored and the User will remain unloaded.
2573 ** CSRF tokens may be fetched from the MediaWiki\Session\Session, which uses
2574 the MediaWiki\Session\Token class.
2575 * MediaWiki will now auto-create users as necessary, removing the need for
2576 extensions to do so. An 'autocreateaccount' right is added to allow
2577 auto-creation when 'createaccount' is not granted to all users.
2578 * Deprecated AuthPluginAutoCreate hook in favor of LocalUserCreated.
2579 * Most cookie-handling methods in User are deprecated.
2580 * $wgAllowAsyncCopyUploads and $CopyUploadAsyncTimeout were removed. This was an
2581 experimental feature that has never worked.
2582 * Login and createaccount tokens now vary by timestamp.
2583 * LoginForm::getLoginToken() and LoginForm::getCreateaccountToken()
2584 return a MediaWiki\Session\Token, and tokens must be checked using that
2585 class's methods.
2586 * $wgEnotifUseJobQ was removed and the job queue is always used.
2587 * The functionality of the ApiSandbox extension has been merged into core. The
2588 extension should no longer be used.
2589 * $wgPreloadJavaScriptMwUtil was removed (deprecated in 1.26).
2590 Extensions, skins, gadgets and scripts that use the mediawiki.util module must
2591 express a dependency on it.
2592 * $wgIncludeLegacyJavaScript, deprecated in MediaWiki 1.26, now defaults false.
2593 Extensions, skins, gadgets and scripts that need the mediawiki.legacy.wikibits
2594 module should express a dependency on it.
2595 * Removed configuration option $wgCopyrightIcon (deprecated since 1.18). Use
2596 $wgFooterIcons['copyright']['copyright'] instead.
2597 * If the openssl and mcrypt PHP extensions are both unavailable, secure
2598 session storage (used for login) will raise an exception. This exception may
2599 be bypassed by setting $wgSessionInsecureSecrets = true.
2600 * Massive overhaul to authentication:
2601 ** AuthPlugin and AuthPluginUser are deprecated.
2602 ** LoginForm and associated templates are deprecated. Extensions which called
2603 static LoginForm methods should be converted into authentication providers.
2604 ** The following hooks are deprecated:
2605 *** AbortAutoAccount (create a MediaWiki\Auth\PreAuthenticationProvider instead)
2606 *** AbortLogin (create a MediaWiki\Auth\PreAuthenticationProvider instead)
2607 *** AbortNewAccount (create a MediaWiki\Auth\PreAuthenticationProvider instead)
2608 *** AddNewAccount (use LocalUserCreated instead)
2609 *** AuthPluginSetup (create a MediaWiki\Auth\PrimaryAuthenticationProvider instead)
2610 *** ChangePasswordForm (use AuthChangeFormFields instead, or security levels)
2611 *** LoginUserMigrated (create a MediaWiki\Auth\PreAuthenticationProvider instead)
2612 *** UserCreateForm (create a MediaWiki\Auth\AuthenticationProvider of some type instead)
2613 *** UserLoginForm (create a MediaWiki\Auth\AuthenticationProvider of some type instead)
2614 ** The following hooks are removed:
2615 *** AbortChangePassword
2616 *** LoginPasswordResetMessage
2617 *** PrefsPasswordAudit
2618 ** The UserLoginComplete hook will no longer be called for all logins, only for
2619 those via the web UI. Use UserLoggedIn if you need to do something on all
2620 logins.
2621 ** $wgRequirePasswordforEmailChange is removed.
2622
2623 === New features in 1.27 ===
2624 * $wgDataCenterUpdateStickTTL was also added. This decides how long a user
2625 sticks to the primary DC (via cookies) after they make changes to the site.
2626 * Added a new hook, 'UserMailerTransformContent', to transform the contents
2627 of an email. This is similar to the EmailUser hook but applies to all mail
2628 sent via UserMailer.
2629 * Added a new hook, 'UserMailerTransformMessage', to transform the contents
2630 of an emai after MIME encoding.
2631 * Added a new hook, 'UserMailerSplitTo', to control which users have to be
2632 emailed separately (ie. there is a single address in the To: field) so
2633 user-specific changes to the email can be applied safely.
2634 * $wgCdnMaxageLagged was added, which limits the CDN cache TTL
2635 when any load balancer uses a DB that is lagged beyond the 'max lag'
2636 setting in the relevant section of $wgLBFactoryConf.
2637 * User::newSystemUser() may be used to simplify the creation of passwordless
2638 "system" users for logged actions from scripts and extensions.
2639 * Extensions can now return detailed error information via the API when
2640 preventing user actions using 'getUserPermissionsErrors' and similar hooks
2641 by using ApiMessage instances instead of strings for the $result value.
2642 * $wgAPIMaxLagThreshold was added to limit bot changes when databases lag
2643 becomes too high.
2644 * Skins and extensions can now use FlexBox mixins (.flex-display(@display: flex)
2645 and .flex(@grow: 1, @shrink: 1, @width: auto, @order: 1)) in Less to create
2646 cross-browser-compatible FlexBox rules. Users will still need to add fallback
2647 float rules or the like for compatibility with IE9- separately.
2648 * Added MWTimestamp::getTimezoneString() which returns the localized timezone
2649 string, if available. To localize this string, see the comments of
2650 $wgLocaltimezone in includes/DefaultSettings.php.
2651 * Added CentralIdLookup, a service that allows extensions needing a concept of
2652 "central" users to get that without having to know about specific central
2653 authentication extensions.
2654 * $wgMaxUserDBWriteDuration added to limit huge user-generated transactions.
2655 Regular web request transactions that takes longer than this are aborted.
2656 * Added a new hook, 'TitleMoveCompleting', which runs before a page move is
2657 committed.
2658 * $wgCdnReboundPurgeDelay was added to provide secondary delayed purges of URLs
2659 from CDN to mitigate DB replication lag and WAN cache purge lag.
2660 * (T49162) Installer will default to setting CACHE_ACCEL as the main cache type
2661 if it is available.
2662 * It is now possible to patrol file uploads (both for new files and new versions
2663 of existing files). Special:NewFiles has gained an option to filter by patrol
2664 status. This functionality can be disabled using $wgUseFilePatrol.
2665 * MediaWiki\Session infrastructure allows for easier use of session mechanisms
2666 other than the usual cookies.
2667 ** SessionMetadata and SessionCheckInfo hooks allow for setting and checking
2668 custom session metadata.
2669 * Added MWGrants and associated configuration settings $wgGrantPermissions and
2670 $wgGrantPermissionGroups to hold configuration for authentication features
2671 such as OAuth that want to allow restricting the user rights a user may make
2672 use of.
2673 ** If you're already using the OAuth extension, these new variables are
2674 identical to (and will replace) $wgMWOAuthGrantPermissions and
2675 $wgMWOAuthGrantPermissionGroups.
2676 * Added MWRestrictions as a class to check restrictions on a WebRequest, e.g.
2677 to assert that the request comes from a particular IP range.
2678 * Added bot passwords, a rights-restricted login mechanism for API-using bots.
2679 * Whitelisted the following HTML attributes for all elements in wikitext:
2680 aria-describedby, aria-flowto, aria-label, aria-labelledby, aria-owns.
2681 * Removed "presentation" restriction on the HTML role attribute in wikitext.
2682 All values are now allowed for the role attribute.
2683 * $wgContentHandlers now also supports callbacks to create an instance of the
2684 appropriate ContentHandler subclass.
2685 * Added $wgAuthenticationTokenVersion, which if non-null prevents the
2686 user_token database field from being exposed in cookies. Setting this would
2687 be a good idea, but will log out all current sessions.
2688 * $wgEventRelayerConfig was added, for managing PubSub event relay configuration,
2689 specifically for reliable CDN url purges.
2690 * Requests have unique IDs, equal to the UNIQUE_ID environment variable (when
2691 MediaWiki is behind Apache+mod_unique_id or something similar) or a randomly-
2692 generated 24-character string. This request ID is used to annotate log records
2693 and error messages. It is available client-side via mw.config.get( 'wgRequestId' ).
2694 The request ID supplants exception IDs. Accordingly, MWExceptionHandler::getLogId()
2695 is deprecated.
2696 * (T33313) Add a preference for watching uploads by default, also applies
2697 to API-based upload tools.
2698 * $wgJpegPixelFormat was added to override chroma subsampling for JPEG image
2699 thumbnails created via ImageMagick. Defaults to 'yuv420', providing bandwidth
2700 savings versus the previous behavior on many files.
2701 * MediaWiki\Auth infrastructure (called "AuthManager") allows for more flexible
2702 configuration of multiple authentication pieces that was possible with
2703 AuthPlugin. For example, it's now easy to plug in second-factor
2704 authentication, or add additional checks to the login process, or to support
2705 multiple login methods at once, or to support non-password-based login methods.
2706 ** Providers are configured via the global setting $wgAuthManagerConfig.
2707 ** A global, $wgDisableAuthManager, is temporarily available to disable
2708 AuthManager until extensions are ready to support it.
2709 ** New hook, AuthChangeFormFields, to adjust the form fields on
2710 AuthManager-related special pages.
2711 ** New hook, AuthManagerLoginAuthenticateAudit, for additional logging of
2712 AuthManager-related authentication requests.
2713 ** New hook, ChangeAuthenticationDataAudit, for additional logging of
2714 AuthManager-related authentication data changes.
2715 ** New hook, SecuritySensitiveOperationStatus, to work with the new mechanism
2716 for requiring a recent login before taking security-sensitive operations
2717 like changing a password.
2718 ** Two new globals, $wgChangeCredentialsBlacklist and $wgRemoveCredentialsBlacklist
2719 can be used to prevent the web UI and the API changing certain authentication data.
2720 * The file upload dialog (available if you install WikiEditor or VisualEditor)
2721 can now be configured using $wgUploadDialog.
2722
2723 === External library changes in 1.27 ===
2724
2725 ==== Upgraded external libraries ====
2726 * Updated oojs/oojs-ui from v0.12.12 to v0.13.3.
2727 * Updated composer/semver from v1.0.0 to v1.2.0.
2728 * Updated liuggio/statsd-php-client to 1.0.18.
2729 * Updated QUnit from v1.18.0 to v1.22.0.
2730
2731 ==== New external libraries ====
2732 * Added wikimedia/base-convert v1.0.1.
2733 * Added wikimedia/cldr-plural-rule-parser v1.0.0.
2734 * Added wikimedia/relpath v1.0.3.
2735 * Added wikimedia/running-stat v1.1.0.
2736 * Added wikimedia/php-session-serializer v1.0.3.
2737
2738 ==== Removed and replaced external libraries ====
2739
2740 === Bug fixes in 1.27 ===
2741 * Special:Upload will now display correct maximum allowed file size when running
2742 under HHVM (T116347).
2743 * (T54077) The APIEditBeforeSave hook will once again give only the content of
2744 the section being edited, rather than the whole revision. This reverts the
2745 change made in MediaWiki 1.22.
2746
2747 === Action API changes in 1.27 ===
2748 * Added list=allrevisions.
2749 * generator=recentchanges now has the option to generate revids.
2750 * ApiPageSet::setRedirectMergePolicy() was added. This allows generator
2751 modules to define how generator data for a redirect source gets merged
2752 into the redirect destination.
2753 * prop=imageinfo&iiprop=uploadwarning will no longer include the possibility of
2754 "was-deleted" warning.
2755 * Added difftotextpst to query=revisions which preforms a pre-save transform on
2756 the text before diffing it.
2757 * Deprecated formats dbg, txt, and yaml have been removed.
2758 * (T47988) The protect log event details now use new-style formatting.
2759 * The following response properties from action=login are deprecated, and may
2760 be removed in the future: lgtoken, cookieprefix, sessionid. Clients should
2761 handle cookies to properly manage session state.
2762 * action=login transparently allows login using bot passwords. Clients should
2763 merely need to change the username and password used after setting up a bot
2764 password.
2765 * action=upload no longer understands statuskey, asyncdownload or leavemessage.
2766 * Several changes when $wgDisableAuthManager is false:
2767 ** action=login is deprecated for uses other than bot passwords.
2768 ** list=users can now indicate if a missing username is creatable.
2769 ** action=createaccount is changed in a non-backwards-compatible manner.
2770 ** Added action=query&meta=authmanagerinfo.
2771 ** Added action=clientlogin to be used to log into the main account instead of
2772 action=login.
2773 ** Added action=linkaccount.
2774 ** Added action=unlinkaccount.
2775 ** Added action=changeauthenticationdata.
2776 ** Added action=removeauthenticationdata.
2777 ** Added action=resetpassword.
2778
2779 === Action API internal changes in 1.27 ===
2780 * ApiQueryORM removed.
2781 * The following classes have been removed:
2782 ** ApiFormatDbg
2783 ** ApiFormatTxt
2784 ** ApiFormatYaml
2785 * ApiBase::addTokenProperties() was removed (deprecated since 1.24).
2786 * ApiBase::getFinalPossibleErrors() was removed (deprecated since 1.24).
2787 * ApiBase::getFinalResultProperties() was removed (deprecated since 1.24).
2788 * ApiBase::getRequireAtLeastOneParameterErrorMessages() was removed (deprecated since 1.24).
2789 * ApiBase::getPossibleErrors() was removed (deprecated since 1.24).
2790 * ApiBase::getRequireMaxOneParameterErrorMessages() was removed (deprecated since 1.24).
2791 * ApiBase::getRequireOnlyOneParameterErrorMessages() was removed (deprecated since 1.24).
2792 * ApiBase::getResultProperties() was removed (deprecated since 1.24).
2793 * ApiBase::getTitleOrPageIdErrorMessage() was removed (deprecated since 1.24).
2794 * ApiBase::parseErrors() was removed (deprecated since 1.24).
2795 * ApiQueryBase::titleToKey(), ApiQueryBase::keyToTitle() and
2796 ApiQueryBase::keyPartToTitle() all removed (deprecated since 1.24).
2797 * ApiQueryBase::checkRowCount() was removed (deprecated since 1.24).
2798 * ApiQueryBase::getDirectionDescription() was removed (deprecated since 1.25).
2799 * ApiQuery::getGenerators() was removed (deprecated since 1.21).
2800 * ApiQuery::getModules() was removed (deprecated since 1.21).
2801 * ApiQuery::getModuleType() was removed (deprecated since 1.21).
2802 * ApiQuery::setGeneratorContinue() was removed (deprecated since 1.24).
2803 * ApiMain::getModules() was removed (deprecated since 1.21).
2804 * ApiBase::getVersion() was removed (deprecated since 1.21).
2805 * ApiMain::getShowVersions() was removed (deprecated in 1.21).
2806 * ApiMain::addModule() was removed (deprecated in 1.21).
2807 * ApiMain::addFormat() was removed (deprecated in 1.21).
2808 * ApiMain::getFormats() was removed (deprecated in 1.21).
2809 * ApiPageSet::finishPageSetGeneration() was removed (deprecated in 1.21).
2810 * ApiCreateAccount was removed.
2811
2812 === Languages updated in 1.27 ===
2813
2814 MediaWiki supports over 350 languages. Many localisations are updated
2815 regularly. Below only new and removed languages are listed, as well as
2816 changes to languages because of Phabricator reports.
2817
2818 * (T113688) Change default numerals from Gurmukhi to Arabic for Punjabi locale.
2819 * (T116020) Aliases of magic words in MessagesXx.php are sorted by usage.
2820
2821 === Other changes in 1.27 ===
2822 * Added dependency injection (DI) infrastructure, see docs/injection.txt for details.
2823 It is planned to incrementally move MediaWiki code towards using DI, using the
2824 service locator (SL) pattern as a stepping stone.
2825 * ProfilerOutputUdp was removed. Note that there is a ProfilerOutputStats class.
2826 * WikiPage::doDeleteArticleReal() and WikiPage::doDeleteArticle() now
2827 ignore the 2nd and 3rd arguments (formerly $id and $commit).
2828 * Removed "loaderScripts" option from ResourceLoaderFileModule class.
2829 * Removed ORM-like wrapper added in 1.20.
2830 * LinkCache::getGoodLinks and LinkCache::getBadLinks were removed
2831 (deprecated in 1.26).
2832 * WikiPage::doQuickEdit() was removed (deprecated since 1.21).
2833 * Removed SiteObject and SiteArray classes (deprecated in 1.21).
2834 * MessageBlobStore::getInstance() was removed (deprecated since 1.25).
2835 * (T84937) Free external links ("autolinked" urls) will now be terminated
2836 by &nbsp; and HTML entity encodings of &nbsp, <, and >.
2837 * (T36948) The default file revert message's timestamp is now in
2838 $wgLocaltimezone, instead of UTC.
2839 * The default name of the 'suppress' group page has been changed from
2840 'Project:Oversight' to 'Project:Suppress'.
2841 * DatabaseBase::resultObject() is now protected (use outside Database classes
2842 not necessary since 1.11).
2843 * Calling ResourceLoaderFileModule::readStyleFiles() without a
2844 ResourceLoaderContext instance is deprecated.
2845 * ResourceLoader::getLessCompiler() now takes an optional parameter of
2846 additional LESS variables to set for the compiler.
2847 * wfBaseConvert() marked as deprecated, use Wikimedia\base_convert() directly
2848 instead.
2849 * Obsolete maintenance scripts clearCacheStats.php and showCacheStats.php
2850 were removed. The underlying data is sent to StatsD (see $wgStatsdServer).
2851 * Removed msg_resource_links database table and associated code.
2852 * Removed msg_resource database table and associated code.
2853 * Skin::getNamespaceNotice() was removed.
2854 * wfIsConfiguredProxy() was removed (deprecated since 1.24).
2855 * wfDebugTimer() was removed (deprecated since 1.25).
2856 * wfIsTrustedProxy() was removed (deprecated since 1.24).
2857 * wfGetIP() was removed (deprecated since 1.19).
2858 * MWHookException was removed.
2859 * OutputPage::appendSubtitle() was removed (deprecated since 1.19).
2860 * OutputPage::loginToUse() was removed (deprecated since 1.19).
2861 * Article::loadContent() was removed (deprecated since 1.19).
2862 * User::editToken() was removed (deprecated since 1.19).
2863 * Removed --force-normal option of dumpBackup.php, as it no longer served
2864 any useful purpose since 1.22.
2865 * The functions processOption() and processArgs() on the BackupDumper and
2866 TextPassDumper classes have been removed.
2867 * The maintenance/backupTextPass.inc file was deleted. You should include
2868 maintenance/dumpTextPass.php instead.
2869 * WikiPage::getUsedTemplates() was removed (deprecated since 1.19).
2870 * wfEmptyMsg() was removed (deprecated since 1.18).
2871 * OutputPage::permissionRequired() was removed (deprecated since 1.18).
2872 * OutputPage::blockedPage() was removed (deprecated since 1.18).
2873 * User::getSkin() was removed (deprecated since 1.18).
2874 * OutputPage::includeJQuery() was removed (deprecated since 1.17).
2875 * WikiPage::updateRestrictions() was removed (deprecated since 1.19).
2876 * WikiPage::testPreSaveTransform() was removed (deprecated since 1.19).
2877 * LogPage::logName() was removed (deprecated since 1.19).
2878 * LogPage::logHeader() was removed (deprecated since 1.19).
2879 * wfCheckLimits() was removed (deprecated since 1.24).
2880 * Linker::makeKnownLinkObj() was removed (deprecated since 1.16).
2881 * Linker::makeLinkObj() was removed (deprecated since 1.16).
2882 * wfMsgForContentNoTrans() was removed (deprecated since 1.18).
2883 * ChangesList::usePatrol was removed (deprecated since 1.22).
2884 * wfMsgNoTrans() was removed (deprecated since 1.18).
2885 * Linker::makeImageLink2 was removed (deprecated since 1.20).
2886 * Title::userIsWatching() was removed (deprecated since 1.20).
2887 * Removed WaitForSlave maintenance script; use SELECT MASTER_POS_WAIT()
2888 database function directly instead.
2889 * wfMsg() was removed (deprecated since 1.18).
2890 * wfMsgForContent() was removed (deprecated since 1.18).
2891 * wfMsgReal() was removed (deprecated since 1.18).
2892 * wfMsgGetKey() was removed (deprecated since 1.18).
2893 * wfMsgHtml() was removed (deprecated since 1.18).
2894 * wfMsgWikiHtml() was removed (deprecated since 1.18).
2895 * wfMsgExt() was removed (deprecated since 1.18).
2896 * Language::armourMath() was removed (deprecated since 1.22).
2897 * LanguageConverter::armourMath() was removed (deprecated since 1.22).
2898 * FakeConverter::armourMath() was removed (deprecated since 1.22).
2899 * The unused jquery.validate ResourceLoader module was removed.
2900 * FileRepo::getRootUrl() was removed (deprecated since 1.20).
2901 * User::generateToken() was removed (deprecated since 1.20).
2902 * WikiPage::getRawText() was removed (deprecated since 1.21).
2903 * ParserOutput::hasCustomDataUpdates() was removed (deprecated since 1.25).
2904 * ParserOutput::addSecondaryDataUpdate() was removed (deprecated since 1.25).
2905 * ParserOutput::getSecondaryDataUpdates() was removed (deprecated since 1.25).
2906 * Gallery images with multiple caption pipes no longer concatenate them all
2907 together but instead pick the final one, similar to image syntax.
2908 * XML-like parser tags (such as <gallery>), when unclosed, will be left unparsed
2909 rather than consume everything until the end of the page.
2910 * New maintenance script resetUserEmail.php allows sysadmins to reset user emails in case
2911 a user forgot password/account was stolen.
2912 * wfCheckEntropy() was removed (deprecated in 1.27).
2913 * Browser support for Internet Explorer 8 lowered from Grade A to Grade C.
2914 * ContentHandler::supportsCategories method added. Default is true.
2915 CategoryMembershipChangeJob updates are skipped for content that
2916 does not support categories.
2917 * wikidiff difference engine is no longer supported, anyone still using it are encouraged
2918 to upgrade to wikidiff2 which is actively maintained and has better package availability.
2919 * Database logic was removed from WatchedItem and a WatchedItemStore was created:
2920 ** WatchedItem::IGNORE_USER_RIGHTS and WatchedItem::CHECK_USER_RIGHTS were deprecated.
2921 User::IGNORE_USER_RIGHTS and User::CHECK_USER_RIGHTS were introduced.
2922 ** WatchedItem::fromUserTitle was deprecated in favour of the constructor.
2923 ** WatchedItem::resetNotificationTimestamp was deprecated.
2924 ** WatchedItem::batchAddWatch was deprecated.
2925 ** WatchedItem::addWatch was deprecated.
2926 ** WatchedItem::removeWatch was deprecated.
2927 ** WatchedItem::isWatched was deprecated.
2928 ** WatchedItem::duplicateEntries was deprecated.
2929 ** EmailNotification::updateWatchlistTimestamp was deprecated.
2930 ** User::getWatchedItem was removed.
2931 * Unit tests don't work with external PHPUnit anymore, Composer is now the only supported
2932 way. Run `composer install` to install it and other dev dependencies to run unit tests.
2933 * wl_id field added to the watchlist table.
2934 * Revision::getRawText() was removed (deprecated since 1.21).
2935 * WikiPage::replaceSection() was removed (deprecated since 1.21).
2936 * Article::replaceSection() was removed (deprecated since 1.21).
2937 * Language::getLangObj() was removed (deprecated since 1.24).
2938 * Language::getLanguageName() was removed (deprecated since 1.20).
2939 * Language::getLanguageNames() was removed (deprecated since 1.20).
2940 * Language::getTranslatedLanguageNames() was removed (deprecated since 1.20).
2941 * Language::specialPage() was removed (deprecated since 1.24).
2942 * MediaWikiTestCase::assertException() was removed (deprecated since 1.22).
2943 * OutputPage::getHeadItems() was removed (deprecated since 1.24).
2944 * OutputPage::getScript() was removed (deprecated since 1.24).
2945 * OutputPage::out() was removed (deprecated since 1.22).
2946 * OutputPage::setAllowedModules() was removed (deprecated since 1.24).
2947 * UserrightsPage::makeGroupNameListForLog() was removed (deprecated since 1.21).
2948 * MediaWikiSite::newFromGlobalId() was removed (deprecated since 1.21).
2949 * Title::newFromRedirect() was removed (deprecated since 1.21).
2950 * Skin::commonPrintStylesheet() was removed (deprecated since 1.22).
2951 * Skin::getCommonStylePath() was removed (deprecated since 1.24).
2952 * Skin::newFromKey() was removed (deprecated since 1.24).
2953 * Skin::getUsableSkins() was removed (deprecated since 1.23).
2954 * LoadBalancer::pickRandom() was removed (deprecated in 1.21).
2955 * Article::getUndoText() and WikiPage::getUndoText were removed (deprecated since
2956 1.21).
2957 * DifferenceEngine::setText() was removed (deprecated in 1.21).
2958 * Title::newFromRedirectArray() was removed (deprecated in 1.21).
2959 * UserMailer::send() no longer accepts $replyto as the 5th argument and $contentType
2960 as the 6th. These must be passed in the options array now.
2961 * Title::newFromRedirectRecurse() was removed (deprecated in 1.21).
2962 * Skin::accesskey was removed (deprecated since 1.21).
2963 * Skin::blockLink was removed (deprecated since 1.21).
2964 * Skin::buildRollbackLink was removed (deprecated since 1.21).
2965 * Skin::emailLink was removed (deprecated since 1.21).
2966 * Skin::formatComment was removed (deprecated since 1.21).
2967 * Skin::formatHiddenCategories was removed (deprecated since 1.21).
2968 * Skin::formatLinksInComment was removed (deprecated since 1.21).
2969 * Skin::formatRevisionSize was removed (deprecated since 1.21).
2970 * Skin::formatSize was removed (deprecated since 1.21).
2971 * Skin::formatTemplates was removed (deprecated since 1.21).
2972 * Skin::generateTOC was removed (deprecated since 1.21).
2973 * Skin::getInternalLinkAttributes was removed (deprecated since 1.21).
2974 * Skin::getInternalLinkAttributesObj was removed (deprecated since 1.21).
2975 * Skin::getInterwikiLinkAttributes was removed (deprecated since 1.21).
2976 * Skin::getInvalidTitleDescription was removed (deprecated since 1.21).
2977 * Skin::getLinkColour was removed (deprecated since 1.21).
2978 * Skin::getRevDeleteLink was removed (deprecated since 1.21).
2979 * Skin::getRollbackEditCount was removed (deprecated since 1.21).
2980 * Skin::makeBrokenImageLinkObj was removed (deprecated since 1.21).
2981 * Skin::makeCommentLink was removed (deprecated since 1.21).
2982 * Skin::makeExternalImage was removed (deprecated since 1.21).
2983 * Skin::makeExternalLink was removed (deprecated since 1.21).
2984 * Skin::makeHeadline was removed (deprecated since 1.21).
2985 * Skin::makeImageLink was removed (deprecated since 1.21).
2986 * Skin::makeMediaLinkFile was removed (deprecated since 1.21).
2987 * Skin::makeMediaLinkObj was removed (deprecated since 1.21).
2988 * Skin::makeSelfLinkObj was removed (deprecated since 1.21).
2989 * Skin::makeThumbLink2 was removed (deprecated since 1.21).
2990 * Skin::makeThumbLinkObj was removed (deprecated since 1.21).
2991 * Skin::normaliseSpecialPage was removed (deprecated since 1.21).
2992 * Skin::normalizeSubpageLink was removed (deprecated since 1.21).
2993 * Skin::processResponsiveImages was removed (deprecated since 1.21).
2994 * Skin::revComment was removed (deprecated since 1.21).
2995 * Skin::revDeleteLink was removed (deprecated since 1.21).
2996 * Skin::revDeleteLinkDisabled was removed (deprecated since 1.21).
2997 * Skin::revUserLink was removed (deprecated since 1.21).
2998 * Skin::revUserTools was removed (deprecated since 1.21).
2999 * Skin::specialLink was removed (deprecated since 1.21).
3000 * Skin::splitTrail was removed (deprecated since 1.21).
3001 * Skin::titleAttrib was removed (deprecated since 1.21).
3002 * Skin::tocIndent was removed (deprecated since 1.21).
3003 * Skin::tocLine was removed (deprecated since 1.21).
3004 * Skin::tocLineEnd was removed (deprecated since 1.21).
3005 * Skin::tocList was removed (deprecated since 1.21).
3006 * Skin::tocUnindent was removed (deprecated since 1.21).
3007 * Skin::tooltip was removed (deprecated since 1.21).
3008 * Skin::tooltipAndAccesskeyAttribs was removed (deprecated since 1.21).
3009 * Skin::userTalkLink was removed (deprecated since 1.21).
3010 * Skin::userToolLinksRedContribs was removed (deprecated since 1.21).
3011 * wikidiff3 is now the default and only PHP diff engine. It provides improved diff
3012 performance on complex changes. $wgExternalDiffEngine = 'wikidiff3' therefore
3013 makes no difference now. Users are still recommended to use wikidiff2 if possible,
3014 though.
3015 * User::addNewUserLogEntry() was deprecated.
3016 * User::addNewUserLogEntryAutoCreate() was deprecated.
3017 * User::isPasswordReminderThrottled() was deprecated.
3018 * Bot-oriented parameters to Special:UserLogin (wpCookieCheck, wpSkipCookieCheck)
3019 were removed.
3020 * Installer can now be customized without patching MediaWiki code, see
3021 mw-config/overrides/README for details.
3022
3023 === Compatibility ===
3024
3025 MediaWiki 1.27 requires PHP 5.5.9 or later. There is experimental support for
3026 HHVM 3.6.5 or later.
3027
3028 MySQL is the recommended DBMS. PostgreSQL or SQLite can also be used, but
3029 support for them is somewhat less mature. There is experimental support for
3030 Oracle and Microsoft SQL Server.
3031
3032 The supported versions are:
3033
3034 * MySQL 5.0.3 or later
3035 * PostgreSQL 8.3 or later
3036 * SQLite 3.3.7 or later
3037 * Oracle 9.0.1 or later
3038 * Microsoft SQL Server 2005 (9.00.1399)
3039
3040 === Upgrading ===
3041
3042 1.27 has several database changes since 1.26, and will not work without schema
3043 updates. Note that due to changes to some very large tables like the revision
3044 table, the schema update may take quite long (minutes on a medium sized site,
3045 many hours on a large site).
3046
3047 If upgrading from before 1.11, and you are using a wiki as a commons
3048 repository, make sure that it is updated as well. Otherwise, errors may arise
3049 due to database schema changes.
3050
3051 If upgrading from before 1.7, you may want to run refreshLinks.php to ensure
3052 new database fields are filled with data.
3053
3054 If you are upgrading from MediaWiki 1.4.x or earlier, you should upgrade to
3055 1.5 first. The upgrade script maintenance/upgrade1_5.php has been removed
3056 with MediaWiki 1.21.
3057
3058 Don't forget to always back up your database before upgrading!
3059
3060 See the file UPGRADE for more detailed upgrade instructions.
3061
3062 For notes on 1.26.x and older releases, see HISTORY.
3063
3064
3065 = MediaWiki 1.26 =
3066
3067 == MediaWiki 1.26.4 ==
3068
3069 This is a maintenance release of the MediaWiki 1.26 branch.
3070
3071 === Changes since 1.26.3 ===
3072 * BREAKING CHANGE: $wgHTTPProxy is now *required* for all external requests
3073 made by MediaWiki via a proxy. Relying on the http_proxy environment
3074 variable is no longer supported.
3075 * (T124163) Fixed fatal error in DifferenceEngine under HHVM.
3076 * (T139565) SECURITY: API: Generate head items in the context of the given title
3077 * (T137264) SECURITY: XSS in unclosed internal links
3078 * (T133147) SECURITY: Escape '<' and ']]>' in inline <style> blocks
3079 * (T133147) SECURITY: Require login to preview user CSS pages
3080 * (T132926) SECURITY: Do not allow undeleting a revision deleted file if it is
3081 the top file
3082 * (T129738) SECURITY: Make $wgBlockDisablesLogin also restrict logged in
3083 permissions
3084 * (T129738) SECURITY: Make blocks log users out if $wgBlockDisablesLogin is true
3085 * (T115333) SECURITY: Check read permission when loading page content in ApiParse
3086 * Remove support for $wgWellFormedXml = false, all output is now well formed
3087
3088 == MediaWiki 1.26.3 ==
3089
3090 This is a maintenance release of the MediaWiki 1.26 branch.
3091
3092 === Changes since 1.26.2 ===
3093 * (T116266) Fixed undefined property notices in DairikiDiff under HHVM.
3094 * (T123166) Fix fatal error when importing pages to titles which cannot be
3095 created, such as invalid titles or titles the user is not allowed to edit.
3096 * (T122056) Old tokens are remaining valid within a new session
3097 * (T127114) Login throttle can be tricked using non-canonicalized usernames
3098 * (T123653) Cross-domain policy regexp is too narrow
3099 * (T123071) Incorrectly identifying http link in a's href attributes, due to
3100 m modifier in regex
3101 * (T129506) MediaWiki:Gadget-popups.js isn't renderable
3102 * (T125283) Users occasionally logged in as different users after
3103 SessionManager deployment
3104 * (T103239) Patrol allows click catching and patrolling of any page
3105 * (T122807) [tracking] Check php crypto primatives
3106 * (T98313) Graphs can leak tokens, leading to CSRF
3107 * (T130947) Diff generation should use PoolCounter
3108 * (T133507) Careless use of $wgExternalLinkTarget is insecure
3109 * (T132874) API action=move is not rate limited
3110 * (T110143) strip markers can be used to get around html attribute escaping in
3111 (many?) parser tags
3112 * (T116030) Increase pbkdf2 parameter strengths
3113 * (T127420) Pbkdf2Password does not check if hash_pbkdf2() succeeded
3114 * (T126685) Globally throttle password attempts
3115
3116 == MediaWiki 1.26.2 ==
3117
3118 This is a maintenance release of the MediaWiki 1.26 branch.
3119
3120 === Changes since 1.26.1 ===
3121 * (T121892) Fix fatal error on some Special pages, introduced in 1.26.1.
3122
3123 == MediaWiki 1.26.1 ==
3124
3125 This is a maintenance release of the MediaWiki 1.26 branch.
3126
3127 === Changes since 1.26.0 ===
3128 * (T117899) SECURITY: $wgArticlePath can no longer be set to relative paths
3129 that do not begin with a slash. This enabled trivial XSS attacks.
3130 Configuration values such as "http://my.wiki.com/wiki/$1" are fine, as are
3131 "/wiki/$1". A value such as "$1" or "wiki/$1" is not and will now throw an
3132 error.
3133 * (T119309) SECURITY: Use hash_compare() for edit token comparison
3134 * (T118032) SECURITY: Don't allow cURL to interpret POST parameters starting
3135 with '@' as file uploads
3136 * (T115522) SECURITY: Passwords generated by User::randomPassword() can no
3137 longer be shorter than $wgMinimalPasswordLength
3138 * (T97897) SECURITY: Improve IP parsing and trimming. Previous behavior could
3139 result in improper blocks being issued
3140 * (T109724) SECURITY: Special:MyPage, Special:MyTalk, Special:MyContributions
3141 and related pages no longer use HTTP redirects and are now redirected by
3142 MediaWiki
3143 * Fixed ConfigException in ExpandTemplates due to AlwaysUseTidy.
3144 * Fixed stray literal \n in Special:Search.
3145 * Fix issue that breaks HHVM Repo Authorative mode.
3146 * (T120267) Work around APCu memory corruption bug
3147
3148 == MediaWiki 1.26.0 ==
3149
3150 === Configuration changes in 1.26 ===
3151 * $wgPasswordResetRoutes['email'] = true by default.
3152 * $wgEnableParserCache was deprecated, set $wgParserCacheType to CACHE_NONE
3153 instead if you want to disable the parser cache.
3154 * New-style continuation is now the default for API action=continue. Clients may
3155 use the 'rawcontinue' parameter to receive raw query-continue data, but the
3156 new style is encouraged as it's harder to implement incorrectly.
3157 * Deprecated API formats dump and wddx have been completely removed.
3158 * (T7645) The "Signature" button on the edit toolbar is now hidden by default
3159 in non-talk namespaces. A new configuration variable,
3160 $wgExtraSignatureNamespaces, controls in which subject (non-talk) namespaces
3161 the "Signature" button on the edit toolbar will be displayed.
3162 * $wgResourceLoaderUseESI was deprecated and removed. This was an experimental
3163 feature that was never enabled by default.
3164 * $wgResourceLoaderExperimentalAsyncLoading was deprecated and removed.
3165 This experimental feature was never enabled by default and is obsolete as of
3166 MediaWiki 1.26, in where ResourceLoader became fully asynchronous.
3167 * $wgMasterWaitTimeout was removed (deprecated in 1.24).
3168 * Fields in ParserOptions are now private. Use the accessors instead.
3169 * Custom LESS functions (defined via $wgResourceLoaderLESSFunctions or
3170 in extension.json) have been removed, after being deprecated in 1.24.
3171 * $wgAlwaysUseTidy has been removed.
3172 * ResetSessionID hook has been removed. Nothing seems to use it.
3173 * Certain AuthPlugin methods are deprecated in favor of new hooks:
3174 ** AuthPlugin::initUser() is replaced by LocalUserCreated.
3175 ** AuthPlugin::updateUser() is replaced by UserLoggedIn.
3176 ** AuthPlugin::updateExternalDB() is replaced by the existing UserSaveSettings.
3177 ** AuthPlugin::updateExternalDBGroups() is replaced by UserGroupsChanged.
3178 ** AuthPluginUser::isHidden() is replaced by UserIsHidden.
3179 ** AuthPluginUser::isLocked() is replaced by UserIsLocked.
3180 * The UserRights hook is deprecated in favor of the new UserGroupsChanged hook.
3181 * AuthPlugin::initUser() and AuthPlugin::updateUser() should no longer replace
3182 the passed User object.
3183 * $wgBlockAllowsUTEdit is now set to true by default. This allows
3184 blocked users to edit their talk pages unless explicitly disabled
3185 when they are being blocked.
3186
3187 === New features in 1.26 ===
3188 * (T51506) Now action=info gives estimates of actual watchers for a page.
3189 See $wgRCMaxAge, $wgWatchersMaxAge and $wgUnwatchedPageSecret
3190 to learn how to configure if needed.
3191 * Change tags can now be hidden in the interface by disabling the associated
3192 "tag-<id>" interface message.
3193 * ':' (colon) is now invalid in usernames for new accounts. Existing accounts
3194 are not affected.
3195 * Added a new hook, 'LogException', to log exceptions in nonstandard ways.
3196 * Revive the 'SpecialSearchResultsAppend' hook which occurs after the list of
3197 search results are rendered. The initial use case is to append a "give us
3198 feedback" link beneath the search results.
3199 * Added a new hook, 'RejectParserCacheValue', which allows extensions to
3200 reject an otherwise-successful parser cache lookup. The intent is to allow
3201 extensions to manage the eviction of archaic HTML output from the cache.
3202 * (T68699) The expiration of the UserID and Token login cookies
3203 ($wgExtendedLoginCookieExpiration) can be configured independently of the
3204 expiration of all other cookies ($wgCookieExpiration).
3205 * (T50519) Support for generating JPEG/PNG thumbnails from WebP images added
3206 if ImageMagick is used as image scaler ($wgUseImageMagick = true). Uploading
3207 of WebP images still disabled by default. Add $wgFileExtensions[] =
3208 'webp'; to LocalSettings.php to enable uploading of WebP images.
3209 * Added new hooks 'EnhancedChangesListModifyLineData' &
3210 'EnhancedChangesListModifyBlockLineData', to modify the data used to build
3211 lines in enhanced recentchanges and watchlist.
3212 * Caches that need purging ability now use the WANObjectCache interface.
3213 This corresponds to a new $wgMainWANCache setting, which defaults to using
3214 the $wgMainCacheType settings.
3215 * Callers needing fast light-weight data stores use $wgMainStash to select
3216 the store type from $wgObjectCaches. The default is the local database.
3217 * Interface message overrides in the MediaWiki namespace will now be cached in
3218 memcached and APC (if available), rather than memcached and local files.
3219 * Added a new hook, 'RandomPageQuery', to allow modification of the query used
3220 by Special:Random to select random pages.
3221 * $wgTransactionalTimeLimit was added, which controls the request time limit
3222 for potentially slow POST requests that need to be as atomic as possible.
3223 * ResourceLoader now loads all scripts asynchronously. The top-queue and
3224 startup modules are no longer synchronously loaded.
3225 * 'mediawiki.ui.button' styles are no longer unconditionally loaded on every
3226 page. During the deprecation period, the styles will only be loaded on pages
3227 which contain 'mw-ui-button' in their HTML. Starting in 1.28, the styles will
3228 only be loaded if explicitly required.
3229 * If search returns zero results and current search engine has a "did you mean"
3230 suggestion, results for suggestion will be shown. Can be disabled by setting
3231 $wgSearchRunSuggestedQuery to false.
3232 * Added several JavaScript libraries for uploading files to MediaWiki
3233 from the client-side. See documentation for mw.Upload and its
3234 subclasses for more information.
3235 * Added OOUI dialogs and layout for file upload interfaces. See
3236 documentation for mw.Upload.Dialog, mw.Upload.BookletLayout and its
3237 subclasses for more information.
3238
3239 === extension.json changes in 1.26 ===
3240 * (T99344) The extension.json schema is now versioned. All extensions
3241 and skins should set a "manifest_version" property corresponding to
3242 the schema version they were written for. The only supported version
3243 currently is "1".
3244 * (T102523) The error message if a non-array attribute is set was improved.
3245 * (T107646) Configuration settings can now specify how they should be merged,
3246 which is necessary for arrays using integer keys.
3247 * (T110389) Adding namespaces through extension.json now actually works
3248 * $wgNamespaceProtection can now be set in extension.json.
3249 * $wgCapitalLinkOverrides can now be set in extension.json.
3250 * (T97186) Extensions using a custom prefix for their configuration settings
3251 can now set a "_prefix" key to override the default of "wg".
3252 * (T99084) Extensions can now specify what MediaWiki core versions they
3253 depend upon.
3254 * (T105236) The extension.json schema now validates custom classes in
3255 the "ResourceModules" property properly.
3256
3257 === External library changes in 1.26 ===
3258 ==== Upgraded external libraries ====
3259 * Updated es5-shim from v4.0.0 to v4.1.5.
3260 * Updated json2 from revision 2014-02-04 to 2015-05-03.
3261 * Updated Sinon.JS from 1.10.3 to 1.15.4.
3262 * Updated jQuery Client from v1.0.0 to v2.0.0.
3263 * Updated QUnit from v1.17.1 to v1.18.0.
3264 * Updated liuggio/statsd-php-client from v1.0.12 to v1.0.16.
3265 * Updated oojs/oojs-ui from v0.11.3 to v0.12.12.
3266 * Updated wikimedia/cdb from v1.0.1 to v1.3.0.
3267 * Updated wikimedia/utfnormal from v1.0.2 to v1.0.3.
3268 * Updated wikimedia/composer-merge-plugin from v1.0.0 to v1.3.0.
3269 * Updated zordius/lightncandy from v0.18 to v0.21.
3270
3271 ==== New external libraries ====
3272 * Added composer/semver v1.0.0.
3273 * Added mediawiki/at-ease v1.1.0.
3274 * Added wikimedia/assert v0.2.2.
3275 * Added wikimedia/ip-set v1.0.1.
3276 * Added wikimedia/wrappedstring v2.0.0.
3277
3278 ==== Removed and replaced external libraries ====
3279 * Replaced leafo/lessphp v0.5.0 with oyejorge/less.php v1.7.0.9.
3280
3281 === Bug fixes in 1.26 ===
3282 * (T53283) load.php sometimes sends 304 response without full headers
3283 * (T65198) Talk page tabs now have a "rel=discussion" attribute
3284 * (T98841) {{msgnw:}} now preserves comments even when subst: is not used.
3285 * (T104142) $wgEmergencyContact and $wgPasswordSender now use their default
3286 value if set to an empty string.
3287
3288 === Action API changes in 1.26 ===
3289 * New-style continuation is now the default for action=continue. Clients may
3290 use the 'rawcontinue' parameter to receive raw query-continue data, but the
3291 new style is encouraged as it's harder to implement incorrectly.
3292 * Deprecated API formats dump and wddx have been completely removed.
3293 * API action=query&list=tags: The displayname can now be boolean false if the
3294 tag is meant to be hidden from user interfaces.
3295 * action=import no longer allows both the namespace= and rootpage= parameters
3296 to be set. If they are both set, the value of rootpage= will be ignored.
3297 * prop=revision output in enum mode is now sorted by timestamp rather than
3298 revision ID. This usually won't make any difference.
3299 * (T102645) Namespace list from meta=siteinfo&siprop=namespaces is now an array
3300 with formatversion=2.
3301 * Various other output from meta=siteinfo will now always be arrays instead of
3302 sometimes being numerically-indexed objects with formatversion=2.
3303 * When errors about users being blocked are returned, they now include
3304 information about the relevant block.
3305 * (T99926) list=random has higher limits, in line with other API modules.
3306 * list=random's rnredirect parameter is deprecated in favor of a new
3307 rnfilterredir parameter that also allows for listing both redirects and
3308 non-redirects.
3309 * list=random now supports continuation.
3310 * API responses to GET requests may now include ETag and Last-Modified headers,
3311 and will honor corresponding If-None-Match and If-Modified-Since on such
3312 requests.
3313
3314 === Action API internal changes in 1.26 ===
3315 * New metadata item ApiResult::META_KVP_MERGE to allow for merging the KVP key
3316 into the value when the value is an assoc.
3317 * API action modules may now provide values for the RFC 7232 ETag and
3318 Last-Modified headers. The API will check these against If-None-Match and
3319 If-Modified-Since request headers on GET requests and avoid executing the
3320 module when appropriate.
3321
3322 === Languages updated in 1.26 ===
3323
3324 MediaWiki supports over 350 languages. Many localisations are updated
3325 regularly. Below only new and removed languages are listed, as well as
3326 changes to languages because of Phabricator reports.
3327
3328 * Languages added:
3329 ** ase (American sign language), thanks to translator Icemandeaf
3330 ** dty (डोटेली/Doteli), thanks to translators जनक राज भट्ट, बिप्लब आनन्द,
3331 मेश सिंह बोहरा, and राम प्रसाद जोशी
3332 ** luz (لئری دوٙمینی / Southern Luri)
3333 ** olo (Livvinкarjala / Livvi-Karelian), thanks to translators Denö, Hiloin Natoi,
3334 Ilja.mos, and Mashoi7
3335
3336 === Other changes in 1.26 ===
3337 * ChangeTags::tagDescription() will return false if the interface message
3338 for the tag is disabled.
3339 * Added PageHistoryPager::doBatchLookups hook.
3340 * Added $wikiId parameter to FormatAutocomments hook.
3341 * Added ParserCacheSaveComplete to ParserCache
3342 * supportsDirectEditing and supportsDirectApiEditing methods added to
3343 ContentHandler, to provide a way for ApiEditPage and EditPage to check
3344 if direct editing of content is allowed. These methods return false,
3345 by default for the ContentHandler base class and true for TextContentHandler
3346 and it's derivative classes (everything in core). For Content types that
3347 do not support direct editing, an alternative mechanism should be provided
3348 for editing, such as action overrides or specific api modules.
3349 * mediaWiki.confirmCloseWindow now returns an object of functions, instead of
3350 one function. The callback can't be called directly any more. The callback
3351 function is replaced with confirmCloseWindow.release().
3352 * BREAKING CHANGE: Added an optional ResouceLoaderContext parameter to
3353 ResourceLoaderModule::getDependencies(). Extension classes that override that
3354 method should be updated. If they aren't updated, PHP Strict standards
3355 warnings will appear when E_STRICT error reporting is enabled. Note: in the
3356 near future, this parameter will probably become non-optional.
3357 * Removed maintenance script deleteImageMemcached.php.
3358 * MWFunction::newObj() was removed (deprecated in 1.25).
3359 ObjectFactory::getObjectFromSpec() should be used instead.
3360 * The parser will no longer randomize the string it uses to mark the place of
3361 items that were stripped during parsing. It will use a fixed string instead.
3362 This causes the parser to re-use the regular expressions it uses to search
3363 and replace markers rather than generate novel expressions on each parse.
3364 Re-using regular expressions will improve performance on HHVM and the
3365 forthcoming PHP 7. The interfaces changes accompanying this change are:
3366 - Parser::getRandomString() and Parser::uniqPrefix() have been deprecated.
3367 - The $uniq_prefix argument for Parser::extractTagsAndParams() and the
3368 $prefix argument for StripState::_construct() are deprecated and their
3369 value is ignored.
3370 * wfSuppressWarnings() and wfRestoreWarnings() were split into a separate library,
3371 mediawiki/at-ease, and are now deprecated. Callers should use
3372 MediaWiki\suppressWarnings() and MediaWiki\restoreWarnings() directly.
3373 * The Block class constructor now takes an associative array of parameters
3374 instead of many optional positional arguments. Calling the constructor the old
3375 way will issue a deprecation warning.
3376 * The jquery.mwExtension module was deprecated.
3377 * $wgSpecialPageGroups was removed (deprecated in 1.21).
3378 * SpecialPageFactory::setGroup was removed (deprecated in 1.21).
3379 * SpecialPageFactory::getGroup was removed (deprecated in 1.21).
3380 * DatabaseBase::ignoreErrors() is now protected.
3381 * BREAKING CHANGE: mediawiki.legacy.ajax has been removed, following
3382 a lengthy deprecation period.
3383 * The ScopedPHPTimeout class was removed.
3384 * Removed maintenance script fixSlaveDesync.php.
3385 * Watchlist tokens, SpecialResetTokens, and User::getTokenFromOption()
3386 are deprecated. Applications using those can work via the OAuth
3387 extension instead. New tokens types should not be added.
3388 * DatabaseBase::errorCount() was removed (unused).
3389 * $wgDeferredUpdateList was removed.
3390 * DeferredUpdates::addHTMLCacheUpdate() was removed.
3391
3392 = MediaWiki 1.25 =
3393
3394 == MediaWiki 1.25.6 ==
3395
3396 This is a maintenance release of the MediaWiki 1.25 branch.
3397
3398 === Changes since 1.25.5 ===
3399 * (T123166) Fix fatal error when importing pages to titles which cannot be
3400 created, such as invalid titles or titles the user is not allowed to edit.
3401 * (T122056) Old tokens are remaining valid within a new session
3402 * (T127114) Login throttle can be tricked using non-canonicalized usernames
3403 * (T123653) Cross-domain policy regexp is too narrow
3404 * (T123071) Incorrectly identifying http link in a's href attributes, due to
3405 m modifier in regex
3406 * (T129506) MediaWiki:Gadget-popups.js isn't renderable
3407 * (T125283) Users occasionally logged in as different users after
3408 SessionManager deployment
3409 * (T103239) Patrol allows click catching and patrolling of any page
3410 * (T122807) [tracking] Check php crypto primatives
3411 * (T98313) Graphs can leak tokens, leading to CSRF
3412 * (T130947) Diff generation should use PoolCounter
3413 * (T133507) Careless use of $wgExternalLinkTarget is insecure
3414 * (T132874) API action=move is not rate limited
3415 * (T110143) strip markers can be used to get around html attribute escaping in
3416 (many?) parser tags
3417 * (T116030) Increase pbkdf2 parameter strengths
3418 * (T127420) Pbkdf2Password does not check if hash_pbkdf2() succeeded
3419 * (T126685) Globally throttle password attempts
3420
3421 == MediaWiki 1.25.5 ==
3422
3423 This is a maintenance release of the MediaWiki 1.25 branch.
3424
3425 === Changes since 1.25.4 ===
3426 * (T121892) Fix fatal error on some Special pages, introduced in 1.25.4.
3427
3428 == MediaWiki 1.25.4 ==
3429
3430 This is a security and maintenance release of the MediaWiki 1.25 branch.
3431
3432 === Changes since 1.25.3 ===
3433 * (T117899) SECURITY: $wgArticlePath can no longer be set to relative paths
3434 that do not begin with a slash. This enabled trivial XSS attacks.
3435 Configuration values such as "http://my.wiki.com/wiki/$1" are fine, as are
3436 "/wiki/$1". A value such as "$1" or "wiki/$1" is not and will now throw an
3437 error.
3438 * (T119309) SECURITY: Use hash_compare() for edit token comparison
3439 * (T118032) SECURITY: Don't allow cURL to interpret POST parameters starting
3440 with '@' as file uploads
3441 * (T115522) SECURITY: Passwords generated by User::randomPassword() can no
3442 longer be shorter than $wgMinimalPasswordLength
3443 * (T97897) SECURITY: Improve IP parsing and trimming. Previous behavior could
3444 result in improper blocks being issued
3445 * (T109724) SECURITY: Special:MyPage, Special:MyTalk, Special:MyContributions
3446 and related pages no longer use HTTP redirects and are now redirected by
3447 MediaWiki
3448 * (T103237) $wgUseGzip had no effect when using file cache.
3449 * (T114606) mw.notify was not correctly fixed to the page if
3450 initialized while not at the top of the page.
3451 * Fix issue that breaks HHVM Repo Authorative mode.
3452
3453 == MediaWiki 1.25.3 ==
3454
3455 This is a security and maintenance release of the MediaWiki 1.25 branch.
3456
3457 === Changes since 1.25.2 ===
3458
3459 * (T98975) Fix having multiple callbacks for a single hook.
3460 * (T107632) maintenance/refreshLinks.php did not always remove all links
3461 pointing to nonexistent pages.
3462 * (T104142) $wgEmergencyContact and $wgPasswordSender now use their default
3463 value if set to an empty string.
3464 * (T62174) Provide fallbacks for use of mb_convert_encoding() in
3465 HtmlFormatter. It was causing an error when accessing the api help page
3466 if the mbstring PHP extension was not installed.
3467 * (T105896) Confirmation emails would sometimes contain invalid codes.
3468 * (T105597) Fixed edit stash inclusion queries.
3469 * (T91850) SECURITY: Add throttle check in ApiUpload and SpecialUpload
3470 * (T91203, T91205) SECURITY: API: Improve validation in chunked uploading
3471 * (T95589) SECURITY: RevDel: Check all revisions for suppression, not just the
3472 first
3473 * (T108616) SECURITY: Avoid exposure of local path in PNG thumbnails
3474
3475 == MediaWiki 1.25.2 ==
3476
3477 This is a security and maintenance release of the MediaWiki 1.25 branch.
3478
3479 === Changes since 1.25.1 ===
3480
3481 * (T94116) SECURITY: Compare API watchlist token in constant time
3482 * (T97391) SECURITY: Escape error message strings in thumb.php
3483 * (T106893) SECURITY: Don't leak autoblocked IP addresses on
3484 Special:DeletedContributions
3485 * (T102562) Fix InstantCommons parameters to handle the new HTTPS-only
3486 policy of Wikimedia Commons.
3487 * (T100767) Setting a configuration setting for skin or extension to
3488 false in LocalSettings.php was not working.
3489 * (T100635) API action=opensearch json output no longer breaks when
3490 $wgDebugToolbar is enabled.
3491 * (T102522) Using an extension.json or skin.json file which has
3492 a "manifest_version" property for 1.26 compatability will no longer
3493 trigger warnings.
3494 * (T86156) Running updateSearchIndex.php will not throw an error as
3495 page_restrictions has been added to the locked table list.
3496 * Special:Version would throw notices if using SVN due to an incorrectly
3497 named variable. Add an additional check that an index is defined.
3498
3499 == MediaWiki 1.25.1 ==
3500
3501 This is a bug fix release of the MediaWiki 1.25 branch.
3502
3503 === Changes since 1.25 ===
3504 * (T100351) Fix syntax errors in extension.json of ConfirmEdit extension
3505
3506 == MediaWiki 1.25.0 ==
3507
3508 === Configuration changes in 1.25 ===
3509 * $wgPageShowWatchingUsers was removed.
3510 * $wgLocalVirtualHosts has been added to replace $wgConf->localVHosts.
3511 * $wgAntiLockFlags was removed.
3512 * $wgJavaScriptTestConfig was removed.
3513 * Edit tokens returned from User::getEditToken may change on every call. Token
3514 validity must be checked by passing the user-supplied token to
3515 User::matchEditToken rather than by testing for equality with a
3516 newly-generated token.
3517 * (T74951) The UserGetLanguageObject hook may be passed any IContextSource
3518 for its $context parameter. Formerly it was documented as receiving a
3519 RequestContext specifically.
3520 * Profiling was restructured and $wgProfiler now requires an 'output' parameter.
3521 See StartProfiler.sample for details.
3522 * $wgMangleFlashPolicy was added to make MediaWiki's mangling of anything that
3523 might be a flash policy directive configurable.
3524 * ApiOpenSearch now supports XML output. The OpenSearchXml extension should no
3525 longer be used. If extracts and page images are desired, the TextExtracts and
3526 PageImages extensions are required.
3527 * $wgOpenSearchTemplate is deprecated in favor of $wgOpenSearchTemplates.
3528 * Edits are now prepared via AJAX as users type edit summaries. This behavior
3529 can be disabled via $wgAjaxEditStash.
3530 * (T46740) The temporary option $wgIncludejQueryMigrate was removed, along
3531 with the jQuery Migrate library, as indicated when this option was provided in
3532 MediaWiki 1.24.
3533 * ProfilerStandard and ProfilerSimpleTrace were removed. Make sure that any
3534 StartProfiler.php config is updated to reflect this. Xhprof is available
3535 for zend/hhvm. Also, for hhvm, one can consider using its xenon profiler.
3536 * Default value of $wgSVGConverters['rsvg'] now uses the 'rsvg-convert' binary
3537 rather than 'rsvg'.
3538 * Default value of $wgSVGConverters['ImageMagick'] now uses transparent
3539 background with white fallback color, rather than just white background.
3540 * MediaWikiBagOStuff class removed, make sure any object cache config
3541 uses SqlBagOStuff instead.
3542 * The 'daemonized' flag must be set to true in $wgJobTypeConf for any redis
3543 job queues. This means that mediawiki/services/jobrunner service has to
3544 be installed and running for any such queues to work.
3545 * $wgAutopromoteOnce no longer supports the 'view' event. For keeping some
3546 compatibility, any 'view' event triggers will still trigger on 'edit'.
3547 * $wgExtensionDirectory was added for when your extensions directory is somewhere
3548 other than $IP/extensions (as $wgStyleDirectory does with the skins directory).
3549
3550 === New features in 1.25 ===
3551 * (T64861) Updated plural rules to CLDR 26. Includes incompatible changes
3552 for plural forms in Russian, Prussian, Tagalog, Manx and several languages
3553 that fall back to Russian.
3554 * (T60139) ResourceLoaderFileModule now supports language fallback
3555 for 'languageScripts'.
3556 * Added a new hook, "ContentAlterParserOutput", to allow extensions to modify the
3557 parser output for a content object before links update.
3558 * (T37785) Enhanced recent changes and extended watchlist are now default.
3559 Documentation: https://meta.wikimedia.org/wiki/Special:MyLanguage/Help:Enhanced_recent_changes
3560 and https://www.mediawiki.org/wiki/Special:MyLanguage/Manual:$wgDefaultUserOptions.
3561 * (T69341) SVG images will no longer be base64-encoded when being embedded
3562 in CSS. This results in slight size increase before gzip compression (due to
3563 percent-encoding), but up to 20% decrease after it.
3564 * Update jStorage to v0.4.12.
3565 * MediaWiki now natively supports page status indicators: icons (or short text
3566 snippets) usually displayed in the top-right corner of the page. They have
3567 been in use on Wikipedia for a long time, implemented using templates and CSS
3568 absolute positioning.
3569 - Basic wikitext syntax: <indicator name="foo">[[File:Foo.svg|20px]]</indicator>
3570 - Usage instructions: https://www.mediawiki.org/wiki/Help:Page_status_indicators
3571 - Adjusting custom skins to support indicators:
3572 https://www.mediawiki.org/wiki/Special:MyLanguage/Manual:Skinning#Page_status_indicators
3573 * Edit tokens may now be time-limited: passing a maximum age to
3574 User::matchEditToken will reject any older tokens.
3575 * The debug logging internals have been overhauled, and are now using the
3576 PSR-3 interfaces.
3577 * Update CSSJanus to v1.1.1.
3578 * Update lessphp to v0.5.0.
3579 * Added a hook, "ApiOpenSearchSuggest", to allow extensions to provide extracts
3580 and images for ApiOpenSearch output. The semantics are identical to the
3581 "OpenSearchXml" hook provided by the OpenSearchXml extension.
3582 * PrefixSearchBackend hook now has an $offset parameter. Combined with $limit,
3583 this allows for pagination of prefix results. Extensions using this hook
3584 should implement supporting behavior. Not doing so can result in undefined
3585 behavior from API clients trying to continue through prefix results.
3586 * Update jQuery from v1.11.1 to v1.11.3.
3587 * External libraries installed via composer will now be displayed
3588 on Special:Version in their own section. Extensions or skins that are
3589 installed via composer will not be shown in this section as it is assumed
3590 they will add the proper credits to the skins or extensions section. They
3591 can also be accessed through the API via the new siprop=libraries to
3592 ApiQuerySiteInfo.
3593 * Update QUnit from v1.14.0 to v1.16.0.
3594 * Update Moment.js from v2.8.3 to v2.8.4.
3595 * Special:Tags now allows for manipulating the list of user-modifiable change
3596 tags.
3597 * Added 'managetags' user right and 'ChangeTagCanCreate', 'ChangeTagCanDelete',
3598 and 'ChangeTagCanCreate' hooks to allow for managing user-modifiable change
3599 tags.
3600 * Added 'ChangeTagsListActive' hook, to separate the concepts of "defined" and
3601 "active" formerly conflated by the 'ListDefinedTags' hook.
3602 * Added TemplateParser class that provides a server-side interface to cachable
3603 dynamically-compiled Mustache templates (currently uses lightncandy library).
3604 * Clickable anchors for each section heading in the content are now generated
3605 and appear in the gutter on hovering over the heading.
3606 * Added 'CategoryViewer::doCategoryQuery' and 'CategoryViewer::generateLink' hooks
3607 to allow extensions to override how links to pages are rendered within NS_CATEGORY
3608 * (T19665) Special:WantedPages only lists page which having at least one red link
3609 pointing to it.
3610 * New hooks 'ApiMain::moduleManager' and 'ApiQuery::moduleManager', can be
3611 used for conditional registration of API modules.
3612 * New hook 'EnhancedChangesList::getLogText' to alter, remove or add to the
3613 links of a group of changes in EnhancedChangesList.
3614 * A full interface for StatsD metric reporting has been added to the context
3615 interface, reachable via IContextSource::getStats().
3616 * Move the jQuery Client library from being mastered in MediaWiki as v0.1.0 to a
3617 proper, published library, which is now tagged as v1.0.0.
3618 * A new message (defaulting to blank), 'editnotice-notext', can be shown to users
3619 when they are editing if no edit notices apply to the page being edited.
3620 * (T94536) You can now make the sitenotice appear to logged-in users only by
3621 editing MediaWiki:Anonnotice and replacing its content with "". Setting it to
3622 "-" (default) will continue disable it and fallback to MediaWiki:Sitenotice.
3623 * Modifying the tagging of a revision or log entry is now available via
3624 Special:EditTags, generally accessed via the revision-deletion-like interface
3625 on history pages and Special:Log is likely to be more useful.
3626 * Added 'applychangetags' and 'changetags' user rights.
3627 * (T35235) LogFormatter subclasses are now responsible for formatting the
3628 parameters for API log event output. Extensions should implement the new
3629 getParametersForApi() method in their log formatters.
3630
3631 ==== External libraries ====
3632 * MediaWiki now requires certain external libraries to be installed. In the past
3633 these were bundled inside the Git repository of MediaWiki core, but now they
3634 need to be installed separately. For users using the tarball, this will be taken
3635 care of and no action will be required. Users using Git will either need to use
3636 composer to fetch dependencies or use the mediawiki/vendor repository which includes
3637 all dependencies for MediaWiki core and ones used in Wikimedia deployment. Detailed
3638 instructions can be found at:
3639 https://www.mediawiki.org/wiki/Download_from_Git#Fetch_external_libraries
3640 * The following libraries are now required:
3641 ** psr/log
3642 This library provides the interfaces set by the PSR-3 standard (http://www.php-fig.org/psr/psr-3/)
3643 which are used by MediaWiki internally via the
3644 MediaWiki\Logger\LoggerFactory class.
3645 See the structured logging RfC (https://www.mediawiki.org/wiki/Special:MyLanguage/Requests_for_comment/Structured_logging)
3646 for more background information.
3647 ** cssjanus/cssjanus
3648 This library was formerly bundled with MediaWiki core and has been removed.
3649 It automatically flips CSS for RTL support.
3650 ** leafo/lessphp
3651 This library was formerly bundled with MediaWiki core and has been removed.
3652 It compiles LESS files into CSS.
3653 ** wikimedia/cdb
3654 This library was formerly a part of MediaWiki core, and has been moved into a separate library.
3655 It provides CDB functions which are used in the Interwiki and Localization caches.
3656 More information about the library can be found at https://www.mediawiki.org/wiki/Special:MyLanguage/CDB.
3657 ** liuggio/statsd-php-client
3658 This library provides a StatsD client API for logging application metrics to a remote server.
3659
3660 === Bug fixes in 1.25 ===
3661 * (T73003) No additional code will be generated to try to load CSS-embedded
3662 SVG images in Internet Explorer 6 and 7, as they don't support them anyway.
3663 * (T69021) On Special:BookSources, corrected validation of ISBNs (both
3664 10- and 13-digit forms) containing "X".
3665 * Page moving was refactored into a MovePage class. As part of that:
3666 ** The AbortMove hook was removed.
3667 ** MovePageIsValidMove is for extensions to specify whether a page
3668 cannot be moved for technical reasons, and should not be overridden.
3669 ** MovePageCheckPermissions is for checking whether the given user is
3670 allowed to make the move.
3671 ** Title::moveNoAuth() was deprecated. Use the MovePage class instead.
3672 ** Title::moveTo() was deprecated. Use the MovePage class instead.
3673 ** Title::isValidMoveOperation() broken down into MovePage::isValidMove()
3674 and MovePage::checkPermissions().
3675 * (T18530) Multiple autocomments are now formatted in an edit summary.
3676 * (T70361) Autocomments containing "/*" are parsed correctly.
3677 * The Special:WhatLinksHere page linked from 'Number of redirects to this page'
3678 on action=info about a file page does not list file links anymore.
3679 * (T78637) Search bar is not autofocused unless it is empty so that proper scrolling using arrow keys is possible.
3680 * (T50853) Database::makeList() modified to handle 'NULL' separately when building IN clause
3681 * (T85192) Captcha position modified in Usercreate template. As a result:
3682 ** extrafields parameter added to Usercreate.php to insert additional data
3683 ** 'extend' method added to QuickTemplate to append additional values to any field of data array
3684 * (T86974) Several Title methods now load from the database when necessary
3685 (instead of returning incorrect results) even when the page ID is known.
3686 * (T74070) Duplicate search for archived files on file upload now omits the extension.
3687 This requires the fa_sha1 field being populated.
3688 * Removed rel="archives" from the "View history" link, as it did not pass
3689 HTML validation.
3690 * $wgUseTidy is now set when parserTests are run with the tidy option to match
3691 output on wiki.
3692 * (T37472) update.php will purge ResourceLoader cache unless --nopurge is passed to it.
3693 * (T72109) mediawiki.language should respect $wgTranslateNumerals in convertNumber().
3694
3695 === Action API changes in 1.25 ===
3696 * (T67403) XML tag highlighting is now only performed for formats
3697 "xmlfm" and "wddxfm".
3698 * action=paraminfo supports generalized submodules (modules=query+value),
3699 querymodules and formatmodules are deprecated
3700 * action=paraminfo no longer outputs descriptions and other help text by
3701 default. If needed, it may be requested using the new 'helpformat' parameter.
3702 * action=help has been completely rewritten, and outputs help in HTML
3703 rather than plain text.
3704 * Hitting api.php without specifying an action now displays only the help for
3705 the main module, with links to submodule help.
3706 * API help is no longer displayed on errors.
3707 * 'uselang' is now a recognized API parameter; "uselang=user" may be used to
3708 explicitly select the language from the current user's preferences, and
3709 "uselang=content" may be used to select the wiki's content language.
3710 * Default output format for the API is now jsonfm.
3711 * Simplified continuation will return a "batchcomplete" property in the result
3712 when a batch of pages is complete.
3713 * Pretty-printed HTML output now has nicer formatting and (if available)
3714 better syntax highlighting.
3715 * Deprecated list=deletedrevs in favor of newly-added prop=deletedrevisions and
3716 list=alldeletedrevisions.
3717 * prop=revisions will gracefully continue when given too many revids or titles,
3718 rather than just ignoring the extras.
3719 * prop=revisions will no longer die if rvcontentformat doesn't match a
3720 revision's content model; it will instead warn and omit the content.
3721 * If the user has the 'deletedhistory' right, action=query's revids parameter
3722 will now recognize deleted revids.
3723 * prop=revisions may be used as a generator, generating revids.
3724 * (T68776) format=json results will no longer be corrupted when
3725 $wgMangleFlashPolicy is in effect. format=php results will cleanly return an
3726 error instead of returning invalid serialized data.
3727 * Generators may now return data for the generated pages when used with
3728 action=query.
3729 * Query page data for generator=search and generator=prefixsearch will now
3730 include an "index" field, which may be used by the client for sorting the
3731 search results.
3732 * ApiOpenSearch now supports XML output.
3733 * ApiOpenSearch will now output descriptions and URLs as array indexes 2 and 3
3734 in JSON format.
3735 * (T76051) list=tags will now continue correctly.
3736 * (T76052) list=tags can now indicate whether a tag is defined.
3737 * (T75522) list=prefixsearch now supports continuation
3738 * (T78737) action=expandtemplates can now return page properties.
3739 * (T78690) list=allimages now accepts multiple pipe-separated values
3740 for the 'aimime' parameter.
3741 * prop=info with inprop=protections will now return applicable protection types
3742 with the 'restrictiontypes' key.
3743 * (T85417) When resolving redirects, ApiPageSet will now add the targets of
3744 interwiki redirects to the list of interwiki titles.
3745 * (T85417) When outputting the list of redirect titles, a 'tointerwiki'
3746 property (like the existing 'tofragment' property) will be set.
3747 * Added action=managetags to allow for managing the list of
3748 user-modifiable change tags. Actually modifying the tagging of a revision or
3749 log entry is not implemented yet.
3750 * list=tags has additional properties to indicate 'active' status and tag
3751 sources.
3752 * siprop=libraries was added to ApiQuerySiteInfo to list installed external libraries.
3753 * (T88010) Added action=checktoken, to test a CSRF token's validity.
3754 * (T88010) Added intestactions to prop=info, to allow querying of
3755 Title::userCan() via the API.
3756 * Default type param for query list=watchlist and list=recentchanges has
3757 been changed from all types (e.g. including 'external') to 'edit|new|log'.
3758 * Added formatversion to format=json. Still "experimental" as further changes
3759 to the output formatting might still be made.
3760 * (T73020) Log event details are now always under a 'params' subkey for
3761 list=logevents, and a 'logparams' subkey for list=watchlist and
3762 list=recentchanges.
3763 * Log event details are changing formatting:
3764 * block events now report flags as an array rather than as a comma-separated
3765 list.
3766 * patrol events now report the 'auto' flag as a boolean (absent/empty string
3767 for BC formats) rather than as an integer.
3768 * rights events now report the old and new group lists as arrays rather than
3769 as comma-separated lists.
3770 * merge events use new-style formatting.
3771 * delete/event and delete/revision events use new-style formatting.
3772 * The root node and various other nodes will now always be an object in formats
3773 such as json that distinguish between arrays and objects.
3774 * Except for action=opensearch where the spec requires an array.
3775
3776 === Action API internal changes in 1.25 ===
3777 * ApiHelp has been rewritten to support i18n and paginated HTML output.
3778 Most existing modules should continue working without changes, but should do
3779 the following:
3780 * Add an i18n message "apihelp-{$moduleName}-description" to replace getDescription().
3781 * Add i18n messages "apihelp-{$moduleName}-param-{$param}" for each parameter
3782 to replace getParamDescription(). If necessary, the settings array returned
3783 by getParams() can use the new ApiBase::PARAM_HELP_MSG key to override the
3784 message.
3785 * Implement getExamplesMessages() to replace getExamples().
3786 * Modules with submodules (like action=query) must have their submodules
3787 override ApiBase::getParent() to return the correct parent object.
3788 * The 'APIGetDescription' and 'APIGetParamDescription' hooks are deprecated,
3789 and will have no effect for modules using i18n messages. Use
3790 'APIGetDescriptionMessages' and 'APIGetParamDescriptionMessages' instead.
3791 * Api formatters will no longer be asked to display the help screen on errors.
3792 * ApiMain::getCredits() was removed. The credits are available in the
3793 'api-credits' i18n message.
3794 * ApiFormatBase has been changed to support i18n and syntax highlighting via
3795 extensions with the new 'ApiFormatHighlight' hook. Core syntax highlighting
3796 has been removed.
3797 * ApiFormatBase now always buffers. Output is done when
3798 ApiFormatBase::closePrinter is called.
3799 * Much of the logic in ApiQueryRevisions has been split into ApiQueryRevisionsBase.
3800 * The 'revids' parameter supplied by ApiPageSet will now count deleted
3801 revisions as "good" if the user has the 'deletedhistory' right. New methods
3802 ApiPageSet::getLiveRevisionIDs() and ApiPageSet::getDeletedRevisionIDs() are
3803 provided to access just the live or just the deleted revids.
3804 * Added ApiPageSet::setGeneratorData() and ApiPageSet::populateGeneratorData()
3805 to allow generators to include data in the action=query result.
3806 * New hooks 'ApiMain::moduleManager' and 'ApiQuery::moduleManager', can be
3807 used for conditional registration of API modules.
3808 * Added ApiBase::lacksSameOriginSecurity() to allow modules to easily check if
3809 the current request was sent with the 'callback' parameter (or any future
3810 method that breaks the same-origin policy).
3811 * Profiling methods in ApiBase are deprecated and no longer need to be called.
3812 * ApiResult was greatly overhauled. See inline documentation for details.
3813 * ApiResult will automatically convert objects to strings or arrays (depending
3814 on whether a __toString() method exists on the object), and will refuse to
3815 add unsupported value types.
3816 * An informal interface, ApiSerializable, exists to override the default
3817 object conversion.
3818 * ApiResult/ApiFormatBase "raw mode" is deprecated.
3819 * ApiFormatXml now assumes defaults and so on instead of throwing errors when
3820 metadata isn't set.
3821 * (T35235) LogFormatter subclasses are now responsible for formatting log event
3822 parameters for the API.
3823 * Many modules have changed result data formats. While this shouldn't affect
3824 clients not using the experimental formatversion=2, code using
3825 ApiResult::getResultData() without the transformations for backwards
3826 compatibility may need updating, as will code that wasn't following the old
3827 conventions for API boolean output.
3828 * The following methods have been deprecated and may be removed in a future
3829 release:
3830 * ApiBase::getDescription
3831 * ApiBase::getParamDescription
3832 * ApiBase::getExamples
3833 * ApiBase::makeHelpMsg
3834 * ApiBase::makeHelpArrayToString
3835 * ApiBase::makeHelpMsgParameters
3836 * ApiBase::getModuleProfileName
3837 * ApiBase::profileIn
3838 * ApiBase::profileOut
3839 * ApiBase::safeProfileOut
3840 * ApiBase::getProfileTime
3841 * ApiBase::profileDBIn
3842 * ApiBase::profileDBOut
3843 * ApiBase::getProfileDBTime
3844 * ApiBase::getResultData
3845 * ApiFormatBase::setUnescapeAmps
3846 * ApiFormatBase::getWantsHelp
3847 * ApiFormatBase::setHelp
3848 * ApiFormatBase::formatHTML
3849 * ApiFormatBase::setBufferResult
3850 * ApiFormatBase::getDescription
3851 * ApiFormatBase::getNeedsRawData
3852 * ApiMain::setHelp
3853 * ApiMain::reallyMakeHelpMsg
3854 * ApiMain::makeHelpMsgHeader
3855 * ApiResult::setRawMode
3856 * ApiResult::getIsRawMode
3857 * ApiResult::getData
3858 * ApiResult::setElement
3859 * ApiResult::setContent
3860 * ApiResult::setIndexedTagName_recursive
3861 * ApiResult::setIndexedTagName_internal
3862 * ApiResult::setParsedLimit
3863 * ApiResult::beginContinuation
3864 * ApiResult::setContinueParam
3865 * ApiResult::setGeneratorContinueParam
3866 * ApiResult::endContinuation
3867 * ApiResult::size
3868 * ApiResult::convertStatusToArray
3869 * ApiQueryImageInfo::getPropertyDescriptions
3870 * ApiQueryLogEvents::addLogParams
3871 * The following classes have been deprecated and may be removed in a future
3872 release:
3873 * ApiQueryDeletedrevs
3874
3875 === Languages updated in 1.25 ===
3876
3877 MediaWiki supports over 350 languages. Many localisations are updated
3878 regularly. Below only new and removed languages are listed, as well as
3879 changes to languages because of Bugzilla reports.
3880
3881 * Languages added:
3882 ** awa (अवधी / Awadhi), thanks to translator 1AnuraagPandey;
3883 ** bgn (بلوچی رخشانی / Western Balochi), thanks to translators
3884 Baloch Afghanistan, Ibrahim khashrowdi and Rachitrali;
3885 ** ses (Koyraboro Senni), thanks to translator Songhay.
3886 * (T66440) Kazakh (kk) wikis should no longer forcefully reset the user's
3887 interface language to kk where unexpected.
3888 * The Chinese conversion table was substantially updated to fix a lot of
3889 bugs and ensure better reading experience for different variants.
3890
3891 === Other changes in 1.25 ===
3892 * (T45591) Links to MediaWiki.org translatable help were added to indicators,
3893 mostly in special pages. Local custom target titles can be placed in the
3894 relevant '(namespace-X|action name|special page name)-helppage' system
3895 message. Extensions can use the addHelpLink() function to do the same.
3896 * The skin autodiscovery mechanism, deprecated in MediaWiki 1.23, has been
3897 removed. See https://www.mediawiki.org/wiki/Manual:Skin_autodiscovery for
3898 migration guide for creators and users of custom skins that relied on it.
3899 * Javascript variables 'wgFileCanRotate' and 'wgFileExtensions' now only
3900 available on Special:Upload.
3901 * (T58257) Set site logo from mediawiki.skinning.interface module instead of
3902 inline styles in the HTML.
3903 * Removed ApiQueryUsers::getAutoGroups(). (deprecated since 1.20)
3904 * Removed XmlDumpWriter::schemaVersion(). (deprecated since 1.20)
3905 * Removed LogEventsList::getDisplayTitle(). (deprecated since 1.20)
3906 * Removed Preferences::trySetUserEmail(). (deprecated since 1.20)
3907 * Removed mw.user.name() and mw.user.anonymous() methods. (deprecated since 1.20)
3908 * Removed 'ok' and 'err' parameters in the mediawiki.api modules. (deprecated
3909 since 1.20)
3910 * Removed 'async' parameter from the mw.Api#getCategories() method. (deprecated
3911 since 1.20)
3912 * Removed 'jquery.json' module. (deprecated since 1.24)
3913 Use the 'json' module and global JSON object instead.
3914 * Deprecated OutputPage::readOnlyPage() and OutputPage::rateLimited().
3915 Also, the former will now throw an MWException if called with one or more
3916 arguments.
3917 * Removed hitcounters and associated code.
3918 * The "temp" zone of the upload respository is now considered private. If it
3919 already exists (such as under the images/ directory), please make sure that
3920 the directory is not web readable (e.g. via a .htaccess file).
3921 * BREAKING CHANGE: In the XML dump format used by Special:Export and
3922 dumpBackup.php, the <model> and <format> tags now apprear before the <text>
3923 tag, instead of after the <text> and <sha1> tags.
3924 The new schema version is 0.10, the new schema URI is:
3925 https://www.mediawiki.org/xml/export-0.10.xsd
3926 * MWFunction::call() and MWFunction::callArray() were removed, having being
3927 deprecated in 1.22.
3928 * Deprecated the getInternalLinkAttributes, getInternalLinkAttributesObj,
3929 and getInternalLinkAttributes methods in Linker, and removed
3930 getExternalLinkAttributes method, which was deprecated in MediaWiki 1.18.
3931 * Removed Sites class, which was deprecated in 1.21 and replaced by SiteSQLStore.
3932 * Added wgRelevantArticleId to the client-side config, for use on special pages.
3933 * Deprecated the TitleIsCssOrJsPage hook. Superseded by the
3934 ContentHandlerDefaultModelFor hook since MediaWiki 1.21.
3935 * Deprecated the TitleIsWikitextPage hook. Superseded by the
3936 ContentHandlerDefaultModelFor hook since MediaWiki 1.21.
3937 * Changed parsing of variables in schema (.sql) files:
3938 ** The substituted values are no longer parsed. (Formerly, several passes
3939 were made for each variable, so depending on the order in which variables
3940 were defined, variables might have been found inside encoded values. This
3941 is no longer the case.)
3942 ** Variables are no longer string encoded when the /*$var*/ syntax is used.
3943 If string encoding is necessary, use the '{$var}' syntax instead.
3944 ** Variable names must only consist of one or more of the characters
3945 "A-Za-z0-9_".
3946 ** In source text of the form '{$A}'{$B}' or `{$A}`{$B}`, where variable A
3947 does not exist yet variable B does, the latter may not be replaced.
3948 However, this difference is unlikely to arise in practice.
3949 * (T67278) RFC, PMID, and ISBN "magic links" must be surrounded by non-word
3950 characters on both sides.
3951 * The FormatAutocomments hook will now receive $pre and $post as booleans,
3952 rather than as strings that must be prepended or appended to $comment.
3953 * (T30950, T31025) RFC, PMID, and ISBN "magic links" can no longer contain
3954 newlines; but they can contain &nbsp; and other non-newline whitespace.
3955 * The 'mediawiki.action.edit' ResourceLoader module no longer generates the edit
3956 toolbar, which has been moved to a separate 'mediawiki.toolbar' module. If you
3957 relied on this behavior, update your scripts' dependencies.
3958 * HTMLForm's 'vform' display style has been separated to a subclass. Therefore:
3959 * HTMLForm::isVForm() is now deprecated.
3960 * You can no longer do this:
3961 $form = new HTMLForm( … );
3962 $form->setDisplayFormat( 'vform' ); // throws exception
3963 Instead, do this:
3964 $form = HTMLForm::factory( 'vform', … );
3965 * Deprecated Revision methods getRawUser(), getRawUserText() and getRawComment().
3966 * BREAKING CHANGE: mediawiki.user.generateRandomSessionId:
3967 The alphabet of the prior string returned was A-Za-z0-9 and now it is 0-9A-F
3968 * (T87504) Avoid serving SVG background-images in CSS for Opera 12, which
3969 renders them incorrectly when combined with border-radius or background-size.
3970 * Removed maintenance script dumpSisterSites.php.
3971 * DatabaseBase class constructors must be called using the array argument style.
3972 Ideally, DatabaseBase:factory() should be used instead in most cases.
3973 * Deprecated ParserOutput::addSecondaryDataUpdate and ParserOutput::getSecondaryDataUpdates.
3974 This is a hard deprecation, with getSecondaryDataUpdates returning an empty array and
3975 addSecondaryDataUpdate throwing an exception. These functions will be removed in 1.26,
3976 since they interfere with caching of ParserOutput objects.
3977 * Introduced new hook 'SecondaryDataUpdates' that allows extensions to inject custom updates.
3978 * Introduced new hook 'OpportunisticLinksUpdate' that allows extensions to perform
3979 updates when a page is re-rendered.
3980 * EditPage::attemptSave has been modified not to call handleStatus itself and
3981 instead just returns the Status object. Extension calling it should be aware of
3982 this.
3983 * Removed class DBObject. (unused since 1.10)
3984 * wfDiff() is deprecated.
3985 * The -m (maximum replication lag) option of refreshLinks.php was removed.
3986 It had no effect since MediaWiki 1.18 and should be removed from any cron
3987 jobs or similar scripts you may have set up.
3988 * (T85864) The following messages no longer support raw html: redirectto,
3989 thisisdeleted, viewdeleted, editlink, retrievedfrom, version-poweredby-others,
3990 retrievedfrom, thisisdeleted, viewsourcelink, lastmodifiedat, laggedslavemode,
3991 protect-summary-cascade
3992 * All BloomCache related code has been removed. This was largely experimental.
3993 * $wgResourceModuleSkinStyles no longer supports per-module local or remote paths. They
3994 can only be set for the entire skin.
3995 * Removed global function swap(). (deprecated since 1.24)
3996 * Deprecated the ".php5" file extension entry points and the $wgScriptExtension
3997 configuration variable. Refer to the ".php" files instead. If you want
3998 ".php5" URLs to continue to work, set up redirects. In Apache, this can be
3999 done by enabling mod_rewrite and adding the following rules to your
4000 configuration:
4001
4002 RewriteEngine On
4003 RewriteBase /
4004 RewriteRule ^(.*)\.php5 $1.php [R=301,L]
4005
4006 * The global importScriptURI and importStylesheetURI functions, as well as the
4007 loadedScripts object, from wikibits.js (deprecated since 1.17) now emit
4008 warnings through mw.log.warn when accessed.
4009
4010 = MediaWiki 1.24 =
4011
4012 == MediaWiki 1.24.6 ==
4013
4014 This is a maintenance release of the MediaWiki 1.24 branch.
4015
4016 === Changes since 1.24.5 ===
4017 * (T121892) Fix fatal error on some Special pages, introduced in 1.24.5.
4018
4019 == MediaWiki 1.24.5 ==
4020
4021 This is a security and maintenance release of the MediaWiki 1.23 branch.
4022
4023 === Changes since 1.24.4 ===
4024 * (T117899) SECURITY: $wgArticlePath can no longer be set to relative paths
4025 that do not begin with a slash. This enabled trivial XSS attacks.
4026 Configuration values such as "http://my.wiki.com/wiki/$1" are fine, as are
4027 "/wiki/$1". A value such as "$1" or "wiki/$1" is not and will now throw an
4028 error.
4029 * (T119309) SECURITY: Use hash_compare() for edit token comparison
4030 * (T118032) SECURITY: Don't allow cURL to interpret POST parameters starting
4031 with '@' as file uploads
4032 * (T115522) SECURITY: Passwords generated by User::randomPassword() can no
4033 longer be shorter than $wgMinimalPasswordLength
4034 * (T97897) SECURITY: Improve IP parsing and trimming. Previous behavior could
4035 result in improper blocks being issued
4036 * (T109724) SECURITY: Special:MyPage, Special:MyTalk, Special:MyContributions
4037 and related pages no longer use HTTP redirects and are now redirected by
4038 MediaWiki
4039 * (T103237) $wgUseGzip had no effect when using file cache.
4040
4041 == MediaWiki 1.24.4 ==
4042
4043 This is a security and maintenance release of the MediaWiki 1.24 branch.
4044
4045 === Changes since 1.24.3 ===
4046
4047 * (T91653) Minimal PSR-3 debug logger to support backports from 1.25+.
4048 * (T68650) Fix indexing of moved pages with PostgreSQL. Requires running
4049 update.php to fix.
4050 * (T91850) SECURITY: Add throttle check in ApiUpload and SpecialUpload
4051 * (T91203, T91205) SECURITY: API: Improve validation in chunked uploading
4052 * (T95589) SECURITY: RevDel: Check all revisions for suppression, not just the
4053 first
4054 * (T108616) SECURITY: Avoid exposure of local path in PNG thumbnails
4055
4056 == MediaWiki 1.24.3 ==
4057
4058 This is a security and maintenance release of the MediaWiki 1.24 branch.
4059
4060 === Changes since 1.24.2 ===
4061
4062 * (T94116) SECURITY: Compare API watchlist token in constant time
4063 * (T97391) SECURITY: Escape error message strings in thumb.php
4064 * (T106893) SECURITY: Don't leak autoblocked IP addresses on
4065 Special:DeletedContributions
4066 * Update jQuery from v1.11.2 to v1.11.3.
4067 * (T102562) Fix InstantCommons parameters to handle the new HTTPS-only
4068 policy of Wikimedia Commons.
4069
4070 == MediaWiki 1.24.2 ==
4071
4072 This is a security and maintenance release of the MediaWiki 1.24 branch.
4073
4074 === Changes since 1.24.1 ===
4075
4076 * (T85848, T71210) SECURITY: Don't parse XMP blocks that contain XML entities,
4077 to prevent various DoS attacks.
4078 * (T85848) SECURITY: Don't allow directly calling Xml::isWellFormed, to reduce
4079 likelihood of DoS.
4080 * (T88310) SECURITY: Always expand xml entities when checking SVG's.
4081 * (T73394) SECURITY: Escape > in Html::expandAttributes to prevent XSS.
4082 * (T85855) SECURITY: Don't execute another user's CSS or JS on preview.
4083 * (T64685) SECURITY: Allow setting maximal password length to prevent DoS when
4084 using PBKDF2.
4085 * (T85349, T85850, T86711) SECURITY: Multiple issues fixed in SVG filtering to
4086 prevent XSS and protect viewer's privacy.
4087 * Fix case of SpecialAllPages/SpecialAllMessages in SpecialPageFactory to fix
4088 loading these special pages when $wgAutoloadAttemptLowercase is false.
4089 * (bug T70087) Fix Special:ActiveUsers page for installations using
4090 PostgreSQL.
4091 * (bug T76254) Fix deleting of pages with PostgreSQL. Requires a schema change
4092 and running update.php to fix.
4093
4094 == MediaWiki 1.24.1 ==
4095
4096 This is a security and maintenance release of the MediaWiki 1.24 branch.
4097
4098 === Changes since 1.24.0 ===
4099
4100 * (bug T76686) [SECURITY] thumb.php outputs wikitext message as raw HTML, which
4101 could lead to xss. Permission to edit MediaWiki namespace is required to
4102 exploit this.
4103 * (bug T77028) [SECURITY] Malicious site can bypass CORS restrictions in
4104 $wgCrossSiteAJAXdomains in API calls if it only included an allowed domain as
4105 part of its name.
4106 * (bug T74222) The original patch for T74222 was reverted as unnecessary.
4107 * Fixed a couple of entries in RELEASE-NOTES-1.24.
4108 * (bug T76168) OutputPage: Add accessors for some protected properties.
4109 * (bug T74834) Make 1.24 branch directly installable under PostgreSQL.
4110
4111 == MediaWiki 1.24.0 ==
4112
4113 === Configuration changes in 1.24 ===
4114 * MediaWiki will no longer run if register_globals is enabled. It has been
4115 deprecated for 5 years now, and was removed in PHP 5.4. For more information
4116 about why, see <https://www.mediawiki.org/wiki/register_globals>.
4117 * MediaWiki now requires PHP's iconv extension. openSUSE users may need to
4118 install the php5-iconv package. Users of other systems may need to add
4119 extension=iconv.so to php.ini or recompile PHP without --without-iconv.
4120 * MediaWiki will no longer function if magic quotes are enabled. It has
4121 been deprecated for 5 years now, and was removed in PHP 5.4.
4122 * The server's canonical hostname is available as $wgServerName, which is
4123 exposed in both mw.config and ApiQuerySiteInfo.
4124 * Introduced $wgPagePropsHaveSortkey as a backwards-compatibility switch,
4125 for using the old schema of the page_props table, in case the respective
4126 schema update was not applied.
4127 * $wgSearchEverythingOnlyLoggedIn was removed as the 'searcheverything'
4128 user option was removed. Use $wgNamespacesToBeSearchedDefault instead or
4129 if you used to have $wgDefaultUserOptions['searcheverything'] = 1.
4130 * $wgMasterWaitTimeout has been deprecated.
4131 * $wgDBClusterTimeout has been removed.
4132 * $wgProxyKey has been removed. It is no longer used by MediaWiki core.
4133 Ensure $wgSecretKey is set in LocalSettings.php.
4134 * $wgExtraInterlanguageLinkPrefixes is a new configuration variable that
4135 contains an array of interwiki prefixes that should be treated as language
4136 prefixes (i.e. turned into interlanguage links when $wgInterwikiMagic is set
4137 to true).
4138 * $wgParserTestRemote has been removed.
4139 * $wgCountTotalSearchHits has been removed. If you're concerned about efficiency
4140 of search, you should use something like CirrusSearch instead of built in
4141 search.
4142 * Users in the 'sysop' group have access to Special:MergeHistory by default.
4143 * $wgFileStore was removed after having been deprecated in 1.17. Alternative
4144 configurations are $wgDeletedDirectory and $wgHashedUploadDirectory.
4145 * The deprecated $wgUseCommaCount variable has been removed.
4146 * $wgEnableSorbs and $wgSorbsUrl have been removed.
4147 * The UserCryptPassword and UserComparePassword hooks are no longer called.
4148 Any extensions using them must be updated to use the Password Hashing API.
4149 * $wgCompiledFiles has been removed.
4150 * $wgSortSpecialPages was removed, the listing on Special:SpecialPages is
4151 now always sorted.
4152 * $wgSpecialPages may now use callback functions as an alternative to plain class names.
4153 This allows more control over constructor parameters.
4154 * $wgHTCPMulticastAddress, $wgHTCPMulticastRouting and $wgHTCPPort were removed.
4155 * $wgRC2UDPAddress, $wgRC2UDPInterwikiPrefix, $wgRC2UDPOmitBots, $wgRC2UDPPort
4156 and $wgRC2UDPPrefix have been removed.
4157 * The default password type for MediaWiki has been changed from MD5 to PBKDF2.
4158 Password hashes will automatically be updated as users log in. If necessary, the
4159 old MD5 hashing can be restored by changing $wgPasswordDefault to 'B'. In addition,
4160 there is a maintenance script wrapOldPassword.php that can wrap all passwords in
4161 PBKDF2 (or the hashing algorithm of your choice) if you don't want to wait for your
4162 users to log in.
4163 * $wgImportSources can now either be a regular array, or an associative map
4164 specifying subprojects on the interwiki map of the target wiki, or a mix of
4165 the two. Existing configurations will still work.
4166 * Users must be able to edit through a page's protection to be able to delete it.
4167 * The default thumb size ($wgDefaultUserOptions['thumbsize']) is now 300px, up from
4168 180px. If you have altered the number of entries in $wgThumbLimits for your wiki, you
4169 may need to adjust your default user settings to compensate for the index change.
4170 * $wgDeferredUpdateList is now deprecated, you should use DeferredUpdates::addUpdate()
4171 instead.
4172 * $wgCanonicalLanguageLinks has been removed. Per Google recommendations, we
4173 will not send a rel=canonical pointing to a variant-neutral page, however
4174 we will send rel=alternate.
4175 * $wgResourceLoaderLESSFunctions has been deprecated and will be removed in the future.
4176 * $wgGoToEdit has been removed. Use the SpecialSearchNogomatch hook for similar
4177 functionality.
4178
4179 === New features in 1.24 ===
4180 * Added new hook WatchlistEditorBeforeFormRender, allowing subscribers to
4181 manipulate the list of pages and/or preload lots of data at once.
4182 * Added new argument &$link in hook WatchlistEditorBuildRemoveLine, allowing the
4183 link to the title to be changed.
4184 * Added a new hook, "WhatLinksHereProps", to allow extensions to annotate
4185 WhatLinksHere entries.
4186 * Added a new hook, "ContentGetParserOutput", to customize parser output for
4187 a given content object.
4188 * Deprecated the hook "ShowRawCssJs", use "ContentGetParserOutput" instead.
4189 * HTMLForm's HTMLTextField now supports the 'url' type.
4190 * HTMLForm fields may now be dynamically hidden based on the values of other
4191 fields in the form.
4192 * HTMLForm now supports multiple copies of an input field or set of input
4193 fields, e.g. the form may request "one or more usernames" without having to
4194 have the user enter delimited list of names into a text field.
4195 * Added a new hook, "SidebarBeforeOutput", to allow to edit the structure of
4196 the sidebar just before its display.
4197 * (bug 49156) Added the mediawiki.cookie ResourceLoader module, which wraps
4198 jquery.cookie so that getting/setting a cookie is syntactically and
4199 functionally similar to using the WebRequest::getCookie() and
4200 WebResponse::setcookie() methods.
4201 * (bug 44740) jQuery upgraded from 1.8.3 to 1.11.1. A new configuration option,
4202 $wgIncludejQueryMigrate, also loads the jQuery Migrate hack to let extensions
4203 and gadgets use the long-deprecated functions that were removed in jQuery 1.9.
4204 This option is turned off by default, and will be removed in MediaWiki 1.25.
4205 * (bug 47076) jQuery UI upgraded from 1.8.24 to 1.9.2.
4206 * Changes to content typography (fonts, etc.). See
4207 https://www.mediawiki.org/wiki/Typography_refresh for further information.
4208 * WikitextContent will now render redirects with the expected "redirect"
4209 header, rather than as an ordered list. Code calling Article::viewRedirect
4210 can probably be changed to no longer special-case redirects.
4211 * Header font set to a serif font stack. See
4212 https://www.mediawiki.org/wiki/Typography_refresh for further information.
4213 * (bug 65567) Added a new hook, "BeforeHttpsRedirect", to allow cancellation of
4214 the HTTP to HTTPS redirect due to forceHTTPS cookie, userRequires, etc. This
4215 is only for page views, since this hook doesn't affect UserLogin, OAuth,
4216 CentralAuth, etc. ATTENTION: This hook is likely to be removed soon due to
4217 overall design of the system.
4218 * (bug 17367) It is now possible to add pages to your watchlist from
4219 Special:UnwatchedPages without reloading the special page.
4220 * New methods setVolatile and isVolatile are added to PPFrame, so that
4221 extensions such as Cite.php can mark that their output is volatile and
4222 shouldn't be cached.
4223 * (bug 52817) Advanced search options are now saved on the search page itself,
4224 rather than in a dedicated pane in the preferences panel.
4225 * (bug 44591) The dropdown actions menu (little triangle next to page tabs) in
4226 the Vector skin has gained a label that should make it more discoverable.
4227 * MWCryptHKDF added for fast, cryptographically secure random number generation
4228 that won't deplete openssl's entropy pool.
4229 * ResourceLoader: File modules can now provide a skip function that uses an
4230 inline feature test to bypass loading of the module.
4231 * (bug 20210) Special pages may now provide autocompletion of their subpage
4232 names in search suggestions. Right now the only useful implementation is in
4233 Special:Log, but more are to come.
4234 * Special:MostLinkedTemplates is no longer limited to transclusions from the
4235 Template namespace.
4236 * Skins can now use 'remoteSkinPath' when defining ResourceLoader modules.
4237 This works the same as 'remoteExtPath' but is relative to the skins/ folder
4238 instead of the extensions/ folder.
4239 * Added the json2.js polyfill for the ES5 JSON.stringify and JSON.parse methods.
4240 Exposed as module "json" with a skip function to optimise loading.
4241 * Extensions and skins may now use 'namemsg' in $wgExtensionCredits in addition
4242 to 'name', to allow for the name to be localizable. 'name' should still be
4243 specified for backwards-compatibility and to define the path Special:Version
4244 uses to find extension license information.
4245 * Browser tests are now included to verify basic wiki functionality in developer
4246 environments. For details on running tests, see tests/browser/README.mediawiki.
4247 * Upgrade jStorage to v0.4.10.
4248 * {{!}} is now a magic word that produces the | character. This removes the need
4249 for Template:! for purposes such as passing pipes inside of parameters.
4250 * (bug 20790) The block log snippet on Special:Contributions and while
4251 editing user and user talk pages now works for IP range blocks.
4252 * (bug 9360) Added ability to change the page language for MediaWiki pages using
4253 Special:PageLanguage. All pages are set to wiki language by default.
4254 The feature needs to be enabled with $wgPageLanguageUseDB=true and
4255 permission needs to be set for 'pagelang'.
4256 * Upgrade Moment.js to v2.8.3.
4257 * (bug 67042) Added support for the HTML5 <rtc> tag for East Asian typography.
4258 * Upgrade Sinon.JS to 1.10.3.
4259 * Added the es5-shim polyfill for older or non-compliant javascript engines.
4260 * Upgrade jQuery Cookie to v1.3.1.
4261 * (bug 20476) Add a "viewsuppressed" user right to be able to view
4262 suppressed content but not suppress it ("suppressrevision" right).
4263 * (bug 66440) The MediaWiki web installer will now allow you to choose the skins
4264 to enable (from the ones included in download tarball) and decide which one
4265 should be the default.
4266 * (bug 68085, 68802) Links like [[localInterwikiPrefix:languageCode:pageTitle]],
4267 where localInterwikiPrefix is a member of the $wgLocalInterwikis array, will
4268 no longer be displayed in the sidebar when $wgInterwikiMagic is true. In a
4269 similar way, links like [[localInterwikiPrefix:File:Image.png]] and
4270 [[localInterwikiPrefix:Category:Hello]] will now render as regular links, and
4271 will not include the file or add the page to the category.
4272 * New special page, MyLanguage, to redirect users to subpages with localised
4273 versions of a page. (Integrated from Extension:Translate)
4274 * MediaWiki now supports multiple password types, including bcrypt and PBKDF2.
4275 The default type can be changed with $wgPasswordDefault and the type
4276 configurations can be changed with $wgPasswordConfig.
4277 * Skins can now define custom styles for default ResourceLoader modules using
4278 the $wgResourceModuleSkinStyles global. See the Vector skin for examples.
4279 * (bug 4488) There is now a preference to watch pages where the user has
4280 rollbacked an edit by default.
4281 * (bug 15484) Users will now be redirected to the login page when they need to
4282 log in, rather than being shown a page asking them to log in and having to click
4283 another link to actually get to the login page.
4284 * A JsonContent and JsonContentHandler were added for extensions to extend.
4285 * (bug 35045) Redirects to sections will now update the URL in browser's address
4286 bar using the HTML5 History API. When [[Dog]] redirects to [[Animals#Dog]],
4287 the user will now see "Animals#Dog" in their browser instead of "Dog#Dog".
4288 * API token handling has been rewritten. Any API module using tokens will need
4289 to be updated. See the entry below under "Action API internal changes".
4290 * Added HTMLAutoCompleteSelectField.
4291 * Added a new hook, "SkinPreloadExistence", to allow extensions to add titles to
4292 link existence cache before the page is rendered.
4293 * Config::set() was moved to its own interface, MutableConfig. GlobalVarConfig::set()
4294 is now deprecated, does not implement MutableConfig.
4295 * A MutableConfig named HashConfig was added, that stores an array of configuration
4296 settings.
4297 * (bug 69418) A MultiConfig implementation was added that supports fallback
4298 to multiple Config instances.
4299 * Update CSSJanus to v1.1.0.
4300 * Added FormatJson::parse() returning status with result or localized error message
4301 * Added DeletedContribsPager::reallyDoQuery hook allowing extensions to data to
4302 Special:DeletedContributions
4303 * Added DeletedContributionsLineEnding hook allowing extensions to format
4304 Special:DeletedContributions lines
4305 * (T69525) You can now make MediaWiki speed up its thumbnail rendering by using
4306 intermediary thumbnails. $wgThumbnailBuckets must be set to a list of target
4307 thumbnail widths; when a new thumbnail needs to be rendered, MediaWiki will
4308 find the smallest bucket smaller than the original but larger than the target
4309 width + $wgThumbnailMinimumBucketDistance, and it will scale that thumbnail,
4310 rather than the original, down to the target size at greater speed in return
4311 for minor loss of fidelity.
4312
4313 === Bug fixes in 1.24 ===
4314 * (bug 50572) MediaWiki:Blockip should support gender
4315 * (bug 49116) Footer copyright notice is now always displayed in user language
4316 rather than content language (same as copyright notice for editing interface).
4317 * (bug 62258) A bug was fixed in File::getUnscaledThumb when a height
4318 restriction was present in the parameters. Images with both the "frame"
4319 option and a size specification set will now always ignore the provided
4320 size and display an unscaled image, as the documentation has always
4321 claimed it would.
4322 * (bug 39035) Improved Vector skin performance by removing collapsibleNav,
4323 which used to collapse some sidebar elements by default.
4324 This removes -list id suffixes like p-lang-list: instead of using things like
4325 #p-lang-list, you can do #p-lang .body ul.
4326 * (bug 890) Links in Special:RecentChanges and Special:Watchlist no longer
4327 follow redirects to their target pages.
4328 * Parser now dies early if called recursively, instead of producing subtle bugs.
4329 * (bug 14323) Redirect pages, when viewed with redirect=no, no longer hide the
4330 remaining page content.
4331 * (bug 52587) Maintenance script deleteBatch.php no longer follows redirects
4332 in the file namespace and delete the file on the target page. It will still
4333 however delete the redirect page.
4334 * (bug 22683) {{msgnw:}} and other uses of PPFrame::RECOVER_ORIG will correctly
4335 recover the original code of extension tags.
4336 * (bug 65757) MSSQL: Update script drops unnamed constraints to be prepared
4337 for future updates. Because it's doing so heuristically, it may fail or drop
4338 wrong constraints.
4339 * (bug 67870) wfShellExec() cuts off stdout at multiples of 8192 bytes.
4340 * $wgRunJobsAsync now works with private wikis (e.g. read requires login).
4341 * (bugs 57238, 65206) Blank pages can now be directly created.
4342 * (bug 69789) Title::getContentModel() now loads from the database when
4343 necessary instead of incorrectly returning the default content model.
4344 * (bug 69249) wfBaseConvert() now works around PHP Bug #50175 when using GMP.
4345 * (bug 57909) URLs in the externallinks table will no longer have certain
4346 characters decoded in the query string.
4347 * (bug 67368) LESS mixins like .background-image() correctly flip image
4348 references for RTL stylesheets now.
4349
4350 === Action API changes in 1.24 ===
4351 * action=parse API now supports prop=modules, which provides the list of
4352 ResourceLoader modules that should be used to enhance the parsed content.
4353 * action=query&meta=siteinfo&siprop=interwikimap returns a new "protorel"
4354 field which is true if protocol-relative urls can be used to access
4355 a particular interwiki map entry.
4356 * list=logevents now provides logpage, which is the page ID from the
4357 logging table, if ids are requested and the user has the permissions.
4358 * action=edit now requires that appendtext, prependtext, or section=new be used
4359 when using the 'redirect' parameter, to prevent clients accidentally
4360 overwriting the target page with the content of the redirect.
4361 * list=logevents will now return an error if both letitle and leprefix are
4362 specified.
4363 * list=logevents has a new parameter, lenamespace, to allow filtering by
4364 namespace.
4365 * action=expandtemplates has a new parameter, prop, and a new output format.
4366 The old format is still used if prop isn't provided, but this is deprecated.
4367 * meta=userinfo can now return the count of unread pages on the watchlist.
4368 * list=watchlist can now filter by unread status.
4369 * The deprecated action=parse&prop=languageshtml has been removed.
4370 * (bug 48071) action=setnotificationtimestamp no longer throws PHP or database
4371 errors when no pages are given.
4372 * (bug 60734) Actions that use ApiPageSet (e.g. purge, watch,
4373 setnotificationtimestamp) will now include continuation information when
4374 using a generator.
4375 * Removed 'props' and 'errors' from action=paraminfo, as they have extremely
4376 limited use and are generally inaccurate, unmaintained, and impossible to
4377 properly maintain.
4378 * Formats dbg, dump, txt, wddx, and yaml are now deprecated.
4379 * action=paraminfo now indicates when a parameter is specifying a submodule.
4380 * The iwurl parameter to prop=iwlinks is deprecated in favor of iwprop=url, for
4381 parallelism with prop=langlinks.
4382 * All tokens should be fetched from action=query&meta=tokens; all other methods
4383 of fetching tokens are deprecated. The value needed for meta=tokens's 'type'
4384 parameter for each module is documented in the action=help output and is
4385 returned from action=paraminfo.
4386 * New action ClearHasMsg that can be used to clear HasMsg flag.
4387 * The cmstartsortkey and cmendsortkey parameters to list=categorymembers are
4388 deprecated in favor of cmstarthexsortkey and cmendhexsortkey.
4389 * (bug 63326) Add blockedtimestamp field to output of blockinfo property for
4390 the list=allusers and list=users modules.
4391 * prop=imageinfo no longer requires iiurlwidth to be set when using iiurlparam.
4392 * Added prop=linkshere, prop=fileusage, and prop=transcludedin, which are
4393 roughly equivalent to list=backlinks, list=imageusage, and list=embeddedin
4394 but can work on a list of titles (including titles from a generator).
4395 * prop=redirects can now filter returned redirects by namespace.
4396
4397 === Action API internal changes in 1.24 ===
4398 * Methods for handling continuation are added to ApiResult, so actions other
4399 than query that use generators can easily support continuation.
4400 * $wgAPIModules (and the related $wgAPIFormatModules, $wgAPIMetaModules,
4401 $wgAPIPropModules, and $wgAPIListModules settings) now allow API modules
4402 to be specified using a "module spec" array instead of a plain class name.
4403 A "module spec" is an associative array containing at least the 'class' key
4404 for the module's class, and optionally a 'factory' key for the factory function
4405 to use for the module. This is intended for extensions that want control over
4406 the instantiation of their API modules, to allow for proper dependency
4407 injection.
4408 * A new param type 'submodule' is available. Parameters of this type will take
4409 the list of valid values from the module's ApiModuleManager for the group
4410 corresponding to the parameter name.
4411 * The 'APIGetPossibleErrors' and 'APIGetResultProperties' hooks are no longer used.
4412 * API token handling has been rewritten. Any API module using tokens will need
4413 to be updated:
4414 * ApiBase::needsToken now returns a token type instead of boolean true when a
4415 token is needed. Returning true will throw an exception. See documentation
4416 of that method for details.
4417 * Information for the 'token' parameter is automatically set by ApiBase
4418 getFinalParams and getFinalParamDescription.
4419 * ApiBase::getTokenSalt has been removed.
4420 * The hooks APIQueryInfoTokens, APIQueryRevisionsTokens,
4421 APIQueryRecentChangesTokens, APIQueryUsersTokens, and
4422 ApiTokensGetTokenTypes are deprecated, but are still called to support
4423 backwards-compatible token access.
4424 * ApiBase::validateLimit and ApiBase::validateTimestamp are now protected.
4425 * ApiQueryRedirects was removed; prop=redirects is now implemented by
4426 ApiQueryBacklinksProp along with the newly-added prop modules.
4427 * The following methods have been deprecated and may be removed in a future
4428 release:
4429 * ApiBase::getResultProperties
4430 * ApiBase::getFinalResultProperties
4431 * ApiBase::addTokenProperties
4432 * ApiBase::getRequireOnlyOneParameterErrorMessages
4433 * ApiBase::getRequireMaxOneParameterErrorMessages
4434 * ApiBase::getRequireAtLeastOneParameterErrorMessages
4435 * ApiBase::getTitleOrPageIdErrorMessage
4436 * ApiBase::getPossibleErrors
4437 * ApiBase::getFinalPossibleErrors
4438 * ApiBase::parseErrors
4439 * ApiQuery::setGeneratorContinue
4440 * ApiQueryBase::checkRowCount
4441 * ApiQueryBase::titleToKey
4442 * ApiQueryBase::keyToTitle
4443 * ApiQueryBase::keyPartToTitle
4444 * ApiQueryInfo::getTokenFunctions
4445 * ApiQueryInfo::resetTokenCache
4446 * ApiQueryInfo::getEditToken
4447 * ApiQueryInfo::getDeleteToken
4448 * ApiQueryInfo::getProtectToken
4449 * ApiQueryInfo::getMoveToken
4450 * ApiQueryInfo::getBlockToken
4451 * ApiQueryInfo::getUnblockToken
4452 * ApiQueryInfo::getEmailToken
4453 * ApiQueryInfo::getImportToken
4454 * ApiQueryInfo::getWatchToken
4455 * ApiQueryInfo::getOptionsToken
4456 * ApiQueryRecentChanges::getTokenFunctions
4457 * ApiQueryRecentChanges::getPatrolToken
4458 * ApiQueryRevisions::getTokenFunctions
4459 * ApiQueryRevisions::getRollbackToken
4460 * ApiQueryUsers::getTokenFunctions
4461 * ApiQueryUsers::getUserrightsToken
4462 * The following classes have been deprecated and may be removed in a future
4463 release:
4464 * ApiFormatDbg
4465 * ApiFormatDump
4466 * ApiFormatTxt
4467 * ApiFormatWddx
4468 * ApiFormatYaml
4469 * ApiTokens
4470 * The following class constants have been deprecated and may be removed in a
4471 future release:
4472 * ApiBase::PROP_ROOT
4473 * ApiBase::PROP_LIST
4474 * ApiBase::PROP_TYPE
4475 * ApiBase::PROP_NULLABLE
4476
4477 === Languages updated in 1.24 ===
4478
4479 MediaWiki supports over 350 languages. Many localisations are updated
4480 regularly. Below only new and removed languages are listed, as well as
4481 changes to languages because of Bugzilla reports.
4482
4483 === Other changes in 1.24 ===
4484 * The deprecated jquery.delayedBind ResourceLoader module was removed.
4485 * The deprecated function mw.util.toggleToc was removed.
4486 * The Special:Search hooks SpecialSearchGo and SpecialSearchResultsAppend
4487 were removed as they were unused.
4488 * (bug 65477) User::pingLimiter() now has an additional profile point varying
4489 by action being used.
4490 * mediawiki.util.$content no longer supports old versions of the Vector,
4491 Monobook, Modern and CologneBlue skins that don't yet implement the "mw-body"
4492 and/or "mw-body-primary" class name in their html.
4493 * Added pp_sortkey column to page_props table, so pages can be efficiently
4494 queried and sorted by property value (bug 58032).
4495 See $wgPagePropsHaveSortkey if you want to postpone the schema change.
4496 * BREAKING CHANGE: All four built-in MediaWiki skins (Vector, MonoBook, Modern
4497 and Cologne Blue) were moved out of MediaWiki core to their own respective
4498 repositories. They will be installed with the release tarball, but you must
4499 install them separately if installing MediaWiki from source code. A warning
4500 message displayed until you do it should guide you through the process. See
4501 also <https://www.mediawiki.org/wiki/Manual:Skin_configuration>.
4502 * BREAKING CHANGE: Skins built for MediaWiki 1.15 and earlier that do not use
4503 the "headelement" template key are no longer supported. Setting
4504 $useHeadElement = false; is no longer supported and will not cause old keys
4505 like "headlinks", "skinnameclass", etc. to be defined.
4506 * BREAKING CHANGE: The files commonElements.css, commonContent.css and
4507 commonInterface.css (in skins/common/) have been removed. Skins may no longer
4508 rely on their presence and include them in their style modules. ResourceLoader
4509 modules introduced in MediaWiki 1.23 should be loaded instead:
4510 - skins/common/commonElements.css → 'mediawiki.skinning.elements' module
4511 - skins/common/commonContent.css → 'mediawiki.skinning.content' module
4512 - skins/common/commonInterface.css → 'mediawiki.skinning.interface' module
4513 * The deprecated 'SpecialVersionExtensionTypes' hook was removed.
4514 * (bug 63891) Add 'X-Robots-Tag: noindex' header in action=render pages.
4515 * SpecialPage no longer supports the syntax for invoking wfSpecial*() functions.
4516 Special pages should subclass SpecialPage and implement the execute() method.
4517 * (bug 63755) The deprecated constants RC_MOVE and RC_MOVE_OVER_REDIRECT were
4518 removed.
4519 * Special:MostLinkedTemplates has been renamed to Special:MostTranscludedPages.
4520 * The skin autodiscovery mechanism has been deprecated and will be removed in
4521 MediaWiki 1.25. See https://www.mediawiki.org/wiki/Manual:Skin_autodiscovery
4522 for migration guide for creators and users of custom skins that relied on it.
4523 * ResourceLoaderFileModule#getAllStyleFiles now returns all style files and all
4524 skin style files used by the module.
4525 * Removed getLang() from IContextSource and subclasses. (deprecated since 1.19)
4526 * Removed setLang() from subclasses of IContextSource. (deprecated since 1.19)
4527 * Removed WebRequest::escapeAppendQuery(). (deprecated since 1.20)
4528 * Removed info(), purge(), revert() and rollback() from the Article class; they
4529 have since become subclasses of the Action class. (deprecated since 1.19)
4530 * SearchEngineReplacePrefixesComplete hook was removed.
4531 * The "jquery.json" module has been deprecated. Use the "json" module instead.
4532 * Removed HTMLForm::addJS(). (deprecated since 1.18)
4533 * Removed LogEventsList::showHeader(). (deprecated since 1.19)
4534 * Removed ImageGalleryBase::useSkin(). (deprecated since 1.18)
4535 * Removed DatabaseMysqlBase::getLagFromProcesslist(). (deprecated since 1.19)
4536 * Removed LoadBalancer::closeConnecton(). (deprecated since 1.18)
4537 * Removed ApiBase::createContext(). (deprecated since 1.19)
4538 * BREAKING CHANGE: The undocumented Special{$this->getName()}BeforeFormDisplay
4539 set of hooks has been removed and replaced by a single new hook
4540 SpecialPageBeforeFormDisplay.
4541 * (bug 65781) Removed block warning on included {{Special:Contributions}}
4542 * Removed Skin::makeGlobalVariablesScript(). (deprecated since 1.19)
4543 * Removed MWNamespace::isMain(). (deprecated since 1.19)
4544 * Removed Preferences::loadOldSearchNs(). (deprecated since 1.19)
4545 * Removed OutputPage::getStatusMessage(). (deprecated since 1.18)
4546 * Removed OutputPage::isUserJsAllowed(). (deprecated since 1.18)
4547 * Removed Title::updateTitleProtection(). (deprecated since 1.19)
4548 * Removed ParserOptions::setSkin(). (deprecated since 1.19)
4549 * Removed Title::escapeCanonicalURL(). (deprecated since 1.19)
4550 * Removed Title::escapeLocalURL(). (deprecated since 1.19)
4551 * Removed Title::escapeFullURL(). (deprecated since 1.19)
4552 * Removed User::isValidEmailAddr(). (deprecated since 1.18)
4553 * Removed Title::getEscapedText(). (deprecated since 1.19)
4554 * Removed Language::getFallbackLanguageCode(). (deprecated since 1.19)
4555 * Removed WikiPage::isBigDeletion(). (deprecated since 1.19)
4556 * Removed MWInit class which contained functions related to a now discontinued
4557 PHP compiler called hphpc. (deprecated since 1.22)
4558 * ApiResult::enableSizeCheck() and disableSizeCheck() are now obsolete.
4559 * Removed ResourceLoaderGetStartupModules hook. (deprecated since 1.23)
4560 * Removed getFormFields(), onSubmit() and onSuccess() from FormlessAction, as
4561 these were meant specifically for FormAction instead.
4562 * Removed Action::execute().
4563 * Removed AjaxAddScript which has been obsolete since ResourceLoader and
4564 is unused by any modern extension.
4565 * Removed maintenance/nextJobDB.php; no longer in use.
4566 * Removed global function wfViewPrevNext(). (deprecated since 1.19)
4567 * Removed global function xmlsafe() from Export.php. (moved to OAIRepo extension)
4568 * Removed Title::userCanRead(). (deprecated since 1.19)
4569 * Removed maintenance script importTextFile.php. Use edit.php script instead.
4570 * A _from_namespace field has been added to the templatelinks, pagelinks,
4571 and filelinks tables. Run update.php to apply this change to the schema.
4572 * Removed File::sha1Base36(). (deprecated since 1.19)
4573 * Removed File::getPropsFromPath(). (deprecated since 1.19)
4574 * Removed functions blockedPage(), noCreatePermission(), readOnlyPage() and
4575 userNotLoggedInPage() from EditPage.php. (deprecated since 1.19)
4576 * Removed functions getContent(), getPreloadedText(), mergeChangesInto() and
4577 setPreloadedText() from EditPage.php. (deprecated since 1.21)
4578 * Removed global functions wfArrayLookup(), wfArrayMerge(), wfDebugDieBacktrace()
4579 and wfTime(). (deprecated since 1.22)
4580 * Browser support for Internet Explorer 6 and 7 lowered from Grade A to Grade C,
4581 meaning that JavaScript is no longer executed in these browser versions.
4582 * Browser support for Opera 11 lowered from Grade A to Grade C.
4583 * Removed IEFixes module which existed purely to provide support for MSIE versions
4584 below 7 (conditionally loaded only for those browsers).
4585 * Deprecated SpecialPageFactory::getList() in favor of
4586 SpecialPageFactory::getNames()
4587 * Action::checkCanExecute() no longer has a return value.
4588 * Removed cleanupForIRC(), loadFromCurRow(), newFromCurRow(), notifyRC2UDP()
4589 and sendToUDP() from RecentChange.php. (deprecated since 1.22)
4590 * Removed EnhancedChangesList::arrow(), sideArrow(), downArrow(), spacerArrow().
4591 * Removed Xml::namespaceSelector(). (deprecated since 1.19)
4592 * Removed WikiPage::estimateRevisionCount(). (deprecated since 1.19)
4593 * MYSQL: Enum item added to "major MIME type" columns.
4594 Running update.php on MySQL < v5.1 may result in heavy processing.
4595 * RSS and Atom feeds generated by MediaWiki no longer include a fallback
4596 stylesheet. It was ignored by most browsers these days anyway.
4597 * SpecialSearchNoResults hook has been removed. SpecialSearchResults is now
4598 called unconditionally.
4599 * TablePager::getBody() is now 'final' and can't be overridden in subclasses.
4600 * TablePager::getBody() is deprecated, use getBodyOutput() or getFullOutput().
4601 * Added $outputPage parameter to the SkinTemplateGetLanguageLink hook.
4602 * log_page for move log entries store the original page ID, rather than that
4603 of the new redirect page. This is not retroactive.
4604 * LCStoreAccel was removed. $wgLocalisationCacheConf can no longer be set to
4605 use this store class.
4606 * Html::infoBox() no longer accepts paths relative to skins/common/images/.
4607 * Deprecated defunct Skin::getCommonStylePath().
4608 * Some extensions had their ResourceLoader modules depend on the "mediawiki"
4609 and "jquery" modules. In the past, this behavior was undefined, now it will
4610 throw an error.
4611 * Removed BagOStuff::replace(). (deprecated since 1.23)
4612 * In Linker.php, link(), linkText() and makeBrokenImageLinkObj() now display
4613 warnings if their first parameter is not a Title object. Also makeImageLink()
4614 now requires a Parser as its first parameter.
4615 * (bug 67368) LESS functions embed() and embeddable(), added in MediaWiki 1.23
4616 and broken by design, have been removed. Use appropriate LESS mixins instead.
4617 * Removed cssjanus.py from maintenance directory as it was unused.
4618 * Removed maintenance/purgeOldText.inc and the PurgeRedundantText() function
4619 it contained (superseded by Maintenance::purgeRedundantText() in 1.16).
4620 The purgeOldText.php maintenance script has been retained.
4621 * PHPUnit tests can be found by directory discovery, by adding the directory
4622 path from your UnitTestsList callback. Older versions of MediaWiki core will
4623 barf at this usage.
4624
4625 ==== Renamed classes ====
4626 * CLDRPluralRuleConverter_Expression to CLDRPluralRuleConverterExpression
4627 * CLDRPluralRuleConverter_Fragment to CLDRPluralRuleConverterFragment
4628 * CLDRPluralRuleConverter_Operator to CLDRPluralRuleConverterOperator
4629 * CLDRPluralRuleEvaluator_Range to CLDRPluralRuleEvaluatorRange
4630 * CSSJanus_Tokenizer to CSSJanusTokenizer
4631 * MediaWiki_I18N to MediaWikiI18N
4632 * Parser_DiffTest to ParserDiffTest
4633 * RevDel_ArchiveItem to RevDelArchiveItem
4634 * RevDel_ArchiveList to RevDelArchiveList
4635 * RevDel_ArchivedFileItem to RevDelArchivedFileItem
4636 * RevDel_ArchivedFileList to RevDelArchivedFileList
4637 * RevDel_ArchivedRevisionItem to RevDelArchivedRevisionItem
4638 * RevDel_FileItem to RevDelFileItem
4639 * RevDel_FileList to RevDelFileList
4640 * RevDel_Item to RevDelItem
4641 * RevDel_List to RevDelList
4642 * RevDel_LogItem to RevDelLogItem
4643 * RevDel_LogList to RevDelLogList
4644 * RevDel_RevisionItem to RevDelRevisionItem
4645 * RevDel_RevisionList to RevDelRevisionList
4646 * WebInstaller_Complete to WebInstallerComplete
4647 * WebInstaller_Copying to WebInstallerCopying
4648 * WebInstaller_DBConnect to WebInstallerDBConnect
4649 * WebInstaller_DBSettings to WebInstallerDBSettings
4650 * WebInstaller_Document to WebInstallerDocument
4651 * WebInstaller_ExistingWiki to WebInstallerExistingWiki
4652 * WebInstaller_Install to WebInstallerInstall
4653 * WebInstaller_Language to WebInstallerLanguage
4654 * WebInstaller_Name to WebInstallerName
4655 * WebInstaller_Options to WebInstallerOptions
4656 * WebInstaller_Readme to WebInstallerReadme
4657 * WebInstaller_ReleaseNotes to WebInstallerReleaseNotes
4658 * WebInstaller_Restart to WebInstallerRestart
4659 * WebInstaller_Upgrade to WebInstallerUpgrade
4660 * WebInstaller_UpgradeDoc to WebInstallerUpgradeDoc
4661 * WebInstaller_Welcome to WebInstallerWelcome
4662
4663 ==== Removed classes ====
4664 * IPBlockForm - Use SpecialBlock directly
4665 * WatchlistEditor - Use SpecialEditWatchlist directly
4666 * FormatExif - Use FormatMetadata directly
4667 * RevertFileAction - Use RevertAction directly
4668 * HistoryPage - Use HistoryAction directly
4669 * RawPage - Use RawAction directly
4670 * StubContLang - Use Language::factory() instead
4671 * XMLReader2 - Use XMLReader directly
4672 * ResourceLoaderLESSFunctions - No longer in use, not intended for public usage
4673
4674 ==== Removed files ====
4675 The skins/common/ directory, previously containing some assets intended to be
4676 used by skins and a number of legacy styles and scripts, has been removed. Its
4677 contents have been deleted or relocated into the resources/ directory. Full list
4678 of files that are no longer available follows.
4679
4680 * skins/common/ajax.js
4681 * skins/common/commonContent.css
4682 * skins/common/commonElements.css
4683 * skins/common/commonInterface.css
4684 * skins/common/commonPrint.css
4685 * skins/common/config-cc.css
4686 * skins/common/config.css
4687 * skins/common/config.js
4688 * skins/common/feed.css
4689 * skins/common/IEFixes.js
4690 * skins/common/oldshared.css
4691 * skins/common/protect.js
4692 * skins/common/shared.css
4693 * skins/common/upload.js
4694 * skins/common/wikibits.js
4695 * skins/common/images/add.png
4696 * skins/common/images/ajax-loader.gif
4697 * skins/common/images/arrow_disabled_first_25.png
4698 * skins/common/images/arrow_disabled_last_25.png
4699 * skins/common/images/arrow_disabled_left_25.png
4700 * skins/common/images/arrow_disabled_right_25.png
4701 * skins/common/images/arrow_first_25.png
4702 * skins/common/images/arrow_last_25.png
4703 * skins/common/images/arrow_left_25.png
4704 * skins/common/images/arrow_right_25.png
4705 * skins/common/images/Arr_.png
4706 * skins/common/images/Arr_d.png
4707 * skins/common/images/Arr_l.png
4708 * skins/common/images/Arr_r.png
4709 * skins/common/images/Arr_u.png
4710 * skins/common/images/bullet.gif
4711 * skins/common/images/button_bold.png
4712 * skins/common/images/button_extlink.png
4713 * skins/common/images/button_headline.png
4714 * skins/common/images/button_hr.png
4715 * skins/common/images/button_image.png
4716 * skins/common/images/button_italic.png
4717 * skins/common/images/button_link.png
4718 * skins/common/images/button_media.png
4719 * skins/common/images/button_nowiki.png
4720 * skins/common/images/button_sig.png
4721 * skins/common/images/button_template.png
4722 * skins/common/images/cc-0.png
4723 * skins/common/images/cc-by-nc-sa.png
4724 * skins/common/images/cc-by-sa.png
4725 * skins/common/images/cc-by.png
4726 * skins/common/images/Checker-16x16.png
4727 * skins/common/images/closewindow.png
4728 * skins/common/images/closewindow19x19.png
4729 * skins/common/images/critical-32.png
4730 * skins/common/images/diffunderline.gif
4731 * skins/common/images/download-32.png
4732 * skins/common/images/feed-icon.png
4733 * skins/common/images/feed-icon.svg
4734 * skins/common/images/gnu-fdl.png
4735 * skins/common/images/help-question-hover.gif
4736 * skins/common/images/help-question.gif
4737 * skins/common/images/info-32.png
4738 * skins/common/images/link_icon.gif
4739 * skins/common/images/magnify-clip-rtl.png
4740 * skins/common/images/magnify-clip.png
4741 * skins/common/images/mediawiki.png
4742 * skins/common/images/nextredirectltr.png
4743 * skins/common/images/nextredirectrtl.png
4744 * skins/common/images/poweredby_mediawiki_88x31.png
4745 * skins/common/images/public-domain.png
4746 * skins/common/images/question-small.png
4747 * skins/common/images/question.svg
4748 * skins/common/images/redirectltr.png
4749 * skins/common/images/redirectrtl.png
4750 * skins/common/images/remove.png
4751 * skins/common/images/spinner.gif
4752 * skins/common/images/tick-32.png
4753 * skins/common/images/tipsy-arrow.gif
4754 * skins/common/images/tooltip_icon.png
4755 * skins/common/images/warning-32.png
4756 * skins/common/images/wiki.png
4757 * skins/common/images/Zoom_sans.gif
4758 * skins/common/images/ar/button_bold.png
4759 * skins/common/images/ar/button_headline.png
4760 * skins/common/images/ar/button_italic.png
4761 * skins/common/images/ar/button_link.png
4762 * skins/common/images/ar/button_nowiki.png
4763 * skins/common/images/be-tarask/button_bold.png
4764 * skins/common/images/be-tarask/button_italic.png
4765 * skins/common/images/be-tarask/button_link.png
4766 * skins/common/images/cyrl/button_bold.png
4767 * skins/common/images/cyrl/button_italic.png
4768 * skins/common/images/cyrl/button_link.png
4769 * skins/common/images/de/button_bold.png
4770 * skins/common/images/de/button_italic.png
4771 * skins/common/images/fa/button_bold.png
4772 * skins/common/images/fa/button_headline.png
4773 * skins/common/images/fa/button_italic.png
4774 * skins/common/images/fa/button_link.png
4775 * skins/common/images/fa/button_nowiki.png
4776 * skins/common/images/icons/fileicon-c.png
4777 * skins/common/images/icons/fileicon-cpp.png
4778 * skins/common/images/icons/fileicon-deb.png
4779 * skins/common/images/icons/fileicon-djvu.png
4780 * skins/common/images/icons/fileicon-djvu.xcf
4781 * skins/common/images/icons/fileicon-dvi.png
4782 * skins/common/images/icons/fileicon-exe.png
4783 * skins/common/images/icons/fileicon-h.png
4784 * skins/common/images/icons/fileicon-html.png
4785 * skins/common/images/icons/fileicon-iso.png
4786 * skins/common/images/icons/fileicon-java.png
4787 * skins/common/images/icons/fileicon-mid.png
4788 * skins/common/images/icons/fileicon-mov.png
4789 * skins/common/images/icons/fileicon-o.png
4790 * skins/common/images/icons/fileicon-ogg.png
4791 * skins/common/images/icons/fileicon-ogg.xcf
4792 * skins/common/images/icons/fileicon-pdf.png
4793 * skins/common/images/icons/fileicon-ps.png
4794 * skins/common/images/icons/fileicon-psd.png
4795 * skins/common/images/icons/fileicon-rm.png
4796 * skins/common/images/icons/fileicon-rpm.png
4797 * skins/common/images/icons/fileicon-svg.png
4798 * skins/common/images/icons/fileicon-tar.png
4799 * skins/common/images/icons/fileicon-tex.png
4800 * skins/common/images/icons/fileicon-ttf.png
4801 * skins/common/images/icons/fileicon-txt.png
4802 * skins/common/images/icons/fileicon.png
4803 * skins/common/images/ksh/button_S_italic.png
4804
4805 = MediaWiki 1.23 =
4806
4807 == MediaWiki 1.23.17 ==
4808
4809 === Changes since 1.23.16 === <!--T:69-->
4810 * Fix syntax errors introduced in 1.23.16 when running PHP 5.3.
4811
4812 == MediaWiki 1.23.16 ==
4813 This is a security and maintenance release of the MediaWiki 1.23 branch.
4814
4815 === Changes since 1.23.15 ===
4816 * (T68404) CSS3 attr() function with url type is no longer allowed
4817 in inline styles.
4818 * (T156184) $wgRawHtml will no longer apply to internationalization messages.
4819 * Submitting the lgtoken and lgpassword parameters in the query string to
4820 action=login is now deprecated and outputs a warning. They should be submitted
4821 in the POST body instead.
4822 * (T109140) (T122209) SECURITY: Special:UserLogin and Special:Search allow redirect
4823 to interwiki links.
4824 * (T144845) SECURITY: XSS in SearchHighlighter::highlightText() when
4825 $wgAdvancedSearchHighlighting is true.
4826 * (T125177) SECURITY: API parameters may now be marked as "sensitive" to keep
4827 their values out of the logs.
4828 * (T150044) SECURITY: "Mark all pages visited" on the watchlist now requires a CSRF
4829 token.
4830 * (T156184) SECURITY: Escape content model/format url parameter in message.
4831 * (T151735) SECURITY: SVG filter evasion using default attribute values in DTD
4832 declaration.
4833 * (T48143) SECURITY: Spam blacklist ineffective on encoded URLs inside file inclusion
4834 syntax's link parameter.
4835 * (T108138) SECURITY: Sysops can undelete pages, although the page is protected against
4836 it.
4837
4838 == MediaWiki 1.23.15 ==
4839
4840 This is a maintenance release of the MediaWiki 1.23 branch.
4841
4842 === Changes since 1.23.14 ===
4843 * BREAKING CHANGE: $wgHTTPProxy is now *required* for all external requests
4844 made by MediaWiki via a proxy. Relying on the http_proxy environment
4845 variable is no longer supported.
4846 * (T139565) SECURITY: API: Generate head items in the context of the given title
4847 * (T137264) SECURITY: XSS in unclosed internal links
4848 * (T133147) SECURITY: Escape '<' and ']]>' in inline <style> blocks
4849 * (T133147) SECURITY: Require login to preview user CSS pages
4850 * (T132926) SECURITY: Do not allow undeleting a revision deleted file if it is
4851 the top file
4852 * (T129738) SECURITY: Make $wgBlockDisablesLogin also restrict logged in
4853 permissions
4854 * (T129738) SECURITY: Make blocks log users out if $wgBlockDisablesLogin is true
4855 * (T115333) SECURITY: Check read permission when loading page content in ApiParse
4856 * Remove support for $wgWellFormedXml = false, all output is now well formed
4857
4858 == MediaWiki 1.23.13 ==
4859
4860 This is a maintenance release of the MediaWiki 1.23 branch.
4861
4862 === Changes since 1.23.12 ===
4863 * (T121892) Fix fatal errors on some Special pages, introduced in 1.23.12.
4864
4865 == MediaWiki 1.23.12 ==
4866
4867 This is a security and maintenance release of the MediaWiki 1.23 branch.
4868
4869 === Changes since 1.23.11 ===
4870 * (T117899) SECURITY: $wgArticlePath can no longer be set to relative paths
4871 that do not begin with a slash. This enabled trivial XSS attacks.
4872 Configuration values such as "http://my.wiki.com/wiki/$1" are fine, as are
4873 "/wiki/$1". A value such as "$1" or "wiki/$1" is not and will now throw an
4874 error.
4875 * (T119309) SECURITY: Use hash_compare() for edit token comparison
4876 * (T118032) SECURITY: Don't allow cURL to interpret POST parameters starting
4877 with '@' as file uploads
4878 * (T115522) SECURITY: Passwords generated by User::randomPassword() can no
4879 longer be shorter than $wgMinimalPasswordLength
4880 * (T97897) SECURITY: Improve IP parsing and trimming. Previous behavior could
4881 result in improper blocks being issued
4882 * (T109724) SECURITY: Special:MyPage, Special:MyTalk, Special:MyContributions
4883 and related pages no longer use HTTP redirects and are now redirected by
4884 MediaWiki
4885
4886 == MediaWiki 1.23.11 ==
4887
4888 This is a security and maintenance release of the MediaWiki 1.23 branch.
4889
4890 === Changes since 1.23.10 ===
4891
4892 * (T91850) SECURITY: Add throttle check in ApiUpload and SpecialUpload
4893 * (T91203, T91205) SECURITY: API: Improve validation in chunked uploading
4894 * (T108616) SECURITY: Avoid exposure of local path in PNG thumbnails
4895
4896 == MediaWiki 1.23.10 ==
4897
4898 This is a security and maintenance release of the MediaWiki 1.23 branch.
4899
4900 === Changes since 1.23.9 ===
4901
4902 * (T94116) SECURITY: Compare API watchlist token in constant time
4903 * (T97391) SECURITY: Escape error message strings in thumb.php
4904 * (T106893) SECURITY: Don't leak autoblocked IP addresses on
4905 Special:DeletedContributions
4906 * (bug 67644) Make AutoLoaderTest handle namespaces
4907 * (T91653) Minimal PSR-3 debug logger to support backports from 1.25+.
4908 * (T102562) Fix InstantCommons parameters to handle the new HTTPS-only
4909 policy of Wikimedia Commons.
4910
4911 == MediaWiki 1.23.9 ==
4912
4913 This is a security and maintenance release of the MediaWiki 1.23 branch.
4914
4915 === Changes since 1.23.8 ===
4916
4917 * (T85848, T71210) SECURITY: Don't parse XMP blocks that contain XML entities,
4918 to prevent various DoS attacks.
4919 * (T85848) SECURITY: Don't allow directly calling Xml::isWellFormed, to reduce
4920 likelihood of DoS.
4921 * (T88310) SECURITY: Always expand xml entities when checking SVG's.
4922 * (T73394) SECURITY: Escape > in Html::expandAttributes to prevent XSS.
4923 * (T85855) SECURITY: Don't execute another user's CSS or JS on preview.
4924 * (T85349, T85850, T86711) SECURITY: Multiple issues fixed in SVG filtering to
4925 prevent XSS and protect viewer's privacy.
4926 * (bug T68650) Fix indexing of moved pages with PostgreSQL. Requires running
4927 update.php to fix.
4928 * (bug T70087) Fix Special:ActiveUsers page for installations using
4929 PostgreSQL.
4930
4931 == MediaWiki 1.23.8 ==
4932
4933 This is a security and maintenance release of the MediaWiki 1.23 branch.
4934
4935 === Changes since 1.23.7 ===
4936
4937 * (bug T76686) [SECURITY] thumb.php outputs wikitext message as raw HTML, which
4938 could lead to xss. Permission to edit MediaWiki namespace is required to
4939 exploit this.
4940 * (bug T77028) [SECURITY] Malicious site can bypass CORS restrictions in
4941 $wgCrossSiteAJAXdomains in API calls if it only included an allowed domain as
4942 part of its name.
4943 * (bug T74222) The original patch for T74222 was reverted as unnecessary.
4944
4945 == MediaWiki 1.23.7 ==
4946
4947 This is a security and maintenance release of the MediaWiki 1.23 branch.
4948
4949 === Changes since 1.23.6 ===
4950
4951 * (bugs 66776, 71478) SECURITY: User PleaseStand reported a way to inject code
4952 into API clients that used format=php to process pages that underwent flash
4953 policy mangling. This was fixed along with improving how the mangling was done
4954 for format=json, and allowing sites to disable the mangling using
4955 $wgMangleFlashPolicy.
4956 * (bug 70901) SECURITY: User Jackmcbarn reported that the ability to update
4957 the content model for a page could allow an unprivileged attacker to edit
4958 another user's common.js under certain circumstances. The user right
4959 "editcontentmodel" was added, and is needed to change a revision's content
4960 model.
4961 * (bug 71111) SECURITY: User PleaseStand reported that on wikis that allow raw
4962 HTML, it is not safe to preview wikitext coming from an untrusted source such
4963 as a cross-site request. Thus add an edit token to the form, and when raw HTML
4964 is allowed, ensure the token is provided before showing the preview. This
4965 check is not performed on wikis that both allow raw HTML and anonymous
4966 editing, since there are easier ways to exploit that scenario.
4967 * (bug 72222) SECURITY: Do not show log action when the entry is revdeleted with
4968 DELETED_ACTION. NOTICE: this may be reverted in a future release pending a
4969 public RFC about the desired functionality. This issue was reported by user
4970 Bawolff.
4971 * (bug 71621) Make allowing site-wide styles on restricted special pages a
4972 config option.
4973 * (bug 42723) Added updated version history from 1.19.2 to 1.22.13
4974 * $wgMangleFlashPolicy was added to make MediaWiki's mangling of anything that
4975 might be a flash policy directive configurable.
4976
4977 == MediaWiki 1.23.6 ==
4978
4979 This is a maintenance release of the MediaWiki 1.23 branch.
4980
4981 === Changes since 1.23.5 ===
4982 * (Bug 72274) Job queue not running (HTTP 411) due to missing
4983 Content-Length: header
4984 * (Bug 67440) Allow classes to be registered properly from installer
4985
4986 == MediaWiki 1.23.5 ==
4987
4988 This is a security release of the MediaWiki 1.23 branch.
4989
4990 === Changes since 1.23.4 ===
4991 * (bug 70672) SECURITY: OutputPage: Remove separation of css and js module
4992 allowance.
4993
4994 == MediaWiki 1.23.4 ==
4995
4996 This is a security and maintenance release of the MediaWiki 1.23 branch.
4997
4998 === Changes since 1.23.3 ===
4999
5000 * (bug 69008) SECURITY: Enhance CSS filtering in SVG files. Filter <style>
5001 elements; normalize style elements and attributes before filtering; add
5002 checks for attributes that contain css; add unit tests for html5sec and
5003 reported bugs.
5004 * (bug 65998) Make MySQLi work with non-standard socket.
5005 * (bug 66986) GlobalVarConfig shouldn't throw exceptions for null-valued config
5006 settings.
5007
5008 == MediaWiki 1.23.3 ==
5009
5010 This is a maintenance release of the MediaWiki 1.23 branch.
5011
5012 === Changes since 1.23.2 ===
5013
5014 * (bug 68501) Correctly handle incorrect namespace in cleanupTitles.php.
5015 * (bug 64970) Fix support for blobs on DatabaseOracle::update.
5016 * (bug 66574) Display MediaWiki:Loginprompt on the login page.
5017 * (bug 67870) wfShellExec() cuts off stdout at multiples of 8192 bytes.
5018 * (bug 60629) Handle invalid language code gracefully in
5019 Language::fetchLanguageNames.
5020 * (bug 62017) Restore the number of rows shown on Special:Watchlist.
5021 * Check for boolean false result from database query in SqlBagOStuff.
5022
5023 == MediaWiki 1.23.2 ==
5024
5025 This is a security and maintenance release of the MediaWiki 1.23 branch.
5026
5027 === Changes since 1.23.1 ===
5028
5029 * (bug 68187) SECURITY: Prepend jsonp callback with comment.
5030 * (bug 66608) SECURITY: Fix for XSS issue in bug 66608: Generate the URL used
5031 for loading a new page in Javascript,instead of relying on the URL in the link
5032 that has been clicked.
5033 * (bug 65778) SECURITY: Copy prevent-clickjacking between OutputPage and
5034 ParserOutput.
5035 * (bug 68313) Preferences: Turn stubthreshold back into a combo box.
5036 * (bug 65214) Fix initSiteStats.php maintenance script.
5037 * (bug 67594) Special:ActiveUsers: Fix to work with PostgreSQL.
5038
5039 == MediaWiki 1.23.1 ==
5040
5041 This is a security and maintenance release of the MediaWiki 1.23 branch.
5042
5043 === Changes since 1.23.0 ===
5044
5045 * (bug 65839) SECURITY: Prevent external resources in SVG files.
5046 * (bug 67025) Special:Watchlist: Don't try to render empty row.
5047 * (bug 66922) Don't allow some E_NOTICE messages to end up in the LocalSettings.php.
5048 * (bug 66467) FileBackend: Avoid using popen() when "parallelize" is disabled.
5049 * (bug 66428) MimeMagic: Don't seek before BOF. This has weird side effects
5050 like only extracting the tail of the file partially or not at all.
5051 * (bug 66182) Removed -x flag on some php files.
5052
5053 == MediaWiki 1.23.0 ==
5054
5055 === Configuration changes in 1.23 ===
5056 * (bug 13250) Restored method for clearing a watchlist in web UI
5057 so that users with large watchlists don't have to perform
5058 contortions to clear them.
5059 * When $wgJobRunRate is higher than zero, jobs are now executed via an
5060 asynchronous HTTP request to a MediaWiki entry point. This may require
5061 increasing the number of server worker threads. $wgRunJobsAsync has been
5062 added to disable this feature if needed, falling back to executing the job
5063 on the same process but making the execution synchronously.
5064 * $wgDebugLogGroups values may be set to an associative array with a
5065 'destination' key specifying the log destination. The array may also contain
5066 a 'sample' key with a positive integer value N indicating that the log group
5067 should be sampled by dispatching one in every N messages on average. The
5068 sampling is random.
5069 * In addition to the current exception log format, MediaWiki now serializes
5070 exception metadata to JSON and logs it to the 'exception-json' log group.
5071 This makes MediaWiki easier to integrate with log aggregation and analysis
5072 tools.
5073 * $wgSquidServersNoPurge now supports the use of Classless Inter-Domain
5074 Routing (CIDR) notation to specify contiguous blocks of IPv4 and/or IPv6
5075 addresses that should be trusted to provide X-Forwarded-For headers.
5076 * Preferences 'watchcreations', 'watchdefault', 'enotifwatchlistpages' ("Add
5077 pages I create and files I upload to my watchlist", "Add pages and files I
5078 edit to my watchlist", "Email me when a page or file on my watchlist is
5079 changed") are now enabled by default. In addition new user accounts' personal
5080 and talk pages are now watched by them by default.
5081 * $wgLBFactoryConf: Class names have had underscores removed. The configuration
5082 should be updated if LBFactory_Simple or LBFactory_Multi is configured.
5083 * $wgPasswordSenderName has been removed and is no longer functional. To set a
5084 custom mailer name, the system message 'emailsender' should be modified
5085 (default: "{{SITENAME}}").
5086 * (bug 63269) Email notifications were not correctly handling the
5087 [[MediaWiki:Helppage]] message being set to a full URL (the default).
5088 If you customized [[MediaWiki:Enotif body]] (the text of email notifications),
5089 you'll need to edit it locally to include the URL via the new variable
5090 $HELPPAGE instead of the parser functions fullurl and canonicalurl; otherwise
5091 you don't have to do anything.
5092 * $wgDBAhandler was removed as the only class using it was also removed
5093 * The 'max threads' setting was removed from $wgDBservers.
5094 * Support for AdminSettings.php has been completely removed. All configuration
5095 belongs in LocalSettings.php.
5096 * $wgSkipSkin, which has been replaceable by $wgSkipSkins since 2005 (r9249), is
5097 now formally deprecated.
5098 * Removed deprecated $wgDisabledActions as it is hardly used anywhere.
5099 * $wgRateLimitLog has been deprecated and replaced by
5100 $wgDebugLogGroup['ratelimit'].
5101 * $wgLocalInterwikis is an array containing multiple local interwiki prefixes
5102 (interwiki prefixes that point back to the current wiki). This effectively
5103 allows more than one value of $wgLocalInterwiki to be specified and
5104 understood by the parser. The value of $wgLocalInterwiki is automatically
5105 prepended to the start of this array.
5106 * $wgQueryPages has been removed. Query Pages should be added to by using the
5107 wgQueryPages hook.
5108 * $wgHttpOnlyBlacklist has been removed.
5109 * $wgLicenseTerms has been removed as it was unused.
5110 * $wgProfileOnly is now deprecated; set the log file in
5111 $wgDebugLogGroups['profileoutput'] to replace it.
5112 * $wgMaxBacklinksInvalidate was removed; use $wgJobBackoffThrottling instead
5113 * Deprecated ResourceLoaderGetStartupModules hook.
5114
5115 === New features in 1.23 ===
5116 * ResourceLoader can utilize the Web Storage API to cache modules client-side.
5117 Compared to the browser cache, caching in Web Storage allows ResourceLoader
5118 to be more granular about evicting stale modules from the cache while
5119 retaining the ability to retrieve multiple modules in a single HTTP request.
5120 This capability can be enabled by setting $wgResourceLoaderStorageEnabled to
5121 true. This feature is currently considered experimental and should only be
5122 enabled with care.
5123 * (bug 6092) Add expensive parser functions {{REVISIONID:}}, {{REVISIONUSER:}}
5124 and {{REVISIONTIMESTAMP:}} (with friends).
5125 * Add "wgRelevantUserName" to mw.config containing the current
5126 Skin::getRelevantUser value.
5127 * (bug 56033) Add content model to the page information.
5128 * Added Article::MissingArticleConditions hook to give extensions a chance to
5129 hide their (unrelated) log entries.
5130 * Added LonelyPagesQuery hook to let extensions modify the query used to
5131 generate Special:LonelyPages.
5132 * Added $wgOpenSearchDefaultLimit defining the default number of entries to show
5133 on action=opensearch API call.
5134 * For namespaces with $wgNamespaceProtection (including the MediaWiki
5135 namespace), the "protect" tab will be shown only if there are restriction
5136 levels available that would restrict editing beyond what
5137 $wgNamespaceProtection already applies. The protection form will offer only
5138 those protection levels.
5139 * Added $wgAPIFormatModules, allowing extensions to add additional output
5140 formatting modules for the API.
5141 * (bug 47812) The MediaWiki:Group-user.{css,js} pages can now be used to add
5142 custom CSS or JavaScript enabled only for registered users.
5143 * (bug 52005) Special pages RecentChanges, RecentChangesLinked and Watchlist
5144 now include a legend describing the symbols used in lists of changes.
5145 * Improved the accessibility of the tabs in Special:Preferences.
5146 * Added ApiBeforeMain hook, roughly equivalent to the BeforeInitialize hook:
5147 it's called after everything is set up but before any major processing
5148 happens.
5149 * The jquery.client module now performs a component-wise version comparison in
5150 its #test method when strings are used in the browser map: version '1.10' is
5151 now correctly considered larger than '1.2'. Using numbers in the version map
5152 is not affected.
5153 * All API modules now support an assert parameter, which can either be
5154 'user' or 'bot'. The API will throw an error if the user is not logged
5155 in (user) or does not have the 'bot' userright (bot). Based off of the
5156 AssertEdit extension by Steve Sanbeg.
5157 * [[Special:Diff]] was added, allowing users to create internal links to
5158 revision comparison pages using syntax such as [[Special:Diff/12345]],
5159 [[Special:Diff/12345/prev]] or [[Special:Diff/12345/98765]].
5160 * New user accounts' personal and talk pages are now watched by them by default.
5161 * Added SkinTemplateGetLanguageLink hook to allow changing the html of language
5162 links.
5163 * Added MessageCache::get hook as a new way to customize messages across
5164 multiple sites.
5165 * Added jquery.throttle-debounce ResourceLoader module to limit the number of
5166 callbacks for frequently occurring events.
5167 * Special:ProtectedPages shows now a table. The timestamp, the reason and
5168 the protecting user are also shown.
5169 * Added experimental support for using Microsoft SQL Server as the database
5170 backend.
5171 ** Added new Microsoft SQL Server-specific configuration variable
5172 $wgDBWindowsAuthentication, which makes the web server authenticate against
5173 the database server using Integrated Windows Authentication instead of
5174 $wgDBuser/$wgDBpassword.
5175 * HTMLForm 'select', 'selectandother', 'selectorother', 'multiselect', and
5176 'radio' fields can now use message keys as labels via the 'options-messages'
5177 parameter, which overrides the 'options' parameter.
5178 * Admins can expire users passwords manually, or on a schedule using the
5179 $wgPasswordExpirationDays configuration setting.
5180 * Add new hook SendWatchlistEmailNotification, this will be used to determine
5181 whether to send a watchlist email notification.
5182 * (bug 42026) Special:Contributions now includes an option to filter page
5183 creations, similar to the topOnly option.
5184 * Add mediawiki.ui.button styling to all pages so wiki content can use styled
5185 buttons.
5186 * Special:UserLogin/signup now does AJAX checks for invalid and taken usernames,
5187 displaying the error live.
5188 * Added BaseTemplateAfterPortlet hook to allow injecting html after portlets in skins.
5189 * Support has been added for a JSON based localisation file format. The
5190 installer has been updated to use it.
5191 * Changes to content typography (colors, line-height etc.). See
5192 https://www.mediawiki.org/wiki/Typography_refresh for further information.
5193 * The Vector skin's visual treatment of external links has been simplified to a
5194 single icon (from nine). This should not affect local rules unless they were
5195 re-using these icons, which have now been deleted.
5196 * ResourceLoader: mw.loader.using() now implements a Promise interface.
5197 * Add new hook ChangesListInitRows accessed via ChangesList::initChangesListRows.
5198 If called by the ChangesList consumer this gives extensions a chance to batch
5199 process the result set prior to rendering.
5200 * A PoolCounterRedis class was added which can be make use of in $wgPoolCounterConf.
5201 This requires at least one Redis 2.6+ server.
5202 * $wgProfileToDatabase was removed. Set $wgProfiler to ProfilerSimpleDB
5203 in StartProfiler.php instead of using this.
5204 * (bug 63444) Made it possible to change the indent string (default: 4 spaces)
5205 used by FormatJson::encode().
5206
5207 === Bug fixes in 1.23 ===
5208 * (bug 41759) The "updated since last visit" markers (on history pages, recent
5209 changes and watchlist) and the talk page message indicator are now correctly
5210 updated when the user is viewing old revisions of pages, instead of always
5211 acting as if the latest revision was being viewed.
5212 * (bug 56443) Special:ConfirmEmail no longer shows a "Mail a confirmation code"
5213 when the email address is already confirmed. Also, consistently use
5214 "confirmed", rather than "authenticated", when messaging whether or not the
5215 user has confirmed an email address.
5216 * (bug 19415) action=render no longer shows section edit links. This affects
5217 behavior of several other features where (bogus) section edit links will
5218 disappear, such as file description pages loaded via $wgUseInstantCommons or
5219 pages transcluded cross-wiki via $wgEnableScaryTranscluding.
5220 * (bug 56912) Show correct link color on cached result of Special:DeadendPages.
5221 * Classes TitleListDependency and TitleDependency have been removed, as they
5222 have been found unused in core and extensions for a long time.
5223 * (bug 57098) SpecialPasswordReset now obeys returnto parameter
5224 * (bug 37812) ResourceLoader will notice when a module's definition changes and
5225 recompile it accordingly.
5226 * (bug 57201) SpecialRecentChangesFilters hook is now executed for feeds.
5227 * (bug 58640) Fixed a compatibility issue with PCRE 8.34 that caused pages
5228 to appear blank or with missing text.
5229 * (bug 56931) Updated the plural rules to CLDR 24. They are in new format
5230 which is detailed in UTS 35 Rev 33. The PHP parser and evaluator as well as
5231 the JavaScript evaluator were updated to support the new format. Plural rules
5232 for some languages have changed, most notably Russian. Affected software
5233 messages have been updated and marked for review at translatewiki.net.
5234 * (bug 23542) imagelinks now stores both the redirect and target (as
5235 templatelinks does).
5236 * (bug 58167) The web installer no longer throws an exception when PHP is
5237 compiled without support for MySQL yet with support for another DBMS.
5238 * (bug 56199) Raw option of parser functions must now match complete word,
5239 to take effect.
5240 * (bug 60543) Special:PrefixIndex forgot stripprefix=1 for "Next page" link
5241 * (bug 29762) Undoing an already-undone edit will now display an appropriate
5242 message instead of leading the user to make a null edit.
5243 * (bug 52659) mediawiki.notification: Notification area remained visible when
5244 empty and thus was stealing pointer events from links on the page.
5245 * (bug 26811) When a DBUnexpectedError occurs, DB server hostnames are now
5246 hidden unless $wgShowExceptionDetails is true, and $wgShowDBErrorBacktrace
5247 no longer applies in such cases.
5248 * (bug 60960) Avoid doing file_exist() checks on data: URIs, as they cause
5249 warnings to be printed on Windows due to large path length.
5250 * (bug 48084) Fixed a bug in the installer that could cause $wgLogo to hold
5251 the wrong path to the placeholder logo (skins/common/images/wiki.png).
5252 * (bug 64289) jquery.textSelection: Don't throw errors on empty collections.
5253
5254 === Web API changes in 1.23 ===
5255 * (bug 54884) action=parse&prop=categories now indicates hidden and missing
5256 categories.
5257 * action=query&meta=filerepoinfo now returns additional information for each
5258 repo.
5259 * action=parse&prop=languageshtml was deprecated in 1.18 and will be removed in
5260 MediaWiki 1.24.
5261 * action=parse now has disabletoc flag to disable table of contents in output.
5262 * (bug 25702) list=allcategories, list=allimages, list=alllinks, list=allpages,
5263 list=deletedrevs and list=filearchive did not handle case-sensitivity
5264 properly for all parameters.
5265 * ApiQueryBase::titlePartToKey allows an extra parameter that indicates the
5266 namespace in order to properly capitalize the title part.
5267 * (bug 57874) action=feedcontributions no longer has one item more than limit.
5268 * All API modules now support an assert parameter. See the new features section
5269 for more details.
5270 * Added prop=contributors to fetch the list of contributors to the page.
5271 * The following API modules will now return entries where fields have been
5272 revision-deleted: list=deletedrevs, list=filearchive, list=recentchanges,
5273 list=watchlist. "hidden" indicators will be included, in the same style as is
5274 already done for prop=revisions.
5275 * The following API modules will now return the content of revision-deleted
5276 fields, in addition to the "hidden" indicators, if the querying user has the
5277 necessary rights: list=logevents, list=usercontribs, prop=imageinfo,
5278 prop=revisions.
5279 * The above modules, where applicable, will now return entries filtered by
5280 revision-deleted fields if the querying user has the necessary rights. For
5281 example, prop=revisions with rvuser or rvexcludeuser will no longer skip
5282 revisions where the user was revision-deleted if the current user has the
5283 deletedhistory right.
5284 * The 'hideuser' right, used when blocking, is no longer necessary or
5285 sufficient for seeing contributions with revision-deleted in
5286 list=usercontribs.
5287 * list=watchlist now uses the querying user's rights rather than the wlowner's
5288 rights when checking whether wlprop=patrol is allowed.
5289 * (bug 32151) ApiWatch now has pageset capabilities (titles/pageids/generators).
5290 Title parameter is now deprecated.
5291 * (bug 23005) Added action=revisiondelete.
5292 * Added siprop=restrictions to API action=query&meta=siteinfo for querying
5293 possible page restriction (protection) levels and types.
5294 * Added prop 'limitreportdata' and 'limitreporthtml' to action=parse.
5295 * (bug 58627) Provide language names on action=parse&prop=langlinks.
5296 * Deprecated llurl= in favour of llprop=url for action=query&prop=langlinks.
5297 * Added llprop=langname and llprop=autonym for action=query&prop=langlinks.
5298 * prop=redirects is added, to return redirects to the pages in the query.
5299 * list=allredirects is added, to list all redirects pointing to a namespace.
5300 * (bug 42026) Added ucshow={new,!new,top,!top} to list=usercontribs.
5301 Also added newonly to action=feedcontributions.
5302 * (bug 42026) Deprecated uctoponly in favor of ucshow=top.
5303 * list=search no longer has a "srredirects" parameter. Redirects are now
5304 included in all searches.
5305 * Added list=prefixsearch that works like action=opensearch but can be used as
5306 a generator.
5307 * (bug 24782) Various modules will now use unique continuation parameters.
5308 * (bug 63249) Cache RecentChanges Atom feed in varnish for 15 seconds.
5309
5310 === Languages updated in 1.23 ===
5311
5312 MediaWiki supports over 350 languages. Many localisations are updated
5313 regularly. Below only new and removed languages are listed, as well as
5314 changes to languages because of Bugzilla reports.
5315
5316 * Support was added for Algerian Spoken Arabic (arq).
5317 * Support was added for Riograndenser Hunsrückisch (hrx).
5318 * Support was added for Northern Luri (lrc).
5319
5320 === Other changes in 1.23 ===
5321 * The rc_type field in the recentchanges table has been superseded by a new
5322 rc_source field. The rc_source field is a string representation of the
5323 change type where rc_type was a numeric constant. This field is not yet
5324 queried but will be in a future release.
5325 ** Utilize update.php to create and populate this new field. On larger wikis
5326 which do not wish to update recentchanges table in one large update please
5327 review the SQL and comments in maintenance/archives/patch-rc_source.sql.
5328 ** The rc_type field of recentchanges will be deprecated in a future release.
5329 * The global variable $wgArticle has been removed after a lengthy deprecation.
5330 * The global functions addButton and insertTags (for mw.toolbar.addButton and
5331 mw.toolbar.insertTags) now emits mw.log.warn when accessed.
5332 * The ExpandTemplates extension has been moved into MediaWiki core.
5333 * (bug 52812) Removed "Disable search suggestions" from Preference.
5334 * (bug 52809) Removed "Disable browser page caching" from Preference.
5335 * Three new modules intended for use by custom skins were added:
5336 'mediawiki.skinning.elements', 'mediawiki.skinning.content', and
5337 'mediawiki.skinning.interface', representing three levels of standard
5338 MediaWiki styling. Previously skin creators wishing to use them had to refer
5339 to the file names of appropriate files directly, which is now discouraged.
5340 * The modules 'skins.vector' and 'skins.monobook' have been renamed to
5341 'skins.vector.styles' and 'skins.monobook.styles', respectively,
5342 and their definition was changed not to include the common*.css files;
5343 the two skins now load the 'mediawiki.skinning.interface' module instead.
5344 * A page_links_updated field has been added to the page table.
5345 * SpecialPage::getTitle has been deprecated in favor of
5346 SpecialPage::getPageTitle.
5347 * BREAKING CHANGE: Two potentially backwards-incompatible changes have been made
5348 to the 'SpecialWatchlistQuery' hook's last parameter (array $values) to make
5349 the hook more consistent with the 'SpecialRecentChangesQuery' one:
5350 ** Several array keys have been renamed: hideMinor → hideminor,
5351 hideBots → hidebots, hideAnons → hideanons, hideLiu → hideliu,
5352 hidePatrolled → hidepatrolled, hideOwn → hidemyself.
5353 ** The parameter value is now a FormOptions object, not a plain array (array
5354 access operators should continue to work, as it implements the ArrayAccess
5355 interface).
5356 * Option to mark hooks as deprecated has been added.
5357 * (bug 52811) Preference "Enable section editing via [edit] links" was removed.
5358 * (bug 52813) Preference "Show table of contents (for pages with more than
5359 3 headings)" was removed.
5360 * (bug 52810) Preference "Justify paragraphs" was removed.
5361 * OutputPage::showErrorPage raises a notice if arguments are incoherent.
5362 * Thumbnails that keep failing to render in thumb.php will be rate-limited
5363 against further render attempts for 1 hour. $wgAttemptFailureEpoch can be
5364 altered to reset all rate-limited thumbnails at once.
5365 * (bug 56572) Builds of the OOjs and OOjs UI libraries are now available.
5366 * mw.loader.go and mw.loader.version have been removed.
5367 * (bug 52815) Preference "Enable simplified search bar (Vector skin only)"
5368 was removed.
5369 * A user_password_expires column has been added to the user table. The User
5370 object expects this column to exist. Use update.php to create this new field.
5371 * The jquery.delayedBind ResourceLoader module was deprecated in favor of the
5372 jquery.throttle-debounce module. It will be removed in MediaWiki 1.24.
5373 * mw.user.bucket has been deprecated.
5374 * On Special:PrefixIndex, a table#mw-prefixindex-list-table was changed to
5375 table.mw-prefixindex-list-table to avoid duplicate ids when the special page
5376 is transcluded.
5377 * (bug 62198) window.$j has been deprecated.
5378 * Preference "Disable link title conversion" was removed.
5379 * SpecialRecentChanges no longer includes any functionality for generating feeds
5380 - it has been factored out to ApiFeedRecentChanges. Old URLs redirect to new
5381 ones.
5382 * RecentChange::mExtra['lang'] is no longer set and should no longer be used.
5383 Extensions should read from other configuration variables, including
5384 $wgLocalInterwikis, to identify the current wiki.
5385 * Sections in the parser test framework have been renamed and the old
5386 section names are deprecated. Please use "!!wikitext" and "!!html"
5387 (or "!!html/php") instead of "!!input" and "!!result". This allows
5388 us to extend parser tests to accommodate additional input/output
5389 pairs, such as "!!html/parsoid" (for the output of the Parsoid
5390 parser, where it differs from the PHP parser).
5391 * Special:Search no longer has an "include redirects" option on the advanced
5392 tab. Redirects are now included in all searches.
5393 * mediawiki.api.category's getCategories() 'async' parameter was deprecated.
5394 * The locations of resources have been split between upstream libraries, now in
5395 resources/lib/, local libaries in resources/src/, and local forks of upstream
5396 libraries, also in resources/src/.
5397 * BREAKING CHANGE: The automatically-generated function closure with which
5398 ResourceLoader wraps all modules' JavaScript code now binds the identifier
5399 names 'jQuery' and '$' to the jQuery object of the version of jQuery that is
5400 bundled with MediaWiki. If you bind these names to other objects in global
5401 scope (like Zepto.js or document.querySelectorAll, for example) you will need
5402 to use different names to or re-bind them at the top of each
5403 ResourceLoader-loaded module.
5404 * (bug 52342) Preference "Remember my login" was removed.
5405 * The skin autodiscovery mechanism has been deprecated and will be removed in
5406 MediaWiki 1.25. See https://www.mediawiki.org/wiki/Manual:Skin_autodiscovery
5407 for migration guide for creators and users of custom skins that relied on it.
5408
5409 ==== Removed classes ====
5410 * FakeMemCachedClient (deprecated in 1.18)
5411 * RdfMetaData (unused)
5412 * TitleDependency (unused)
5413 * TitleListDependency (unused)
5414 * WikiError (deprecated in 1.17)
5415 * WikiXmlError (deprecated in 1.17)
5416 * WikiErrorMsg (deprecated in 1.17)
5417
5418 ==== Renamed classes ====
5419 * CdbReader_DBA to CdbReaderDBA
5420 * CdbReader_PHP to CdbReaderPHP
5421 * CdbWriter_DBA to CdbWriterDBA
5422 * CdbWriter_PHP to CdbWriterPHP
5423 * DiffOp_Add to DiffOpAdd
5424 * DiffOp_Change to DiffOpChange
5425 * DiffOp_Copy to DiffOpCopy
5426 * DiffOp_Delete to DiffOpDelete
5427 * HWLDF_WordAccumulator to HWLDFWordAccumulator
5428 * LBFactory_Fake to LBFactoryFake
5429 * LBFactory_Multi to LBFactoryMulti
5430 * LBFactory_Simple to LBFactorySimple
5431 * LBFactory_Single to LBFactorySingle
5432 * LCStore_Accel to LCStoreAccel
5433 * LCStore_CDB to LCStoreCDB
5434 * LCStore_DB to LCStoreDB
5435 * LCStore_Null to LCStoreNull
5436 * LoadBalancer_Single to LoadBalancerSingle
5437 * LoadMonitor_MySQL to LoadMonitorMySQL
5438 * LoadMonitor_Null to LoadMonitorNull
5439 * LocalisationCache_BulkLoad to LocalisationCacheBulkLoad
5440 * csvStatsOutput to CsvStatsOutput
5441 * extensionLanguages to ExtensionLanguages
5442 * languages to Languages
5443 * statsOutput to StatsOutput
5444 * textStatsOutput to TextStatsOutput
5445 * wikiStatsOutput to WikiStatsOutput
5446
5447 ==== Removed methods ====
5448 * ApiBase::getValidNamespaces() (deprecated in 1.17)
5449 * ApiMain::setCachePrivate() (deprecated in 1.17)
5450 * ApiMain::setVaryCookie (deprecated in 1.17)
5451 * Article::doRedirect() (deprecated in 1.18)
5452 * Article::doUnwatch() (deprecated in 1.18)
5453 * Article::doWatch() (deprecated in 1.18)
5454 * Article::forUpdate() (deprecated in 1.18)
5455 * Article::markpatrolled() (deprecated in 1.18)
5456 * Article::unwatch() (deprecated in 1.18)
5457 * Article::watch() (deprecated in 1.18)
5458 * Block::clear() (deprecated in 1.18)
5459 * Block::decodeExpiry() (deprecated in 1.18)
5460 * Block::encodeExpiry() (deprecated in 1.18)
5461 * Block::forUpdate() (deprecated in 1.18)
5462 * Block::infinity() (deprecated in 1.18)
5463 * Block::load() (deprecated in 1.18)
5464 * Block::newFromDB() (deprecated in 1.18)
5465 * Block::normaliseRange() (deprecated in 1.18)
5466 * Block::parseExpiryInput() (deprecated in 1.18)
5467 * CategoryViewer::addSubcategory() (deprecated in 1.17)
5468 * EditPage::spamPage() (deprecated since 1.17)
5469 * Exif::getFormattedData() (deprecated in 1.18)
5470 * Exif::makeFormattedData() (deprecated in 1.18)
5471 * in_string (deprecated in 1.21)
5472 * Language::convertLinkToAllVariants() (deprecated in 1.17)
5473 * LanguageConverter::convertLinkToAllVariants() (deprecated in 1.17)
5474 * Linker::makeBrokenLink() (deprecated in 1.16)
5475 * Linker::makeBrokenLinkObj() (deprecated in 1.16)
5476 * Linker::makeColouredLinkObj() (deprecated in 1.16)
5477 * Linker::makeSizeLinkObj() (deprecated in 1.17)
5478 * MediaWiki::articleFromTitle() (deprecated in 1.18)
5479 * ParserOptions::getkin() (deprecated 1.18)
5480 * ProfilerSimple::getCpuTime (deprecated in 1.20)
5481 * Revision::revText() (deprecated in 1.17)
5482 * SkinTemplate::jstext() (deprecated in 1.21)
5483 * SpecialPage::__call() (deprecated in 1.17)
5484 * SpecialPage::executePath() (deprecated in 1.18)
5485 * SpecialPage::exists() (deprecated in 1.18)
5486 * SpecialPage::file() (deprecated in 1.18)
5487 * SpecialPage::func() (deprecated in 1.18)
5488 * SpecialPage::getGroup() (deprecated in 1.18)
5489 * SpecialPage::getPage() (deprecated in 1.18)
5490 * SpecialPage::getPageByAlias() (deprecated in 1.18)
5491 * SpecialPage::getLocalNameFor() (deprecated in 1.18)
5492 * SpecialPage::getRegularPages() (deprecated in 1.18)
5493 * SpecialPage::getRestrictedPages() (deprecated in 1.18)
5494 * SpecialPage::getTitleForAlias() (deprecated in 1.18)
5495 * SpecialPage::getUsablePages() (deprecated in 1.18)
5496 * SpecialPage::includable() (deprecated in 1.18)
5497 * SpecialPage::init()
5498 * SpecialPage::initAliasList() (deprecated in 1.18)
5499 * SpecialPage::initList() (deprecated in 1.18)
5500 * SpecialPage::name() (deprecated in 1.18)
5501 * SpecialPage::removePage() (deprecated in 1.18)
5502 * SpecialPage::resolveAlias() (deprecated in 1.18)
5503 * SpecialPage::resolveAliasWithSubpage() (deprecated in 1.18)
5504 * SpecialPage::restriction() (deprecated in 1.18)
5505 * SpecialPage::setGroup() (deprecated in 1.18)
5506 * SpecialRecentChanges::feedSetup()
5507 * SpecialRevisionDelete::extractBitField() (deprecated in 1.22)
5508 * User::getPageRenderingHash() (deprecated in 1.17)
5509 * WebRequest::getFileSize() (deprecated in 1.17)
5510 * WebRequest::isPathInfoBad() (deprecated in 1.17)
5511 * wfGenerateToken (deprecated in 1.20)
5512 * wfStreamFile (deprecated in 1.19)
5513 * wfUILang (deprecated in 1.18)
5514 * WikiPage::createUpdates() (deprecated in 1.18)
5515 * WikiPage::quickEdit() (deprecated in 1.18)
5516 * WikiPage::useParserCache() (deprecated in 1.18)
5517 * WikiPage::viewUpdates() (deprecated in 1.18)
5518
5519 ==== Removed globals ====
5520 * $wgBetterDirectionality (deprecated in 1.18)
5521
5522 = MediaWiki 1.22 =
5523
5524 == MediaWiki 1.22.15 ==
5525
5526 This is a security and maintenance release of the MediaWiki 1.22 branch.
5527
5528 === Changes since 1.22.14 ===
5529
5530 * (bug T76686) [SECURITY] thumb.php outputs wikitext message as raw HTML, which
5531 could lead to xss. Permission to edit MediaWiki namespace is required to
5532 exploit this.
5533 * (bug T77028) [SECURITY] Malicious site can bypass CORS restrictions in
5534 $wgCrossSiteAJAXdomains in API calls if it only included an allowed domain as
5535 part of its name.
5536 * (bug T74222) The original patch for T74222 was reverted as unnecessary.
5537
5538 == MediaWiki 1.22.14 ==
5539
5540 This is a security and maintenance release of the MediaWiki 1.22 branch.
5541
5542 === Changes since 1.22.13 ===
5543
5544 * (bugs 66776, 71478) SECURITY: User PleaseStand reported a way to inject code
5545 into API clients that used format=php to process pages that underwent flash
5546 policy mangling. This was fixed along with improving how the mangling was done
5547 for format=json, and allowing sites to disable the mangling using
5548 $wgMangleFlashPolicy.
5549 * (bug 70901) SECURITY: User Jackmcbarn reported that the ability to update
5550 the content model for a page could allow an unprivileged attacker to edit
5551 another user's common.js under certain circumstances. The user right
5552 "editcontentmodel" was added, and is needed to change a revision's content
5553 model.
5554 * (bug 72222) SECURITY: Do not show log action when the entry is revdeleted with
5555 DELETED_ACTION. NOTICE: this may be reverted in a future release pending a
5556 public RFC about the desired functionality. This issue was reported by user
5557 Bawolff.
5558 * (bug 71621) Make allowing site-wide styles on restricted special pages a
5559 config option.
5560 * $wgMangleFlashPolicy was added to make MediaWiki's mangling of anything that
5561 might be a flash policy directive configurable.
5562
5563 == MediaWiki 1.22.13 ==
5564 This is a maintenance release of the MediaWiki 1.22 branch.
5565
5566 === Changes since 1.22.12 ===
5567 * (bug 67440) Allow classes to be registered properly from installer
5568
5569 == MediaWiki 1.22.12 ==
5570 This is a security release of the MediaWiki 1.22 branch.
5571
5572 === Changes since 1.22.11 ===
5573 * (bug 70672) SECURITY: OutputPage: Remove separation of css and js module allowance.
5574
5575 == MediaWiki 1.22.11 ==
5576 This is a security release of the MediaWiki 1.22 branch.
5577
5578 === Changes since 1.22.10 ===
5579 * (bug 69008) SECURITY: Enhance CSS filtering in SVG files. Filter <style> elements; normalize style elements and attributes before filtering; add checks for attributes that contain css; add unit tests for html5sec and reported bugs.
5580
5581 == MediaWiki 1.22.10 ==
5582 This is a maintenance release of the MediaWiki 1.22 branch.
5583
5584 === Changes since 1.22.9 ===
5585 * (bug 64970) Fix support for blobs on DatabaseOracle::update
5586 * (bug 60719) In MediaWiki 1.22, the job queue execution on each page request was changed (Gerrit change 59797) so, instead of executing the job inside the same PHP process that's rendering the page, a new PHP cli command is spawned to execute runJobs.php in the background. It will only work if $wgPhpCli is set to an actual path or safe mode is off, otherwise, the old method will be used. https://www.mediawiki.org/wiki/Manual:Job_queue#Changes_introduced_in_MediaWiki_1.22 for more information. This change was in earlier releases of 1.22 but was not noted here until now.
5587
5588 == MediaWiki 1.22.9 ==
5589 This is a security and maintenance release of the MediaWiki 1.22 branch.
5590
5591 === Changes since 1.22.8 ===
5592 * (bug 68187) SECURITY: Prepend jsonp callback with comment.
5593 * (bug 66608) SECURITY: Fix for XSS issue in bug 66608: Generate the URL used for loading a new page in Javascript,instead of relying on the URL in the link that has been clicked.
5594 * (bug 65778) SECURITY: Copy prevent-clickjacking between OutputPage and ParserOutput.
5595 * (bug 59147) The img_metadata field was not being decoded from bytea into text.
5596
5597 == MediaWiki 1.22.8 ==
5598 This is a security and maintenance release of the MediaWiki 1.22 branch.
5599
5600 === Changes since 1.22.7 ===
5601 * (bug 65839) SECURITY: Prevent external resources in SVG files.
5602 * (bug 66428) MimeMagic: Don't seek before BOF. This has weird side effects like only extracting the tail of the file partially or not at all.
5603
5604 == MediaWiki 1.22.7 ==
5605 This is a security and maintenance release of the MediaWiki 1.22 branch.
5606
5607 === Changes since 1.22.6 ===
5608 * (bug 65501) SECURITY: Don't parse usernames as wikitext on Special:PasswordReset.
5609 * (bug 36356) Add space between two feed links.
5610 * (bug 63269) Email notifications were not correctly handling the MediaWiki:Helppage message being set to a full URL. This is a regression from the 1.22.5 point release, which made the default value for it a URL. If you customized MediaWiki:Enotif body (the text of email notifications), you'll need to edit it locally to include the URL via the new variable $HELPPAGE instead of the parser functions fullurl and canonicalurl; otherwise you don't have to do anything.
5611 Add missing uploadstash.us_props for PostgreSQL.
5612 * (bug 56047) Fixed stream wrapper in PhpHttpRequest.
5613
5614 == MediaWiki 1.22.6 ==
5615 This is a security release of the MediaWiki 1.22 branch.
5616
5617 === Changes since 1.22.5 ===
5618 * (bug 63251) SECURITY: Escape sortKey in pageInfo.
5619
5620 == MediaWiki 1.22.5 ==
5621 This is a security and maintenance release of the MediaWiki 1.22 branch.
5622
5623 === Changes since 1.22.4 ===
5624 * (bug 62497) SECURITY: Add CSRF token on Special:ChangePassword.
5625 * (bug 62467) Set a title for the context during import on the cli.
5626 * Fix custom local MediaWiki:Helppage values.
5627 * mediawiki.js: Fix documentation breakage.
5628 * (bug 58153) Make MySQLi work with non standard port.
5629 * (bug 53887) Reintroduced a link to help pages in the default sidebar, that any sysop can customize by editing MediaWiki:Sidebar locally. The link now points to a mediawiki.org page which is guaranteed to exist. Nothing needs to be done on your end, but remember to adjust MediaWiki:Sidebar for the needs of your wikis. Everyone can help with the shared documentation by translating: https://www.mediawiki.org/wiki/Special:Translate/agg-Help_pages .
5630 * (bug 53888) Corrected a regression in 1.22 which introduced red links on the login page. If you previously installed 1.22.x and have created a local page to make the red link blue, write its title as in MediaWiki:helplogin-url if you didn't already. Otherwise, you don't need to do anything, but you can translate the help page at https://www.mediawiki.org/wiki/Help:Logging_in .
5631
5632 == MediaWiki 1.22.4 ==
5633 This is a maintenance release of the MediaWiki 1.22 branch.
5634
5635 === Changes since 1.22.3 ===
5636 * Use the correct branch of the extensions' git repositories.
5637
5638 == MediaWiki 1.22.3 ==
5639 This is a security and bugfix release of the MediaWiki 1.22 branch.
5640
5641 === Changes since 1.22.2 ===
5642 * (bug 60771) SECURITY: Disallow uploading SVG files using non-whitelisted namespaces. Also disallow iframe elements. * User will get an error including the namespace name if they use a non- whitelisted namespace.
5643 * (bug 61346) SECURITY: Make token comparison use constant time. It seems like our token comparison would be vulnerable to timing attacks. This will take constant time.
5644 * (bug 61362) SECURITY: API: Don't find links in the middle of api.php links.
5645 * (bug 53710) Add sequence support for upsert in DatabaseOracle in the same way as in selectInsert
5646 * (bug 60231, bug 58719) Various fixes to job running code in Wiki.php: Make it async on Windows. Fixed possible "invalid filename" errors on Windows. Redirect output to dev/null to avoid hanging PHP.
5647 * (bug 60083) Correct sequence name for fresh Postgres installation. Spotted by gebhkla
5648 * (bug 60531) Avoid variable naming conflicts in DatabasePostgres::selectSQLText. Spotted by gebhkla
5649 * (bug 60094) Fix rebuildall.php fatal error with PostgreSQL.
5650 * (bug 43817) Add error handling if descriptionmsg isn't defined for extension.
5651 * (bug 60543) Special:PrefixIndex omits stripprefix=1 for "Next page" link.
5652
5653 == MediaWiki 1.22.2 ==
5654 This is a security and bugfix release of the MediaWiki 1.22 branch.
5655
5656 === Changes since 1.22.1 ===
5657 * (bug 60339) SECURITY: Sanitize shell arguments to DjVu files, and other media formats
5658 * (bug 58253) Check for very old PCRE versions in installer and updater
5659 * (bug 60054) Make WikiPage::$mPreparedEdit public
5660
5661 == MediaWiki 1.22.1 ==
5662 This is a security and maintenance release of the MediaWiki 1.22 branch.
5663
5664 === Changes since 1.22.0 ===
5665 * (bug 57550) SECURITY: Disallow stylesheets in SVG Uploads
5666 * (bug 58088) SECURITY: Don't normalize U+FF3C to \ in CSS Checks
5667 * (bug 58472) SECURITY: Disallow -o-link in styles
5668 * (bug 58553) SECURITY: Return error on invalid XML for SVG Uploads
5669 * (bug 58699) SECURITY: Fix RevDel log entry information leaks
5670 * (bug 58178) Restore compatibility with curl < 7.16.2.
5671 * (bug 56931) Updated the plural rules to CLDR 24. They are in new format which is detailed in UTS 35 Rev 33. The PHP parser and evaluator as well as the JavaScript evaluator were updated to support the new format. Plural rules for some languages have changed, most notably Russian. Affected software messages have been updated and marked for review at translatewiki.net. This change is backported from the development branch of MediaWiki 1.23.
5672 * (bug 58434) The broken installer for database backend Oracle was fixed.
5673 * (bug 58167) The web installer no longer throws an exception when PHP is compiled without support for MySQL yet with support for another DBMS.
5674 * (bug 58640) Fixed a compatibility issue with PCRE 8.34 that caused pages to appear blank or with missing text.
5675 * (bug 47055) Changed FOR UPDATE handling in Postgresql
5676 * (bug 57026) Avoid extra parsing in prepareContentForEdit()
5677
5678 == MediaWiki 1.22.0 ==
5679
5680 === Configuration changes in 1.22 ===
5681 * $wgRedirectScript was removed. It was unused.
5682 * Removed $wgLocalMessageCacheSerialized, it is now always true.
5683 * $wgVectorUseIconWatch is now enabled by default.
5684 * $wgCascadingRestrictionLevels was added.
5685 * ftps, ssh, sftp, xmpp, sip, sips, tel, sms, bitcoin, magnet, urn, and geo
5686 have been whitelisted inside of $wgUrlProtocols.
5687 * $wgDocType and $wgDTD have been removed and are no longer used for the DOCTYPE.
5688 * $wgHtml5 is no longer used by core. Setting it to false will no longer disable HTML5.
5689 It is still set to true for extension compatibility but doing so in extensions is deprecated.
5690 * $wgXhtmlDefaultNamespace is no longer used by core. Setting it will no longer change the
5691 xmlns used by MediaWiki. Reliance on this variable by extensions is deprecated.
5692 * $wgHandheldStyle was removed.
5693 * $wgHandheldForIPhone was removed.
5694 * $wgJsMimeType is no longer used by core. Most usage has been removed since
5695 HTML output is now exclusively HTML5.
5696 * $wgDBOracleDRCP added. True enables persistent connection with DRCP on Oracle.
5697 * $wgLogAutopatrol added to allow disabling logging of autopatrol edits in the logging table.
5698 Default for $wgLogAutopatrol is true.
5699 * The 'edit' right no longer allows for editing a user's own CSS and JS.
5700 * New rights 'editmyusercss', 'editmyuserjs', 'viewmywatchlist',
5701 'editmywatchlist', 'viewmyprivateinfo', 'editmyprivateinfo', and
5702 'editmyoptions' restrict actions that were formerly allowed by default. They
5703 have been added to the default for $wgGroupPermissions['*'].
5704 * The 'editprotected' right no longer allows bypassing of all page protection
5705 restrictions. Any group using it for this purpose will now need to have all
5706 the individual rights listed in $wgRestrictionTypes for the same effect.
5707 * The 'protect' and 'autoconfirmed' rights are no longer used for the default
5708 page protection levels. The rights 'editprotected' and 'editsemiprotected'
5709 are now used for this purpose instead.
5710 * (bug 40866) wgOldChangeTagsIndex removed.
5711 * $wgNoFollowDomainExceptions now only matches entire domains. For example,
5712 an entry for 'bar.com' will still match 'foo.bar.com' but not 'foobar.com'.
5713 * $wgCopyUploadTimeout and $wgCopyUploadAsyncTimeout added to change the timeout times for
5714 fetching the file during upload by url.
5715 * New key added to $wgGalleryOptions - $wgGalleryOptions['mode'] to set
5716 default gallery mode.
5717 * New hook 'GalleryGetModes' to allow extensions to make new gallery modes.
5718 * The checkbox for staying in HTTPS displayed on the login form when $wgSecureLogin is
5719 enabled has been removed. Instead, whether the user stays in HTTPS will be determined
5720 based on the user's preferences, and whether they came from HTTPS or not.
5721 * $wgRC2UDPAddress, $wgRC2UDPInterwikiPrefix, $wgRC2UDPOmitBots, $wgRC2UDPPort,
5722 and $wgRC2UDPPrefix configuration options have been deprecated in favor of a
5723 $wgRCFeeds configuration array. $wgRCFeeds makes both the format and
5724 destination of recent change notifications customizable, and allows for
5725 multiple destinations to be specified.
5726 * (bug 53862) portal-url, currentevents-url and helppage have been removed from the
5727 default Sidebar.
5728 * The 'vector-simplesearch' preference is now enabled by default. Previously
5729 it was only enabled if the Vector extension was installed.
5730 * The precise format of metric datagrams produced by the UDP profiler and stats counter
5731 may now be specified as $wgUDPProfilerFormatString and $wgStatsFormatString,
5732 respectively.
5733 * (bug 54597) $wgBlockOpenProxies, $wgProxyPorts, $wgProxyScriptPath, and
5734 $wgProxyMemcExpiry have been removed, along with the open proxy scanner
5735 script they were added for.
5736 * Default value of $wgMaxShellMemory has been tripled (it's now 300 MB).
5737
5738 === New features in 1.22 ===
5739 * You can now install extensions using Composer.
5740 See https://www.mediawiki.org/wiki/Composer
5741 * (bug 44525) mediawiki.jqueryMsg can now parse (whitelisted) HTML elements and attributes.
5742 * (bug 33454) Language::sprintfDate now has a timezone parameter, and supports
5743 the "eIOPTZ" formatting characters.
5744 * EditWarning: A warning is shown when an editor leaves the edit form without
5745 saving (enabled by default, users can opt-out via the 'useeditwarning'
5746 preference). This feature was moved from the Vector extension, and is now part
5747 of core for all skins. Take care when upgrading that you don't use an older
5748 version of the Vector extension as this feature may conflict.
5749 * New 'mediawiki.ui' CSS module providing mw-ui-* styles for buttons and a
5750 compact vertical form layout.
5751 * HTMLForm supports a new display format 'vform' which applies this compact vertical
5752 layout and button styling. Special:PasswordReset uses this format.
5753 * New versions of login (Special:UserLogin) and create account
5754 (Special:UserLogin/signup) forms using the "vform" compact vertical form layout.
5755 These forms use new messages that assume a "Help logging in" link, see
5756 https://www.mediawiki.org/wiki/Manual:Page_customizations;
5757 https://www.mediawiki.org/wiki/Account_creation_user_experience/Strings lists the
5758 message key changes.
5759 * (bug 23343) Implemented ability to apply IP blocks to the contents of X-Forwarded-For headers
5760 by adding a new configuration variable $wgApplyIpBlocksToXff (disabled by default).
5761 * The new hook 'APIGetPossibleErrors' to modify the list of possible errors was
5762 added.
5763 * (bug 25592) LogEventsList::showLogExtract() will now ignore various
5764 Pager-related WebRequest parameters by default, as this is overwhelmingly
5765 likely to be what was intended by users of the method. If any caller wishes
5766 to use these parameters, the new param 'useRequestParams' may be set to true.
5767 * mw.util.addPortletLink: Tooltip is no longer required to be plain (without
5768 an accesskey in it already). As such it now rountrips. Creating a link with a
5769 message as tooltip, grabbing the title attribute and using it to create
5770 another portlet will work as expected.
5771 * (bug 6747) {{ROOTPAGENAME}} introduced, contains the name of the topmost
5772 page without namespace.
5773 * BREAKING CHANGE: (bug 41729) Display editsection links next to headings. Also
5774 change their class name from .editsection to .mw-editsection and place them at
5775 the end of the heading element instead of the beginning. Client-side code and
5776 screen-scrapers will have to be adjusted to handle both cases (old HTML will
5777 still be visible on cached page renders until they are purged); extensions
5778 using the DoEditSectionLink or EditSectionLink hooks might need adjustments as
5779 well.
5780 * (bug 45535) introduced the new 'LanguageLinks' hook for manipulating the
5781 language links associated with a page before display.
5782 * Chosen (http://harvesthq.github.io/chosen/) was added as module 'jquery.chosen'
5783 * HTMLForm will turn multiselect checkboxes into a Chosen interface when setting cssclass 'mw-chosen'
5784 * rebuildLocalisationCache learned --lang option. Let you rebuild l10n caches
5785 of the specified languages instead of all of them.
5786 * New GetNewMessagesAlert hook allowing extensions to disable or modify the new
5787 messages alert
5788 * New wgUserNewMsgRevisionId JS global for logged in users. This will be null
5789 if the user has no new talk page messages. Otherwise it will be set to the
5790 revision ID of the oldest new talk page message. This will allow gadgets and
5791 extensions to create their own new message alerts on the client side.
5792 * mediawiki.log: Added log.warn wrapper (uses console.warn and console.trace).
5793 * mediawiki.log: Implemented log.deprecate. This method defines a property and
5794 uses ES5 getter/setter to emit a warning when they are used.
5795 * $wgCascadingRestrictionLevels was added, allowing one to specify restriction levels
5796 which can be cascading (previously 'sysop' was hard-coded as the only one).
5797 * XHTML5 support has been improved. If you set $wgMimeType = 'application/xhtml+xml'
5798 MediaWiki will try outputting markup according to XHTML5 rules.
5799 * Altered hook 'ProtectionForm::save', adding the reason page protection is
5800 changed as third parameter.
5801 * New hook 'TitleSquidURLs' for manipulating the list of URLs to be purged from
5802 HTTP caches when a page is changed.
5803 * Changed the patrolling system to always show the link for patrolling in case the
5804 current revision is patrollable. This also removed the usage of the rcid URI parameters.
5805 * Oracle DB backend now supports Database Resident Connection Pooling (DRCP).
5806 Can be enabled by setting $wgDBOracleDRCP=true.
5807 Requires Oracle DB 11gR1 or above, enabled DRCP inside the DB itself and a
5808 propper connect string.
5809 More about DRCP can be found at:
5810 http://www.oracle-base.com/articles/11g/database-resident-connection-pool-11gr1.php
5811 * Add a new parameter $patrolFooterShown to hook ArticleViewFooter so the hook
5812 handlers can take further action based on the status of the patrol footer
5813 * A new hook TitleQuickPermissions was added to allow overriding of quick
5814 permissions in the Title class.
5815 * LinkCache singleton can now be altered or cleared, letting one to specify
5816 another instance that does not rely on a database backend.
5817 * MediaWiki's PHPUnit tests can now use PHPUnit installed using composer --dev.
5818 * (bug 43689) The lists of templates used on the page and hidden categories it
5819 is a member of, shown below the edit form, are now collapsible (and collapsed
5820 by default).
5821 * Parser profiling data, formerly only available in the "NewPP limit report"
5822 HTML comment, is now also displayed at the bottom of page previews.
5823 * Added ParserLimitReportPrepare and ParserLimitReportFormat hooks, deprecated
5824 ParserLimitReport hook.
5825 * New user rights have been added to increase granularity in rights management
5826 for extensions such as OAuth:
5827 ** editmyusercss controls whether a user may edit their own CSS subpages.
5828 ** editmyuserjs controls whether a user may edit their own JS subpages.
5829 ** viewmywatchlist controls whether a user may view their watchlist.
5830 ** editmywatchlist controls whether a user may edit their watchlist.
5831 ** viewmyprivateinfo controls whether a user may access their private
5832 information (e.g. registered email address, real name).
5833 ** editmyprivateinfo controls whether a user may change their private
5834 information.
5835 ** editmyoptions controls whether a user may change their preferences.
5836 * Add new hook AbortTalkPageEmailNotification, this will be used to determine
5837 whether to send the regular talk page email notification
5838 * Action classes registered in $wgActions are now also supported in the form of
5839 a callback (which returns an instance of Action) instead of providing the name
5840 of a subclass of Action.
5841 * (bug 46513) Vector: Add the collapsibleTabs script from the Vector extension.
5842 * Added $wgRecentChangesFlags for defining new flags for RecentChanges and
5843 watchlists.
5844 * (bug 40518) mw.toolbar: Implemented mw.toolbar.addButtons for adding multiple
5845 button objects in one call.
5846 * Rights used for the default protection levels ('sysop' and 'autoconfirmed')
5847 are now used just for that purpose, instead of overloading other rights. This
5848 allows easy granting of the ability to edit sysop-protected pages without
5849 also granting the ability to protect and unprotect.
5850 * (bug 48256) Make brackets in section edit links accessible to CSS.
5851 They are now wrapped in <span class="mw-editsection-bracket" />.
5852 * (bug 8480) Allow handler specific parameters in galleries (like page number)
5853 * jquery.client: Add detection for Opera 15 and Internet Explorer 11.
5854 * Change tags (used by the AbuseFilter extension) are now shown on diff pages.
5855 * Change tag lists (shown on recent changes, watchlist, user contributions,
5856 history pages, diff pages) now include a link to Special:Tags to distinguish
5857 them from edit summaries.
5858 * Added a new method and hook, User::isEveryoneAllowed() and
5859 UserIsEveryoneAllowed, for use in situations where a "does everyone have this
5860 right?" check is used to avoid more expensive checks.
5861 * (bug 14431) Display "(No difference)" instead of an empty diff (when comparing
5862 revisions in the history or when previewing changes while editing).
5863 * New hook 'IsUploadAllowedFromUrl' is added which can be used to intercept uploads by
5864 URL, useful for blacklisting specific URLs
5865 * (bug 21912) Watchlist token implementation has been refactored and
5866 Special:ResetTokens was added to allow users to reset their tokens
5867 instead of presenting them in Preferences.
5868 * Special:PrefixIndex now lets you strip the searched prefix from the displayed
5869 titles. Given a list of articles named Bug1, Bug2, you can now transclude the
5870 list of bug numbers using: {{Special:PrefixIndex/Bug|stripprefix=1}}.
5871 The special page form received a new checkbox matching that option.
5872 * (bug 23580) Implement javascript callback interface "mw.hook".
5873 * (bug 30713) New mw.hook "wikipage.content".
5874 * (bug 40430) jquery.placeholder gets a new parameter to set the attribute value
5875 to be used.
5876 * $wgHTCPMulticastRouting renamed $wgHTCPRouting since it accepts unicast.
5877 * $wgHTCPRouting rules can now be passed an array of hosts/ports to send purge
5878 too. Can be used whenever several multicast group could be interested by a
5879 specific purge.
5880 * (bug 25931) Add Special:RandomInCategory.
5881 * mediawiki.util: addPortletLink now supports passing a jQuery object as nextnode.
5882 * <wbr> can now be used inside WikiText.
5883 * WebResponse::setcookie is much more featureful. Callers using PHP's
5884 setcookie() or setrawcookie() should begin using this instead.
5885 * New hook WebResponseSetCookie, called from WebResponse::setcookie().
5886 * New hook ResetSessionID, called when the session id is reset.
5887 * Add a mode parameter to <gallery> tag with potential options of "traditional",
5888 "nolines", "packed", "packed-overlay", or "packed-hover".
5889 * (bug 47399) A success message is now displayed after changing the password.
5890 * Make thumb.php give HTTP redirects for file redirects
5891 * (bug 30607) Special:ListFiles can now show old versions of files. Additionally
5892 Special:AllMyUploads was introduced so the user can get a list of all things
5893 they have ever uploaded, even if it was subsequently overridden.
5894 * Introduced Special:MyFiles and Special:AllMyFiles as an alias for Special:MyUploads
5895 and Special:AllMyUploads respectively.
5896 * IPv6 addresses in X-Forwarded-For headers are now normalised before checking
5897 against allowed proxy lists.
5898 * Add deferrable update support for callback/closure.
5899 * Add TitleMove hook before page renames.
5900 * Revision deletion backend code is moved out of SpecialRevisiondelete
5901 * Added {{REVISIONSIZE}} variable to get the current size of a revision.
5902 * Add support for the LESS stylesheet language to ResourceLoader. LESS is a
5903 stylesheet language that compiles into CSS. ResourceLoader file modules may
5904 include LESS style files; ResourceLoader will compile these files into CSS
5905 before sending them to the client.
5906 ** The $wgResourceLoaderLESSVars configuration variable is an associative array
5907 mapping variable names to string CSS values. These variables are considered
5908 declared for all LESS files. Additional variables may be registered by
5909 adding keys to the array.
5910 ** $wgResourceLoaderLESSFunctions is an associative array of custom LESS
5911 function names to PHP callables. See <http://leafo.net/lessphp/docs/#custom_functions>
5912 for more details regarding custom functions.
5913 ** $wgResourceLoaderLESSImportPaths is an array of file system paths. Files
5914 referenced in LESS '@import' statements are looked up here first.
5915 * ResourceLoader supports hashes as module cache invalidation trigger (instead
5916 of or in addition to timestamps).
5917 * Added $wgExtensionEntryPointListFiles for use in mergeMessageFileList.php.
5918 * Added a hook, APIQuerySiteInfoStatisticsInfo, to allow extensions to modify
5919 the output of the API query meta=siteinfo&siprop=statistics
5920 * Primary keys have been added to both the archive table and the externallinks
5921 tables.
5922 * Added $wgEnableParserLimitReporting to control whether the NewPP limit report is
5923 output in a HTML comment.
5924 * The 'UnwatchArticle' and 'WatchArticle' hooks now support a Status object
5925 instead of just a boolean return value to abort the hook.
5926 * Added a hook, SpecialWatchlistGetNonRevisionTypes, to allow extensions
5927 with custom recentchanges entries to hook into the Watchlist without
5928 clobbering each other.
5929 * A hidden, empty input field was added to the edit form, and any edit that fills
5930 it in will be rejected. This prevents against the simplest form of spambots.
5931 Previously in the "SimpleAntiSpam" extension by Ryan Schmidt.
5932 * populateRevisionLength.php maintenance script updated to also populate
5933 archive.ar_len field.
5934 * (bug 43571) DatabaseMySQLBase learned to list views, optionally filtered by a
5935 prefix. Also fixed PHPUnit test suite when using a MySQL backend containing
5936 views.
5937
5938 === Bug fixes in 1.22 ===
5939 * (bug 47271) $wgContentHandlerUseDB should be set to false during the upgrade
5940 * Disable Special:PasswordReset when $wgEnableEmail is false. Previously one
5941 could still navigate to the page by entering the URL directly.
5942 * (bug 47138) Fixed a fatal error when a blocked user tries to automatically
5943 create an account on login due external authentication in some circumstances.
5944 * (bug 23393) HTML <hN> headings containing line breaks are now handled
5945 correctly.
5946 * (bug 45803) Whitespace within == Headline == syntax and within <hN> headings
5947 is now non-significant and not preserved in the HTML output.
5948 * (bug 47218) Special:BlockList now handles correctly user names with spaces
5949 when passed as subpage.
5950 * Pager's properly validate which fields are allowed to be sorted on.
5951 * mw.util.tooltipAccessKeyRegexp: The regex now matches "option-" as well.
5952 Support for Mac "option" was added in 1.16, but the regex was never updated.
5953 * (bug 46768) Usernames of blocking users now display correctly, even if numeric.
5954 * (bug 39590) Self-transclusions now show the most up to date result always
5955 after save instead of being a revision behind.
5956 * A bias in wfRandomString() toward digits 1-7 has been corrected. Generated
5957 strings will now start with digits 0 and 8-f as often as they should.
5958 * (bug 45371) Removed Parser_LinkHooks and CoreLinkFunctions classes.
5959 * (bug 41545) Allow <kbd>, <samp>, and <var> to be nested like allowed in html.
5960 * PLURAL magic word no longer causes a PHP notice when no matching form exists.
5961 * (bug 36641) Patrol page links no longer show on non-existent revisions.
5962 * (bug 35810) Pages not linked from Special:RecentChanges or Special:NewPages
5963 are patrollable now.
5964 * (bug 30213) JavaScript for search suggestions is now disabled when the API
5965 is disabled, and AJAX patrolling and watching are now disabled when use of
5966 the write API is not allowed.
5967 * (bug 48294) API: Fix chunk upload async mode.
5968 * (bug 46749) Broken files tracking category removed from pages if an image
5969 with that name is uploaded.
5970 * (bug 14176) System messages that are empty were previously incorrectly treated
5971 as non-existent, causing a fallback to the default. This stopped users from
5972 overriding system messages to make them blank.
5973 * (bug 48319) action=parse no longer returns an error if passed none of 'oldid',
5974 'pageid', 'page', 'title', and 'text' (e.g. if only passed 'summary'). A
5975 warning will instead be issued if 'title' is non-default, unless no props are
5976 requested.
5977 * Special:Recentchangeslinked will now include upload log entries
5978 * (bug 41281) Fixed ugly output if file size could not be extracted for multi-page media.
5979 * (bug 50315) list=logevents API module will now output log entries by anonymous users.
5980 * (bug 38911) Handle headers with rowspan in jquery.tablesorter
5981 * (bug 658) Converted the table of contents on wiki pages from <table> to <div>
5982 and adjusted skin CSS accordingly. The CSS was carefully crafted to be
5983 backwards-compatible in all reasonable cases (uses of the __TOC__ magic word,
5984 the #toc CSS id and the .toc CSS class). However, particularly bad abuse of
5985 the id or the class can possibly break.
5986 * CSSJanus now supports rgb, hsl, rgba, and hsla color syntaxes.
5987 * Special:Listfiles can no longer be sorted by image name when filtering
5988 by user in miser mode.
5989 * (bug 49074) CSSJanus: Handle values of border-radius correctly.
5990 * Handle relative inclusions ({{../name}}) in main namespace with subpages
5991 enabled correctly (previously MediaWiki tried to include Template:Parent/name
5992 instead of just Parent/name).
5993 * Added $wgAPIUselessQueryPages to allow extensions to flag their query pages
5994 for non-inclusion in ApiQueryQueryPages.
5995 * (bug 50870) mediawiki.notification: Notification area should remain visible
5996 when scrolled down.
5997 * (bug 13438) Special:MIMESearch no longer an expensive special page.
5998 * (bug 48342) Fixed a fatal error when $wgValidateAllHtml is set to true and
5999 the function apache_request_headers() function is not available.
6000 * (bug 33399) LivePreview: Re-run wikipage content handlers
6001 (jquery.makeCollapsible, jquery.tablesorter) after preview content is loaded.
6002 * (bug 51891) Fixed PHP notice on Special:PagesWithProp when no properties
6003 are defined.
6004 * (bug 52006) Corrected documentation of $wgTranscludeCacheExpiry.
6005 * (bug 52077) The APIEditBeforeSave hook is giving the content of the whole
6006 revision as second argument now, rather than just the current section.
6007 * (bug 49694) $wgSpamRegex is now also applied on the new section headline text
6008 adding a new topic on a page
6009 * (bug 41756) Improve treatment of multiple comments on a blank line.
6010 * (bug 51064) Purge upstream caches when deleting file assets.
6011 * (bug 39012) File types with a mime that we do not know the extension for
6012 can no longer be uploaded as an extension that we do know the mime type
6013 for.
6014 * (bug 51742) Add data-sort-value for better sorting of hitcounts Special:Tags
6015 * (bug 26811) On DB error pages, server hostnames are now hidden when both
6016 $wgShowHostnames and $wgShowSQLErrors are false.
6017 * (bug 6200) line breaks in <blockquote> are handled like they are in <div>
6018 * (bug 14931) Default character set now set to 'utf8' when a new MySQL
6019 database is created.
6020 * (bug 47191) Fixed "Column 'si_title' cannot be part of FULLTEXT index"
6021 MySQL error when installing using the binary character set option.
6022 * (bug 45288) Support mysqli PHP extension
6023 * (bug 55818) BREAKING CHANGE: Removed undocumented 'Debug' hook in wfDebug.
6024 This resolves an infinite loop when using $wgDebugFunctionEntry = true.
6025 * (bug 56707) Correct tooltip of "Next n results" on query special pages.
6026 * (bug 56770) mw.util.addPortletLink: Check length before access array index.
6027
6028 === API changes in 1.22 ===
6029 * (bug 25553) The JSON output formatter now leaves forward slashes unescaped
6030 to improve human readability of URLs and similar strings. Also, a "utf8"
6031 option is now provided to use UTF-8 encoding instead of hex escape codes
6032 for most non-ASCII characters.
6033 * (bug 46626) xmldoublequote parameter was removed. Because of a bug, the
6034 parameter has had no effect since MediaWiki 1.16, and so its removal is
6035 unlikely to impact existing clients.
6036 * (bug 47216) action=query&meta=siteinfo&siprop=skins will now indicate which
6037 skin is the default and which are unusable (e.g. listed in $wgSkipSkins).
6038 * (bug 25325) Added support for wlshow filtering (bots/anon/minor/patrolled)
6039 to action=feedwatchlist.
6040 * WDDX formatted output will actually be formatted (and normal output will no
6041 longer be), and will no longer choke on booleans.
6042 * action=opensearch no longer silently ignores the format parameter.
6043 * action=opensearch now supports format=jsonfm.
6044 * list=usercontribs&ucprop=ids will now include the parent revision id.
6045 * BREAKING CHANGE: action=parse no longer returns all langlinks for the page
6046 with prop=langlinks by default. The new effectivelanglinks parameter will
6047 request that the LanguageLinks hook be called to determine the effective
6048 language links.
6049 * BREAKING CHANGE: list=allpages, list=langbacklinks, and prop=langlinks do not
6050 apply the new LanguageLinks hook, and thus only consider language links
6051 stored in the database.
6052 * (bug 47219) Allow specifying change type of Wikipedia feed items
6053 * prop=imageinfo now allows setting iiurlheight without setting iiurlwidth
6054 * prop=info now adds the content model and page language of the title.
6055 * New upload log entries will now contain information on the relevant
6056 image (sha1 and timestamp).
6057 * (bug 49239) action=parse now can parse in preview and section preview modes.
6058 * (bug 49259) action=patrol now accepts revision ids.
6059 * (bug 48129) list=blocks&bkip= now correctly handles IPv6 CIDR ranges and
6060 honors $wgBlockCIDRLimit. Note any clients passing invalid values to bkip
6061 will now receive an error, rather than the previous behavior listing all
6062 user blocks.
6063 * (bug 48201) action=parse&text=foo now assumes wikitext if no title is given,
6064 rather than using the content model of the page "API".
6065 * action=watch no longer silently ignores hook abort.
6066 * (bug 50785) action=purge with forcelinkupdate=1 no longer queues refreshLinks
6067 jobs in the job queue for link table updates of pages that use the given page
6068 as a template. Instead, forcerecursivelinkupdate=1 is introduced and should
6069 be used if that behaviour is desirable.
6070 * The 'debugLog' property (enabled by $wgDebugToolbar) no longer sets the log
6071 entry values through ApiResult::content but directly. This changes the JSON
6072 output from an array of objects with content in '*' to an array of strings
6073 with the content.
6074 * (bug 51342) prop=imageinfo iicontinue now contains the dbkey, not the text
6075 version of the title.
6076 * (bug 52538) action=edit will now use empty text instead of the contents
6077 of section 0 when passed prependtext or appendtext with section=new.
6078 * Support for the 'gettoken' parameter to action=block and action=unblock,
6079 deprecated since 1.20, has been removed.
6080 * (bug 49090) Token-getting functions will fail when using jsonp callbacks.
6081 * (bug 52699) action=upload returns normalized file name on warning
6082 "exists-normalized" instead of filename to be uploaded to.
6083 * (bug 53884) action=edit will now return an error when the specified section
6084 does not exist in the page.
6085 * Added meta=filerepoinfo API module for getting information about foreign
6086 file repositories, and related ForeignAPIRepo methods getInfo and getApiUrl.
6087 * The new query module list=allfileusages to enumerate file usages was added.
6088
6089 === Languages updated in 1.22 ===
6090
6091 MediaWiki supports over 350 languages. Many localisations are updated
6092 regularly. Below only new and removed languages are listed, as well as
6093 changes to languages because of Bugzilla reports.
6094
6095 * Batak Toba (bbc-latn) added.
6096 * (bug 46751) Made Buryat (Russia) (буряад) (bxr) fallback to Russian.
6097
6098 === Other changes in 1.22 ===
6099 * BREAKING CHANGE: Implementation of MediaWiki's JS and JSON value encoding
6100 has changed:
6101 ** MediaWiki no longer supports PHP installations in which the native JSON
6102 extension is missing or disabled.
6103 ** XmlJsCode objects can no longer be nested inside objects or arrays.
6104 (For Xml::encodeJsCall(), this individually applies to each argument.)
6105 ** The sets of characters escaped by default, along with the precise escape
6106 sequences used, have changed (except for the Xml::escapeJsString()
6107 function, which is now deprecated).
6108 * BREAKING CHANGE: The Services_JSON class has been removed. If necessary,
6109 be sure to upgrade affected extensions at the same time (e.g. Collection).
6110 * redirect.php was removed. It was unused.
6111 * ClickTracking integration was dropped from the mediaWiki.user.bucket
6112 JavaScript function. The 'tracked' option is now ignored.
6113 * BREAKING CHANGE: Legacy skins Simple, MySkin, Chick, Standard and Nostalgia
6114 were all removed. (Nostalgia was moved to an extension.) The SkinLegacy and
6115 LegacyTemplate classes that supported them were removed as well and are now a
6116 part of the Nostalgia extension.
6117 * Event namespace used by jquery.makeCollapsible has been changed from
6118 'mw-collapse' to 'mw-collapsible' for consistency with the module name.
6119 * BREAKING CHANGE: The "ExternalAuth" authentication subsystem was removed, along
6120 with its associated globals of $wgExternalAuthType, $wgExternalAuthConf,
6121 $wgAutocreatePolicy and $wgAllowPrefChange. Affected users are encouraged to
6122 use AuthPlugin for external authentication/authorization needs.
6123 * The Quickbar feature of the legacy skin model and the last remnants of it
6124 throughout the code base have been removed.
6125 * Externaledit/externaldiff preference was removed. Very few users used this
6126 feature, and improper configuration can actually prevent a user from editing
6127 * Calling Linker methods using a skin will now output deprecation warnings.
6128 * (bug 46680) "Return to" links are no longer tagged with rel="next".
6129 * BREAKING CHANGE: mw.util.tooltipAccessKeyRegexp: The match group for the
6130 accesskey character is now $6 instead of $5.
6131 * HipHop compiler (hphpc) support was removed. HipHop VM support (hhvm) was
6132 added.
6133 * A new Special:Redirect page was added, providing lookup by revision ID,
6134 user ID, or file name. The old Special:Filepath page was reimplemented
6135 to redirect through Special:Redirect.
6136 * Monobook: Removed the old conditional stylesheets for Opera 6, 7 and 9.
6137 * Support for XHTML 1.0 has been removed. MediaWiki now only outputs (X)HTML5.
6138 * wikibits: User-agent related globals have been deprecated. The following
6139 properties now default to false and emit mw.log.warn: is_gecko, is_chrome_mac,
6140 is_chrome, webkit_version, is_safari_win, is_safari, webkit_match, is_ff2,
6141 ff2_bugs, is_ff2_win, is_ff2_x11, opera95_bugs, opera7_bugs, opera6_bugs,
6142 is_opera_95, is_opera_preseven, is_opera, and ie6_bugs.
6143 * (bug 48276) MediaWiki will now flash a confirmation message upon successfully
6144 editing a page.
6145 * (bug 40785) mediawiki.legacy.ajax has been marked as deprecated. The following
6146 properties now emit mw.log.warn when accessed: sajax_debug, sajax_init_object,
6147 sajax_do_call and wfSupportsAjax.
6148 * BREAKING CHANGE: meta keywords are no longer supported. A <meta name="keywords"
6149 will no longer be output and OutputPage::addKeyword no longer exists.
6150 * Methods Title::userCanEditCssSubpage and Title::userCanEditJsSubpage,
6151 deprecated since 1.19, have been removed.
6152 * (bug 50134) Hook functions are no longer required to return a value. When a
6153 hook function does not return a value (or when it returns an explicit null),
6154 processing continues. To abort the hook, a hook function must return an
6155 explicit, boolean false or a string error message. Other falsey values are
6156 tantamount to a 'return true' in earlier versions of MediaWiki.
6157 * BREAKING CHANGE: The EditSectionLink hook was removed after being
6158 deprecated since MediaWiki 1.14. Use DoEditSectionLink instead.
6159 * (bug 48256) The 'editsection-brackets' optional message was removed.
6160 Section edit links' brackets can now be customized using CSS by
6161 styling span.mw-editsection-bracket.
6162 * The usePatrol function in ChangesList has been marked as deprecated.
6163 * (bug 50785) A "null edit", that is, a save action in which no changes to the
6164 page text are made and no revision recorded, will no longer send refreshLinks
6165 jobs to the job table to update pages which use the edited page as a template.
6166 * The LivePreviewPrepare and LivePreviewDone events triggered on "jQuery( mw )"
6167 have been deprecated in favour of using mw.hook.
6168 * The 'showjumplinks' user preference has been removed, jump links are now
6169 always included.
6170 * Methods RecentChange::notifyRC2UDP, RecentChange::sendToUDP, and
6171 RecentChange::cleanupForIRC have been deprecated, as it is now the
6172 responsibility of classes implementing the RCFeedFormatter and RCFeedEngine
6173 interfaces to implement the formatting and delivery for recent change
6174 notifications.
6175 * SpecialPrefixindex methods namespacePrefixForm() and showPrefixChunk() have
6176 been made protected. They were accepting form variance arguments, this is now
6177 using properties in the SpecialPrefixindex class.
6178 * (bug 50310) BREAKING CHANGE: wikibits: Drop support for mwCustomEditButtons.
6179 It defaults to an empty array and emits mw.log.warn when accessed.
6180 * BREAKING CHANGE: Special:Disambiguations has been removed from MediaWiki core.
6181 Functions related to disambiguation pages are now handled by the Disambiguator
6182 extension (https://www.mediawiki.org/wiki/Extension:Disambiguator) (bug
6183 35981).
6184 * BREAKING CHANGE: The 'mediawiki.legacy.wikiprintable' module has been removed.
6185 The skins/common/wikiprintable.css file no longer exists. Return value of
6186 Skin#commonPrintStylesheet is ignored. Please use the 'mediawiki.legacy.commonPrint'
6187 module instead or base your skin on SkinTemplate.
6188 * (bug 49629) The hook ExtractThumbParameters has been deprecated in favour
6189 of media handler overriding MediaHandler::parseParamString.
6190 * (bug 46512) The collapsibleNav feature from the Vector extension has been moved
6191 to the Vector skin in core.
6192 * SpecialRecentChanges::addRecentChangesJS() function has been renamed
6193 to addModules() and made protected.
6194 * Methods WatchAction::doWatch and WatchAction::doUnwatch now return a Status
6195 object instead of a boolean.
6196 * Information boxes (CSS classes errorbox, warningbox, successbox) have been
6197 made more subtle.
6198 * BREAKING CHANGE: The module 'mediawiki.legacy.IEFixes' has been removed as it was
6199 unused. The file skins/common/IEFixes.js remains but is only used by wikibits.
6200 The file never contained any re-usable components. To use it in a skin, load
6201 'mediawiki.legacy.wikibits' (which IEFixes depends on) and that will import
6202 IEFixes automatically if user agent conditions are met.
6203 * Code specific to the Math extension was marked as deprecated.
6204 * mediawiki.util: mw.util.wikiGetlink has been renamed to getUrl. (The old name
6205 still works, but is deprecated.)
6206
6207 = MediaWiki 1.21 =
6208
6209 == MediaWiki 1.21.11 ==
6210 This is a security and maintenance release of the MediaWiki 1.21 branch.
6211
6212 === Changes since 1.21.10 ===
6213 * (bug 65839) SECURITY: Prevent external resources in SVG files.
6214 * (bug 66428) MimeMagic: Don't seek before BOF. This has weird side effects like only extracting the tail of the file partially or not at all.
6215
6216 == MediaWiki 1.21.10 ==
6217 This is a security and maintenance release of the MediaWiki 1.21 branch.
6218
6219 === Changes since 1.21.9 ===
6220 * (bug 65501) SECURITY: Don't parse usernames as wikitext on Special:PasswordReset.
6221 * (bug 36356) Add space between two feed links.
6222
6223 == MediaWiki 1.21.9 ==
6224 This is a security and maintenance release of the MediaWiki 1.21 branch.
6225
6226 === Changes since 1.21.8 ===
6227 * (bug 63251) SECURITY: Escape sortKey in pageInfo.
6228 * (bug 58640) Fixed a compatibility issue with PCRE 8.34 that caused pages to appear blank or with missing text.
6229
6230 == MediaWiki 1.21.8 ==
6231 This is a security and maintenance release of the MediaWiki 1.21 branch.
6232
6233 === Changes since 1.21.7 ===
6234 * (bug 62497) SECURITY: Add CSRF token on Special:ChangePassword.
6235 * (bug 62467) Set a title for the context during import on the cli.
6236
6237 == MediaWiki 1.21.7 ==
6238 This is a maintenance release of the MediaWiki 1.21 branch.
6239
6240 === Changes since 1.21.6 ===
6241 * Use the correct branch of the extensions' git repositories.
6242
6243 == MediaWiki 1.21.6 ==
6244 This is a security release of the MediaWiki 1.21 branch.
6245
6246 === Changes since 1.21.5 ===
6247 * (bug 60771) SECURITY: Disallow uploading SVG files using non-whitelisted namespaces. Also disallow iframe elements. * User will get an error including the namespace name if they use a non- whitelisted namespace.
6248 * (bug 61346) SECURITY: Make token comparison use constant time. It seems like our token comparison would be vulnerable to timing attacks. This will take constant time.
6249 * (bug 61362) SECURITY: API: Don't find links in the middle of api.php links.
6250
6251 == MediaWiki 1.21.5 ==
6252 This is a security release of the MediaWiki 1.21 branch.
6253
6254 === Changes since 1.21.4 ===
6255 * (bug 60339) SECURITY: Sanitize shell arguments to DjVu files, and other media formats
6256
6257 == MediaWiki 1.21.4 ==
6258 This is a security release of the MediaWiki 1.21 branch.
6259
6260 === Changes since 1.21.3 ===
6261 * (bug 57550) SECURITY: Disallow stylesheets in SVG Uploads
6262 * (bug 58088) SECURITY: Don't normalize U+FF3C to \ in CSS Checks
6263 * (bug 58472) SECURITY: Disallow -o-link in styles
6264 * (bug 58553) SECURITY: Return error on invalid XML for SVG Uploads
6265 * (bug 58699) SECURITY: Fix RevDel log entry information leaks
6266
6267 == MediaWiki 1.21.3 ==
6268 This is a security and maintenance release of the MediaWiki 1.21 branch.
6269
6270 === Changes since 1.21.2 ===
6271 * (bug 53032) SECURITY: Don't cache when a call could autocreate
6272 * (bug 55332) SECURITY: Improve css javascript detection
6273 * (bug 49717) Fix behaviour $wgVerifyMimeType = false; in Upload
6274 * Fix comma errors in various js files
6275 * Translations
6276
6277 == MediaWiki 1.21.2 ==
6278 This is a security and maintenance release of the MediaWiki 1.21 branch.
6279
6280 === Changes since 1.21.1 ===
6281 * SECURITY: Fix extension detection with 2 .'s
6282 * SECURITY: Support for the 'gettoken' parameter to action=block and action=unblock, deprecated since 1.20, has been removed.
6283 * SECURITY: Sanitize ResourceLoader exception messages
6284 * Purge upstream caches when deleting file assets.
6285 * Unit test suite now runs the AutoLoader tests. Also fixed the autoloading entry for the PageORMTableForTesting class though it had no impact.
6286
6287 == MediaWiki 1.21.1 ==
6288 This is a maintenance release of the MediaWiki 1.21 branch.
6289
6290 === Changes since 1.21.0 ===
6291 * An incorrect version number was used for 1.21.0. 1.21.1 has the correct number.
6292 * A problem with the Oracle SQL table creation was fixed.
6293 * (PdfHandler extension) Fix warning if pdfinfo fails but pdftext succeeds.
6294
6295 == MediaWiki 1.21.0 ==
6296
6297 === Configuration changes in 1.21 ===
6298 * (bug 29374) $wgVectorUseSimpleSearch is now enabled by default.
6299 * Deprecated $wgAllowRealName is removed. Use $wgHiddenPrefs[] = 'realname'
6300 instead.
6301 * (bug 39957) Added $wgUnwatchedPageThreshold, specifying minimum count
6302 of page watchers required for the number to be accessible to users
6303 without the unwatchedpages permission.
6304 * $wgBug34832TransitionalRollback has been removed.
6305 * (bug 29472) $wgUseDynamicDates has been removed and its functionality
6306 disabled.
6307
6308 === New features in 1.21 ===
6309 * (bug 38110) Schema changes (adding or dropping tables, indices and
6310 fields) can be now be done separately from other changes that
6311 update.php makes. This is useful in environments that use database
6312 permissions to restrict schema changes but allow the DB user that
6313 MediaWiki normally runs as to perform other changes that update.php
6314 makes. Schema changes can be run separately. See the file UPGRADE
6315 for more information.
6316 * (bug 34876) jquery.makeCollapsible has been improved in performance.
6317 * Added ContentHandler facility to allow extensions to support other content
6318 than wikitext. See docs/contenthandler.txt for details.
6319 * New feature was developed for showing high-DPI thumbnails for high-DPI mobile
6320 and desktop displays (configurable with $wgResponsiveImages).
6321 * Added new backend to represent and store information about sites and site
6322 specific configuration.
6323 * jQuery upgraded from 1.8.2 to 1.8.3.
6324 * jQuery UI upgraded from 1.8.23 to 1.8.24.
6325 * Added separate fa_sha1 field to filearchive table. This allows sha1
6326 searches with the api in miser mode for deleted files.
6327 * Add initial and programmatic sorting for tablesorter.
6328 * Add the event "sortEnd.tablesorter", triggered after sorting has completed.
6329 * The Job system was refactored to allow for different backing stores for
6330 queues as well as cross-wiki access to queues, among other things. The schema
6331 for the DB queue was changed to support better concurrency and reduce
6332 deadlock errors.
6333 * Added ApiQueryORM class to facilitate creation of query API modules based on
6334 tables that have a corresponding ORMTable class.
6335 * (bug 40876) Icon for PSD (Adobe Photoshop) file types.
6336 * (bug 40641) Implemented Special:Version/Credits with a list of contributors.
6337 * (bug 7851) Implemented one-click AJAX patrolling.
6338 * The <data>, <time>, <meta>, and <link> elements are allowed within WikiText
6339 for use with Microdata.
6340 * The HTML5 <mark> tag has been whitelisted.
6341 * Added ParserCloned hook for when the Parser object is cloned.
6342 * Added AlternateEditPreview hook to allow extensions to replace the page
6343 preview from the edit page.
6344 * Added EditPage::showStandardInputs:options hook to allow extensions to add
6345 new fields to the "editOptions" area of the edit form.
6346 * Upload stash DB schema altered to improve upload performance.
6347 * The following global functions are now reporting deprecated warnings in
6348 debug mode: wfMsg, wfMsgNoTrans, wfMsgForContent, wfMsgForContentNoTrans,
6349 wfMsgReal, wfMsgGetKey, wfMsgHtml, wfMsgWikiHtml, wfMsgExt, wfEmptyMsg. Use
6350 the Message class, or the global method wfMessage.
6351 * Added $wgEnableCanonicalServerLink, off by default. If enabled, a
6352 <link rel=canonical> tag is added to every page indicating the correct server
6353 to use.
6354 * Debug message emitted by wfDebugLog() will now be prefixed with the group
6355 name when its logged to the default log file. That is the case whenever the
6356 group has no key in wgDebugLogGroups, that will help triage the default log.
6357 * (bug 24620) Add types to LogFormatter.
6358 * jQuery JSON upgraded from 2.3 to 2.4.0.
6359 * Added GetDoubleUnderscoreIDs hook, for modifying the list of magic words.
6360 * DatabaseUpdater class has two new methods to ease extensions schema changes:
6361 dropExtensionIndex and renameExtensionIndex.
6362 * New preference type - 'api'. Preferences of this type are not shown on
6363 Special:Preferences, but are still available via the action=options API.
6364 * (bug 39397) Hide rollback link if a user is the only contributor of the page.
6365 * $wgPageInfoTransclusionLimit limits the list size of transcluded articles
6366 on the info action. Default is 50.
6367 * Added action=createaccount to allow user account creation.
6368 * (bug 40124) action=options API also allows for setting of arbitrary
6369 preferences, provided that their names are prefixed with 'userjs-'. This
6370 officially reenables the feature that was undocumented and defective
6371 in MW 1.20 (saving preferences using Special:Preferences cleared any
6372 additional fields) and which has been disabled in 1.20.1 as a part of
6373 a security fix (bug 42202).
6374 * Added option to specify "others" as author in extension credits using
6375 "..." as author name.
6376 * Added the ability to limit the wall clock time used by shell processes,
6377 as well as the CPU time. Configurable with $wgMaxShellWallClockTime.
6378 * Allow memory of shell subprocesses to be limited using Linux cgroups
6379 instead of ulimit -v, which tends to cause deadlocks in recent versions
6380 of ImageMagick. Configurable with $wgShellCgroup.
6381 * Added $wgWhitelistReadRegexp for regex whitelisting.
6382 * (bug 5346) Categories that are redirects will be displayed italic in
6383 the category links section at the bottom of a page.
6384 * (bug 43915) New maintenance script deleteEqualMessages.php.
6385 * You can now create checkbox option matrices through the HTMLCheckMatrix
6386 subclass in HTMLForm.
6387 * WikiText now permits the use of WAI-ARIA's role="presentation" inside of
6388 html elements and tables. This allows presentational markup, especially
6389 tables. To be marked up as such.
6390 * maintenance/sql.php learned the --cluster option. Let you run the script
6391 on some external cluster instead of the primary cluster for a given wiki.
6392 * (bug 20281) test the parsing of inline URLs.
6393 * Added Special:PagesWithProp, which lists pages using a particular page property.
6394 * Implemented language-specific collations for category sorting for 67 languages
6395 based in latin, greek and cyrillic alphabets. This allows one to *finally* get
6396 articles to be correctly sorted on category pages. They are named
6397 'uca-<langcode>', where <langcode> is one of: af, ast, az, be, bg, br, bs, ca,
6398 co, cs, cy, da, de, dsb, el, en, eo, es, et, eu, fi, fo, fr, fur, fy, ga, gd,
6399 gl, hr, hsb, hu, is, it, kk, kl, ku, ky, la, lb, lt, lv, mk, mo, mt, nl, no,
6400 oc, pl, pt, rm, ro, ru, rup, sco, sk, sl, smn, sq, sr, sv, tk, tl, tr, tt, uk,
6401 uz, vi.
6402 * Added 'CategoryAfterPageAdded' and 'CategoryAfterPageRemoved' hooks.
6403 * Added 'HistoryRevisionTools' and 'DiffRevisionTools' hooks.
6404 * Added 'SpecialSearchResultsPrepend' and 'SpecialSearchResultsAppend' hooks.
6405 * (bug 33186) Add image rotation api "imagerotate"
6406 * (bug 34040) Add "User rights management" link on user page toolbox.
6407 * (bug 45526) Add QUnit assertion helper "QUnit.assert.htmlEqual" for asserting
6408 structual equality of HTML (ignoring insignificant differences like
6409 quotmarks, order and whitespace in the attribute list).
6410 * (bug 23393) HTML <hN> headings containing line breaks are now handled
6411 correctly.
6412 * (bug 45803) Whitespace within == Headline == syntax and within <hN> headings
6413 is now non-significant and not preserved in the HTML output.
6414
6415 === Bug fixes in 1.21 ===
6416 * (bug 40353) SpecialDoubleRedirect should support interwiki redirects.
6417 * (bug 40352) fixDoubleRedirects.php should support interwiki redirects.
6418 * (bug 9237) SpecialBrokenRedirect should not list interwiki redirects.
6419 * (bug 34960) Drop unused fields rc_moved_to_ns and rc_moved_to_title from
6420 recentchanges table.
6421 * (bug 32951) Do not register internal externals with absolute protocol,
6422 when server has relative protocol.
6423 * (bug 39005) When purging proxies listed in $wgSquidServers using HTTP PURGE
6424 method requests, we now send a Host header by default, for Varnish
6425 compatibility. This also works with Squid in reverse-proxy mode. If you wish
6426 to support Squid configured in forward-proxy mode, set
6427 $wgSquidPurgeUseHostHeader to false.
6428 * (bug 37020) sql.php with readline eats semicolon.
6429 * (bug 11748) Properly handle optionally-closed HTML tags when Tidy is
6430 disabled, and don't wrap HTML-syntax definition lists in paragraphs.
6431 * (bug 41409) Diffs while editing an old revision should again diff against the
6432 current revision.
6433 * (bug 41494) Honor $wgLogExceptionBacktrace when logging non-API exceptions
6434 caught during API execution.
6435 * (bug 37963) Fixed loading process for user options.
6436 * (bug 26995) Update filename field on Upload page after having sanitized it.
6437 * (bug 41793) Contribution links to users with 0 edits on Special:ListUsers
6438 didn't show up red.
6439 * (bug 41899) A PHP notice no longer occurs when using the "rvcontinue" API
6440 parameter.
6441 * (bug 42036) Account creation emails now contain canonical (not
6442 protocol-relative) URLs.
6443 * (bug 41990) Fix regression: API edit with redirect=true and lacking
6444 starttimestamp and basetimestamp should not cause an edit conflict.
6445 * (bug 41706) EditPage: Preloaded page should be converted if possible and
6446 needed.
6447 * (bug 41886) Rowspans are no longer exploded by tablesorter until the table is
6448 actually sorted.
6449 * (bug 2865) User interface HTML elements don't use lang attribute.
6450 (completed the fix by adding the lang attribute to firstHeading).
6451 * (bug 42173) Removed namespace prefixes on Special:UncategorizedCategories.
6452 * (bug 36053) Log in "returnto" feature forgets query parameters if no
6453 title parameter was specified.
6454 * (bug 42410) API action=edit now returns correct timestamp for the new edit.
6455 * (bug 14901) Email notification mistakes log action for new page creation.
6456 Enotif no longer sends "page has been created" notifications for some log
6457 actions. The following events now have a correct message: page creation,
6458 deletion, move, restore (undeletion), change (edit). Parameter
6459 $CHANGEDORCREATED is deprecated in 'enotif_body' and scheduled for removal in
6460 MediaWiki 1.23.
6461 * (bug 457) In the sidebar of Vector, CologneBlue, Monobook, and Monobook-based
6462 skins, the heading levels have been changed from (variously per skin)
6463 <h4>, <h5> or <h6> to only <h3>s, with a <h2> hidden heading above them.
6464 If you are styling or scripting the headings in a custom way, this change
6465 will require updates to your site's CSS or JS.
6466 * (bug 41342) jquery.suggestions should cancel any active (async) fetches
6467 before it triggers another fetch.
6468 * (bug 42184) $wgUploadSizeWarning missing second variable.
6469 * (bug 34581) removeUnusedAccounts.php maintenance script now ignores newuser
6470 log when determining whether an account is used.
6471 * (bug 43379) Gracefully fail if rev_len is unavailable for a revision on the
6472 History page.
6473 * (bug 42949) API no longer assumes all exceptions are MWException.
6474 * (bug 41733) Hide "New user message" (.usermessage) element from printable view.
6475 * (bug 39062) Special:Contributions will display changes that don't have
6476 a parent id instead of just an empty bullet item.
6477 * (bug 37209) "LinkCache doesn't currently know about this title" error fixed.
6478 * wfMerge() now works if $wgDiff3 contains spaces
6479 * (bug 43052) mediawiki.action.view.dblClickEdit.dblClickEdit should trigger
6480 ca-edit click instead opening URL directly.
6481 * (bug 43964) Invalid value of "link" parameter in <gallery> no longer produces
6482 a fatal error.
6483 * (bug 44775) The username field is not pre-filled when creating an account.
6484 * (bug 45069) wfParseUrl() no longer produces a PHP notice if passed a "mailto:"
6485 URL without address
6486 * (bug 45012) Creating an account by e-mail can no longer show a
6487 "password mismatch" error.
6488 * (bug 44599) On Special:Version, HEADs for submodule checkouts (e.g. for
6489 extensions) performed using Git 1.7.8+ should now appear.
6490 * (bug 42184) $wgUploadSizeWarning missing second variable
6491 * (bug 40326) Check if files exist with a different extension during uploading
6492 * (bug 34798) Updated CSS for Atom/RSS recent changes feeds to match on-wiki diffs.
6493 * (bug 42430) Calling numRows on MySQL no longer propagates unrelated errors.
6494 * (bug 44719) Removed mention of non-existing maintenance/migrateCurStubs.php
6495 script in includes/DefaultSettings.php
6496 * (bug 45143) jquery.badge: Treat non-Latin variants of zero as zero as well.
6497 * (bug 46151) mwdocgen.php should not ignore exit code of doxygen command.
6498 * (bug 41889) Fix $.tablesorter rowspan exploding for complex cases.
6499
6500 === API changes in 1.21 ===
6501 * prop=revisions can now report the contentmodel and contentformat.
6502 See docs/contenthandler.txt.
6503 * action=edit and action=parse now support contentmodel and contentformat
6504 parameters to control the interpretation of page content.
6505 See docs/contenthandler.txt for details.
6506 * (bug 35693) ApiQueryImageInfo now suppresses errors when unserializing metadata.
6507 * (bug 40111) Disable minor edit for page/section creation by API.
6508 * (bug 41042) Revert change to action=parse&page=... behavior when the page
6509 does not exist.
6510 * (bug 27202) Add timestamp sort to list=allimages.
6511 * (bug 43137) Don't return the sha1 of revisions through the API if the content is
6512 revision-deleted.
6513 * ApiQueryImageInfo now also returns imageinfo for redirects.
6514 * list=alltransclusions added to enumerate every instance of page embedding
6515 * list=alllinks & alltransclusions now allow both 'from' and 'continue' in
6516 the same query. When both are present, 'from' is simply ignored.
6517 * list=alllinks & alltransclusions now allow 'unique' in generators, to yield
6518 a list of all link/template target pages instead of source pages.
6519 * BREAKING CHANGE: list=logevents output format changed for details of some log
6520 types. Specifically, details that were formerly reported under a key like
6521 "4::foo" will now be reported under a key of simply "foo".
6522 * BREAKING CHANGE: '??_badcontinue' error code was changed to '??badcontinue'
6523 for all query modules.
6524 * ApiQueryBase adds 'badcontinue' error code if module has 'continue' parameter.
6525 * (bug 35885) Removed version parameter and all getVersion() methods.
6526 * action=options now takes a "resetkinds" option, which allows only resetting
6527 certain types of preferences when the "reset" option is set.
6528 * (bug 36751) ApiQueryImageInfo now returns imageinfo for the redirect target
6529 when queried with &redirects=.
6530 * (bug 31849) ApiQueryImageInfo no longer gets confused when asked for info on
6531 a redirect and its target.
6532 * (bug 43849) ApiQueryImageInfo no longer throws exceptions with ForeignDBRepo
6533 redirects.
6534 * On error, any warnings generated before that error will be shown in the result.
6535 * action=help supports generalized submodules (modules=query+value), querymodules obsolete
6536 * ApiQueryImageInfo continuation is more reliable. The only major change is
6537 that the imagerepository property will no longer be set on page objects not
6538 processed in the current query (i.e. non-images or those skipped due to
6539 iicontinue).
6540 * Add supports for all pageset capabilities - generators, redirects, converttitles to
6541 action=purge and action=setnotificationtimestamp.
6542 * (bug 43251) prop=pageprops&ppprop= now accepts multiple props to query.
6543 * ApiQueryImageInfo will now limit the number of calls to File::transform made
6544 in any one query. If there are too many, iicontinue will be returned.
6545 * action=query&meta=siteinfo&siprop=general will now return the regexes used for
6546 link trails and link prefixes. Added for Parsoid support.
6547 * Added an API query module list=pageswithprop, which lists pages using a
6548 particular page property.
6549 * Added an API query module list=pagepropnames, which lists all page prop names
6550 currently in use on the wiki.
6551 * (bug 44921) ApiMain::execute() will now return after the CORS check for an
6552 HTTP OPTIONS request.
6553 * (bug 44923) action=upload works correctly if the entire file is uploaded in
6554 the first chunk.
6555 * Added 'continue=' parameter to streamline client iteration over complex query results
6556 * (bug 44909) API parameters may now be marked as type "upload", which is now
6557 used for action=upload's 'file' and 'chunk' parameters. This type will raise
6558 an error during parameter validation if the parameter is given but not
6559 recognized as an uploaded file.
6560 * (bug 44244) prop=info may now return the number of people watching each page.
6561 * (bug 33304) list=allpages will no longer return duplicate entries when
6562 querying protection.
6563 * (bug 33304) list=allpages will now find really old indefinite protections.
6564 * (bug 45937) meta=allmessages will report a syntactically invalid lang as a
6565 proper error instead of as an uncaught exception.
6566 * (bug 25325) added support for wlshow filtering (bots/anon/minor/patrolled)
6567 to action=feedwatchlist
6568 * WDDX formatted output will actually be formatted (and normal output will no
6569 longer be), and will no longer choke on booleans.
6570
6571 === API internal changes in 1.21 ===
6572 * For debugging only, a new global $wgDebugAPI removes many API restrictions when true.
6573 Never use on the production servers, as this flag introduces security holes.
6574 Whenever enabled, a warning will also be added to all output.
6575 * ApiModuleManager now handles all submodules (actions,props,lists) and instantiation
6576 * Query stores prop/list/meta as submodules
6577 * ApiPageSet can now be used in any action to process titles/pageids/revids or any generator.
6578 * BREAKING CHANGE: ApiPageSet constructor now has two params instead of three, with only the
6579 first one keeping its meaning. ApiPageSet is now derived from ApiBase.
6580 * BREAKING CHANGE: ApiQuery::newGenerator() and executeGeneratorModule() were deleted.
6581 * ApiQueryGeneratorBase::setGeneratorMode() now requires a pageset param.
6582 * $wgAPIGeneratorModules is now obsolete and will be ignored.
6583 * Added flags ApiResult::OVERRIDE and ADD_ON_TOP to setElement() and addValue()
6584 * Internal API calls will now include <warnings> in case of unused parameters
6585
6586 === Languages updated in 1.21 ===
6587
6588 MediaWiki supports over 350 languages. Many localisations are updated
6589 regularly. Below only new and removed languages are listed, as well as
6590 changes to languages because of Bugzilla reports.
6591
6592 * South Azerbaijani (azb) added.
6593 * (bug 30040) Autonym for nds-nl is now 'Nedersaksies' (was 'Nedersaksisch').
6594 * (bug 45436) Autonym for pi (Pali) is now 'पालि' (was ''पाळि').
6595 * (bug 34977) Now formatted numbers in Spanish use space as separator
6596 for thousands, as mandated by the Real Academia Española.
6597 * (bug 35031) Kurdish formatted numbers now use period and comma
6598 as separators for thousands and decimals respectively.
6599
6600 === Other changes in 1.21 ===
6601 * BREAKING CHANGE: (bug 44385) Removed the jquery.collapsibleTabs module and
6602 moved it to the Vector extension. It was entirely Vector-extension-specific,
6603 deeply interconnected with the extension, and this functionality really
6604 belongs to the extension instead of the skin anyway. In the unlikely case you
6605 were using it, you have to either copy it to your extension, or install the
6606 Vector extension (and possibly disable its features using config settings if
6607 you don't want them).
6608 * Experimental IBM DB2 support was removed due to lack of interest and maintainership
6609 * BREAKING CHANGE: Filenames of maintenance scripts were standardized into
6610 lowerCamelCase format, and made more explicit:
6611 - clear_stats.php -> clearCacheStats.php
6612 - clear_interwiki_cache.php -> clearInterwikiCache.php
6613 - initStats.php -> initSiteStats.php
6614 - proxy_check.php -> proxyCheck.php
6615 - stats.php -> showCacheStats.php
6616 - showStats.php -> showSiteStats.php.
6617 Class names were renamed accordingly:
6618 - clear_stats -> ClearCacheStats
6619 - InitStats -> InitSiteStats
6620 - CacheStats -> ShowCacheStats
6621 - ShowStats -> ShowSiteStats.
6622 * BREAKING CHANGE: (bug 38244) Removed the mediawiki.api.titleblacklist module
6623 and moved it to the TitleBlacklist extension.
6624
6625 = MediaWiki 1.20 =
6626
6627 == MediaWiki 1.20.8 ==
6628 This is a security release of the MediaWiki 1.20 branch.
6629
6630 === Changes since 1.20.7 ===
6631 * (bug 53032) SECURITY: Don't cache when a call could autocreate
6632 * (bug 55332) SECURITY: Improve css javascript detection
6633 * (bug 49717) Fix behaviour $wgVerifyMimeType = false; in Upload
6634 * Fix comma errors in various js files
6635 * Translations
6636
6637 == MediaWiki 1.20.7 ==
6638 This is a security release of the MediaWiki 1.20 branch.
6639
6640 === Changes since 1.20.6 ===
6641 * SECURITY: Fix extension detection with 2 .'s
6642 * SECURITY: Token-getting functions will fail when using jsonp callbacks.
6643 * SECURITY: Sanitize ResourceLoader exception messages
6644 * Purge upstream caches when deleting file assets.
6645
6646 == MediaWiki 1.20.6 ==
6647 This is a security and maintenance release of the MediaWiki 1.20 branch.
6648
6649 === Changes since 1.20.5 ===
6650 * (bug 48306) SECURITY: Run file validation checks on chunked uploads, and chunks of upload, during the upload process.
6651 * (bug 44327) mediawiki.user: Use session ID instead of 1-year cross-session cookies
6652 * (bug 47202) wikibits: FF2Fixes.css should not be loaded in Firefox 20.
6653 * (bug 31044) Make ResourceLoader behave in read-only mode
6654
6655 == MediaWiki 1.20.5 ==
6656 This is a security and maintenance release of the MediaWiki 1.20 branch.
6657
6658 === Changes since 1.20.4 ===
6659 * (bug 46590) Add hook AbortChangePassword to Special:ChangePassword
6660 * (bug 47304) SECURITY: Check SVG xml encoding against whitelist
6661 * Localisation updates from http://translatewiki.net.
6662 * mwdocgen.php: Implement --version option.
6663 * Remove svnstat stuff used in Doxygen generation
6664 * (bug 43594) Correctly suppress warnings that were missed after the upstream
6665 * PHP change to E_STRICT being included in E_ALL.
6666
6667 == MediaWiki 1.20.4 ==
6668 This is a security release of the MediaWiki 1.20 branch.
6669
6670 === Changes since 1.20.3 ===
6671 * (bug 47251) SECURITY: Disable external entities in Import
6672 * (bug 46859) SECURITY: Disable external entities in XMLReader
6673 * (bug 46084) SECURITY: Sanitize $limitReport before outputting
6674
6675 == MediaWiki 1.20.3 ==
6676 This is a security and maintenance release of the MediaWiki 1.20 branch.
6677
6678 === Changes since MediaWiki 1.20.2 ===
6679 * New preference type - 'api'. Preferences of this type are not shown on Special:Preferences, but are still available via the action=options API. (Unbreaks MLEB.)
6680 * (bug 44010) Context is passed to UserGetLanguageObject.
6681 * The recursion guard on RequestContext::getLanguage() was weakened.
6682 * (bug 40585) Don't drop 'step="any"' in HTML input fields.
6683 * (bug 44024) Fixed problems in ObjectCache when using XCache.
6684 * (bug 44010) FauxRequest leaked cookie data from primary request.
6685 * (bug 44135/bug 42441) Pass '2' instead of 'true' to CURLOPT_SSL_VERIFYHOST
6686 * (bug 43518) API action=unblock should return the user name, not the full user object
6687 * (bug 45355) Prevent read of arbitrary files through mwdoc-filter.php
6688
6689 == MediaWiki 1.20.2 ==
6690 This is a maintenance release of the MediaWiki 1.20 branch
6691
6692 === Changes since MediaWiki 1.20.1 ===
6693 * (bug 42638) Fix API action=options&reset=1 & unit tests.
6694 * (bug 42370) Fixed backport of 60cc060 to use mDoneWrites — caused * (bug 42592) User rights, preferences and other things are not saving in 1.20.1.
6695
6696 == MediaWiki 1.20.1 ==
6697 This is a security release of the MediaWiki 1.20 branch
6698
6699 === Changes since 1.20.0 ===
6700 * (bug 42202) Validate options to prevent html injection
6701 * (bug 40995) Prevent session fixation in Special:UserLogin (CVE-2012-5391)
6702 * (bug 41400) Prevent linker regex from exceeding PCRE backtrack limit
6703 * Javscript Lint fixes
6704 * (bug 40632) Remove CleanupPresentationalAttributes feature
6705 * [Database] Fixed case where trx idle callbacks might be lost.
6706
6707 == MediaWiki 1.20.0 ==
6708
6709 === PHP 5.3 now required ===
6710 Since 1.20, the lowest supported version of PHP is now 5.3.2. Please
6711 upgrade PHP if you have not done so prior to upgrading MediaWiki.
6712
6713 === Configuration changes in 1.20 ===
6714 * $wgGitRepositoryViewers defines a mapping from Git remote repository to the
6715 Gitweb instance URL used in Special:Version.
6716 * `$wgUsePathInfo = true;` is no longer needed to make $wgArticlePath work on servers
6717 using like nginx, lighttpd, and apache over fastcgi. MediaWiki now always extracts
6718 path info from REQUEST_URI if it's available.
6719 * The user right 'upload_by_url' is no longer given to sysops by default.
6720 This only affects installations which have $wgAllowCopyUploads set to true.
6721 * Removed f-prot support from $wgAntivirusSetup.
6722 * New variable $wgDBerrorLogTZ to provide dates in the error log in a
6723 different timezone than the wiki timezone set by $wgLocaltimezone.
6724 * New variables $wgDBssl and $wgDBcompress to enable SSL and compression for database
6725 connections, if either are available for the selected DB type.
6726 * $wgUseCombinedLoginLink now defaults to false, making MediaWiki output separate
6727 login and create account links by default.
6728
6729 === New features in 1.20 ===
6730 * Added TitleIsAlwaysKnown hook which gets called when determining if a page exists.
6731 * Added NamespaceIsMovable hook which gets called when determining if pages in a
6732 certain namespace can be moved.
6733 * Added SpecialPageBeforeExecute hook which gets called before SpecialPage::execute.
6734 * Added SpecialPageAfterExecute hook which gets called after SpecialPage::execute.
6735 * Added ORMTable, ORMRow and ORMResult classes for additional abstraction of
6736 database interaction.
6737 * Added CacheHelper and associated SpecialCachedPage and CachedAction helper classes.
6738 * (bug 32341) Add upload by URL domain limitation.
6739 * &useskin=default will now always display the default skin. Useful for users with a
6740 preference for the non-default skin to look at something using the default skin.
6741 * (bug 27619) Remove preference option to display broken links as link?
6742 * (bug 34896) jQuery JSON plugin upgraded to v2.3 (2011-09-17).
6743 * (bug 34302) Add CSS classes to email fields in user preferences.
6744 * Introduced $wgDebugDBTransactions to trace transaction status (currently PostgreSQL only).
6745 * (bug 23795) Add parser itself to ParserMakeImageParams hook.
6746 * Introduce a cryptographic random number generator source api for use when
6747 generating various tokens.
6748 * (bug 30963) Option on Special:Prefixindex and Special:Allpages to not show redirects.
6749 * (bug 18062) New message when edit or create the local page of a shared file.
6750 * (bug 22870) Separate interface message when creating a page.
6751 * (bug 17615) nosummary option should be reassigned on preview/captcha.
6752 * (bug 34355) Add a variable and parser function for the namespace number.
6753 * (bug 35649) Special:Version now shows hashes of extensions checked out from git.
6754 * (bug 35728) Git revisions are now linked on Special:Version.
6755 * "Show Changes" on default messages shows now diff against default message text
6756 * (bug 23006) create #speciale parser function.
6757 * generateSitemap can now optionally skip redirect pages.
6758 * (bug 27757) New API command just for retrieving tokens (not page-based).
6759 * Added GitViewers hook for extensions using external git repositories to have a web-based
6760 repository viewer linked to from Special:Version.
6761 * Memcached debug logs can now be sent to their own file logs by setting
6762 $wgDebugLogFile['memcached'] to some filepath.
6763 * (bug 35685) api.php URL and other entry point URLs are now listed on
6764 Special:Version
6765 * Edit notices can now be translated.
6766 * jQuery upgraded to 1.8.2.
6767 * jQuery UI upgraded to 1.8.23.
6768 * QUnit upgraded from v1.2.0 to v1.10.0.
6769 * (bug 37604) jquery.cookie upgraded to 2011 version.
6770 * (bug 22887) Add warning and tracking category for preprocessor errors
6771 * (bug 31704) Allow selection of associated namespace on the watchlist
6772 * (bug 5445) Now remove autoblocks when a user is unblocked.
6773 * Added $wgLogExceptionBacktrace, on by default, to allow logging of exception
6774 backtraces.
6775 * Added device detection for determining device capabilities.
6776 * QUnit.newMwEnvironment now supports passing a custom setup and/or teardown function.
6777 Arguments signature has changed. First arguments is now an options object of which
6778 'config' can be a property. Previously 'config' itself was the first and only argument.
6779 * New getCreator and getOldestRevision methods added to WikiPage class
6780 * (bug 4220) the XML dump format schema now have unique identity constraints
6781 for page and revision identifiers. Patch by Elvis Stansvik.
6782 * cleanupSpam.php now can delete spam pages if --delete was specified instead of blanking
6783 them.
6784 * Added new hook ChangePasswordForm to allow adding of additional fields in Special:ChangePassword
6785 * Added new function getDomain to AuthPlugin for getting a user's domain
6786 * (bug 23427) New magic word {{PAGEID}} which gives the current page ID.
6787 Will be null on previewing a page being created.
6788 * (bug 37627) UserNotLoggedIn() exception to show a generic error page whenever
6789 a user is not logged in.
6790 * Watched status in changes lists are no longer indicated by <strong></strong>
6791 tags with class "mw-watched". Instead, each line now has a class
6792 "mw-changeslist-line-watched" or "mw-changeslist-line-not-watched", and the
6793 title itself is surrounded by <span></span> tags with class "mw-title".
6794 * Added ContribsPager::reallyDoQuery hook allowing extensions to data to MyContribs
6795 * Added new hook ParserAfterParse to allow extensions to affect parsed output
6796 after the parse is complete but before block level processing, link holder
6797 replacement, and so on.
6798 * (bug 34678) Added InternalParseBeforeSanitize hook which gets called during Parser's
6799 internalParse method just before the parser removes unwanted/dangerous HTML tags.
6800 * Added new hook AfterFinalPageOutput to allow modifications to buffered page output before sent
6801 to the client.
6802 * (bug 36783) Implement jQuery Promise interface in mediawiki.api module.
6803 * Make dates in sortable tables sort according to the page content language
6804 instead of the site content language
6805 * (bug 37926) Deleterevision will no longer allow users to delete log entries,
6806 the new deletelogentry permission is required for this.
6807 * (bug 14237) Allow PAGESINCATEGORY to distinguish between 'all', 'pages', 'files'
6808 and 'subcats'
6809 * (bug 38362) Make Special:Listuser includeable on wiki pages.
6810 * Added support in jquery.localize for placeholder attributes.
6811 * (bug 38151) Implemented mw.user.getRights for getting and caching the current
6812 user's user rights.
6813 * Session storage can now configured independently of general object cache
6814 storage, by using $wgSessionCacheType. $wgSessionsInMemcached has been
6815 renamed to $wgSessionsInObjectCache, with the old name retained for backwards
6816 compatibility. When this feature is enabled, the expiry time can now be
6817 configured with $wgObjectCacheSessionExpiry.
6818 * Added a Redis client for object caching.
6819 * Implemented mw.user.getGroups for getting and caching user groups.
6820 * (bug 37830) Added $wgRequirePasswordforEmailChange to control whether password
6821 confirmation is required for changing an email address or not.
6822 * HTMLForm mutators can now be chained (they return $this)
6823 * A new message, "api-error-filetype-banned-type", is available for formatting
6824 API upload errors due to the file extension blacklist.
6825 * New hook 'ParserTestGlobals' allows to set globals before running parser tests.
6826 * Allow importing pages as subpage.
6827 * Add lang and hreflang attributes to language links on Login page.
6828 * (bug 22749) Create Special:MostInterwikis.
6829 * Show change tags when transclude Special:Recentchanges(linked) or Special:Newpages.
6830 * (bug 23226) Add |class= parameter to image links in order to add class(es) to HTML img tag.
6831 * (bug 39431) SVG animated status is now shown in long description.
6832 * (bug 39376) jquery.form upgraded to 3.14.
6833 * SVG files will now show the actual width in the SVG's specified units
6834 in the metadata box.
6835 * Added ResourceLoader module "jquery.jStorage" (v0.3.0, http://jStorage.info/).
6836 * (bug 39273) Added AJAX support for "Show changes" (diff) in LivePreview.
6837 * Added ResourceLoader module "jquery.badge".
6838 * mw.util.$content now points to the overall content area in the skin rather than just
6839 page text content area. If you need the old behavior please use $( '#mw-content-text').
6840 * jsMessage has been replaced with a floating bubble notification system complete
6841 with auto-hide, multi-message support, and message replacement tags.
6842 * jquery.messageBox which appears to be unused by both core and extensions has
6843 been removed.
6844 * (bug 34939) Made link parsing insensitive ([HttP://]).
6845 * (bug 40072) Add CSS classes to items in output of ChangesList pages.
6846 * Added $wgCopyUploadProxy global to define which proxy to use for copy
6847 uploads.
6848 * (bug 40448) mediawiki.legacy.mwsuggest has been replaced with a new module,
6849 mediawiki.searchSuggest, based on SimpleSearch from Extension:Vector.
6850
6851 === Known issues in 1.20.0 ===
6852 These are issues that we're targeting to be fixed in a later release
6853 in the 1.20 series. Issues may be added or removed from this list as
6854 we see fit. For now, it is comprised of those bugs on the 1.20.0
6855 milestone in Bugzilla.
6856
6857 * (bug 35894): Reports of secret key generation "hanging" on windows
6858 This is probably a bug that has been fixed in PHP. If you run
6859 into this, try upgrading your PHP.
6860 * (bug 38334): PHP Notice: Undefined index: href in /www/w/skins/Vector.php on line 416
6861 We think this is a problem in some extension. If you see this,
6862 try disabling your extensions and check out the logging patch on
6863 this bug. Or try this patch:
6864 <https://gerrit.wikimedia.org/r/#/c/27937/1/skins/Vector.php>
6865 * (bug 39268): [Regression] Toolbar inserts in main textarea only (instead of the focussed textarea)
6866 This should only be an issue if you are using the ProofreadPage
6867 extension.
6868 * (bug 40641): Clicking "others" in Special:Version asks to download a file
6869 If you encounter this, you can tell your webserver to serve the
6870 CREDITS file with text/plain MIME type to fix it.
6871
6872 === Bug fixes in 1.20 ===
6873 * (bug 40939): [Regression] InfoAction: Call to a member function getUserText() on a non-object
6874 * (bug 40780): searchsuggest-containing line ("containing...") doesn't include the entered text
6875 * (bug 37714): [Regression] Incomplete log entries
6876 * (bug 27202): API: Add timestamp sort to list=allimages
6877 * (bug 30245) Use the correct way to construct a log page title.
6878 * (bug 34237) Regenerate an empty user_token and save to the database
6879 when we try to set the user's cookies for login.
6880 * (bug 32210) New edit emails for watched pages always provide a link to the
6881 edit which triggered the mail.
6882 * (bug 12021) Added user talk link on Special:Listusers.
6883 * (bug 34445) section edit and TOC hide/show links are excluded from selection and
6884 copy/paste on supporting browsers.
6885 * (bug 34428) Fixed incorrect hash mismatch errors in the DiffHistoryBlob
6886 history compression method.
6887 * (bug 34702) Localised parentheses are now used in more special pages.
6888 * (bug 34723) When editing a script page on a RTL wiki the textbox should be LTR.
6889 * (bug 34762) Calling close() on a DatabaseBase object now clears the connection.
6890 * (bug 34863) Show deletion log extract on non-existent file pages if applicable.
6891 * (bug 28019) Let ?preloadtitle=foo be passed on to target of
6892 Special:MyPage and Special:MyTalk.
6893 * (bug 34929) Show the correct diff when a section edit is rejected by the spam
6894 filter.
6895 * (bug 15816) Add a switch for SETting the search_path (Postgres).
6896 * (bug 34521) Returning to the previous page after logging in loses any array-
6897 valued parameters in the query string.
6898 * (bug 34735) Updated compressOld.php documentation to mention the different
6899 usages of -s and -n parameters depending on compression type.
6900 * (bug 13896) Rendering of devanagari numbers in automatic '#' number lists.
6901 * (bug 33689) Upgrade to 1.19 on Postgres fails due to incomplete query when
6902 trying to defer foreign key for externallinks.
6903 * (bug 32748) Printer friendly version of article decode Unicode chars as a
6904 pretty IRI in footer.
6905 * Removed white border around thumbnails in galleries.
6906 * (bug 31236) "Next" and "Previous" buttons are shown incorrectly in
6907 an RTL environment.
6908 * (bug 35749) Updated maintenance/checkSyntax.php to use Git instead of
6909 Subversion when invoked with the --modified option.
6910 * (bug 35069) On history pages, the " . . " separator after the number of
6911 characters changed in a revision is now suppressed if no text would follow.
6912 * (bug 18704) Add a unique CSS class or ID to the tagfilter table row at RecentChanges
6913 * (bug 33564) transwiki import sometimes result in invalid title.
6914 * (bug 35572) Blocks appear to succeed even if query fails due to wrong DB structure
6915 * (bug 31757) Add a word-separator between help-messages in HTMLForm
6916 * (bug 30410) Removed deprecated $wgFilterCallback and the 'filtered' API error.
6917 * (bug 32604) Some messages needs escaping of wikitext inside username.
6918 * (bug 36537) Rename wfArrayToCGI to wfArrayToCgi for consistency with wfCgiToArray.
6919 * (bug 25946) The message on the top of Special:RecentChanges is now displayed
6920 in user language instead of content language.
6921 * (bug 35264) Wrong type used for <ns> in export.xsd
6922 * (bug 24985) Use $wgTmpDirectory as the default temp directory so that people
6923 who don't have access to /tmp can specify an alternative.
6924 * (bug 27283) SqlBagOStuff breaks PostgreSQL transactions.
6925 * (bug 35727) mw.Api ajax() should put token parameter last.
6926 * (bug 37708) mw.Uri.clone() should make a deep copy.
6927 * (bug 38024) ResourceLoader should not create empty stylesheets for modules
6928 that don't have stylesheets.
6929 * (bug 36812) Special:ActiveUsers "Hide bots" should hide users from any group
6930 having the "bot" user right, instead of just the default "bot" user group.
6931 * (bug 35082) mw.util.addPortletLink incorrectly adds link to mutiple <ul> tags.
6932 * (bug 36991) jquery.tablesorter should extract date sort format from date
6933 string instead of global config. Dates like "April 1 2012" and "1 April 2012"
6934 now sort correctly regardless of the content language's DefaultDateFormat.
6935 * (bug 31895) mw.loader mode now correct when triggered from a $.fn.ready
6936 handler that is bound before mediawiki.js's handler (e.g. browser-userscripts
6937 like greasemonkey).
6938 * (bug 38152) jquery.tablesorter: Use .data() instead of .attr(), so that live
6939 values are used instead of just the fixed values from when the tablesorter
6940 was initialized.
6941 * (bug 38093) Gender of changed user groups missing in Special:Log/rights
6942 * (bug 35893) Special:Block needs to load mediawiki.special.block.js.
6943 * (bug 37331) ResourceLoader modules sometimes execute twice in Firefox
6944 * (bug 31644) GlobalUsage, CentralAuth and AbuseLog extensions should not use
6945 insecure links to foreign wikis in the WikiMap.
6946 * (bug 36073) Avoid duplicate element IDs on File pages.
6947 * (bug 25095) Special:Categories should also include the first relevant item
6948 when "from" is filled.
6949 * (bug 35526) jquery.tablesorter now uses a stable sort.
6950 * (bug 38953) --memory-limit switch not working for runJobs.php.
6951 * (bug 33037) Make subpage of Special:newfiles control how many files
6952 are returned, like in previous versions.
6953 * (bug 36524) "Show" options on Special:RecentChanges and Special:RecentChangesLinked
6954 are now remembered between successive clicks.
6955 * (bug 26069) Page title is no longer "Error" for all error pages.
6956 * (bug 39297) Show warning if thumbnail of animated image will not be animated.
6957 * (bug 38249) Parser will throw an exception instead of outputting gibberish if
6958 PCRE is compiled without support for unicode properties.
6959 * (bug 30390) Suggested file name on Special:Upload should not contain
6960 illegal characters.
6961 * EXIF below sea level GPS altitude data is now shown correctly.
6962 * (bug 39284) jquery.tablesorter should not consider "."" or "?"" to be a currency.
6963 * (bug 39273) "Show changes" should not be incorrectly displayed in the Live Preview state.
6964 * Made body-content lang attribute honor the variant language when it is set.
6965 * (bug 36761) "Mark pages as visited" now submits previously established filter options.
6966 * (bug 39635) PostgreSQL LOCK IN SHARE MODE option is a syntax error.
6967 * (bug 36329) Accesskey tooltips for Firefox 14 on Mac should use "ctrl-option-" prefix.
6968 * (bug 32552) Drop unused database field cat_hidden from table category.
6969 * (bug 24502) Do not allow multiple language links to the same language.
6970 * (bug 40214) Category pages no longer use deprecated "width" HTML attribute.
6971 * (bug 39941) Add missing stylesheets to the installer pages
6972 * In HTML5 mode, allow new input element types values (such as color, range..)
6973 * (bug 36151) mw.Title: Don't limit extension in title parsing.
6974 * (bug 38158) jquery.byteLimit sometimes causes an unexpected 0 maxLength being enforced.
6975 * (bug 38163) jquery.byteLimit incorrectly limits input when using methods other than
6976 basic per-char typing.
6977 * (bug 34495) patrol log now credit the user patrolling (instead of patrolled
6978 user).
6979 * (bug 31676) ResourceLoader should work around IE stylesheet limit.
6980 * (bug 40498) ResourceLoader should not output an empty "@media print { }" block.
6981 * (bug 40500) ResourceLoader should not ignore media-type for urls in debug mode.
6982 * (bug 40660) ResourceLoaderWikiModule should not convert "&nbsp;" to a space
6983 for pages from the MediaWiki-namespace.
6984 * (bug 40329) (bug 40632) Removed CleanupPresentationalAttributes feature.
6985
6986 === API changes in 1.20 ===
6987 * (bug 34316) Add ability to retrieve maximum upload size from MediaWiki API.
6988 * (bug 34313) MediaWiki API intro message about "HTML format" should mention
6989 the format parameter.
6990 * (bug 32384) Allow descending order for list=watchlistraw.
6991 * (bug 31883) Limit of bkusers of list=blocks and titles of action=query is
6992 not documented in API help.
6993 * (bug 32492) API now allows editing using pageid.
6994 * (bug 32497) API now allows changing of protection level using pageid.
6995 * (bug 32498) API now allows comparing pages using pageids.
6996 * (bug 30975) API import of pages with invalid characters in this wiki leads to Fatal Error.
6997 * (bug 30488) API now allows listing of backlinks/embeddedin/imageusage per pageid.
6998 * (bug 34927) Output media_type for list=filearchive.
6999 * (bug 28814) add properties to output of action=parse.
7000 * (bug 33224) add variants of content language to meta=siteinfo.
7001 * (bug 32643) action=purge with forcelinkupdate no longer crashes when ratelimit is reached.
7002 * The paraminfo module now also contains result properties for most modules.
7003 * (bug 32348) Allow descending order for list=alllinks.
7004 * (bug 31777) Upload unknown error ``fileexists-forbidden''.
7005 * (bug 32382) Allow descending order for list=iwbacklinks.
7006 * (bug 32381) Allow descending order for list=backlinks, list=embeddedin and list=imageusage.
7007 * (bug 32383) Allow descending order for list=langbacklinks.
7008 * API meta=siteinfo can now return the list of known variable IDs.
7009 * (bug 35980) list=deletedrevs now honors drdir correctly in "all" mode (mode #3).
7010 * (bug 29290) API avoids mangling fields in continuation parameters
7011 * (bug 36987) API avoids mangling fields in continuation parameters
7012 * (bug 30836) siteinfo prop=specialpagealiases will no longer return nonexistent special pages
7013 * (bug 38190) Add "required" flag to some token params for hint in api docs.
7014 * (bug 27567) Add file repo support to prop=duplicatefiles.
7015 * (bug 27610) Add archivename for non-latest image version to list=filearchive
7016 * (bug 38231) Add xml parse tree to action=parse.
7017 * Watchlist notification timestamp may be queried by page and may be updated via the API.
7018 * (bug 38904) prop=revisions&rvstart=... no longer blows up when continuing.
7019 * (bug 39032) ApiQuery generates help in constructor.
7020 * (bug 11142) Improve file extension blacklist error reporting in API upload.
7021 * (bug 39665) List of query generators is now not built using reflection, instead it is
7022 defined in code.
7023 * (bug 35993) Deprecated gettoken parameter - support will be removed in 1.22.
7024
7025 === Languages updated in 1.20 ===
7026
7027 MediaWiki supports over 350 languages. Many localisations are updated
7028 regularly. Below only new and removed languages are listed, as well as
7029 changes to languages because of Bugzilla reports.
7030
7031 * Emilian (egl) added.
7032 * Tornedalen Finnish (fit) added.
7033 * Mizo (lus) added.
7034 * Santali (sat) added.
7035 * (bug 34192) Namespace gender aliases for Albanian languages (sq & aln).
7036 * (bug 35541) Namespace gender aliases for Croatian (hr).
7037 * (bug 36012) Space in $separatorTransformTable should be non-breaking in
7038 Portuguese, Esperanto and Udmurt.
7039 * Turoyo (tru) added.
7040 * Cyrillic-Latin language converter added for Uzbek (uz).
7041
7042 === Other changes in 1.20 ===
7043 * The user_token field is now left empty until a user attempts to login and
7044 cookies need to be set. It is also now possible to reset every user's
7045 user_token simply by clearing the values in the user_token column.
7046 * Removed ./tests/qunit/index.html from core. It wasn't actively maintained and
7047 has been made obsolete when [[Special:JavaScriptTest/qunit]] was introduced,
7048 which actually uses ResourceLoader, LocalSettings and the Skin.
7049 * Removed $wgDBtransactions global. This was only checked in one class
7050 and only applies to MyISAM or similar DBs. Those should only be used
7051 for archived sites anyway. We can't get edit conflicts on such sites,
7052 so the WikiPage code wasn't useful there either.
7053 * Deprecated mw.user.name in favour of mw.user.getName.
7054 * Deprecated mw.user.anonymous in favour of mw.user.isAnon.
7055 * Deprecated DatabaseBase functions newFromParams(), newFromType(), set(),
7056 quote_ident(), and escapeLike() were removed.
7057 * Use of __DIR__ instead of dirname( __FILE__ ).
7058 * OutputPage::wrapWikiMsg() no longer supports the 'options' parameter. It was
7059 not used and complicated migration to Message class.
7060 * Live preview functionality has been improved and moved into the
7061 'mediawiki.action.edit.preview' module. The old 'mediawiki.legacy.preview' module
7062 has been removed.
7063 * (bug 40448) Removed mediawiki.legacy.mwsuggest module, and removed the
7064 following that has become obsolete:
7065 - globals $wgEnableMWSuggest and $wgMWSuggestTemplate.
7066 - mw.config.values wgMWSuggestTemplate and wgSearchNamespaces.
7067 - method SearchEngine::getMWSuggestTemplate().
7068
7069 == MediaWiki 1.19 ==
7070
7071 == MediaWiki 1.19.24 ==
7072
7073 This is a security and maintenance release of the MediaWiki 1.19 branch.
7074
7075 === Changes since 1.19.23 ===
7076
7077 * ({{bug|T85848}}, {{bug|T71210}}) SECURITY: Don't parse XMP blocks that
7078 contain XML entities, to prevent various DoS attacks.
7079 * ({{bug|T88310}}) SECURITY: Always expand xml entities when checking SVG's.
7080 * ({{bug|T73394}}) SECURITY: Escape > in Html::expandAttributes to prevent XSS.
7081 * ({{bug|T85855}}) SECURITY: Don't execute another user's CSS or JS on preview.
7082 * ({{bug|T85349}}, {{bug|T85850}}, {{bug|T86711}}) SECURITY: Multiple issues
7083 fixed in SVG filtering to prevent XSS and protect viewer's privacy.
7084
7085 == MediaWiki 1.19.23 ==
7086
7087 This is a security and maintenance release of the MediaWiki 1.19 branch.
7088
7089 === Changes since 1.19.22 ===
7090
7091 * (bug T76686) [SECURITY] thumb.php outputs wikitext message as raw HTML, which
7092 could lead to xss. Permission to edit MediaWiki namespace is required to
7093 exploit this.
7094 * (bug T74222) The original patch for T74222 was reverted as unnecessary.
7095 * Add missing $ in front of variable in OutputPage.php
7096
7097 == MediaWiki 1.19.22 ==
7098
7099 This is a security and maintenance release of the MediaWiki 1.19 branch.
7100
7101 === Changes since 1.19.21 ===
7102
7103 * ({{bug|66776}}, {{bug|71478}}) SECURITY: User PleaseStand reported a way to
7104 inject code into API clients that used format=php to process pages that
7105 underwent flash policy mangling. This was fixed along with improving how the
7106 mangling was done for format=json, and allowing sites to disable the mangling
7107 using $wgMangleFlashPolicy.
7108 * ({{bug|72222}}) SECURITY: Do not show log action when the entry is revdeleted
7109 with DELETED_ACTION. NOTICE: this may be reverted in a future release pending a
7110 public RFC about the desired functionality. This issue was reported by user
7111 Bawolff.
7112 * ({{bug|71621}}) Make allowing site-wide styles on restricted special pages a
7113 config option.
7114 * $wgMangleFlashPolicy was added to make MediaWiki's mangling of anything that
7115 might be a flash policy directive configurable.
7116
7117 == MediaWiki 1.19.21 ==
7118 This is a maintenance release of the MediaWiki 1.19 branch.
7119
7120 === Changes since 1.19.20 ===
7121 * (bug 67440) Allow classes to be registered properly from installer.
7122 * (bug 47281) Fixed a dumpBackup.php error with --uploads --include-filesoptions: Unable to find the wrapper "mwstore". * System administrators are encouraged to upgrade to this release or 1.22+ and produce a full data dump. https://www.mediawiki.org/wiki/Special:MyLanguage/Manual:Backing_up_a_wiki
7123 * (bug 63049) Removed anonymous functions from ApiFormatBase, added in1.19.13 as part of the fix for bug 61362, for PHP 5.2 compatibility.
7124
7125 == MediaWiki 1.19.20 ==
7126 This is a security release of the MediaWiki 1.19 branch.
7127
7128 === Changes since 1.19.19 ===
7129 * (bug 70672) SECURITY: OutputPage: Remove separation of css and js module allowance.
7130
7131 == MediaWiki 1.19.19 ==
7132 This is a security release of the MediaWiki 1.19 branch.
7133
7134 === Changes since 1.19.18 ===
7135 * (bug 69008) SECURITY: Enhance CSS filtering in SVG files. Filter <style> elements; normalize style elements and attributes before filtering; add checks for attributes that contain css; add unit tests for html5sec and reported bugs.
7136
7137 == MediaWiki 1.19.18 ==
7138 This is a security release of the MediaWiki 1.19 branch.
7139
7140 === Changes since 1.19.17 ===
7141 * (bug 68187) SECURITY: Prepend jsonp callback with comment.
7142 * (bug 65778) SECURITY: Copy prevent-clickjacking between OutputPage and ParserOutput.
7143
7144 == MediaWiki 1.19.17 ==
7145 This is a security and maintenance release of the MediaWiki 1.19 branch.
7146
7147 === Changes since 1.19.16 ===
7148 * (bug 65839) SECURITY: Prevent external resources in SVG files.
7149 * (bug 66428) MimeMagic: Don't seek before BOF. This has weird side effects like only extracting the tail of the file partially or not at all.
7150
7151 == MediaWiki 1.19.16 ==
7152 This is a security release of the MediaWiki 1.19 branch.
7153
7154 === Changes since 1.19.15 ===
7155 * (bug 65501) SECURITY: Don't parse usernames as wikitext on Special:PasswordReset.
7156
7157 == MediaWiki 1.19.15 ==
7158 This is a security and maintenance release of the MediaWiki 1.19 branch.
7159
7160 === Changes since 1.19.14 ===
7161 Fixed resetting passwords.
7162 * (bug 58640) Fixed a compatibility issue with PCRE 8.34 that caused pages to appear blank or with missing text.
7163
7164 == MediaWiki 1.19.14 ==
7165 This is a security and maintenance release of the MediaWiki 1.19 branch.
7166
7167 === Changes since 1.19.13 ===
7168 * (bug 62497) SECURITY: Add CSRF token on Special:ChangePassword.
7169 * (bug 62467) Set a title for the context during import on the cli.
7170
7171 == MediaWiki 1.19.13 ==
7172 This is a security and maintenance release of the MediaWiki 1.19 branch.
7173
7174 === Changes since 1.19.12 ===
7175 * (bug 61362) SECURITY: API: Don't find links in the middle of api.php links.
7176 * Use the correct branch of the extensions' git repositories.
7177
7178 == MediaWiki 1.19.12 ==
7179 This is a security release of the MediaWiki 1.19 branch.
7180
7181 === Changes since 1.19.11 ===
7182 * (bug 60771) SECURITY: Disallow uploading SVG files using non-whitelisted namespaces. Also disallow iframe elements. * User will get an error including the namespace name if they use a non- whitelisted namespace.
7183 * (bug 61346) SECURITY: Make token comparison use constant time. It seems like our token comparison would be vulnerable to timing attacks. This will take constant time.
7184
7185 == MediaWiki 1.19.11 ==
7186 This is a security release of the MediaWiki 1.19 branch.
7187
7188 === Changes since 1.19.10 ===
7189 * (bug 60339) SECURITY: Sanitize shell arguments to DjVu files, and other media formats
7190
7191 == MediaWiki 1.19.10 ==
7192 This is a security release of the MediaWiki 1.19 branch.
7193
7194 === Changes since 1.19.9 ===
7195 * (bug 57550) SECURITY: Disallow stylesheets in SVG Uploads
7196 * (bug 58088) SECURITY: Don't normalize U+FF3C to \ in CSS Checks
7197 * (bug 58472) SECURITY: Disallow -o-link in styles
7198 * (bug 58553) SECURITY: Return error on invalid XML for SVG Uploads
7199 * (bug 58699) SECURITY: Fix RevDel log entry information leaks
7200
7201 == MediaWiki 1.19.9 ==
7202 This is a security and maintenance release of the MediaWiki 1.19 branch.
7203
7204 === Changes since 1.19.8 ===
7205 * (bug 53032) SECURITY: Don't cache when a call could autocreate
7206 * (bug 55332) SECURITY: Improve css javascript detection
7207 * (bug 49717) Fix behaviour $wgVerifyMimeType = false; in Upload
7208 * Translations
7209
7210 == MediaWiki 1.19.8 ==
7211 2013-09-03
7212
7213 This is a security and maintenance release of the MediaWiki 1.19 branch.
7214
7215 === Changes since 1.19.7 ===
7216 * SECURITY: Sanitize ResourceLoader exception messages
7217 * SECURITY: Token-getting functions will fail when using jsonp callbacks.
7218 * SECURITY: Fix extension detection with 2 .'s
7219 * Allow a string other than '*' as condition for DatabaseBase::delete()
7220 * Purge upstream caches when deleting file assets.
7221 * jquery.tablesorter: Add missing dependency on jquery.mwExtension
7222
7223 == MediaWiki 1.19.7 ==
7224 2013-05-21
7225
7226 This is a security release of the MediaWiki 1.19 branch
7227
7228 === Changes since 1.19.6 ===
7229 * (bug 48306) SECURITY: Run file validation checks on chunked uploads, and chunks of upload, during the upload process.
7230
7231 == MediaWiki 1.19.6 ==
7232 2013-04-30
7233
7234 This is a security and maintenance release of the MediaWiki 1.19 branch
7235
7236 === Changes since 1.19.5 ===
7237 * (bug 47304) SECURITY: Check SVG xml encoding against whitelist
7238 * (bug 46590) Added AbortChangePassword hook to allow extensions to abort password changes from Special:ChangePassword
7239 * Localisation updates from http://translatewiki.net.
7240 * mwdocgen.php: Implement --version option.
7241 * Remove svnstat stuff used in Doxygen generation
7242 * E_USER_DEPRECATED undefined prior to php 5.3
7243
7244 == MediaWiki 1.19.5 ==
7245 2013-04-15
7246
7247 This is a security and maintenance release of the MediaWiki 1.19 branch
7248
7249 === Changes since 1.19.4 ===
7250 * (bug 47251) SECURITY: Disable external entities in Import
7251 * (bug 46859) SECURITY: Disable external entities in XMLReader
7252 * (bug 46084) SECURITY: Sanitize $limitReport before outputting
7253 * (bug 43594) Fix notices displayed on PHP 5.4
7254 * (bug 40585) Don't drop 'step="any"' in HTML input fields.
7255
7256 == MediaWiki 1.19.4 ==
7257 2013-03-04
7258
7259 This is a security release of the MediaWiki 1.19 branch
7260
7261 === Changes since 1.19.3 ===
7262 * New preference type - 'api'. Preferences of this type are not shown on Special:Preferences, but are still available via the action=options API.
7263 * (bug 44010) Context is passed to UserGetLanguageObject.
7264 * The recursion guard on RequestContext::getLanguage() was weakened.
7265 * (bug 44135/bug 42441) Pass '2' instead of 'true' to CURLOPT_SSL_VERIFYHOST
7266 * (bug 43518) API action=unblock should return the user name, not the full user object
7267
7268 == MediaWiki 1.19.3 ==
7269 2012-11-30
7270
7271 This is a security release of the MediaWiki 1.19 branch
7272
7273 === Changes since 1.19.2 ===
7274 * (bug 40995) Prevent session fixation in Special:UserLogin (CVE-2012-5391)
7275 * (bug 41400) Prevent linker regex from exceeding PCRE backtrack limit
7276 * Increase permitted runtime for testParserTest (only used for continuous integration).
7277 * Updated messages translations from http://translatewiki.net/
7278
7279 == MediaWiki 1.19.2 ==
7280
7281 This is a security release of the MediaWiki 1.19 branch
7282
7283 === Changes since 1.19.1 ===
7284 * (bug 39700) File: link to non-existing file can inject html
7285 * (bug 39823) Hidden block text leaking to admins
7286 * (bug 39184) LDAP password leakage
7287 * (bug 39180) Disallow framing of api results
7288 * (bug 37587) Enforce language codes to be html safe
7289 * (bug 39824) Check global blocks on account creation
7290
7291 == MediaWiki 1.19 ==
7292
7293 MediaWiki 1.19 is a large release that contains many new features and bug
7294 fixes. This is a summary of the major changes of interest to users.
7295 You can consult the RELEASE-NOTES-1.19 file for the full list of changes in
7296 this version.
7297
7298 Our thanks go to everyone who helped to improve MediaWiki by testing the beta
7299 release and submitting bug reports.
7300
7301 === Changes since 1.19.1 ===
7302 * (bug 38406) Properly quote table names in DatabaseBase::tableName()
7303 * (bug 38249) Parser will throw an exception instead of outputting gibberish if
7304 PCRE is compiled without support for unicode properties.
7305
7306 === Changes since 1.19.0 ===
7307 * (bug 36568) Fixed "Illegal string offset 'LIMIT'" warnings in updater
7308 * (bug 36938) Correctly escape uselang attribute to prevent xss
7309 * Expanded Blacklist for SVG Files
7310
7311 === Changes since 1.19 beta 2 ===
7312 * Special:Watchlist no longer sets links to feed when the user is anonymous.
7313 * (bug 35961) Hash comparison should always be strict.
7314 * Fix broken email confirmation expiration caused by MWCryptRand changes.
7315 * (bug 35671) PHP Notice: Undefined index: gettoken in includes/api/ApiMain.php
7316 on line 598.
7317 * (bug 36042) 'show' causes a fatal in blocks API.
7318
7319 === Changes since 1.19 beta 1 ===
7320 * (bug 35014) Including a special page no longer sets the page's title to the
7321 included page
7322 * (bug 35019) Edit summaries are no longer transformed in notification e-mails
7323 * (bug 35152) Help message for e-mail is shown again in user preferences
7324 * (bug 34887) $3 and $4 parameters are now substituted correctly in message
7325 "movepage-moved"
7326 * (bug 34841) Edit links are no longer displayed when display old page versions
7327 * (bug 34889) User name should be normalized on Special:Contributions
7328 * (bug 35051) If heading has a trailing space after == then its name is not
7329 preloaded into edit summary on section edit
7330 * (bug 31417) New ID mw-content-text around the actual page text, without categories,
7331 contentSub, ... The same div often also contains the class mw-content-ltr/rtl.
7332 * (bug 35303) Proxy and DNS blacklist blocking works again
7333 * (bug 22555) Remove or skip strip markers from tag hooks like &lt;nowiki&gt; in
7334 core parser functions which operate on strings, such as padleft.
7335 * (bug 18295) Don't expose strip markers when a tag appears inside a link
7336 inside a heading.
7337 * (bug 34212) ApiBlock/ApiUnblock allow action to take place without a token
7338 parameter present.
7339 * (bug 34907) Fixed exposure of tokens through load.php that could have facilitated
7340 CSRF attacks.
7341 * (bug 35317) CSRF in Special:Upload.
7342
7343 === Configuration changes in 1.19 ===
7344 * Removed SkinTemplateSetupPageCss hook; use BeforePageDisplay instead.
7345 * (bug 27132) movefile right granted by default to registered users.
7346 * Default cookie lifetime ($wgCookieExpiration) is increased to 180 days.
7347 * (bug 31204) Removed old user.user_options.
7348 * $wgMaxImageArea now applies to jpeg files if they are not scaled with
7349 ImageMagick.
7350 * Introduced $wgQueryPageDefaultLimit (defaults to 50) for the number of
7351 items to show by default on query pages (special pages such as Whatlinkshere).
7352 * (bug 32470) Increase the length of ug_group.
7353 * (bug 32239) Removed $wgEnableTooltipsAndAccesskeys.
7354 * Removed $wgVectorShowVariantName.
7355 * Removed $wgExtensionAliasesFiles. Use $wgExtensionMessagesFiles.
7356 * Removed $wgResourceLoaderInlinePrivateModules , now always enabled.
7357
7358 === New features in 1.19 ===
7359 * (bug 19838) Add ability to get all interwiki prefixes also if the interwiki
7360 cache is used.
7361 * $wgDnsBlacklistUrls now accepts an array with url and key as the
7362 elements to work with DNSBLs that require keys, such as
7363 Project Honeypot.
7364 * (bug 30022) Add support for custom loadScript sources to ResourceLoader.
7365 * (bug 19052) Unicode space separator characters (Zs) now terminates external
7366 links and images links.
7367 * (bug 30160) Add public method to mw.loader to get module names from registry.
7368 * (bug 15558) Parameters to special pages included in wikitext can now be passed
7369 as with templates.
7370 * Installer now issues a warning if mod_security is present.
7371 * (bug 29455) Add support for a filter callback function in jQuery byteLimit
7372 plugin.
7373 * Added two new GetLocalURL hooks to better serve extensions working on a
7374 limited type of titles.
7375 * Added a --no-updates flag to importDump.php that skips updating the links
7376 tables.
7377 * Most presentational html attributes like valign are now converted to inline
7378 css style rules. These attributes were removed from html5 and so we clean
7379 them up when $wgHtml5 is enabled. This can be disabled using
7380 $wgCleanupPresentationalAttributes.
7381 * Magic words (time and number-formatting ones, plus DIRECTIONMARK, but not
7382 NAMESPACE) now depend on the page content language instead of the site
7383 language. In theory this sets the right magic words in system messages,
7384 although they are not used there.
7385 * (bug 30451) Add page_props to RefreshLinks::deleteLinksFromNonexistent.
7386 * (bug 30450) Clear page_props table on page deletion.
7387 * Hook added to check for exempt from account creation throttle.
7388 * (bug 30344) Add configuration variable for setting custom priorities when
7389 generating sitemaps.
7390 * (bug 96170) Add array support for space-separated list attributes (like
7391 'class') in the Html helper class.
7392 * (bug 26470) Add checkered background image on hover on files pages.
7393 * (bug 30774) mediawiki.html: Add support for numbers and booleans in the
7394 attribute values and element contents.
7395 * Conversion script between Tifinagh and Latin for the Tachelhit language.
7396 * (bug 16755) Add options 'noreplace' and 'noerror' to {{DEFAULTSORT:...}}
7397 to stop it from replace an already existing default sort, and suppress error.
7398 * (bug 18578) Rewrote revision delete related messages to allow better
7399 localisation.
7400 * (bug 30364) LanguageConverter now depends on the page content language
7401 instead of the wiki content language.
7402 * Jump links will now be usable in CSS-capable browsers instead of only
7403 in outdated text browsers.
7404 * New common*.css files usable by skins instead of having to copy piles
7405 of generic styles from MonoBook or Vector's css.
7406 * Some deprecated presentational html attributes will now be automatically
7407 converted to css.
7408 * (bug 31297) Add support for namespaces in Special:RecentChanges subpage filter
7409 syntax.
7410 * The default user signature now contains a talk link in addition to the user link.
7411 * (bug 25306) Add link of old page title to MediaWiki:Delete_and_move_reason.
7412 * Added hook BitmapHandlerCheckImageArea.
7413 * (bug 30062) Add $wgDBprefix option to cli installer.
7414 * getUserPermissionsErrors and getUserPermissionsErrorsExpensive hooks are now
7415 also called when checking for 'read' permission.
7416 * Introduce $wgEnableSearchContributorsByIP which controls whether searching
7417 for an IP address redirects to the contributions list for that IP.
7418 * (bug 8859) Database::update should take array of tables too.
7419 * (bug 19698) Add "Inverse namespaces" option to Special:Contributions.
7420 * (bug 24037) Add byte length of revision to Special:Contributions.
7421 * (bug 1672) Added $wgDisableUploadScriptChecks to allow uploading of files
7422 containing HTML or JS. DISABLING THESE CHECKS IS VERY DANGEROUS.
7423 * New path mappings can be added using the WebRequestPathInfoRouter hook
7424 and adding paths to the PathRouter.
7425 * (bug 32666) Special:ActiveUsers now allows a subpage to be used as value for the
7426 "target" query parameter (eg. Special:ActiveUsers/Username).
7427 * New JavaScript variable wgPageContentLanguage.
7428 * Added new debugging toolbar, enabled with $wgDebugToolbar.
7429 * Differences in the history page now uses slightly better colors for people
7430 perceiving colors differently.
7431 * (bug 32879) Upgrade jQuery to 1.7.1.
7432 * jQuery UI upgraded to 1.8.17.
7433 * Extensions can use the 'Language::getMessagesFileName' hook to define new
7434 languages using messages files outside of core.
7435 * (bug 32512) Add 'Associated namespace' checkbox to Special:Contributions.
7436 * Added $wgSend404Code, true by default, which can be set to false to send a
7437 200 status code instead of 404 for nonexistent articles.
7438 * (bug 33447) Link to the broken image tracking category from Special:Wantedfiles.
7439 * (bug 27724) Add timestamp to job queue.
7440 * (bug 30339) Implement SpecialPage for running javascript tests. Disabled by default, due to
7441 tests potentially being harmful, not to be run on a production wiki.
7442 Enable by setting $wgEnableJavaScriptTest to true.
7443 * Extensions can use the RequestContextCreateSkin hook to override what skin is
7444 loaded in some contexts.
7445 * (bug 33456) Show $wgQueryCacheLimit on cached query pages.
7446 * (bug 10574) Add an option to allow all pages to be exported by Special:Export.
7447 * mediawiki.js Message object constructor is now publicly available as mw.Message.
7448 * (bug 29309) Allow CSS class per tooltip (tipsy).
7449 * (bug 33565) Add accesskey/tooltip to submit buttons on Special:EditWatchlist.
7450 * (bug 17959) Inline rendering/thumbnailing for Gimp XCF images.
7451 * (bug 27775) Namespace has it's own XML tag in the XML dump file.
7452 * (bug 30513) Redirect tag is now resolved in XML dump file.
7453 * sha1 xml tag added to XML dump file.
7454 * (bug 33646) Badtitle error page now emits a 400 HTTP status.
7455 * Special:MovePage now has a dropdown menu for namespaces.
7456 * (bug 34420) Special:Version now shows git HEAD sha1 when available.
7457 * (bug 33952) Refactor mw.toolbar to allow dynamic additions at any time.
7458
7459 === Bug fixes in 1.19 ===
7460 * $wgUploadNavigationUrl should be used for file redlinks if.
7461 $wgUploadMissingFileUrl is not set. The first was used for this
7462 until the second was introduced in 1.17.
7463 * BREAKING CHANGE: Style rules for wikitable are now more specific and prevent
7464 inheritance to nested tables which caused various issues (bug 30485 and bug
7465 33434). If your wiki has overridden rules for ".wikitable", please revise them and
7466 adjust where necessary. For comparison, use the "table.wikitable" section in
7467 skins/common/shared.css as base.
7468 * $wgUploadNavigationUrl is now used for file redlinks if
7469 $wgUploadMissingFileUrl is not set. The former was used for this until the
7470 second was introduced in 1.17.
7471 * (bug 27894) Move 'editondblclick' event listener down from body to
7472 div#bodyContent.
7473 * (bug 30172) The check for posix_isatty() in maintenance scripts did not detect
7474 when the function exists but is disabled. Introduced
7475 Maintenance::posix_isatty().
7476 * (bug 30264) Changed installer-generated LocalSettings.php to use
7477 require_once() instead require() for included extensions.
7478 * Do not convert text in the user interface language to another script.
7479 * (bug 26283) Previewing user JS/CSS pages didn't load other user JS/CSS pages.
7480 * (bug 26486) ResourceLoader modules with paths to nonexistent files cause PHP
7481 warnings/notices to be thrown.
7482 * (bug 30335) Fix for HTMLForms using GET that were breaking when non-friendly
7483 URLs are used.
7484 * (bug 28649) Preventing half truncated multi-byte unicode characters when
7485 truncating log comments.
7486 * Show --batch-size option in help of maintenance scripts that support it.
7487 * (bug 4381) Magic quotes cleaning was not comprehensive, key strings were not
7488 unescaped.
7489 * (bug 23057) Importers no longer can 'edit' or 'create' a fully-protected page by
7490 importing a new revision into it.
7491 * Allow moving the associated talk pages of subpages even if the base page
7492 has no subpage.
7493 * Per page edit-notices now work in namespaces without subpages enabled.
7494 * (bug 31081) $wgEnotifUseJobQ is no longer unconditionally enqueueing jobs.
7495 * (bug 30202) File names are now restricted on upload to 240 bytes, because of
7496 restrictions on some of the database fields.
7497 * Timezones are now recognised in user preferences when offset is different
7498 due to DST.
7499 * (bug 31692) "summary" parameter now also works when undoing revisions.
7500 * (bug 18823) "move succeeded" text displayed bluelinks even when redirect was
7501 suppressed.
7502 * (bug 19186) Special:UserLogin's title on Special:SpecialPages now says
7503 "create account" when the user cannot create an account.
7504 * (bug 31818) 'usercreated' message now supports GENDER.
7505 * (bug 32022) Our phpunit.php script can now be executed from another directory.
7506 * (bug 26020) Setting $wgEmailConfirmToEdit to true no longer removes diffs
7507 from recent changes feeds.
7508 * (bug 30232) add current time to message wlnote on Special:Watchlist.
7509 * (bug 29110) $wgFeedDiffCutoff did not affect new pages.
7510 * (bug 32168) Add wfRemoveDotSegments for use in wfExpandUrl.
7511 * (bug 32358) Do not display "No higher resolution available" for dimensionless
7512 files (like audio files).
7513 * (bug 32168) Add wfAssembleUrl for use in wfExpandUrl.
7514 * (bug 32168) fixed - wfExpandUrl expands dot segments now.
7515 * (bug 31535) Upload comments now truncated properly, and don't have brackets.
7516 * (bug 32086) Special:PermanentLink now shows an error message when no subpage
7517 was specified.
7518 * (bug 30368) Special:Newpages now shows the new page name for moved pages.
7519 * (bug 1697) The way to search blocked usernames in block log should be clearer.
7520 * (bug 29747) eAccelerator shared memory caching has been removed since it is
7521 now disabled by default and is buggy. APC, XCache and WinCache are not affected.
7522 * Installer now refuses to install if php was not compiled with Ctype support.
7523 * (bug 29475) Remove "trackback" feature entirely from core.
7524 * (bug 32665) Special:BlockList prefills the username in the input field if
7525 using the Special:BlockList/username URL.
7526 * (bug 27721) Make JavaScript variables wgSeparatorTransformTable and
7527 wgDigitTransformTable depend on page content language so the sort script
7528 sorts correctly more often.
7529 * (bug 32230) Expose wgRedirectedFrom in JavaScript.
7530 * (bug 31212) History tab not collapsed when the screen is narrow.
7531 * (bug 15521) Use new section summary when the action of adding a new section
7532 also happens to create the page.
7533 * (bug 32960) Remove EmailAuthenticationTimestamp from database when a
7534 email address is removed.
7535 * (bug 32414) Empty page get a empty bytes attribute in Export/Dump.
7536 * (bug 33101) Viewing a User or User talk of username resembling IP ending
7537 with .xxx causes Internal error.
7538 * Warning about undefined index in certain situations when $wgLogRestrictions
7539 causes the first log type requested to be removed but not the others.
7540 * Use separate message ('prefixindex-namespace') for title of
7541 Special:PrefixIndex rather then re-using Special:AllPages's allinnamespace.
7542 * (bug 33156) Special:Block now allows you to confirm you want to block yourself
7543 when using non-normalized username.
7544 * (bug 33246) News icon shown for news:// URLs but not for news: URLs.
7545 * (bug 33305) Make mw.util.addCSS resistant to IE's @font-face bug by setting
7546 cssText after DOM insertion.
7547 * (bug 30711) When adding a new section to a page with section=new, the text is
7548 now always added to the current version of the page.
7549 * (bug 31719) Fix uploads of SVGs exported by Adobe Illustrator by expanding
7550 XML entities correctly.
7551 * (bug 30914) Embeddable ResourceLoader modules (user.options, user.tokens)
7552 should be loaded in <head> for proper dependency resolution.
7553 * (bug 32702) Removed method Skin::makeGlobalVariablesScript() has been readded
7554 for backward compatibility.
7555 * (bug 31469) Make sure tracking category messages expand variables like
7556 {{NAMESPACE}} relative to correct title.
7557 * (bug 33454) ISO-8601 week-based year number (format character 'o') is now
7558 calculated correctly with respect to timezone.
7559 * (bug 32219) InstantCommons now fetches content from Wikimedia Commons using
7560 HTTPS when the local wiki is served over HTTPS.
7561 * (bug 33525) clearTagHooks doesn't clear function hooks.
7562 * (bug 33523) Function tag hooks don't appear on Special:Version.
7563 * Files with IPTC blocks we can't read no longer prevent extraction of exif
7564 or other metadata.
7565 * (bug 33587) Remove action "historysubmit" from history pages.
7566 * (bug 25800) mw.config wgAction should contain the actually performed action instead
7567 of whatever the query value contains.
7568 * (bug 4438) Add CSS hook for current WikiPage action.
7569 * (bug 33703) Common border-bottom color for <abbr> should inherit default (text) color.
7570 * (bug 33819) Display file sizes in appropriate units.
7571 * (bug 32948) {{REVISIONID}} and related variables are no longer blank after doing
7572 a null edit.
7573 * (bug 33880) $wgUsersNotifiedOnAllChanges should not send e-mail to user who made
7574 the edit.
7575 * (bug 33902) Decoding %2B with mw.Uri.decode results in ' ' instead of +.
7576 * (bug 33762) QueryPage-based special pages no longer misses *-summary message.
7577 * Other sizes links are no longer generated for wikis without a 404 thumbnail handler.
7578 * (bug 29454) Enforce byteLimit for page title input on Special:MovePage.
7579 * (bug 34114) CSSMin::remap() doesn't respect its $embed parameter.
7580 * Special:Contributions/newbies now shows the contributions for the user "newbies".
7581 New user contributions are obtained using the form or using ?contribs=newbie in URL.
7582 * It is now possible to delete images that have no corresponding description pages.
7583 * (bug 33165) GlobalFunctions.php line 1312: Call to a member function
7584 getText() on a non-object.
7585 * (bug 31676) Group dynamically inserted CSS into a single <style> tag, to work
7586 around a bug where not all styles were applied in Internet Explorer.
7587 * (bug 28936, bug 5280) Broken or invalid titles can't be removed from watchlist.
7588 * (bug 34600) Older skins using useHeadElement=false were broken in 1.18.
7589 * (bug 34604) [mw.config] wgActionPaths should be an object instead of a numeral
7590 array.
7591 * (bug 12262) Indents and lists are now aligned
7592 * (bug 29753) mw.util.tooltipAccessKeyPrefix should be alt-shift for Chrome
7593 on Windows
7594 * (bug 25095) Special:Categories should also include the first relevant item
7595 when "from" is filled.
7596 * (bug 34972) An error occurred while changing your watchlist settings for
7597 [[Special:WhatLinksHere/Example]]
7598
7599 === API changes in 1.19 ===
7600 * Made action=edit less likely to return "unknownerror", by returning the actual error
7601 message (which may have come from a hook call or similar).
7602 * (bug 19838) siprop=interwikimap can now use the interwiki cache.
7603 * (bug 29748) Add API search prefix support.
7604 * (bug 29684) Set forgotten parameter types in ApiQueryIWLinks.
7605 * (bug 29685) do not output NULL parentid with list=deletedrevs&drprop=parentid.
7606 * siprop=interwikimap and siprop=languages can use silanguagecode to have
7607 a best effort language name translation. Use CLDR extension for best result.
7608 * (bug 30230) action=expandtemplates should not silently override invalid title
7609 inputs.
7610 * (bug 18634) Create API to fetch MediaWiki's language fallback tree structure.
7611 * (bug 26885) Allow show/hide of account blocks, temporary blocks and single IP
7612 address blocks for list=blocks.
7613 * (bug 30591) Add support to only return keys in ApiAllMessages.
7614 * The API now respects $wgShowHostnames and won't share the hostname in
7615 servedby if it's set to false.
7616 * wlexcludeuser parameter added to ApiFeedWatchlist.
7617 * (bug 7304) Links on redirect pages no longer cause the redirect page to show
7618 up as a redirect to the linked page on Special:Whatlinkshere.
7619 * (bug 32609) API: Move captchaid/captchaword of action=edit from core
7620 to Captcha extension(s).
7621 * Added 'APIGetDescription' hook.
7622 * (bug 32688) Paraminfo for parameter "generator" of the query module shows too
7623 many types.
7624 * (bug 32415) Empty page get no size attribute in API output.
7625 * (bug 31759) Undefined property notice in querypages API.
7626 * (bug 32495) API should allow purge by pageids.
7627 * (bug 33147) API examples should explain what they do.
7628 * (bug 33482) Api incorrectly calls ApiBase::parseMultiValue if allowed
7629 values is given as an array.
7630 * (bug 32948) {{REVISIONID}} and related variables are no longer blank after
7631 calling action=purge&forcelinkupdate.
7632 * (bug 34377) action=watch now parses messages using the correct title instead
7633 of "API".
7634 * (bug 35036) WikiLove messages were not automatically updated in JavaScript
7635 after having been changed on-wiki due to a bug in core
7636
7637 === Languages updated in 1.19 ===
7638
7639 MediaWiki supports over 350 languages. Many localisations are updated
7640 regularly. Below only new and removed languages are listed, as well as
7641 changes to languages because of Bugzilla reports.
7642
7643 * Canadian English (en-ca) (new).
7644 * Norwegian (bokmål) (nb) (renamed from no).
7645 * Uighur (Latin) (ug-latn) was incorrectly marked as right-to-left language.
7646 * (bug 30217) Make pt-br a fallback of pt.
7647 * (bug 31193) Set fallback language of Assamese from Bengali to English.
7648 * Update date format for dsb and hsb: month names need the genitive.
7649 * (bug 28643) Serbian variant conversion improvements (Nikola Smolenski).
7650 * (bug 29405, bug 30809) Lower diacritics are invisible in titles in Indic
7651 languages Assamese, Bengali, Hindi, Malyalam and Odiya.
7652 * (bug 32826) Titles in indic languages are partially cut.
7653 * (bug 33367) Gendered namespaces for Czech.
7654 * (bug 33014) Language::formatSize()/formatBitrate() should be able to deal
7655 with larger numbers (tera-yotta).
7656
7657 === Other changes in 1.19 ===
7658 * BREAKING CHANGE: Legacy global array 'ta' and global function 'akeytt' have
7659 been removed from wikibits.js.
7660 * jquery.mwPrototypes module was renamed to jquery.mwExtension.
7661 * The maintenance script populateSha1.php was renamed to the more concise
7662 populateImageSha1.php.
7663 * The Client-IP header is no longer checked for when trying to resolve a client's
7664 real IP address.
7665 * (bug 22096) Although IE5.x and below was already unsupported officially, stylesheets
7666 existing exclusively for IE5.0 and IE5.5 have now been removed (which were in skins
7667 'chick' and 'monobook').
7668 * The constructor for CategoryView has changed, the second parameter is now a
7669 Context source and is required.
7670 * The Title::escape{Local,Full,Canonical}URL methods are deprecated, please use
7671 proper html building methods to escape the normal get{...}URL methods instead.
7672 * The $variant arguments in the Title::get{Local,Full,Link,Canonical}URL methods
7673 have been replaced with a secondary query argument.
7674 * The $variant argument in the hooks for the Title::get{Local,Full,Link,Canonical}URL
7675 methods have been removed, the variant is now part of the $query argument.
7676 * Removed Title::isValidCssJsSubpage(), deprecated since 1.17 in favor of
7677 using Title::isCssJsSubpage() or checking Title::isWrongCaseCssJsPage().
7678 * Support for the deprecated hook MagicWordMagicWords was removed.
7679 * The Xml::namespaceSelector method has been deprecated, please use
7680 Html::namespaceSelector instead (note that the parameters have changed also).
7681 * (bug 33746) Preload popular ResourceLoader modules (mediawiki.util) as stop-gap
7682 for scripts missing dependencies.
7683 New configuration variable $wgPreloadJavaScriptMwUtil has been introduced for this
7684 (set to false by default for new installations). Set to true if your wiki has a large
7685 amount of user/site scripts that are lacking dependency information. In the short to
7686 medium term these user/site scripts should be fixed by adding the used modules to the
7687 dependencies in the module registry and/or wrapping them in a callback to mw.loader.using.
7688
7689 == MediaWiki 1.18 ==
7690
7691 == MediaWiki 1.18.6 ==
7692 2012-11-29
7693
7694 This is a maintenance and security release of the MediaWiki 1.18 branch
7695
7696 === Changes since 1.18.5 ===
7697 * ([[bugzilla:40995|bug 40995]]) Prevent session fixation in Special:UserLogin
7698 (CVE-2012-5391)
7699 * ([[bugzilla:41400|bug 41400]]) Prevent linker regex from exceeding PCRE
7700 backtrack limit
7701 * Localisation updates
7702 * Increase permitted runtime for testParserTest
7703 * ([[bugzilla:36179|bug 36179]]) Unquote 'null' for PostgreSQL.
7704
7705 == MediaWiki 1.18.5 ==
7706 2012-08-30
7707
7708 This is a security release of the MediaWiki 1.18 branch
7709
7710 === Changes since 1.18.4 ===
7711 * (bug 39700) File: link to non-existing file can inject html
7712 * (bug 39823) Hidden block text leaking to admins
7713 * (bug 39184) LDAP password leakage
7714 * (bug 39180) Disallow framing of api results
7715 * (bug 37587) Enforce language codes to be html safe
7716 * (bug 39824) Check global blocks on account creation
7717
7718 == MediaWiki 1.18.4 ==
7719 2012-06-12
7720
7721 This is a security release of the MediaWiki 1.18 branch.
7722
7723 === Changes since 1.18.3 ===
7724 * (bug 36938) Correctly escape uselang attribute to prevent xss
7725 * Expanded Blacklist for SVG Files
7726
7727 == MediaWiki 1.18.3 ==
7728 2012-04-25
7729
7730 This is a maintenance release of the MediaWiki 1.18 branch.
7731
7732 === Changes since 1.18.2 ===
7733 * (bug 35446) Using "{{nse:}}" with an invalid namespace name no longer throws
7734 a PHP warning.
7735 * (bug 35567) The whole password reminder e-mail is now sent in the same language.
7736 * (bug 35961) Hash comparison should always be strict.
7737 * (bug 35671) PHP Notice: Undefined index: gettoken in includes/api/ApiMain.php
7738 on line 598.
7739 * Fix broken email confirmation expiration caused by MWCryptRand changes.
7740
7741 == MediaWiki 1.18.2 ==
7742 2012-03-21
7743
7744 This is a maintenance and security release of the MediaWiki 1.18 branch.
7745
7746 === Changes since 1.18.1 ===
7747 * (bug 33686) could not get a list of contributors for an article when using
7748 a SQLite database.
7749 * (Bug 33865) Exception thrown in action=parse when attempting to use the title
7750 parameter without setting the text parameter.
7751 * UserMailer could potentially throw a fatal error when a MailAddress object had
7752 an empty email address.
7753 * (Bug 33087) Exchange server rejected mail sent by MediaWiki
7754 * (bug 34528) Edit section tooltips show correction section name again
7755 * (bug 34246) MediaWiki:Whatlinkshere-summary message is displayed again in
7756 Special:Whatlinkshere
7757 * (bug 22555) Remove or skip strip markers from tag hooks like &lt;nowiki&gt; in
7758 core parser functions which operate on strings, such as formatnum.
7759 * (bug 34212) ApiBlock/ApiUnblock allow action to take place without a token
7760 parameter present.
7761 * (bug 34907) Fixed exposure of tokens through load.php that could have facilitated
7762 CSRF attacks.
7763 * (bug 35317) CSRF in Special:Upload.
7764
7765 == MediaWiki 1.18.1 ==
7766 2012-01-11
7767
7768 This a maintenance and security release of the MediaWiki 1.18 branch.
7769
7770 === Changes since 1.18.0 ===
7771 * (bug 32712) Fix for search indexing of pages with certain unicode chars following URL.
7772 * (bug 3901) Lang, hreflang attribs added to sidebar interlanguage links for screen readers.
7773 * (bug 30774) mediawiki.html: Add support for numbers and booleans in the
7774 attribute values and element contents.
7775 * (bug 32473) [[Special:PasswordReset]] can not be used on private wiki.
7776 * (bug 32853) Fixed CACHE_DBA object cache type.
7777 * (bug 32786) Backward compatibility for extension using 1.17's Database::newFromType().
7778 * Fixed exception when using Special:WhatLinksHere on a Media: file.
7779 * (bug 32709) Private Wiki users were always taken to Special:Badtitle on login.
7780 * (bug 33240) Sort images are missing but referenced in css.
7781 * (bug 31921) Magic words REVISIONDAY, REVISIONMONTH and REVISIONYEAR were
7782 not showing their values on preview.
7783 * (bug 32702) Removed method Skin::makeGlobalVariablesScript() has been readded
7784 for backward compatibility.
7785 * (bug 30172) The check for posix_isatty() in maintenance scripts did not detect
7786 when the function exists but is disabled. Introduced Maintenance::posix_isatty().
7787 * (bug 33305) Make mw.util.addCSS resistant to IE's @font-face bug by setting
7788 cssText after DOM insertion.
7789 * (bug 29102) Upgrades no longer fail with the error "Unknown character set: 'mysql4'.
7790 * (bug 25355) Parser generates edit section links for special pages.
7791 * (bug 33321) Adding a line to MediaWiki:Sidebar that contains a pipe, but doesn't
7792 have any pipes after being transformed by MessageCache, causes exception on
7793 all pages.
7794 * Fixed recentchanges FK violation on page delete and cache purge error in updater
7795 for Oracle DB.
7796 * (bug 33117) prop=revisions allows deleted text to be exposed through cache pollution.
7797
7798 == MediaWiki 1.18.0 ==
7799 2011-11-24
7800
7801 This is the first stable release of the MediaWiki 1.18 branch.
7802
7803 === Summary of selected changes in 1.18 ===
7804
7805 Selected changes since MediaWiki 1.17 that may be of interest:
7806
7807 * Some of the more commonly used MediaWiki extensions are now included in the
7808 release tarball. These extensions are ConfirmEdit, Gadgets, Nuke, ParserFunctions,
7809 Renameuser, Vector and WikiEditor.
7810
7811 * Gender support has been improved, meaning user pages can display the correct gender
7812 variant of "User" can now be used.
7813
7814 * MediaWiki can now detect the camera orientation of an image from the Exif metadata, and
7815 can rotate the image thumbnail appropriately. Metadata support has been generally
7816 improved, and can now extract IPTC and XMP metadata.
7817
7818 * Improved directionality support in 1.18 means that MediaWiki is better to use for
7819 RTL users.
7820
7821 * MediaWiki now supports protocol - relative URLs in links, interwiki targets and $wgServer
7822
7823 * Math support has been removed from core
7824
7825 === Changes since 1.18.0rc1 ===
7826 * (bug 32228) regression in Special:Search which did not conserve profile on new search
7827 * (bug 32460) Categories were improperly aligned in Simple and CologneBlue
7828 * (bug 32412) TOC links on [[Special:EditWatchlist]] points to the fieldsets
7829 * (bug 32582) Fix TOC show/hide link regression on IE 8
7830
7831 === Changes since 1.18 beta 1 ===
7832 * (bug 31886) Wrong titles redirecting to Special:Badtitle in the 1.18 deployment.
7833 * (bug 32051) Fix description for wlprop=sizes.
7834 * (bug 31913) Special:MostLinkedTemplates had an incorrect GROUP BY clause
7835 under Microsoft SQL.
7836 * (bug 32100) installer complains about suhosin GET limit.
7837 * (bug 31933) fix 1.18 regression in Monobook sidebar: huge spacing between portlets
7838 on IE 7 and IE 8/9 in compatibility view.
7839 * (bug 32126) Fix 1.18 regression in watchlist editor when items already removed
7840 from watchlist.
7841 * (bug 32183) remove the client-* classes added from user-agent-sniffing onto
7842 the <html> element.
7843 * (bug 29912) Unit tests break if parsertest tables are still present.
7844 * (bug 31694) During installation, tabbing order (cursor focus) goes to logo
7845 instead of 'continue'.
7846 * (bug 29102) Upgrade fails "Unknown character set: 'mysql4".
7847 * (bug 31990) justify paragraphs pref adds extra space to category listing.
7848 * (bug 20148) Better title for [[Special:Disambiguations]] page.
7849 * (bug 31502) TOC is missing on Special:EditWatchlist.
7850 * (bug 32256) API list=search stops at first invalid result.
7851 * (bug 32047) jquery.tablesorter.js: thead is before caption.
7852 * (bug 29854) Store protocol-relative links twice in the externallinks table,
7853 one with http: in el_index and once with https.
7854 * (bug 31822) Error during upgrade due to output buffer reset in stdout.
7855
7856 === Configuration changes in 1.18 ===
7857 * The WantedPages::getSQL hook has been removed and replaced with
7858 WantedPages::getQueryInfo. This may break older extensions.
7859 * The SkinTemplateBuildContentActionUrlsAfterSpecialPage,
7860 SkinTemplateContentActions and SkinTemplateTabs hooks have been removed in
7861 favor of SkinTemplateNavigation and SkinTemplateNavigation::SpecialPage.
7862 * $wgUseCombinedLoginLink controls whether to output a combined
7863 login / create account link in the personal bar, or to output separate login
7864 and create account links.
7865 * Skin names are no longer created based on a ucfirst version of the key in
7866 $wgValidSkinNames but now the value. This means for
7867 $wgValidSkinNames["monobook"] = "MonoBook"; the skin loader will no longer try
7868 loading SkinMonobook and will instead load SkinMonoBook.
7869 * $wgMaxUploadSize may now be set to an array to specify the upload size limit
7870 per upload type.
7871 * $wgAPICacheHelp added in 1.16 is now removed. To disable API help caching, set
7872 $wgAPICacheHelpTimeout = 0;
7873 * OutputPage::isUserJsAllowed() no longer returns false when scripts are allowed
7874 by the page, but $wgAllowUserJs is set to false.
7875 * Pure "Skin" class based custom skins are no longer supported, all custom skins
7876 should be put together using SkinTemplate and BaseTemplate or QuickTemplate.
7877 * The transliteration for passwords in case they were migrated from an old
7878 Latin-1 install (previous to MediaWiki 1.5) is now only done for wikis with
7879 $wgLegacyEncoding set.
7880 * (bug 27508) Add $wgSVGMetadataCutoff to limit the maximum amount of an SVG we
7881 look at when finding metadata to prevent excessive resource usage.
7882 * $wgSysopUserBans and $wgSysopRangeBans (deprecated in 1.17) are now removed.
7883 Use $wgBlockCIDRLimit = array( 'IPv4' => 43, 'IPv6' => 128 ) to achieve the
7884 same functionality as $wgSysopRangeBans; you can use the BlockIp hook to
7885 replicate $wgSysopUserBans functionality.
7886 * The options on the block form have been standardised such that checking a box
7887 makes the block 'more serious'; so while "check to prevent account creation"
7888 and "check to enable autoblock" remain the same, "check to allow user-talk
7889 edit" is reversed to "check to *disable* user-talk edit", and "check to block
7890 anon-only" becomes "check to block logged-in users too". The default settings
7891 remain the same.
7892 * Most of the field names on the Special:Block form have been changed, which
7893 will probably break screen-scraping bots.
7894 * (bug 26866) The 'trackback' right is no longer granted to sysops by default.
7895 $wgUseTrackbacks is already false by default.
7896 * (bug 17009) the hiddenStructure CSS class, a highly hackish way of at least
7897 *appearing* to hide article elements, has been removed. Use the
7898 ParserFunctions extension to actually remove unwanted elements from the
7899 output.
7900 * (bug 14202) $wgUseTeX has been superseded by the Math extension. To re-enable
7901 math conversion after upgrading, obtain the Math extension from SVN or from
7902 https://www.mediawiki.org/wiki/Extension:Math and add to LocalSettings.php:
7903 require_once "$IP/extensions/Math/Math.php";
7904 * $wgProfiler is now a configuration array, see StartProfiler.sample for
7905 details.
7906 * $wgProfiling has been removed.
7907 * The spyc library is now no longer included in phase3.
7908 * (bug 28343) Unused preferences contextlines/contextchars have been removed
7909 * $wgSkinExtensionFunctions has been removed. Use $wgExtensionFunctions instead.
7910 * $wgProto has been removed. You now only need to set $wgServer to change the
7911 URL protocol.
7912 * $wgRateLimitsExcludedGroups (deprecated in 1.13) has been removed.
7913 * $wgInputEncoding and $wgOutputEncoding (deprecated in 1.5) have now been removed.
7914 * $wgAllowUserSkin (deprecated in 1.16) has now been removed.
7915 * $wgExtraRandompageSQL (deprecated in 1.16) has now been removed.
7916 * LogReader and LogViewer classes (deprecated in 1.14) have now been removed.
7917 * (bug 26033) Added $wgArticleCountMethod to select the method to use to say
7918 whether a page is an article or not. $wgUseCommaCount is now deprecated.
7919 * $wgEnableDublinCoreRdf and $wgEnableCreativeCommonsRdf no longer work in core,
7920 and the functionality has been moved to the relevant extensions. See
7921 https://www.mediawiki.org/wiki/Extension:DublinCoreRdf and
7922 https://www.mediawiki.org/wiki/Extension:CreativeCommonsRdf as appropriate.
7923 * (bug 21107) Split error "customcssjsprotected" into separate messages for JS and CSS
7924 * Removed $wgCheckCopyrightUpload from DefaultSettings, since the relevant feature
7925 was removed in about 1.5.
7926 * LogPageValidTypes, LogPageLogName, LogPageLogHeader and LogPageActionText
7927 hooks have been removed.
7928 * New hook "Collation::factory" to allow extensions to create custom
7929 category collations.
7930 * $wgGroupPermissions now supports per namespace permissions.
7931 * $wgEnableAutoRotation enables or disables auto-rotation. Leaving it set to
7932 null will cause MediaWiki to determine if auto-rotation is available.
7933
7934 === New features in 1.18 ===
7935 * BREAKING CHANGE: action=watch / action=unwatch now requires a token.
7936 * BREAKING CHANGE: Article class hierarchy split into WikiPage (backend)
7937 and Article (frontend) hierarchies. Several hooks now pass a WikiPage object instead
7938 of an Article object. These hooks all use an $article parameter as documented in hooks.txt.
7939 Extensions should be updated to account for this, though most won't require any changes.
7940 * (bug 27860) Minor edit after clicking 'new section' tab
7941 Now the "This is a minor edit" checkbox is not available when you
7942 create a page or new section.
7943 * (bug 8130) Query pages should limit to content namespaces, not just main
7944 namespace.
7945 * Special:Contribs now redirects to Special:Contributions.
7946 * (bug 6672) Images are now autorotated according to their EXIF orientation.
7947 This only affects thumbnails; the source remains unrotated.
7948 * (bug 25708) Update case mappings and normalization to Unicode 6.0.0.
7949 * New hook ArticlePrepareTextForEdit added, called when preparing text to be
7950 saved.
7951 * New parser option PreSaveTransform added, allows the pre-save transformation
7952 to be selectively disabled.
7953 * Alternative to $wgHooks implemented, using the new Hooks class.
7954 * Add width parameter to Special:Filepath to allow getting the file path of a
7955 thumbnail.
7956 * (bug 26870) Add size to {{filepath:}}.
7957 * Upload warnings now show a thumbnail of the uploaded file.
7958 * Introduced the edittools-upload message, which will be inserted under the
7959 upload form instead of edittools if available.
7960 * (bug 26285) Extensions will be automatically generated on upload if the user
7961 specified a filename without extension.
7962 * (bug 26851) Special:UserRights now allows to prefill the reason field
7963 * New maintenance script to fix double redirects
7964 (maintenance/fixDoubleRedirects.php).
7965 * (bug 23315) New body classes to allow easier styling of special pages.
7966 * (bug 27159) Make email confirmation code expiration time configurable.
7967 * (bug 29047) CSS/JS for each user group is imported from MediaWiki:Group-sysop.js,
7968 MediaWiki:Group-autoconfirmed.css, etc.
7969 * (bug 24230) Uploads of ZIP types, such as MS Office or OpenOffice can now be
7970 safely enabled. A ZIP file reader was added which can scan a ZIP file for
7971 potentially dangerous Java applets. This allows applets to be blocked
7972 specifically, rather than all ZIP files being blocked.
7973 * (bug 2429) Allow selection of associated namespace in recent changes.
7974 * (bug 26217) File size is now checked before uploading in HTML5 browsers.
7975 * CSS stylesheet MediaWiki:Noscript.css is now loaded for users with JavaScript
7976 disabled (enclosed in the head in a <noscript> tag).
7977 * Added UserGetLanguageObject hook to change the language used in $wgLang.
7978 * (bug 14645) When $wgMiserMode is on, expensive special pages are styled
7979 differently (italicized by default) on Special:SpecialPages.
7980 * Added $wgAggregateStatsID, which allows UDP stats to be aggregated over
7981 several wikis.
7982 * When $wgAllowMicrodataAttributes is true, all itemtypes are allowed, not just
7983 the three that were defined in the original specification.
7984 * (bug 14706) Added support for the Imagick PHP extension.
7985 * (bug 18691) Added support for SVG rasterization using the Imagick PHP
7986 extension.
7987 * (bug 2581, bug 6834) Added links to thumbnail in several resolutions to the
7988 file description page. The sizes are set by $wgImageLimits.
7989 * (bug 28031) Add pageCount support to ArchivedFile.
7990 * (bug 27924) PhpHttpRequest doesn't return response body if HTTP != 200.
7991 * Added hook BitmapHandlerTransform to allow extension to transform a file
7992 without overriding the entire handler.
7993 * The parser now attempts to output markers for editsection tokens and defer the
7994 rendering of them post-cache to reduce parser cache fragmentation and ensure
7995 skin customizability of edit section links.
7996 * (bug 24755) AuthPlugin auto-creation of local accounts can now be aborted by
7997 other extensions by handling the 'AbortAutoAccount' hook, similar to the
7998 'AbortNewAccount' triggered by explicit account creations. (They are separate
7999 to avoid loops and confusion; auth plugins like CentralAuth need to handle
8000 AbortNewAccount separately.
8001 * Special:ListFiles is now transcludable.
8002 * (bug 13879) Special:Emailuser asks for suitable target user if called without.
8003 * (bug 16956) IPTC and XMP metadata now extracted from images.
8004 * (bug 23816) A tracking category is now added for any pages with broken images.
8005 * (bug 23495) Allow createAndPromote.php to create non-sysop users.
8006 * (bug 28916) A way to to toggle mw.config legacy globals settings from
8007 LocalSettings.php has been created by introducing $wgLegacyJavaScriptGlobals.
8008 * (bug 28503) Support for ircs:// URL protocols.
8009 * (bug 26033) It is now possible to count all non-redirect pages in content
8010 namespaces as articles.
8011 * Images can now be embedded in an XML dump stream using backupDump.php
8012 --include-files and can be imported using importDump.php --uploads;
8013 furthermore, it can import files from the filesystem using --image-base-path.
8014 * Three new hooks in Special:Undelete, 'UndeleteForm::showHistory',
8015 'UndeleteForm::showRevision' and 'UndeleteForm::undelete', so that extensions
8016 may override the usage of PageArchive class and replace it with their own
8017 class that extends PageArchive.
8018 * (bug 28915) Implement QUnit test suite for MediaWiki JavaScript.
8019 Also built-in support for distribution through a TestSwarm instance.
8020 * (bug 29036) For cascade-protected pages, the mw-textarea-cprotected class is
8021 added to the textarea on the edit form.
8022 * mw.util.wikiScript has been implemented (like wfScript in GlobalFunctions.php)
8023 * (bug 29067) Expose user.tokens (like we do user.options) in ResourceLoader.
8024 * New 'Debug' hook used by wfDebug() and wfDebugLog().
8025 * (bug 27655) Require token for watching/unwatching pages)
8026 * (bug 28904) (bug 29773) Update jQuery version from 1.4.4 to 1.6.2 (the latest version)
8027 * (bug 29441) Expose CapitalLinks config in JS to allow modules to properly
8028 handle titles on case-sensitive wikis.
8029 * (bug 29397) Implement mw.Title module in core.
8030 * In MySQL 4.1.9+ with replication enabled, fetch the slave lag from SHOW SLAVE
8031 STATUS instead of SHOW PROCESSLIST. This ensures that lag is reported
8032 correctly in the case where there are no write events occurring. Note that
8033 the DB user now needs to have the REPLICATION CLIENT privilege if you are
8034 using replication.
8035 * Language codes in $wgDummyLanguageCodes are now excluded on localization
8036 statistics (maintenance/language/transstat.php).
8037 * (bug 29586) Make the (next 200) links on categories link directly to
8038 the relevant section of the category.
8039 * (bug 29109) Allow the automatic edit summary for redirect creation
8040 show the first bit of the new redirect page.
8041 * (bug 29723) mw.util.wikiGetlink() now defaults to wgPageName.
8042 * (bug 29680) Add GetDefaultSortkey hook to override the default sortkey.
8043 * (bug 16699) {{#language:}} accepts second parameter to specify the language in
8044 which the language name is wanted. Coverage depends on the cldr extension.
8045 * (bug 15802) An easy way to look up messages: language qqx which returns
8046 the message keys.
8047 * (bug 29868) Add support for passing parameters to mw.msg in jquery.localize.
8048 * (bug 29558) $wgMiserMode now disables update.php by default.
8049 * AjaxCategories: Easily add, edit or delete categories on article pages.
8050 Suggests possible categories when typing, all saves are done via AJAX.
8051 Supports editing of multiple categories and then saving them in one batch.
8052 * $wgAutopromoteOnce was added, allowing for users to be automatically promoted
8053 to explicit usergroups. If a group is removed from a user via Special:UserRights,
8054 it will not automatically be re-added. Configuration is similar to
8055 $wgAutopromote (see DefaultSettings.php).
8056 * The PerformRetroactiveAutoblock hook was added to allow overriding or complementing
8057 retroactive autoblock handling. This runs when blocking a user with the 'autoblock' option.
8058 * MediaWiki now supports using protocol-relative URLs in links, interwiki
8059 targets and $wgServer.
8060 * Introduced $wgVaryOnXFPForAPI which will cause the API to send
8061 Vary: X-Forwarded-Proto headers.
8062 * New maintenance script to refresh image metadata (maintenance/refreshImageMetadata.php).
8063 * (bug 16428) Include permalink in printable version.
8064 * (bug 30722) Add an identity collation that sorts things based on what the
8065 unicode code point is (aka pre-1.17 behavior).
8066 * (bug 30940) Add a hook in User:getDefaultOptions.
8067 To give extensions a better and more flexible way of providing default
8068 values for preferences a hook has been introduced in User:getDefaultOptions().
8069 Setting preferences in $wgDefaultUserOptions still work fine, but when reading
8070 them (i.e. with array_keys) to get a list of all preferences, then
8071 $wgDefaultUserOptions should no longer be used as it will contain those set via
8072 User:getDefaultOptions().
8073 * (bug 30497) Add client-nojs and client-js classes on document element
8074 to let styles easily hide or show things based on general JS availability.
8075 * (bug 31293) If Special:Userlogin is loaded over HTTPS, display
8076 MediaWiki:loginend-https instead of MediaWiki:loginend, if it's not empty.
8077 Same for signupend on the account creation page.
8078 * (bug 31233) New OutputPage::addJsConfigVars() method to make the output page specific
8079 mw.config map extendable.
8080 * mw.util.wikiScript has been implemented (like wfScript in GlobalFunctions.php).
8081
8082 === Bug fixes in 1.18 ===
8083 * (bug 27860) Minor edit after clicking 'new section' tab.
8084 * (bug 23119) WikiError class and subclasses are now marked as deprecated.
8085 * (bug 10871) Javascript and CSS pages in MediaWiki namespace are no longer
8086 treated as wikitext on preview.
8087 * (bug 22753) Output from update.php is more clear when things changed, entries
8088 indicating nothing changed are now all prefixed by "...".
8089 * Page existence is now not revealed (in the colour of the tabs) to users who
8090 cannot read the page in question.
8091 * (bug 19006) {{REVISIONUSER}} no longer acts like {{CURRENTUSER}} in some
8092 cases.
8093 * (bug 16019) $wgArticlePath = "/$1" no longer breaks API edit/watch actions.
8094 * (bug 18372) File types blacklisted by $wgFileBlacklist will no longer be shown
8095 as "Permitted file types" on the upload form.
8096 * (bug 26379) importImages.php gives more descriptive error message on failure.
8097 * (bug 26410) + signs are no longer treated as spaces in internal links if
8098 link has a % sign in it.
8099 * (bug 26412) Search results headers no longer show a bogus edit link.
8100 * (bug 26540) Fixed wrong call to applyPatch in MysqlUpdater.
8101 * (bug 26574) Added 'upload' to $wgRestrictionTypes, allowing upload protected
8102 pages to be queried via the API and Special:ProtectedPages, and allowing
8103 disabling upload protection by removing it from $wgRestrictionTypes.
8104 * If an edit summary exceeds 250 bytes and is truncated, add an ellipse.
8105 * (bug 26638) Database error pages display correctly in RTL languages.
8106 * (bug 26187) Confirmrecreate no longer parses the edit summary.
8107 * (bug 26208) Mark directionality of some interlanguage links.
8108 * (bug 26034) Make the "View / Read" tab in content_navigation style tabs remain
8109 selected when the action is "purge".
8110 * (bug 14267) Support a MediaWiki:Mainpage-nstab override for the subject
8111 namespace tab on the mainpage of a wiki.
8112 * (bug 10158) Do not mention allowing others to contact you when the feature
8113 is disabled ($wgEnableUserEmail=false).
8114 * (bug 26733) Wrap initial table creation in transaction.
8115 * (bug 26729) Category pages should return 404 if they do not exist and have no
8116 members.
8117 * (bug 2585) Image pages should send 404 if no image, no shared image and no
8118 description page.
8119 * Custom editintro's using the editintro url parameter will no longer show
8120 <noinclude> sections on pages they are included on.
8121 * (bug 26449) Keep underlines from headings outside of tables and thumbs by
8122 adding overflow:hidden to h1,h2,h3,h4,h5,h6 (also fixes editsection bunching).
8123 * (bug 26708) Remove background-color:white from tables in Monobook and Vector.
8124 * (bug 28422) Remove color:black from tables in Monobook and Vector. And add it
8125 to table.wikitable instead.
8126 * (bug 26781) {{PAGENAME}} and related parser functions escape their output
8127 better.
8128 * (bug 26716) Provide link to instructions for external editor related
8129 preferences and add a comment to the ini control file explaining what is
8130 going on.
8131 * Trying to upload a file with no extension or with a disallowed MIME type now
8132 gives the right message instead of complaining about a MIME/extension
8133 mismatch.
8134 * (bug 26809) Uploading files with multiple extensions where one of the
8135 extensions is blacklisted now gives the proper extension in the error message.
8136 * (bug 26961) Hide anon edits in watchlist preference now actually works.
8137 * (bug 19751) Filesystem is now checked during image undeletion.
8138 * Send last modified headers for Special:Recentchanges when RC patrol is
8139 enabled, but user cannot see rc patrol links.
8140 * (bug 26548) ForeignAPIRepo (InstantCommons) now works with PDF files
8141 and other multi-paged file formats.
8142 * Files with a mime type that does not match the extension are now properly
8143 thumbnailed.
8144 * (bug 27201) Special:WhatLinksHere output no longer contains duplicate IDs.
8145 * (bug 15905) Nostalgia skin could become more usable by including a Talk:
8146 link at the top of the page.
8147 * (bug 27560) Search queries no longer fail in Walloon language.
8148 * (bug 27679) Broken embedded files with special characters are no longer
8149 double HTML escaped.
8150 * (bug 27700) The upload protection can now also be set for files that do not
8151 exist.
8152 * (bug 27763) Article::getParserOutput() no longer throws a fatal given when an
8153 incorrect revision ID is passed.
8154 * Trim the form field for uploading by url to remove extra spaces which could
8155 cause confusing error messages.
8156 * (bug 27854) Http::isValidURI is way too lax.
8157 * Do not show enotifminoredits preference, if disabled by $wgEnotifMinorEdits.
8158 * AbortLogin returning "ABORTED" now handled. Also allows message identifier
8159 for "ABORTED" reason to be returned and displayed to user.
8160 * (bug 28034) uploading file to local wiki when file exists on shared repository
8161 (commons) gives spurious info in the warning message.
8162 * Usernames get lost when selecting different sorts on Special:listfiles.
8163 * (bug 14005) editing section 0 of an existing but empty page gives no such
8164 section error.
8165 * (bug 26939) Installer does not set $wgMetaNamespace.
8166 * (bug 28166) UploadBase assumes that 'edit' and 'upload' rights are not per
8167 page restrictions.
8168 * Make truncate function automatically consider length of '...' string,
8169 since length can vary by localization.
8170 * (bug 28242) Make redirects generated by urls containing a local interwiki
8171 prefix be a 301 instead of a 302.
8172 * (bug 15641) blocked administrators are now prevented from deleting or
8173 protecting their own talk page; and all blocked users are more
8174 comprehensively prevented from performing other actions.
8175 * (bug 27893) Edit-on-doubleclick now applies only on view and purge actions;
8176 no longer triggers unexpectedly on delete, history etc.
8177 * (bug 28417) Fix PHP notice when importing revision without a listed id.
8178 * (bug 28430) Make html and TeX output of <math> always be left-to-right.
8179 * (bug 28306) Fix exposure of suppressed usernames in ForeignDBRepo.
8180 * (bug 28372) Fix bogus link to suppressed file versions in ForeignDBRepo.
8181 * (bug 27473) Fix regression: bold, italic no longer interfere with linktrail
8182 for ca, kaa.
8183 * (bug 28444) Fix regression: edit-on-doubleclick retains revision id again.
8184 * &apos; character entity is now allowed in wikitext.
8185 * UtfNormal::cleanUp on an invalid utf-8 sequence no longer returns false if
8186 intl installed.
8187 * (bug 28561) The css class small will no longer make nested elements even
8188 smaller.
8189 * (bug 13172) Array type exif data (like GPS) was not being extracted from
8190 images.
8191 * (bug 28532) wfMsgExt() and wfMsgWikiHtml() use $wgOut->parse().
8192 * (bug 16129) Transcluded special pages expose strip markers when they output
8193 parsed messages.
8194 * (bug 27249) "Installed software" table in Special:Version should always be
8195 left-to-right.
8196 * (bug 28719) Do not call mLinkHolders __destruct explicitly.
8197 * (bug 21196) Article::getContributors() no longer fails on PostgreSQL.
8198 * (bug 28752) XCache doesn't work in CLI mode.
8199 * (bug 28076) Thumbnail height limited to 360 pixels on Special:Listfiles.
8200 * (bug 22227) Special:Listfiles no longer throws an error on bogus file entries.
8201 * (bug 19408) user_properties.up_property: 32 bytes is not enough.
8202 * (bug 25262) Fix for minification of hardcoded data: URIs in CSS.
8203 * (bug 29263) Add LTR class to the shared CSS to be used for left-to-right text
8204 such as SQL queries shown in dberrortext and similar messages in RTL
8205 environments.
8206 * (bug 14977) Fixed $wgServer detection in cases where an IPv6 address is used
8207 as the server name.
8208 * The View X deleted revisions is now shown again on Special:Upload.
8209 * (bug 29071) mediawiki.action.watch.ajax.js should pass uselang to API.
8210 * (bug 28868) Show total pages in the subtitle of an image on the
8211 file description page for multi-paged documents.
8212 * (bug 28883) Message names for different compression types commonly
8213 used in Tiff files.
8214 * When transcluding a special page, do not let it interpret url parameters.
8215 * (bug 28887) Special page classes are no longer re-used during 1 request.
8216 * (bug 28888) Searching for something starting with a # sign no longer tells
8217 the user a page named [[:]] already exists.
8218 * (bug 23002) Imagelinks table not updated after imagemove.
8219 * (bug 27864) Transcluding {{Special:Prefix}} with empty prefix now lists all
8220 pages.
8221 * (bug 18803) JPEG2000 images should not be uploadable as .jpg files.
8222 * (bug 11868) If using links to count articles, the checking will now be based
8223 on the real presence of an internal link instead of the "[[" string.
8224 * (bug 28287) The "your changes" box for edit conflicts is now read-only.
8225 * (bug 28940) When making a thumb of an SVG, and only specifying the height
8226 make the width be the max SVG size, not the natrual width of the SVG.
8227 * (bug 1780) Uploading files with non-ascii characters are now forbidden on
8228 Windows.
8229 * (bug 23464) File: prefixes are now chopped off during uploading.
8230 * (bug 28174) Message config-logo-help amended to not explicitly assume any
8231 LTR/RTL screen layout.
8232 * (bug 28992) Revision numbers in the patrol log are transformed in the user
8233 language.
8234 * (bug 27073) ResourceLoaderDynamicStyles marker should be dynamically appended to
8235 the document head if it doesn't exist.
8236 * (bug 27023) After the document is ready, mw.loader is broken (calls callback
8237 before module is parsed).
8238 * (bug 4330) External URLs without a custom title should be treated as LTR,
8239 even in RTL text.
8240 * (bug 29055) Make "don't send email on minor edits" preference apply to
8241 changes to talk page in addition to watchlist edits.
8242 * (bug 28272) Special:AllMessages should have only one "Go" button.
8243 * (bug 29101) Special:FileDuplicateSearch no longer shows silly message.
8244 * (bug 29048) jQuery.tabIndex: firstTabIndex() should not output the same
8245 as lastTabIndex().
8246 * (bug 29332) Warn if user requests mediawiki-announce subscription but does not
8247 enter an e-mail address.
8248 * (bug 25375) Add canonical namespaces to "wgNamespaceIds" in mw.config.
8249 * The class JpegOrTiffHandler was renamed ExifBitmapHandler.
8250 * (bug 29443) Special:Undelete should use JavaScript to invert all checkboxes
8251 instead of reloading the page.
8252 * (bug 29325) Setting $wgStrictFileExtensions to false no longer gives incorrect warning.
8253 * (bug 29437) Multiple apostrophes in deleted article title cause odd rendering.
8254 * (bug 29485) RSS feed of Special:RecentChange grouped together multiple
8255 consecutive edits by same user in included diff, but then linked to
8256 a single ungrouped diff.
8257 * Do not try to group together a page creation and edit in the RSS feed of RC.
8258 * (bug 29342) Patrol preferences shouldn't be visible to users who don't have
8259 patrol permissions.
8260 * (bug 29471) Exception no longer thrown for files with invalid date in metadata.
8261 * (bug 29492) Long-running steps in the installer (such as Upgrade and Install)
8262 no longer cause timeouts.
8263 * (bug 29507) Change 'image link' to 'file link' in Special:Whatlinkshere.
8264 * If the db is really screwed up, and doesn't have a recentchanges table,
8265 make the updater throw an exception instead of a fatal.
8266 * wfArrayToCGI() and wfCgiToArray() now handle nested and associative arrays
8267 correctly.
8268 * (bug 29567) mw.util.addPortletLink should only wrap link in <span> for
8269 "vectorTabs" portlets.
8270 * (bug 8556) Incorrect session failure warning on preview-on-open
8271 namespaces (categories) when combined with $wgRawHtml.
8272 * Use content language in formatting of dates in revertpage message
8273 (rollback revert edit summary) and do not adjust for user timezone.
8274 * (bug 29277) MediaWiki:Filepage.css is also shown on the local wiki
8275 * Make sure Backlink cache does not retrieve interwiki redirects when looking for
8276 redirects to a local page.
8277 * (bug 6100) Allow different directionality (LTR/RTL) for user interface
8278 and wiki content, along with many other RTL and directionality improvements
8279 (such as bugs 28030, 12406, 28349).
8280 * (bug 29712) Removed broken defaultUserOptionOverrides in MessagesXx files and
8281 unneeded CSS flipping of quickbar. Instead, introduce option 5 which sets
8282 left/right according to the directionality of your interface language.
8283 * (bug 19514) Unordered list list-style-image should be IE6-compatible (8-bit).
8284 * (bug 27410) The tag filter on a history page is now within a <label> element.
8285 * (bug 29779) DairikiDiff/WikiDiff <ins> and <del> should undo browser default
8286 styling (strike/underline).
8287 * (bug 28630) Add iwlinks, langlinks, redirect to
8288 RefreshLinks::deleteLinksFromNonexistent.
8289 * (bug 29797) Error: "Tried to load block with invalid type" when subpages
8290 are disabled for user pages.
8291 * (bug 12205) Bidirectional names in action=credits are split and displayed
8292 incorrectly when wrapped to the next line.
8293 * (bug 20781) Move 'mainpagetext' messages to installer's .i18n file.
8294 * (bug 29737) "MediaWiki:Qbsettings-directionality" should refer to script,
8295 not language.
8296 * (bug 26360) $wgSessionHandler was overriding system settings unconditionally.
8297 * Removed AjaxFunctions.php. The last remaining function js_unescape() was moved
8298 to the FCKEditor extension.
8299 * (bug 28762) Resizing to specified height broken for very thin images.
8300 * (bug 29959) Installer fatal when cURL and allow_url_fopen is disabled and user
8301 tries to subscribe to mediawiki-announce.
8302 * (bug 27427) mw.util.getParamValue shouldn't return value from hash even if
8303 param is only present in hash.
8304 * Installer checked for magic_quotes_runtime instead of register_globals.
8305 * (bug 30131) XCache with variable caching disabled no longer used for variable
8306 caching (CACHE_ACCEL)
8307 * $wgSVGMaxSize is now applied to the smaller of width or height, making very wide
8308 pano/timeline/diagram SVGs renderable at saner sizes.
8309 * (bug 30219) The page shown when LocalSettings.php does not exist was broken on
8310 Windows servers.
8311 * (bug 30074) Moving user JS subpages resulted in JS errors because
8312 #REDIRECT [[Foo]] is invalid JS.
8313 * (bug 30335) Fix for HTMLForms using GET breaking when non-friendly URLs
8314 are used.
8315 * (bug 30264) Changed installer-generated LocalSettings.php to use require_once()
8316 instead of require() for included extensions.
8317 * Tracking categories are no longer shown in footer for special pages.
8318 * (bug 30684) Fix bad escaping in mw.message for inexistent messages (i.e. <key>).
8319 * $wgOverrideSiteFeed no longer double escapes urls.
8320 * The preprocessor no longer fails with a PHP warning about XML_PARSE_HUGE when
8321 processing complex pages using newer versions of libxml2.
8322 * (bug 30907) Special:Unusedcategories should sort ascendingly.
8323 * (bug 28545) When using the uca-default collation, sortkey's starting with a
8324 space (U+20) will sort under an invisible header like in 1.16 rather than a U+6DE.
8325 * (bug 30192) Thumbnails of archived files are now deleted.
8326 * (bug 30843) mediawiki.Title should not convert extensions (anything after the
8327 last full stop) to lower case).
8328 * (bug 31213) Exception thrown when trying to move file cross-namespace.
8329 * (bug 18424) Special:Prefixindex and Special:Allpages paging links are
8330 really small, and somewhat inconsistent with each other.
8331 * (bug 30466) Entries in iwlinks table are now cleared when moving a page over
8332 redirect.
8333 * (bug 31674) Can't edit watchlist if it contains special pages.
8334 * (bug 32100) Installer complains about Suhosin GET limit even if it is
8335 already set above 1024 bytes.
8336
8337 === API changes in 1.18 ===
8338 * BREAKING CHANGE: action=watch now requires POST and token.
8339 * (bug 26339) Throw warning when truncating an overlarge API result.
8340 * (bug 14869) Add API module for accessing QueryPage-based special pages.
8341 * (bug 14020) API for Special:Unwatchedpages.
8342 * (bug 24287) Wrap API Help output at 100 characters.
8343 * Add a realname uiprop option to query=userinfo so a user's realname can be
8344 extracted.
8345 * Add a &watchuser option to ApiBlock.
8346 * (bug 26541) Generator-ise ApiQueryRecentChanges.
8347 * action=parse now correctly returns an error for nonexistent pages.
8348 * (bug 25767) Add userrights properties to allusers and users query lists.
8349 * (bug 26558) list=allusers auprop=groups does not list groups a user is
8350 automatically a member of.
8351 * (bug 26559) list=allusers auprop=rights does not match
8352 list=users usprop=rights.
8353 * (bug 26560) On allusers if limit < total number of users, last user gets
8354 duplicate.
8355 * (bug 25135) add "normalized" to action=parse.
8356 * (bug 26460) Add support for listing category members by category pageid.
8357 * (bug 26482) add a imimages param to prop=images.
8358 * (bug 26498) allow LinksUpdate with API.
8359 * (bug 26485) add a elextlinks param to prop=extlinks.
8360 * (bug 26483) add a iwtitles param to prop=iwlinks.
8361 * (bug 26484) add a lltitles param to prop=langlinks.
8362 * (bug 26480) add a pppageprops param to prop=pageprops.
8363 * (bug 26650) Remove $wgAPICacheHelp in favour of $wgAPICacheHelpTimeout.
8364 * (bug 24650) Fix API to work with categorylinks changes.
8365 * Expose list of skins in meta=siteinfo.
8366 * (bug 26548) Add iiurlparam param to query=imageinfo and query=stashimageinfo.
8367 * (bug 27205) aiprop=metadata and aiprop=parsedcomment need help text.
8368 * Add a amtitle param to meta=allmessages.
8369 * (bug 25832) query=allimages now outputs ns/title as well.
8370 * (bug 27199) Thumbnail urls can be fetched for old files as well.
8371 * (bug 27376) when using ApiBase::PARAM_TYPE => 'integer' without a min or
8372 max value, API doesn't validate the input is actually an integer.
8373 * (bug 27479) API error when using both prop=pageprops and
8374 prop=info&inprop=displaytitle.
8375 * (bug 27554) Update API information text to reflect change in bug 26125.
8376 * (bug 27611) list=blocks: Use ipb_by_text instead of join with user table.
8377 * (bug 27616) Add userid of blocked user and blocker to list=blocks.
8378 * (bug 27688) Simplify queries to list user block information.
8379 * (bug 27708) list=users does not have a property to return user id.
8380 * (bug 27715) imageinfo didn't respect revdelete.
8381 * (bug 27862) Useremail module didn't properly return success on success.
8382 * (bug 27590) prop=imageinfo now allows querying the media type.
8383 * (bug 27587) list=filearchive now outputs full title info.
8384 * (bug 27018) Added action=filerevert to revert files to an old version.
8385 * (bug 27897) list=allusers and list=users list hidden users.
8386 * (bug 27717) API's exturlusage module does not respect $wgMiserMode.
8387 * (bug 27588) list=filearchive&faprop=sha1 returns empty attribute.
8388 * (bug 28010) Passing a non existent user to list=users gives internal error.
8389 * (bug 27549) action=query&list=users&usprop=groups doesn't show implicit
8390 groups if a user doesn't have explicit groups.
8391 * (bug 27670) Ordering by timestamp (and usage of start and end) isn't as clear
8392 in auto generated document, as it is on mediawiki.org.
8393 * (bug 27182) API: Add filter by prefix for meta=allmessages.
8394 * (bug 27183) API: Add filter by customisation state for meta=allmessages.
8395 * (bug 27340) API: Allow listing of "small" categories.
8396 * (bug 27342) Add audir param to list=allusers.
8397 * (bug 27203) add fato param to list=filearchive.
8398 * (bug 27341) Add drto param to list=deletedrevs.
8399 * (bug 26630) Add API for Special:ActiveUsers.
8400 * (bug 27020) API: Allow title prefix search of logevents (only when not in
8401 miser mode).
8402 * (bug 26629) add Special:MIMESearch to API.
8403 * (bug 27585) add pagecount to list=filearchive.
8404 * (bug 28104) Namespace for local pages in interwiki backlinks (iwbacklinks)
8405 is missing.
8406 * (bug 27343) Add parseddescription to list=filearchive.
8407 * (bug 27469) label implicit groups in list=allusers&auprop=groups/
8408 list=users&usprop=groups.
8409 * Addition of APIQuerySiteInfoGeneralInfo hook to add extra information to
8410 the general site info results.
8411 * (bug 16288) API: consider making closure status of wikis more clear
8412 with meta=siteinfo.
8413 * (bug 27589) list=allimages&aiprop=archivename is useless.
8414 * (bug 27586) Remove duplication of props in ApiQueryStashImageInfo
8415 by using ApiQueryImageInfo.
8416 * (bug 28226) prop=extlinks&eloffset should be an integer.
8417 * (bug 28070) Fix watchlist RSS for databases that store timestamps in a
8418 real timestamp field.
8419 * API upload errors may now return the parameter that needs to be changed and
8420 a sessionkey to fix the error.
8421 * (bug 28249) allow dupes in meta=allmessages&amargs.
8422 * (bug 28263) cannot import xml with the API, when have not "import" user
8423 right, but "importupload".
8424 * (bug 28365) Added description for uiprop=preferencestoken in meta=userinfo.
8425 * (bug 28394) Set forgotten parameters types in ApiUnblock.
8426 * (bug 28395) Set forgotten parameters types in ApiParse.
8427 * (bug 28368) add hint for multipart/form-data to API information of
8428 action=import&xml=.
8429 * (bug 28391) action=feedwatchlist&allrev should be a bool.
8430 * (bug 28364) add registration date to meta=userinfo.
8431 * (bug 28254) action=paraminfo: Extract type from PARAM_DFLT if
8432 PARAM_TYPE is not set.
8433 * (bug 27712) add parent_id to list=deletedrevs.
8434 * (bug 28455) Add 'toponly' to recentchanges API module.
8435 * (bug 26873) API: Add 'toponly' filter in usercontribs module.
8436 * (bug 28586) YAML: strings that are the same as boolean literals.
8437 * (bug 28591) Update/replace/supplement spyc (YAML parsing library).
8438 * YAML API output is now 1.2 compliant, using JSON as the formatter.
8439 * (bug 28672) give information about misermode on API.
8440 * (bug 28558) Add iw_api and iw_wikiid to meta=siteinfo&siprop=interwikimap
8441 * (bug 26882) Allow listing of indefinite protections with the API.
8442 * (bug 27344) add drprefix param to list=deletedrevs.
8443 * (bug 28560) list=deletedrevs should die, if combination of param is invalid.
8444 * (bug 28238) paraminfo: output both limits for multi param.
8445 * (bug 27179) API: List of extension tags through meta=siteinfo.
8446 * Get a list of function hooks through meta=siteinfo.
8447 * Get a list of all subscribed hooks, and those subscribers.
8448 * (bug 28225) Allow hiding of user groups in list=allusers.
8449 * (bug 27185) API: Add Special:ComparePages.
8450 * (bug 28265) allow outputting of comments for action=expandtemplates.
8451 * (bug 27790) Add query type for querymodules to output of ApiParamInfo.
8452 * (bug 28963) Add langbacklinks query module to the api.
8453 * (bug 27593) API should return error message when sha1/sha1base36 is invalid.
8454 * (bug 28578) API's parse module should not silently override invalid
8455 title inputs.
8456 * (bug 20699) Watchlist API should list log-events.
8457 * (bug 29070) Require a token in API action=watch.
8458 * (bug 29221) Expose oldrevid in ApiQueryWatchlist output.
8459 * (bug 29267) Always give the servername for meta=siteinfo&siprop=dbrepllag.
8460 * (bug 28897) rvparse now respects rvsection for action=query&prop=revisions.
8461 * (bug 25734) API: Possible issue with revids validation.
8462 * (bug 28002) Internal error in ApiFormatRaw::getMimeType.
8463 * (bug 29237) ApiQuery now has an option to output the "iwurl" attribute.
8464 * (bug 28392) Mark action=undelete&timestamps as type "timestamp".
8465 * (bug 21346) Make deleted images searchable by hash (disabled in Miser Mode).
8466 * (bug 27595) sha1 search of list=filearchive does not work.
8467 * (bug 26763) Make RSS/Atom of user contributions more visible.
8468 * (bug 25133) Allow redirects also for action=parse&pageid.
8469 * (bug 29745) Fatal error in API search.
8470 * (bug 29476) API returns page title instead of sectiontitle for
8471 srprop=sectiontitle.
8472 * Correct the documentation of srprop properties.
8473 * (bug 28817) Add reference help page link to API Modules.
8474 * (bug 29935) Improve formatting of examples in ApiParamInfo.
8475 * (bug 29938) list=users&usprop=rights shows rights the user doesn't have.
8476 * (bug 24781) The API will include an XML namespace if the includexmlnamespace
8477 parameter is set.
8478 * (bug 29392) Setting the start or end parameter now works with lists blocks,
8479 categorymembers, deletedrevs, logevents, protectedtitles, usercontributions
8480 and watchlist in Postgres.
8481
8482 === Languages updated in 1.18 ===
8483
8484 MediaWiki supports over 330 languages. Many localisations are updated
8485 regularly. Below only new and removed languages are listed, as well as
8486 changes to languages because of Bugzilla reports.
8487
8488 * Angika (anp) (new).
8489 * Brahui (brh) (new).
8490 * Central Dusun (dtp) (new).
8491 * Jamaican Creole English (jam) (new).
8492 * Khowar (khw) (new).
8493 * Liv (liv) (new).
8494 * Kichwa (qug) (new).
8495 * Tokipona (tp) (removed) 'tokipona' is still valid.
8496 * (bug 17160) Gender specific display text for User namespace.
8497 * Link trail added for sl and sh.
8498 * (bug 27633) Add characters to linkTrail for Portuguese (pt and pt-br).
8499 * (bug 27426) Set $namespaceGenderAliases for Arabic (ar).
8500 * (bug 27385) Set Polish $namespaceGenderAliases.
8501 * (bug 27681) Set $namespaceGenderAliases for Portuguese (pt and pt-br).
8502 * (bug 27785) Fallback language for Kabardian (kbd) is English now.
8503 * (bug 27825) Raw watchlist edit message now uses formatted numbers.
8504 * (bug 28040) Turkish: properly lower case 'I' to 'i' (dotless i) and
8505 uppercase 'i' to 'I' (dotted i).
8506 * Conversion script between Syllabics and Latin for the Inuktitut language.
8507 * Date formats for Indonesian (id) updated.
8508 * Bhojpuri (bho) (renamed from "bh").
8509 * (bug 29031) When translating block log entries, indefinite, infinite, and
8510 infinity are now considered the same.
8511 * Aromanian (rup) (renamed from "rua-rup").
8512 * Kashmiri (ks) split into Kashmiri (Perso-Arabic) (ks-arab) and Kashmiri
8513 (Devanagari) (ks-deva). Defaults to ks-arab.
8514 * (bug 30864) Use bengali numerals for <ol> for Assamese.
8515 * (bug 30817) Restored linktrail for kk (Kazakh).
8516 * (bug 27398) Add $wgExtraGenderNamespaces for configured gendered namespaces.
8517 * (bug 30846) New LanguageOs class.
8518
8519 === Other changes in 1.18 ===
8520 * Removed legacy wgAjaxWatch javascript global object, no longer in use.
8521 * (bug 28556) Upload support for MacBinary files has been removed (Used by
8522 Internet Explorer 5 for Mac OS 9).
8523 * On wiki farm setups using $wgConf, 'wgCanonicalServer' is now expected to be
8524 set for all wikis. This was already the case for 'wgServer'.
8525
8526 == MediaWiki 1.17 ==
8527
8528 == MediaWiki 1.17.5 ==
8529 2012-06-12
8530
8531 This is a security release of the MediaWiki 1.17 branch.
8532
8533 === Summary of selected changes in 1.17 ===
8534
8535 Selected changes since MediaWiki 1.16 that may be of interest:
8536
8537 * A new installer has been introduced. It has a wizard-style interface which is
8538 translated into many languages. Many shortcomings in the old installer were
8539 addressed with this rewrite. Note that it is no longer required for the config
8540 directory to be made writable by the webserver. Instead the generated
8541 LocalSettings.php file is offered as a download, which you must then upload
8542 to the wiki's base directory.
8543
8544 * ResourceLoader, a new framework for delivering client-side resources such as
8545 JavaScript and CSS, has been introduced. These resources are now delivered
8546 through the new entry point script "load.php", instead of as static files
8547 served directly by the web server. This allows minification, compression and
8548 client-side caching to be used more effectively, which should provide a net
8549 performance improvement for most users.
8550
8551 * Category sorting has been improved.
8552 ** Sorting is now case insensitive.
8553 ** Sub-categories, pages and files can now be paged separately.
8554 ** When several pages are given the same sort key, they sort by their
8555 names instead of randomly.
8556
8557 * The lowest supported version of PHP is now 5.2.3. If necessary, please
8558 upgrade PHP prior to upgrading MediaWiki.
8559
8560 === Changes since 1.17.4 ===
8561
8562 * (bug 36938) Correctly escape uselang attribute to prevent xss
8563 * Expanded Blacklist for SVG Files
8564
8565 === Changes since 1.17.3 ===
8566
8567 * (bug 35961) Hash comparison should always be strict.
8568 * Fix broken email confirmation expiration caused by MWCryptRand changes.
8569 * (bug 35671) PHP Notice: Undefined index: gettoken in includes/api/ApiMain.php
8570 on line 598.
8571
8572 === Changes since 1.17.2 ===
8573
8574 * (bug 22555) Remove or skip strip markers from tag hooks like &lt;nowiki&gt; in
8575 core parser functions which operate on strings, such as padleft.
8576 * (bug 34212) ApiBlock/ApiUnblock allow action to take place without a token
8577 parameter present.
8578 * (bug 34907) Fixed exposure of tokens through load.php that could have facilitated
8579 CSRF attacks.
8580 * (bug 35317) CSRF in Special:Upload.
8581
8582 === Changes since 1.17.1 ===
8583 * (bug 33117) prop=revisions allows deleted text to be exposed through cache pollution.
8584 * (bug 32709) Private Wiki users were always taken to Special:Badtitle on login.
8585
8586 === Changes since 1.17.0 ===
8587
8588 * (bug 29535) Added missing Creative Commons CC0 icon.
8589 * (bug 29726) Fixed failure to load internationalization messages in
8590 client-side scripts on WebKit-based browsers.
8591 * Fixed a bug in message transformation where the previous language could leak
8592 into later transformations in the UI language.
8593 * (bug 29091) Fixed form of native name for Ossetic language (Иронау -> Ирон)
8594 * Fixed maintenance scripts upgrade1_5.php and rebuildImages.php, they did not
8595 work at all since 1.17 beta 1.
8596 * (bug 29531) Fixed img_auth.php for thumbnails and other filenames with
8597 multiple dots, was broken by the fix for bug 28840.
8598 * In the maintenance script purgeList.php, fixed a fatal error when a page
8599 title is given, instead of a URL.
8600 * (bug 19514) Unordered list list-style-image should be IE6-compatible (8-bit).
8601 * Installer checked for magic_quotes_runtime instead of register_globals.
8602 * $wgSVGMaxSize is now applied to the smaller of width or height, making very
8603 wide pano/timeline/diagram SVGs renderable at saner sizes.
8604 * (bug 29959) Installer fatal when cURL and allow_url_fopen is disabled and user
8605 tries to subscribe to mediawiki-announce.
8606 * Installer checked for magic_quotes_runtime instead of register_globals
8607 * (bug 30131) XCache with variable caching disabled no longer used for variable
8608 caching (CACHE_ACCEL)
8609 * (bug 30264) Changed installer-generated LocalSettings.php to use require_once()
8610 instead require() for included extensions.
8611 * (bug 26486) ResourceLoader modules with paths to nonexistent files cause PHP
8612 warnings/notices to be thrown
8613 * (bug 30907) Special:Unusedcategories should sort ascendingly.
8614 * (bug 30219) The page shown when LocalSettings.php does not exist was broken on
8615 Windows servers.
8616 * Hardcoded NLS_NUMERIC_CHARACTERS for Oracle DB to prevent type conversion errors.
8617 * Fixed recentchanges FK violation on page delete and cache purge error in updater
8618 for Oracle DB.
8619 * (bug 32276) Skins were generating output using the internal page title which
8620 would allow anonymous users to determine whether a page exists, potentially
8621 leaking private data. In fact, the curid and oldid request parameters would
8622 allow page titles to be enumerated even when they are not guessable.
8623 * (bug 32616) action=ajax requests were dispatched to the relevant internal
8624 functions without any read permission checks being done. This could lead to
8625 data leakage on private wikis.
8626
8627 === Changes since 1.17.0rc1 ===
8628
8629 * Fixed syntax error in generated LocalSettings.php when a non-default user
8630 rights profile is chosen.
8631 * (bug 29399) Fixed PostgreSQL installation when the DB user for installation
8632 is the same as the one for web access.
8633 * (bug 29233) Fixed failover for DB slave servers. When a DB slave went down,
8634 an error was immediately shown to the user, instead of trying another slave.
8635 Was broken since 1.17 beta 1.
8636 * (bug 29278) Fixed PHP fatal error when attempting to add text to a page via a
8637 redirect.
8638 * (bug 29408) Fixed uploads of files with MIME types that aren't detected by
8639 MediaWiki.
8640 * Removed DEFAULT '' NOT NULL field definitions from Oracle DB schema because
8641 using the DEFAULT value ('') in DML broke Oracle backend as it treats an
8642 empty VARCHAR2 value as NULL. Indexes on Oracle do not require NOT NULL
8643 fields.
8644
8645 === Changes since 1.17 beta 1 ===
8646
8647 * Fixed warning about missing file "password.js".
8648 * When installing on MySQL, don't attempt to create a new database user if the
8649 same user is used for installation and web access.
8650 * Fixed SQL query errors in queries with table aliases.
8651 * (bug 27891) Fixed the "chronology protector", broken since 1.17beta1, which
8652 ensures that when database replication is used, the new version is seen by
8653 the user immediately after they create or edit an article.
8654 * (bug 28845) Allow PostgreSQL installation using a non-root user account which
8655 has role creation abilities.
8656 * When installing on PostgreSQL and the install account is the same as the web
8657 account, check to make sure that the account has suitable privileges in the
8658 mediawiki schema.
8659 * (bug 28172) Fixed error in PostgreSQL installation when creating the wiki
8660 sysop account.
8661 * Fixed an issue with the Oracle installer in cases where the user is different
8662 to the database name.
8663 * Added "unblockself" to the list of available rights.
8664 * In the installer, fixed the "user rights profile" option, it never worked.
8665 * (bug 29117) Fixed Hebrew localisation of the installer.
8666 * (bug 28840) Reduce the collateral damage caused by the fix for bug 28235 (XSS
8667 on Internet Explorer 6 due to a file extension in the query string) by
8668 reducing the number of URLs that are blocked, and by redirecting the request
8669 to a safer URL where possible instead of blocking it.
8670 * (bug 28812) Fixed documentation of API action=parse.
8671 * (bug 28979) Fixed styling of <abbr> and <acronym>.
8672 * Fixed the error message displayed when you try to create an account by email,
8673 but an email address is not given.
8674 * Fixed JS error due to missing dependency for jquery.suggestions.
8675 * Exposed $wgExtensionAssetsPath in JavaScript.
8676 * (bug 28738) Made ResourceLoader support environments with small URL length
8677 limits. The length limit can be configured via $wgResourceLoaderMaxQueryLength,
8678 and this is set automatically in the generated LocalSettings.php when the
8679 php.ini variable "suhosin.get.max_value_length" is set. When a URL exceeds
8680 this limit, the request is split up. Also, reduced the average length of
8681 load.php URLs by using a more compact parameter format.
8682 * (bug 25262) Fix for minification of hardcoded data: URIs in CSS.
8683 * (bug 25124) Respect $wgStyleDirectory in ResourceLoader.
8684 * Allow installation when no HTTP client is available, don't throw an exception.
8685 * (bug 27465) Fix metadata extraction for SVG files using unusual namespace
8686 names.
8687 * (bug 29174) Fix regression in upload-by-URL: uploading files larger than the
8688 PHP memory limit should work again.
8689 * Fixed the display of comments in the new user log.
8690 * (bug 28237) When installing extensions using the web-based installer, create
8691 any necessary database tables.
8692 * (bug 28983) Fixed automated installation of extensions that overwrite $path.
8693 * Fixed error caused by missing magic words.
8694 * Fixed breakage of article editing in PostgreSQL due to text search
8695 configuration errors.
8696 * Fixed the HTTPS client used when Curl is not available. This avoids an error
8697 during install about failure of the mediawiki-announce subscription.
8698 * (bug 28162) When installing to PostgreSQL, respect the "database port" input,
8699 it was ignored.
8700
8701 === Configuration changes in 1.17 ===
8702
8703 * $wgLogAutocreatedAccounts controls whether autocreation of accounts is logged
8704 to new users log.
8705 * (bug 22858) $wgLocalStylePath is by default set to the same value as
8706 $wgStylePath but should never point to a different domain than the site is
8707 on, allowing skins to use .htc files which are not cross-domain friendly.
8708 * $wgFileStore has been deprecated. The only usage $wgFileStore['deleted'] has
8709 been turned into $wgDeletedDirectory.
8710 * $wgDeletedDirectory has been added to specify what directory to place deleted
8711 uploads in.
8712 * IBM DB2 database no longer uses the db specific $wgDBport_db2 variable but the
8713 normal $wgDBport.
8714 * $wgCategoryPrefixedDefaultSortkey was removed and is now always false. This
8715 provides more sensible sorting behavior for categories.
8716 * Removed unused globals: $wgEnableSerializedMessages, $wgCheckSerialized,
8717 $wgUseMemCached, $wgDisableSearchContext, $wgColorErrors, $wgUseZhdaemon,
8718 $wgZhdaemonHost and $wgZhdaemonPort.
8719 * (bug 24408) The include_path is not modified in the default LocalSettings.php
8720 * $wgVectorExtraStyles was removed, and is no longer in use.
8721 * Removed $wgUpdates for database updates; extensions should use
8722 DatabaseUpdater::addExtensionUpdate() via the LoadExtensionSchemaUpdates hook.
8723 * Removed $wgServerName. It doesn't need to be set anymore and is no longer
8724 available as input for other configuration items, either.
8725 * It's no longer necessary for LocalSettings.php to include DefaultSettings.php.
8726 * It's no longer necessary to set $wgCacheEpoch to the file modification time
8727 of LocalSettings.php, in LocalSettings.php itself. Instead, this is done
8728 automatically if $wgInvalidateCacheOnLocalSettingsChange is true (which is
8729 the default).
8730 * $wgCopyrightIcon is deprecated and $wgFooterIcons['copyright']['copyright']
8731 should be used instead.
8732 * $wgSysopUserBans is deprecated, and will be made permanently true in 1.18.
8733 If you need this functionality, you should use the BlockIp hook to filter and
8734 reject such blocks.
8735 * $wgSysopRangeBans is deprecated, you should set $wgBlockCIDRLimit to maximum
8736 (32 for IPv4, 128 for IPv6), equivalent to allowing rangeblocks of only 1
8737 address at a time.
8738
8739 === New features in 1.17 ===
8740
8741 * (bug 10183) Users can now add personal styles and scripts to all skins via
8742 User:<name>/common.css and /common.js (if user css/js is enabled).
8743 * (bug 22748) Add anchors on Special:ListGroupRights.
8744 * (bug 21981) Add parameter 'showfilename' to <gallery> to automatically
8745 apply the names of the individual files within the gallery.
8746 * Future-proof redirection to fragments in Gecko, so things work a little nicer
8747 if they fix <https://bugzilla.mozilla.org/show_bug.cgi?id=516293>.
8748 * Support git:// and mms:// protocols by default for external links.
8749 * (bug 15810) Blocked admins can no longer unblock themselves without the
8750 'unblockself' permission (which they have by default).
8751 * (bug 18499) Added "enhanced" URL parameter to switch between old and enhanced
8752 changes list.
8753 * (bug 22925) "sp-contributions-blocked-notice-anon" message now displayed when
8754 viewing contributions of a blocked IP address.
8755 * (bug 22474) {{urlencode:}} now takes an optional second parameter for type of
8756 escaping.
8757 * Special:Listfiles now supports a username parameter.
8758 * Special:Random carries over query string parameters.
8759 * (bug 23206) Add Special::Search hook for detecting successful "Go".
8760 * When visiting a "red link" of a deleted file, a deletion and move log excerpt
8761 is provided on the Upload form.
8762 * (bug 22647) Add category details in search results.
8763 * (bug 23276) Add hook to Special:NewPages to modify query.
8764 * Add accesskey 's' and tooltip to 'Save' button at Special:Preferences.
8765 * Add accesskey 'b' and tooltip to the summary field of edit mode.
8766 * (bug 20186) Allow filtering Special:Contributions for RevisionDeleted edits.
8767 * ajaxwatch now uses the API and JQuery, and can be used to animate arbitrary
8768 watch links, not just to watch the page the link is on.
8769 * (bug 20976) "searchmenu-new-nocreate" message now displayed when there
8770 is no title match in search and the user has no rights to create pages.
8771 * (bug 23429) Added new hook WatchlistEditorBuildRemoveLine.
8772 * (bug 22844) Added support for WinCache object caching (for IIS).
8773 * (bug 23580) Add two new events to LivePreview so that scripts can be notified
8774 about the beginning and finishing of LivePreview actions.
8775 * (bug 21278) Now the sidebar allows inclusion of wiki markup.
8776 * (bug 23733) Add IDs to messages used on CSS/JS pages.
8777 * Show validity period of the login cookie in Special:UserLogin and
8778 Special:Preferences.
8779 * Interlanguage links display the page title in their tooltip.
8780 * (bug 23621) New Special:ComparePages to compare (diff) two articles.
8781 * (bug 4597) Provide support in Special:Contributions to show only "current"
8782 contributions
8783 * (bug 17857) {{anchorencode}} acts more like how the parser creates section ids
8784 * (bug 21477) \& can now be used in <math>
8785 * (bug 11641) \dotsc \dotsm \dotsi \dotso can now be used in <math>
8786 * (bug 21475) \mathtt and \textsf can now be used in <math>
8787 * texvc is now run via ulimit4.sh, to limit execution time.
8788 * SQLite now supports $wgSharedDB.
8789 * (bug 8507) Group file links by namespace:title on image pages.
8790 * Stop emitting named entities, so we can use <!DOCTYPE html> while still being
8791 well-formed XML.
8792 * texvc now supports \bcancel and \xcancel in addition to \cancel and \cancelto
8793 * Added scriptExtension setting to $wgForeignFileRepos.
8794 * ForeignApiRepo uses scriptDirUrl if apiBase not set.
8795 * (bug 24212) Added MediaWiki:Filepage.css which is also included on foreign
8796 client wikis.
8797 * (bug 14685) Double underscore magic word usage is now tracked in the
8798 page_props table, as well as the behavioral magic words {{DEFAULTSORT}} and
8799 {{DISPLAYTITLE}}
8800 * (bug 24045) MediaWiki:Ipb-needreblock is now wrapped in a div with class
8801 "mw-ipb-needreblock"
8802 * Non-file pages can no longer be moved to the file namespace, nor vice versa.
8803 * (bug 671) The <dfn>, <kbd> and <samp> elements have been whitelisted in user
8804 input.
8805 * (bug 21503) There's now a "reason" field when creating account for other users.
8806 * (bug 24418) action=markpatrolled now requires a token.
8807 * A variety of category sort-related fixes, including:
8808 ** (bug 164) In English, lowercase and uppercase letters now sort the same.
8809 ** (bug 1211) Subcategories, ordinary pages, and files now page separately.
8810 ** When several pages are given the same sort key, they sort by their names
8811 instead of randomly.
8812 * (bug 23848) Add {{ARTICLEPATH}} Magic Word.
8813 * (bug 8140) Add dedicated CSS classes to Special:Newpages elements.
8814 * (bug 11005) Add CSS class to empty pages in Special:Newpages.
8815 * The parser cache is now shared amongst users whose different settings aren't
8816 used in the page.
8817 * Any attribute beginning with "data-" can now be used in wikitext, per HTML5.
8818 * (bug 24007) Diff pages now mention the number of users having edited
8819 intermediate revisions.
8820 * Added new hook GetIP.
8821 * Special:Version now displays whether a SQLite database supports full-text
8822 search.
8823 * TS_ISO_8691_BASIC was added as a time format, which is used by ResourceLoader
8824 for versioning.
8825 * Maintenance scripts get a --memory-limit option to override defaults (which
8826 is usually to set it to -1 to disable the limit).
8827 * (bug 25397) Allow uploading (not displaying) of WebP images, disabled
8828 by default.
8829 * (bug 23194) Special:ListFiles now has thumbnails.
8830 * Use hreflang to specify canonical and alternate links, search engine friendly
8831 when a wiki has multiple variant languages.
8832 * (bug 19593) Specifying --server in now works for all maintenance scripts.
8833 * Now rebuildtextindex.php warns if SQLite doesn't support full-text search.
8834 * (bug 10541) Front/backend separation of installation/upgrade code.
8835 * (bug 10596) Allow installer to enable extensions already in extensions folder.
8836 * (bug 20627) Installer should be in languages other than English.
8837 * Support for metadata in SVG files (title, description).
8838 * Special:Search: Add CSS classes to 'none found' and 'create link' messages.
8839 * Add CSS classes (including namespace and pagename) to the enhanced recent
8840 changes/watchlist entries.
8841 * (bug 22463) Add hook 'SkinGetPoweredBy' to make 'powered by' icon/text
8842 customizable.
8843 * Added CSS print pagination to the print stylesheets.
8844 * (bug 25960) Add <link rel=canonical"> for File pages of shared/foreign
8845 file repositories.
8846 * When viewing a redirect, the redirect arrow and redirection target are both
8847 wrapped in a div that has the class "redirectMsg" so that the redirection
8848 arrow can be customized with CSS.
8849 * (bug 21911) Hard coded limit for long page warning removed. New message
8850 [[MediaWiki:Longpage-hint]] (empty per default) can be used instead.
8851 Parameters: $1 shows the formatted textsize in Byte/KB/MB, $2 is the raw
8852 number of the textsize in Byte.
8853 * (bug 3276) Give image <gallery>s fluid width.
8854 * Added uploads link to page subtitle in Special:Contributions.
8855 * Added Special:Myuploads special page that redirects to Special:Listfiles.
8856 * The footerlinks used in Monobook/Vector/Modern are now part of common skin
8857 code, SkinTemplateOutputPageBeforeExec can be used to customize the list.
8858 * Special wrapping setups can now define MW_CONFIG_FILE to load a config file
8859 other than LocalSettings.php. This is like MW_CONFIG_CALLBACK but works in
8860 some cases where MW_CONFIG_CALLBACK will not work.
8861 * (bug 26574) Added 'upload' to $wgRestrictionTypes, allowing upload protected
8862 pages to be queried via the API and Special:ProtectedPages, and allowing
8863 disabling upload protection by removing it from $wgRestrictionTypes.
8864 * The name attribute of HTMLForm fields can now be overridden by passing a
8865 'name' key in the descriptor array. Hidden field names are now treated
8866 consistently with other fields and, by default, prefixed with 'wp'.
8867 * (bug 27402) Add support for disabling MWSuggest.
8868 * (bug 26563) Add bytes changed per revision for stub and full article dumps.
8869 * (bug 27508) Add $wgSVGMetadataCutoff to limit the maximum amount of an svg we
8870 look at when finding metadata to prevent excessive resource usage.
8871 * (bug 198) $wgUpgradeKey allows unlocking the web installer for upgrades
8872 without having to move LocalSettings.php
8873 * Added $wgAllowImageTag, which can be set to true to whitelist the <img> tag
8874 in wikitext.
8875 * (bug 12797) Add $wgGalleryOptions for adjusting of default gallery display
8876 options.
8877 * Added the $wgAllowUserCssPrefs option which allows disabling CSS-based
8878 preferences; which can improve page loading speed.
8879 * Added $wgSQLMode for setting database SQL modes - either performance (null)
8880 or other reasons (such as enabling stricter checks).
8881 * (bug 20193) Added $wgVectorShowVariantName global configuration variable
8882 which causes Vector to render the variants drop-down menu with a label
8883 showing the current variant name. This is off by default, pending further
8884 research into its user experience implications.
8885 * The upload link for missing files can now be set separately from the
8886 navigation link with $wgUploadMissingFileUrl.
8887 * $wgAdditionalMailParams added to allow setting extra options to mail() calls.
8888 * Added $wgSecureLogin to optionally login using HTTPS.
8889 * (bug 25728) Added $wgPasswordSenderName to make the name associated
8890 with $wgPasswordSender configurable.
8891 * (bug 22463) $wgFooterIcons added to allow configuration of the icons shown in
8892 the footers of skins.
8893 * $wgFileCacheDepth can be used to set the depth of the subdirectory hierarchy
8894 used for the file cache. Default value is 2, which matches former behavior.
8895
8896 === Bug fixes in 1.17 ===
8897
8898 * (bug 17560) Half-broken deletion moved image files to deletion archive
8899 without updating database.
8900 * (bug 22666) Submitting user block form with an invalid user name no longer
8901 throws an error.
8902 * (bug 22665, bug 22667) User '0' can now be unblocked and have its block
8903 settings changed.
8904 * (bug 22606) The body of e-mail address confirmation message is now different
8905 when the address changed.
8906 * (bug 22664) Special:Userrights now accepts '0' as a valid user name.
8907 * (bug 5210) Preload parser now parses <noinclude>, <includeonly> and
8908 redirects.
8909 * (bug 22709) IIS7 mishandles redirects generated by OutputPage::output() when
8910 the URL contains a colon.
8911 * (bug 22353) Categorised recent changes now works again.
8912 * (bug 22747) "Reveal my e-mail address in notification e-mails" preference is
8913 now only displayed when relevant.
8914 * (bug 22772) {{#special:}} parser function now works with subpages.
8915 * (bug 18664) Relative URIs in interwiki links cause failed redirects.
8916 * (bug 19270) Relative URIs in interwiki links break interwiki transclusion.
8917 * (bug 22903) Revdelete log entries now show in the user preferred language.
8918 * (bug 22905) Correctly handle <abbr> followed by ISBN.
8919 * (bug 22940) Namespace aliases pointing to main namespace don't work.
8920 * (bug 15810) Blocked admins can no longer block/unblock other users.
8921 * (bug 22876) Avoid possible PHP Notice if $wgDefaultUserOptions is not
8922 correctly set.
8923 * (bug 14952) Page titles are renormalized after html entities are removed so
8924 that links with non-NFC character references work correctly.
8925 * (bug 22991) wgUserGroups JavaScript variable now reports * group for
8926 anonymous users instead of null.
8927 * (bug 22627) Remove PHP notice when deleting a page only hidden users edited.
8928 * (bug 21520) Anonymous previews now also gives a warning about not being
8929 logged in (anonpreviewwarning).
8930 * (bug 22935) image/x-ms-bmp mime type added for BMP files.
8931 * (bug 23024) Special:ListFiles now escapes file names correctly.
8932 * (bug 22867) "View source" tab is now only displayed if there's source text.
8933 * (bug 19393) Feeds now format dates in user language rather than content
8934 language.
8935 * (bug 22852) "Served in" comment is now the time used to cache a single page
8936 when using rebuildFileCache.php
8937 * (bug 22496) Viewing diff of a redirect page without specifying "oldid"
8938 parameter no longer makes the page displayed as being the redirect target.
8939 * (bug 22918) Feed cache keys now use $wgRenderHashAppend.
8940 * (bug 21916) Last-Modified header is now correct when outputting cached feed.
8941 * (bug 20049) Fixed PHP notice in search highlighter that occurs in some cases.
8942 * (bug 23017) Special:Disambiguations now list pages in content namespaces
8943 rather than only main namespace.
8944 * (bug 23063) $wgMaxAnimatedGifArea is checked against the total size of all
8945 frames, and $wgMaxImageArea against the size of the first frame, rather than
8946 the other way around. Both now default to 12.5 megapixels. Also, images
8947 exceeding $wgMaxImageArea can still be embedded at original size.
8948 * (bug 23078) "All public logs" option on Special:Log is now always the first
8949 item.
8950 * (bug 16817) Group names in user rights log are now singular and in lowercase.
8951 * Special:Preferences no longer crashes if the wiki default date formatting
8952 style is not valid for the user's interface language.
8953 * (bug 23167) Check the watch checkbox by default if the watchcreations
8954 preference is set.
8955 * Maintenance script cleanupTitles is now able to fix titles stored
8956 in a negative namespace (which is invalid).
8957 * (bug 19858) Removed obsolete <big> in interface messages.
8958 * (bug 21456) "Bad title" error when showing non-local interwiki pages no longer
8959 displays incorrect tabs.
8960 * (bug 23190) Improved math representation for text browsers.
8961 * (bug 22015) Improved upload-by-url error handling and error display.
8962 * (bug 17941) $wgMaxUploadSize is now honored by all upload sources.
8963 * (bug 23080) New usernames now limited to 235 bytes so that custom skin files
8964 work.
8965 * (bug 23075) Correct MediaTransformError default width in gallery.
8966 * (bug 16487) The Anonymous user account used on Postgres is no longer
8967 displayed on Special:Listusers.
8968 * (bug 23313) Move watchlisthidepatrolled above token in watchlist preferences
8969 to enhance preference grouping.
8970 * (bug 23298) Interwiki links with prefix only in log summaries now link to the
8971 correct link.
8972 * (bug 23284) Times are now rounded correctly.
8973 * (bug 23375) Added ogv, oga, spx as extensions for ogg files.
8974 * (bug 18408) All required permissions for uploading (upload, edit, create)
8975 are now checked when loading Special:Upload. Toolbar link for Special:Upload
8976 is no longer shown if the user does not have the required permissions.
8977 * (bug 23397) texvc in html mode renders \sim as &tilde; not &sim;
8978 * (bug 23241) License selector should be disabled during upload of a new
8979 version.
8980 * (bug 23240) Add ID to namespace selector form on Special:Watchlist.
8981 * The pipe | character in urls is now escaped.
8982 * (bug 23422) mp3 files can now be moved.
8983 * (bug 23448) MediaWiki:Summary-preview is now displayed instead of
8984 MediaWiki:Subject-preview when previewing summary.
8985 * (bug 23426) The {{REVISIONMONTH}} variable is now zero-padded and added
8986 new variable {{REVISIONMONTH1}} when unpadded version is needed.
8987 * Special:Userrights didn't recognize user as changing his/her own rights if
8988 user did not capitalize first letter of username.
8989 * (bug 23507) Add styles for printing wikitables.
8990 * (bug 19586) Avoid JS errors in mwsuggest when using old browsers such
8991 as Opera 8.
8992 * (bug 23563) Old skins now support $wgUploadNavigationUrl and take into
8993 account upload rights.
8994 * (bug 1347) Render \phi in math using images, in order to create consistent
8995 and correct render results.
8996 * (bug 16573) Render \epsilon in math using images, in order to create
8997 consistent and correct render results.
8998 * (bug 22541) Support image redirects when using ForeignAPIRepo.
8999 * (bug 22967) Make edit summary length cut-off behave correctly for multibyte
9000 characters.
9001 * (bug 8689) Long numeric lines no longer kill the parser.
9002 * (bug 23740) Article::doRedirect() now use $extraQuery parameter correctly if
9003 the $noRedir parameter is set to true.
9004 * (bug 23688) Correct mime types for Office 2007 OpenXML documents.
9005 * (bug 23787) Corrected $wgDefaultSkin's comment in DefaultSettings.php.
9006 * (bug 23797) Xml::input() now allows '0' for the value parameter.
9007 * (bug 23747) Make sure that on History pages, the RevDel button is not
9008 accidentally activated when hitting enter.
9009 * (bug 23845) Special:ListFiles now uses correct file names without underscores.
9010 * Ask for permanent login in Special:Preferences only if $wgCookieExpiration > 0.
9011 * (bug 16356) Repair dumpInterwiki.inc to use proper normalization.
9012 * (bug 24006) deleteArchivedRevisions.php maintenance script now longer throws
9013 a fatal error.
9014 * (bug 23465) Don't ignore the predefined destination filename on
9015 Special:Upload after following a red link.
9016 * (bug 23642) Recognize mime types of MS OpenXML documents.
9017 * (bug 22784) Normalise underscores and spaces in autocomments.
9018 * (bug 19910) Headings of the form ===+\s+ are now displayed as valid headings.
9019 * (bug 24022) Only check file extensions on the uploadpage when needed.
9020 * (bug 24076) Recognize Office 2003 files with OpenXML trailers.
9021 * (bug 24244) Updated comments in DefaultSettings.php to reflect
9022 Image: --> File: namespace rename.
9023 * Make wfTimestamp recognize negative unix timestamp values.
9024 * (bug 24401) SimpleSearch: No button/text indicating 'Search' if image is
9025 disabled.
9026 * (bug 23293) Do not show change tags when Special:RecentChanges(linked) or
9027 Special:Newpages is transcluded into another page as it messes up the page.
9028 * (bug 24517) LocalFile::newFromKey() and OldLocalFile::newFromKey() no longer
9029 throw fatal errors.
9030 * (bug 23380) Uploaded files that are larger than allowed by PHP now show a
9031 useful error message.
9032 * Uploading to a protected title will allow the user to choose a new name
9033 instead of showing an error page.
9034 * (bug 24425) Use Database::replace instead of delete/insert in
9035 SqlBagOStuff::set to avoid query errors about duplicate keynames.
9036 * (bug 15470) First letters of filenames are always capitalized by upload JS.
9037 * (bug 21215) NoLocalSettings.php doesn't tolerate rewrite rules.
9038 * (bug 21052) Fix link color for stubs in NewPages.
9039 * (bug 24714) Usage of {{#dateformat: }} in wikis without $wgUseDynamicDates no
9040 longer pollutes the parser cache.
9041 * (bug 17031) Correct which characters the parser allows in tag attributes (a
9042 letter, colon or underscore followed by 0 or more letters, numbers, colons,
9043 underscores, hyphens, and/or periods).
9044 * Save 200 useless queries on each category page view.
9045 * Shell commands will now work on Linux in filesystems mounted noexec.
9046 * (bug 24804) Corrected commafying in Polish and Ukrainian.
9047 * "Difference between pages" is now displayed instead of "Difference between
9048 revisions" on diffs when appropriate.
9049 * (bug 23703) ForeignAPIRepo fails on findBySha1() when using a 1.14 install as
9050 a repository due to missing 'name' attribute from the API list=allimages.
9051 * (bug 24898) MediaWiki uses /tmp even if a vHost-specific tempdir is set, also
9052 make wfTempDir() return a sane value for Windows on worst-case.
9053 * (bug 24824) Support ImageMagick 6.5.6-2+ JPEG decoder size hint, to reduce
9054 memory usage when such an ImageMagick is used for scaling.
9055 * Disable multithreaded behavior in recent ImageMagick, to avoid a deadlock
9056 when a resource limit such as $wgMaxShellMemory is hit.
9057 * (bug 24981) Allow extensions to access SpecialUpload variables again.
9058 * (bug 20744) Wiki forgets about an uploaded file.
9059 * (bug 17913) Don't show "older edit" when no older edit available.
9060 * (bug 6204) TOC not properly rendered when using $wgMaxTocLevel.
9061 * (bug 24977) The accesskey in history page now lead directly to the diff
9062 instead of alternating focus between the two buttons.
9063 * (bug 24987) Special:ListUsers does not take external groups into account.
9064 * (bug 20633) update.php has mixed language output.
9065 * SQLite system table names are now never prefixed.
9066 * (bug 25292) SkinSubPageSubtitle hook now passes the Skin object as second
9067 parameter.
9068 * (bug 25167) Correctly load JS fixes for IE6 (fixing a regression in 1.16).
9069 * (bug 25367) wfShellExec() is more explicit when failing due to disabled
9070 passthru().
9071 * (bug 25462) Fix double-escaping for section edit link tooltips.
9072 * action=raw was removed for Special:Statistics. This information is still
9073 available via the API.
9074 * (bug 23934) Groups defined in $wgRevokePermissions but not in
9075 $wgGroupPermissions now appear on Special:ListGroupRights.
9076 * (bug 23923) Special:Prefixindex no longer shows results if nothing was
9077 requested.
9078 * (bug 22308) Search now finds text in default main page immediately after setup.
9079 * (bug 25697) Make sure empty lines render in diff view.
9080 * Use an actual minus sign in diff views, instead of a hyphen.
9081 * (bug 23732) Clarified "n links" message on Special:MostLinkedFiles.
9082 * (bug 23731) Clarified "n links" message on Special:MostLinkedTemplates.
9083 * (bug 25642) A exception is now thrown instead of a fatal error when using
9084 $wgSMTP without PEAR mail package.
9085 * (bug 19633) When possible, Upscale small SVGs when creating thumbnails.
9086 * (bug 11013) Database driver detection needs rewriting for robustness.
9087 * (bug 13409) Installer prompts could use clarification--now has help boxes.
9088 * (bug 16902) Installer spews warnings when exec() and dl() are not available.
9089 * (bug 19129) Only show MyISAM/InnoDB when supported.
9090 * (bug 17762) Only show other e-mail options when e-mail is globally enabled.
9091 * Cache multiple sizes of InstantCommons thumbnails.
9092 * (bug 25488) Disallowing anonymous users to read pages no longer throws error
9093 on discussion pages with vector as default skin.
9094 * (bug 24833) Files name in includes/diff/ are now less confusing.
9095 * (bug 25713) SpecialPage::resolveAlias() now normalise spaces to underscores.
9096 * (bug 25829) Special:Mypage and Special:Mytalk now forward oldid, diff and dir
9097 parameters.
9098 * (bug 25175) HTML file cache now honor $wgCacheDirectory if
9099 $wgFileCacheDirectory is not set.
9100 * (bug 13353) Diff3 version checks were too strict, did not detect working diff3.
9101 * (bug 25843) Links to special pages using link= attribute on images are now
9102 normalised like normal links to special pages.
9103 * (bug 21364) External links using link= attribute on images now respect
9104 $wgExternalLinkTarget.
9105 * (bug 17789) Added a note to the total views on Special:Statistics saying that
9106 is doesn't count non-existing pages and special pages.
9107 * (bug 17996) HTTP redirects are now combined when requesting a special page.
9108 * (bug 19944) Link on image thumbnails no longer link to "Media:" namespace in
9109 some cases.
9110 * (bug 25670) wfFindFile() now checks the namespace of the given title, only
9111 "File" and "Media" are allowed now.
9112 * (bug 25872) Rename the HttpRequest class to MWHttpRequest to avoid conflict
9113 with php extension that defines same class.
9114 * (bug 20591) There's now a different message on Special:MovePage when
9115 $wgFixDoubleRedirects is set to false.
9116 * Fixed PHP warnings when updating a broken MySQL database.
9117 * (bug 26023) Corrected deleteBacth.php's documentation.
9118 * (bug 25451) Improved datetime representation in 32 bit php >= 5.2.
9119 * Show "skin does not exist error" only when the skin is inputted in the wrong
9120 case.
9121 * (bug 26164) Potential html injection when the database server isn't available.
9122 * (bug 26160) Upload description set by extensions are not propagated.
9123 * (bug 9675) generateSitemap.php now takes an --urlpath parameter to allow
9124 absolute URLs in the sitemap index (as required e.g. by Google).
9125 * Partial workaround for bug 6220: at least make files on shared repositories
9126 show up as (struck-out) bluelinks instead of redlinks on Special:WantedFiles.
9127 * rebuildFileCache.php no longer creates inappropriate cache files for redirects.
9128 * (bug 25512) Subcategory list should not include category prefix for members.
9129 * (bug 10871) Javascript and CSS pages in MediaWiki namespace are no longer
9130 treated as wikitext on preview.
9131 * Page existence is now not revealed (in the colour of the tabs) to users who
9132 cannot read the page in question.
9133 * (bug 22753) Output from update.php is more clear when things changed, entries
9134 indicating nothing changed are now all prefixed by "..."
9135 * (bug 16019) $wgArticlePath = "/$1" no longer breaks API edit/watch actions.
9136 * (bug 18372) File types blacklisted by $wgFileBlacklist will no longer be shown as
9137 "Permitted file types" on the upload form.
9138 * (bug 26540) Fixed wrong call to applyPatch in MysqlUpdater.
9139 * (bug 26034) Make the "View / Read" tab in content_navigation style tabs remain
9140 selected when the action is "purge".
9141 * (bug 26733) Wrap initial table creation in transaction.
9142 * (bug 26208) Mark directionality of some interlanguage links.
9143 * (bug 26716) Provide link to instructions for external editor related preferences.
9144 * (bug 26961) Hide anon edits in watchlist preference now actually works.
9145 * (bug 1379) Installer directory conflicts with some hosts' configuration panel.
9146 * (bug 27781) Installer does not warn about 5.1.x. Added a compatibility function
9147 for array_key_exists().
9148 * Fix XML well-formedness on a few pages when $wgHtml5 is true (the default).
9149 * (bug 28069) MediaWiki fails streaming files when mod_deflate and ob_gzhandler
9150 are also set.
9151 * (bug 26223) Concurrently moving an article to different titles leaks a
9152 redirect revision with no page.
9153 * (bug 15641) Fixed permissions checks in Special:Import which allowed users
9154 without the 'import' permission to import pages from configured import sources.
9155 * (bug 26449) Keep underlines from headings outside of tables and thumbs by
9156 adding overflow:hidden to h1,h2,h3,h4,h5,h6 (also fixes editsection bunching).
9157 * (bug 26708) Remove background-color:white from tables in Monobook and Vector.
9158 * (bug 26781) {{PAGENAME}} and related parser functions escape their output better.
9159 * (bug 26716) Provide link to instructions for external editor related preferences
9160 and add a comment to the ini control file explaining what is going on.
9161 * (bug 28422) Remove color:black from tables in Monobook and Vector. And add it
9162 to table.wikitable instead.
9163 * (bug 27560) Search queries no longer fail in walloon language.
9164 * (bug 27700) The upload protection can now also be set for files that do not
9165 exist.
9166 * (bug 28034) uploading file to local wiki when file exists on shared repository
9167 (commons) gives spurious info in the warning message.
9168 * Usernames get lost when selecting different sorts on Special:listfiles.
9169 * (bug 28166) UploadBase assumes that 'edit' and 'upload' rights are not per
9170 page restrictions.
9171 * (bug 28242) Make redirects generated by urls containing a local interwiki
9172 prefix be a 301 instead of a 302.
9173 * (bug 28568) Entries in the iwlinks table are now removed on page deletion.
9174 * (bug 28306) Fix exposure of suppressed usernames in ForeignDBRepo.
9175 * (bug 28444) Fix regression: edit-on-doubleclick retains revision id again.
9176 * UtfNormal::cleanUp on an invalid utf-8 sequence no longer returns false if
9177 intl installed.
9178 * (bug 26729) Category pages should return 404 if they do not exist and have no
9179 members.
9180 * (bug 28214) When page not found, sends malformed HTTP/1.x instead of HTTP/1.1
9181 in header of response.
9182 * (bug 27634) TOC title appears in wrong language.
9183 * (bug 27761) Fix regression: pages with Esperanto titles containing convertible
9184 character sequences became unreachable.
9185 * (bug 27508) SVGMetadataExtractor takes too much resources on huge svgs.
9186 * (bug 27465) SVG thumbnail generation.
9187 * (bug 27467) preload can leave UNIQ.
9188 * (bug 27539) Allow attributes beginning with a digit in wikitext tag parameters.
9189 * (bug 27328) using relative paths in CSS imports in MediaWiki:Common.css broken
9190 in 1.17.
9191 * (bug 27333) Fix repetitive last-seen time queries on page history.
9192 * (bug 26250, bug 23817) Fix wfObjectToArray() to descend into arrays; fixes
9193 processing of JSON return values for ForeignAPIRepo when native json module
9194 not present.
9195 * (bug 25675) Fix search suggestions for Special: pages with spaces.
9196 * (bug 25571) Xml::encodeJsVar now passes floats natively instead of converting
9197 to strings.
9198 * (bug 27338) Gallery in 1.17 breaks for audio/video + ogghandler.
9199 * (bug 27302) Don't append the current timestamp for user/site modules when no
9200 user/site JS/CSS is present.
9201 * (bug 27016) dumpTextPass.php now consider the "output" parameter.
9202 * (bug 22606) don't send the "someone registred an account" message when setting
9203 email address (i.e. old one empty) in user preferences.
9204 * (bug 26458) Section edit links appear on pages that user does not have right
9205 to edit.
9206 * (bug 28611) Don't die in SqlBagOStuff::incr() if there's a race condition.
9207 * (bug 16886) Sister projects box moves down the extract of the first result
9208 in IE 7.
9209 * (bug 17398) Fixed "link" parameter in image links with "thumb" or "frame"
9210 parameter.
9211
9212 === API changes in 1.17 ===
9213
9214 * BREAKING CHANGE: action=patrol now requires POST.
9215 * BREAKING CHANGE: patrol token is no longer the same as edit token.
9216 * BREAKING CHANGE: Session keys returned by ApiUpload are now strings instead
9217 of integers.
9218 * BREAKING CHANGE: (bug 25303) Fix API parameter integer validation to actually
9219 enforce validation on the input values in addition to giving a warning.
9220 Also add flag to enforce (die) if integer out of range.
9221 * (bug 24650) Fix API to work with categorylinks changes.
9222 * action=parse now correctly returns an error for nonexistent pages.
9223 * (bug 27201) Special:WhatLinksHere output no longer contains duplicate IDs.
9224 * (bug 26560) On allusers if limit < total number of users, last user gets
9225 duplicated.
9226 * (bug 27715) imageinfo didn't respect revdelete.
9227 * (bug 27479) API error when using both prop=pageprops and
9228 prop=info&inprop=displaytitle.
9229 * (bug 27862) Useremail module didn't properly return success on success.
9230 * (bug 27590) prop=imageinfo now allows querying the media type.
9231 * (bug 27587) list=filearchive now outputs full title info.
9232 * (bug 27897) list=allusers and list=users list hidden users.
9233 * (bug 22738) Allow filtering by action type on query=logevent.
9234 * (bug 22764) uselang parameter for action=parse.
9235 * (bug 22944) API: watchlist options are inconsistent.
9236 * (bug 22868) don't list infinite block expiry date as "now" in API logevents.
9237 * (bug 22290) prop=revisions now outputs "comment" field even when comment
9238 is empty, for consistency with list=recentchanges.
9239 * (bug 19721) API action=help should have a way to just list for a specific
9240 module.
9241 * (bug 23458) Add support for pageid parameter to action=parse requests.
9242 * (bug 23460) Parse action should have a section option.
9243 * (bug 21346) Make deleted images searchable by hash.
9244 * (bug 23461) Normalise usage of parameter names in parameter descriptions.
9245 * (bug 23548) Allow access of another users watchlist through watchlistraw
9246 using token and username.
9247 * (bug 23524) Api Modules as followup to bug 14473 (Add iwlinks table to
9248 track inline interwiki link usage).
9249 * Add pltitles and tltemplates to prop=links and prop=templates respectively,
9250 similar to prop=categories's clcategories.
9251 * (bug 23834) Invalid "thumbwidth" and "thumbheight" in "imageinfo" query when
9252 thumbnailing larger than original image.
9253 * (bug 23835) Need "thumbmime" result in "imageinfo" query.
9254 * (bug 23851) Repair diff for file redirect pages.
9255 * (bug 24009) Include implicit groups in action=query&list=users&usprop=groups.
9256 * (bug 24016) API: Handle parameters specified in simple string syntax
9257 ( 'paramname' => 'defaultval' ) correctly when outputting help.
9258 * (bug 24089) Logevents causes PHP Notice if leprop=title isn't supplied.
9259 * (bug 23473) Give description of properties on all modules.
9260 * (bug 24136) unknownerror when adding new section without summary, but
9261 forceditsummary.
9262 * (bug 22339) Added srwhat=nearmatch to list=search to get a "go" result.
9263 * (bug 24303) Added new &servedby parameter to all actions which adds the
9264 hostname that served the request to the result. It is also added
9265 unconditionally on error.
9266 * (bug 24185) Titles in the Media and Special namespace are now supported for
9267 title normalization in action=query. Special pages have their name resolved
9268 to the local alias.
9269 * (bug 24296) Added converttitles parameter to convert titles to their
9270 canonical language variant.
9271 * (bug 23936) Add "displaytitle" to query/info API.
9272 * (bug 24485) Make iwbacklinks a generator, optionally display iwprefix and
9273 iwtitle.
9274 * (bug 24564) Fix fatal errors when using list=deletedrevs, prop=revisions or
9275 one of the backlinks generators with limit=max.
9276 * (bug 24656) API's parse module needs option to disable PP report.
9277 * PARAM_REQUIRED parameter flag added. If this flag is set, and the end user
9278 does not set the parameter, the API will automatically throw an error.
9279 * (bug 24665) When starttimestamp is not specified, fake it by setting it to
9280 NOW, not to the timestamp of the last edit.
9281 * (bug 24677) axto= parameters added to allcategories, allimages, alllinks,
9282 allmessages, allpages, and allusers.
9283 * (bug 24236) Add add, remove, add-self, remove-self tags to
9284 meta=siteinfo&siprop=usergroups.
9285 * (bug 24484) Add prop=pageprops module.
9286 * (bug 24330) Add &redirect parameter to ?action=edit.
9287 * (bug 24722) For list=allusers&auprop=blockinfo, only show blockedby and
9288 blockreason if the user is actually blocked.
9289 * Add format=dump and format=dumpfm, outputs results in PHP's var_dump() format.
9290 * For required string parameters, if '' is provided, this is now classed as
9291 missing.
9292 * (bug 24724) list=allusers is out by 1 (shows total users - 1).
9293 * (bug 24166) API error when using rvprop=tags.
9294 * Introduced "asynchronous download" mode for upload-by-url. Requires
9295 $wgAllowAsyncCopyUploads to be true.
9296 * sinumberingroup correctly gives size of 'user' group, and omits size of
9297 implicit groups rather than showing 0.
9298 * (bug 25248) API: paraminfo errors with certain modules.
9299 * (bug 24792) API help for action=purge sometimes wrongly stated whether a
9300 POST request was needed due to cache pollution.
9301 * Added iiprop=parsedcomment to prop=imageinfo, similar to prop=revisions.
9302 * Added rvparse to parse revisions. For performance reasons if this option is
9303 used, rvlimit is enforced to 1.
9304 * (bug 25748) If a action=parse request provides an oldid that is actually the
9305 current revision id, try the parser cache, and save it to it if necessary.
9306 * (bug 25463) Export header should not be shown if no pages were requested, to
9307 reduce confusion.
9308 * (bug 25648) API discovery information has been added as RSD link in page
9309 <head> and by providing an API module action=rsd. Added hook
9310 ApiRsdServiceApis for extensions to add their own service to the services
9311 list.
9312 * The HTML of diff output markers has changed. Hyphens are now minus signs,
9313 empty markers are now filled with non-breaking-space characters.
9314 * (bug 25741) Add more data to list=search's srprop.
9315 * (bug 25760) counter property still reported by the API when
9316 $wgDisableCounters enabled.
9317 * (bug 25987) prop=info&inprop=watched now also works for missing pages.
9318 * (bug 26006) prop=langlinks now allows obtaining full URL.
9319 * (bug 26075) ApiDelete.php now calls correctly ArticleDelete hook.
9320 * (bug 26089) add block expiration to blockinfo.
9321 * (bug 26125) prop=imageinfo&iiprop=size now returns the page count if the
9322 file is a multi-page file.
9323 * (bug 10268) Added linktodiffs parameter on action=feedwatchlist.
9324 * (bug 26219) Show API limits for multi values in description.
9325 * (bug 28070) Fix watchlist RSS for databases that store timestamps in a
9326 real timestamp field.
9327 * (bug 27722) list=filearchive now supports revdel.
9328
9329 === Language support changes in 1.17 ===
9330
9331 MediaWiki supports over 330 languages. Many localizations are updated regularly.
9332
9333 The following languages were added:
9334
9335 * Moroccan Spoken Arabic (ary)
9336 * Banjar (bjn)
9337 * Kabardian (kbd)
9338 * Kabardian (Cyrillic) (kbd-cyrl)
9339 * Latgalian (ltg)
9340 * Minangkabau (min)
9341 * Dutch (informal) (nl-informal)
9342 * Rusyn (rue)
9343
9344 Other significant changes to MediaWiki's language support:
9345
9346 * Fiji Hindi (Devangari script) was removed.
9347 * Removed deprecated language code "dk" (Danish), use "da" instead.
9348 * Link trail added for sl and sh.
9349 * (bug 27633) Add characters to linkTrail for Portuguese (pt and pt-br).
9350 * (bug 23156) Commafy and search normalization updated for Belarusian
9351 (Taraškievica).
9352 * (bug 23283) Native name for Old English -> Ænglisc.
9353 * (bug 23364) Native name for Azerbaijani -> Azərbaycanca.
9354 * (bug 24593) Native name for Sorani now uses only Arabic script.
9355 * (bug 24628) Generic translations for NS_USER/NS_USER_TALK for Esperanto.
9356 * (bug 24917) Polish as fallback for Kashubia.
9357 * (bug 24794) Tatar link trail updated.
9358 * Esperanto date format corrected.
9359 * (bug 28159) Change interwiki name of language kbd to Къэбэрдеибзэ /
9360 Qabardjajəbza.
9361 * (bug 28184) Namespaces for the Latgalian Wikipedia.
9362 * (bug 25010) Bashkir-language interwikis: linktext change from Башҡорт
9363 to Башҡортса.
9364 * (bug 26395) Change name of Cornish language to Kernowek.
9365
9366 === Other changes in 1.17 ===
9367
9368 * DatabaseFunctions.php that was needed for compatibility with pre-1.3
9369 extensions has been removed.
9370 * XmlFunctions.php has been removed. Use the Xml or Html classes as appropriate.
9371 * The FailFunction "error handling" method has now been removed
9372 * Sysops now have the "suppressredirect" right by default
9373 * Removed $wgRemoteUploads. It was not well supported and superseded by
9374 $wgUploadNavigationUrl.
9375 * (bug 26253) $wgPostCommitUpdateList has been removed
9376 * The PHPUnit test suite has been removed from this release due to serious issues
9377 which should be resolved by the 1.18 release.
9378 * Oracle DB now uses the __destruct function to commit/close connection as it
9379 doesn't commit on close if transation is triggered in OCI.
9380
9381 == MediaWiki 1.16 ==
9382
9383 == MediaWiki 1.16.5 ==
9384 === Changes since 1.16.4 ===
9385
9386 * (bug 28534) Fixed XSS vulnerability for IE 6 clients. This is the third
9387 attempt at fixing bug 28235.
9388 * (bug 28639) Fixed potential privilege escalation when $wgBlockDisablesLogin
9389 is enabled.
9390
9391 == MediaWiki 1.16.4 ==
9392 === Changes since 1.16.3 ===
9393
9394 * (bug 28507) The change we made in 1.16.3 to fix bug 28235 (XSS for IE 6
9395 clients) was not actually sufficient to fix that bug. This release contains
9396 a second attempt, hopefully we have fixed it this time.
9397
9398 == MediaWiki 1.16.3 ==
9399 === Changes since 1.16.2 ===
9400
9401 * (bug 28449) Fixed permissions checks in Special:Import which allowed users
9402 without the 'import' permission to import pages from the configured import
9403 sources.
9404 * (bug 28235) Fixed XSS affecting IE 6 and earlier clients only, due to those
9405 browsers looking for a file extension in the query string of the URL, and
9406 ignoring the Content-Type header if one is found.
9407 * (bug 28450) Fixed a CSS validation issue involving escaped comments, which
9408 led to XSS for Internet Explorer clients and privacy loss for other clients.
9409
9410 == MediaWiki 1.16.2 ==
9411 === Changes since 1.16.1 ===
9412
9413 * (bug 26642) Fixed incorrect translated namespace due to a regression in the
9414 language converter.
9415 * The interface translations were updated.
9416 * (bug 27093, CVE-2011-0047): Fixed CSS injection vulnerability.
9417 * (bug 27094) Fixed server-side arbitrary script inclusion vulnerability.
9418 Affects Windows servers only. A malicious file with extension ".php" must
9419 exist on the server for the exploit to be effective.
9420
9421 == MediaWiki 1.16.1 ==
9422 === Changes since 1.16.0 ===
9423
9424 * (bug 24981) Allow extensions to access SpecialUpload variables again
9425 * (bug 24724) list=allusers was out by 1 (shows total users - 1)
9426 * (bug 24166) Fixed API error when using rvprop=tags
9427 * For wikis using French as a content language, Special:Téléchargement works
9428 again as an alias for Special:Upload.
9429 * (bug 25167) Correctly load JS fixes for IE6 (fixing a regression in 1.16.0)
9430 * (bug 25248) Fixed paraminfo errors in certain API modules.
9431 * The installer now has improved handling for situations where safe_mode is
9432 active or exec() and similar functions are disabled.
9433 * (bug 19593) Specifying --server in now works for all maintenance scripts.
9434 * Fixed $wgLicenseTerms register globals.
9435 * (bug 26561) Fixed clickjacking vulnerabilities by introducing support for
9436 X-Frame-Options. The header value can be configured using $wgBreakFrames and
9437 $wgEditPageFrameOptions.
9438
9439 == MediaWiki 1.16.0 ==
9440 === Changes since 1.16 beta 3 ===
9441
9442 * (bug 23769) Disabled HTML 5 client-side form validation. Was introduced in
9443 1.16 beta 1, but is currently poorly supported by browsers.
9444 * (bug 23175) Re-added window.ta variable for backwards compatibility.
9445 * (bug 23264) Fixed breakage of various command line scripts due to extra line
9446 endings being inserted by Maintenance::output().
9447 * Fixed HTTP client functionality with safe_mode=On.
9448 * Fixed parser tests broken in 1.16 beta 3.
9449 * For Oracle DB backend: fixed parser tests and table prefix feature.
9450 * (bug 23767) Fixed PHP warning when REQUEST_URI is blank (IIS issue).
9451 * Fixed plural function for Northern Sami (se)
9452 * (bug 23597) Fixed conflicts between ID attributes in the Vector skin and
9453 parser-generated heading IDs. Renamed head, panel, head-base and page-base.
9454 * Disabled $wgHitcounterUpdateFreq>1 feature on SQLite, does not work yet.
9455 * (bug 23465) Don't ignore the predefined destination filename on
9456 Special:Upload after following a red link to a file.
9457 * In SQLite full-text search feature: fixed "move page" feature, was non-
9458 functional.
9459 * (bug 24565) Fixed Cache-Control headers sent from API modules, to protect
9460 user privacy in the case where an attacker can access the wiki through the
9461 same HTTP proxy as a logged-in user.
9462 * Fixed an XSS vulnerability in profileinfo.php for installations with
9463 $wgEnableProfileInfo = true (false by default)
9464 * Fixed a case where an X-Vary-Options header was sent despite $wgUseXVO being
9465 false. Fixed a minor header parsing issue when $wgUseXVO = true.
9466 * Fixed a register_globals arbitrary inclusion vulnerability in
9467 MediaWikiParserTest.php, introduced in 1.16 beta 1.
9468
9469 === Changes since 1.16 beta 2 ===
9470
9471 * Fixed bugs in the [[Special:Userlogin]] and [[Special:Emailuser]] handling of
9472 invalid usernames.
9473 * Fixed sorting in [[Special:Allmessages]]
9474 * (bug 23113) Fixed title in the show/hide links on diff pages
9475 * (bug 23117) Fixed API rollback, was returning "badtoken" for valid requests
9476 * (bug 23127) Re-added missing $1 parameter to the uploadtext message
9477 * Fixed a bug in the Vector skin where personal tools display behind the logo
9478 * (bug 23139) Fixed a bug in edit conflict resolution, where both textboxes
9479 showed the same text.
9480 * (bug 23115, bug 23124) Fixed various problems with <title> and <h1> elements
9481 in page views and previews when the language converter is enabled.
9482 * (bug 23148) Fixed a local path disclosure vulnerability in ImageMagick image
9483 scaling, which was introduced in 1.16 beta 1.
9484 * Improved error checking on installer.
9485 * (bug 22970) Fixed a JavaScript error in the upload destination conflict
9486 check.
9487 * (bug 23167) Check the watch checkbox by default if the watchcreations
9488 preference is set.
9489 * (bug 23171) Improve IE6 version check to avoid false positives.
9490 * (bug 23176) Fixed upload warning override feature "upload new version",
9491 broken in 1.16 beta 1.
9492 * Fixed regression in unwatch links sent out in notification emails. When the
9493 mailing job was deferred via the job queue, the title was incorrect.
9494 * (bug 23534) Fixed SQL query error in API list=allusers.
9495 * Fixed a bug in uploads for non-JavaScript clients. An empty string was used
9496 as the default destination filename, instead of the source filename as
9497 expected.
9498 * (bug 23371) Fixed CSRF vulnerability in "e-mail me my password", "create
9499 account" and "create by e-mail" features of [[Special:Userlogin]]
9500 * (bug 23687) Fixed XSS vulnerability affecting IE clients only, due to a CSS
9501 validation issue.
9502 * Fixed a DoS vulnerability in ImageMagick image scaling. ImageMagick
9503 expanded wildcard characters "?" and "*" in image filenames, potentially
9504 causing large numbers of images to be scaled in response to a single request.
9505 The fix for this involves breaking the scaling of such image filenames until
9506 ImageMagick 6.6.1-5 or later is deployed, see bug 23361 for more details.
9507 * (bug 23608) Fixed invalid HTML in diff pages.
9508
9509 === Changes since 1.16 beta 1 ===
9510
9511 * Fixed errors in maintenance/patchSql.php
9512 * (bug 19627) Fix regression from r57867 where HTMLForm would output
9513 <element classes="foo bar"> rather than <element class="foo bar">
9514 * Fixed broken "-r" option to maintenance/lag.php
9515 * (bug 23076) Fixed login CSRF vulnerability. Logins now require a token to
9516 be submitted along with the user name and password.
9517
9518 === Configuration changes in 1.16 ===
9519
9520 * (bug 18222) $wgMinimalPasswordLength default is now 1
9521 * $wgSessionHandler can be used to configure session.save_handler
9522 * $wgLocalFileRepo/$wgForeignFileRepos now have a 'fileMode' parameter to
9523 be used when uploading/moving files
9524 * (bug 18761) $wgHiddenPrefs is a new array for specifying preferences not
9525 to be shown to users
9526 * $wgAllowRealName and $wgAllowUserSkin were deprecated in favor of
9527 $wgHiddenPrefs[] = 'realname', but the former are still retained
9528 for backwards-compatibility
9529 * (bug 9257) $wgRCMaxAge now defaults to three months
9530 * $wgDevelopmentWarnings can be set to true to show warnings about deprecated
9531 functions and other potential errors when developing.
9532 * Subpages are now enabled in the MediaWiki namespace by default. This is
9533 mainly a cosmetic change, and does not in any way affect the MessageCache,
9534 which was already effectively treating the namespace as if it had subpages.
9535 * Oracle: maintenance/ora/user.sql script for creating DB user on oracle with
9536 appropriate privileges. Creating this user with web-install page requires
9537 oci8.privileged_connect set to On in php.ini.
9538 * Removed UserrightsChangeableGroups hook introduced in 1.14
9539 * Added $wgCacheDirectory, to replace $wgFileCacheDirectory,
9540 $wgLocalMessageCache, and any other local caches which need a place to put
9541 files.
9542 * $wgFileCacheDirectory is no longer set to anything by default, and so either
9543 needs to be set explicitly, or $wgCacheDirectory needs to be set instead.
9544 * $wgLocalMessageCache has been removed. Instead, set $wgUseLocalMessageCache
9545 to true
9546 * Removed $wgEnableSerializedMessages and $wgCheckSerialized. Similar
9547 functionality is now available via $wgLocalisationCacheConf.
9548 * $wgMessageCache->addMessages() is deprecated. Messages added via this
9549 interface will not appear in Special:AllMessages.
9550 * $wgRegisterInternalExternals can be used to record external links pointing
9551 to same server
9552 * (bug 19907) $wgCrossSiteAJAXdomains and $wgCrossSiteAJAXdomainExceptions added
9553 to control which external domains may access the API via cross-site AJAX.
9554 * $wgMaintenanceScripts for extensions to add their scripts to the default list
9555 * $wgMemoryLimit has been added, default value '50M'
9556 * $wgExtraRandompageSQL is deprecated, the SpecialRandomGetRandomTitle hook
9557 should be used instead
9558 * (bug 20489) $wgIllegalFileChars added to override the default list of illegal
9559 characters in file names.
9560 * (bug 19646) $wgImgAuthDetails added to display reason access to uploaded file
9561 was denied to users(img_auth only)
9562 * (bug 19646) $wgImgAuthPublicTest added to test to see if img_auth set up
9563 correctly (img_auth only)
9564 * $wgUploadMaintenance added to disable file deletions and restorations during
9565 maintenance
9566 * $wgCapitalLinkOverrides added to configure per-namespace capitalization
9567 * (bug 21172) $wgSorbsUrl can now be an array with multiple DNSBL and renamed
9568 to $wgDnsBlacklistUrls (backward compatibility kept)
9569 * $wgEnableHtmlDiff has been removed
9570 * (bug 3340) $wgBlockCIDRLimit added (default: 16) to configure the low end of
9571 CIDR ranges for blocking
9572 * $wgUseInstantCommons added for quick and easy enabling of Commons as a remote
9573 file repository
9574 * $wgDBAhandler added to choose a DBA handler when using CACHE_DBA
9575 * $wgPreviewOnOpenNamespaces for extensions that create namespaces that behave
9576 similarly to the category namespace.
9577 * $wgEnableSorbs renamed to $wgDnsBlacklistUrls ($wgEnableSorbs kept for
9578 backward compatibility)
9579 * $wgUploadNavigationUrl now also affects inline images that do not
9580 exist. In that case the URL will get (?|&)wpDestFile=<filename> appended to
9581 it as appropriate.
9582 * If $wgLocaltimezone is null, use the server's timezone as the default for
9583 signatures. This was always the behavior documented in DefaultSettings.php
9584 but has not been the actual behavior for some time: instead, UTC was used
9585 by default.
9586 * Added $wgExtensionAssetsPath, to decouple assets serving from $wgScriptPath.
9587 If not specified it will default to $wgScriptPath/extensions
9588 * Added $wgCountTotalSearchHits to make search UI display total number of hits
9589 with some search engines.
9590 * Added $wgAdvertisedFeedTypes to decide what feed types (RSS, Atom, both, or
9591 neither) MediaWiki advertises. Default is array( 'atom' ), so RSS is no
9592 longer advertised by default (but it still works).
9593 * Added $wgMemCachedTimeout, controls how long to wait for data from the
9594 memcached servers.
9595 * New configuration variables $wgDebugTimestamps and $wgDebugPrintHttpHeaders
9596 for controlling debug output.
9597 * New $wgBlockDisablesLogin when set to true disallows blocked users from
9598 logging in.
9599 * (bug 8790) Metadata edition ($wgUseMetadataEdit) has been moved to a separate
9600 extension "MetadataEdit".
9601
9602 === New features in 1.16 ===
9603
9604 * Add CSS defintion of the 'wikitable' class to shared.css
9605 * (bug 17163) Added MediaWiki:Talkpageheader which will be displayed when
9606 viewing talk pages
9607 * Superfluous border="0" removed from images
9608 * Added new hook 'MessageCacheReplace' into MessageCache.php. For instance
9609 to allow extensions to update caches in similar way as MediaWiki invalidates
9610 a cached MonoBook sidebar
9611 * Special:AllPages: Move hardcoded styles from code to CSS
9612 * (bug 18529) New hook: SoftwareInfo for adding information about the software
9613 to Special:Version
9614 * Added $wgExtPGAlteredFields to allow extensions to easily alter the data
9615 type of columns when using the Postgres backend.
9616 * (bug 16950) Show move log when viewing/creating a deleted page
9617 * (bug 18242) Show the Subversion revision number per extensions in
9618 Special:Version
9619 * (bug 18420) Missing file revisions are handled gracefully now
9620 * (bug 9219) Auth plugins can control editing RealName/Email/Nick preferences
9621 * (bug 18466) Add note or warning when overruling a move (semi-)protection
9622 * (bug 18342) insertTags works in edit summary box
9623 * (bug 18411) The upload form also checks post_max_size
9624 * Watchlist now has a specialized <div> tag that contains a unique class for
9625 each page
9626 * Added Minguo calendar support for the Taiwan Chinese language
9627 * Database: unionQueries function to be used for UNION sql construction, so
9628 it can be overloaded on DB abstraction level for DB specific functionality
9629 * (bug 18849) Implement Japanese and North Korean calendars
9630 * (bug 5755) Introduce {{CURRENTMONTH1}} and {{LOCALMONTH1}} to display the
9631 month number without the leading zero
9632 * (bug 13456) categoriespagetext supports PLURAL
9633 * (bug 18860) Blocks of IPs affecting registered users can now block email
9634 * (bug 17093) Date and time are separate parameters in Special:BlockList
9635 * (bug 11484) Added ISO speed rating to default collapsed EXIF metadata view
9636 * (bug 14866) Messages 'recentchangeslinked-toolbox' and
9637 'recentchangeslinked-toolbox' were added to allow more fine grained
9638 customisation of the user interface
9639 * DISPLAYTITLE now accepts a limited amount of wiki markup (the single-quote
9640 items)
9641 * Special:Search now could search terms in all variant-forms. ONLY apply on
9642 wikis enabled LanguageConverter.
9643 * Add autopromote condition APCOND_BLOCKED to autopromote blocked users to
9644 various user groups.
9645 * Add $wgRevokePermissions as a means of restricting a group's rights. The
9646 syntax is identical to $wgGroupPermissions, but users in these groups will
9647 have these rights stripped from them.
9648 * Added a PHP port of CDB (constant database), for improved local caching when
9649 the DBA extension is not available.
9650 * Introduced a new system for localisation caching. The system is based around
9651 fast fetches of individual messages, minimising memory overhead and startup
9652 time in the typical case. The database backend will be used by default, but
9653 set $wgCacheDirectory to get a faster CDB-based implementation.
9654 * Expanded the number of variables which can be set in the extension messages
9655 files.
9656 * Added a feature to allow per-article process pool size control for the parsing
9657 task, to limit resource usage when the cache for a heavily-viewed article is
9658 invalidated. Requires an external daemon.
9659 * (bug 19576) Moved the id attributes from the anchors accompanying section
9660 headers to the <span class="mw-headline"> elements within the section headers,
9661 removing the redundant anchor elements.
9662 * Parser::setFunctionTagHook now can be used to add a new tag which is parsed at
9663 preprocesor level.
9664 * Added $wgShowArchiveThumbnails, allowing sysadmins to disable thumbnail
9665 display for old versions of images.
9666 * In watchlists and Special:RecentChanges, the difference in page size now
9667 appears in dark green if bytes were added and dark red if bytes were removed.
9668 * Added FSRepo configuration properties thumbUrl and thumbDir, to allow the
9669 thumbnails to be stored in a separate location to the source images.
9670 * If config/ directory is not executable, the command to make it executable
9671 now asks the user to cd to the correct directory
9672 * Add experimental new external authentication framework, ExternalAuth
9673 * (bug 18768) Remove AdminSettings requirements. Maintenance environment
9674 will still load it if it exists, but it's not required for anything
9675 * (bug 19900) The "listgrouprights-key" message is now wrapped in a div with
9676 class "mw-listgrouprights-key"
9677 * (bug 471) Allow RSS feeds for watchlist, using an opt-in security token
9678 * (bug 10812) Interwiki links can have names and descriptions, fetched from
9679 message 'interwiki-desc-PREFIX', not really used anywhere yet though
9680 * (bug 9691) Add type (signup or login) parameter to
9681 AuthPlugin::ModifyUITemplate()
9682 * (bug 14454) "Member of group(s)" in Special:Preferences causes language
9683 difficulties
9684 * (bug 16697) Unicode combining characters are difficult to edit in some
9685 browsers
9686 * Parser test supports uploading results to remote CodeReview instance
9687 * (bug 20013) Added CSS class "mw-version-ext-version" is wrapped on the
9688 extension version in Special:Version
9689 * (bug 20014) Added CSS class "mw-listgrouprights-right-name" is wrapped on the
9690 right name in Special:ListGroupRights
9691 * (bug 12920) New CoreParserFunction {{nse:...}} as an url-friendly equivalent
9692 to {{ns:...}}
9693 * (bug 16322) Allow maintenance scripts to accept DB user/pass over input or
9694 params
9695 * (bug 18566) Maintenance script to un/protect pages
9696 * (bug 671) The HTML <abbr> tag is now permitted.
9697 * RecentChanges now has a legend to explain what the Nmb! flags mean, and the
9698 flags have tooltips.
9699 * (bug 15209) New hook BeforeInitialize called after everything has been setup
9700 but before Mediawiki::performRequestForTitle()
9701 * wgMainPageTitle variable now available to JavaScript code to identify the main
9702 page link, so it doesn't have to be extracted from the link URLs.
9703 * (bug 16836) Display preview of signature in user preferences and describe its
9704 use
9705 * The default output format is now HTML 5 instead of XHTML 1.0 Transitional.
9706 This can be disabled by setting $wgHtml5 = false;. Specific features enabled
9707 if HTML 5 is used:
9708 ** Some extra inputs will be autofocused, in supporting browsers.
9709 ** The summary attribute has been removed from tables of contents. summary is
9710 obsolete in HTML 5 and wasn't useful here anyway.
9711 ** Unnecessary type="" attribute removed for CSS and JS.
9712 ** If $wgWellFormedXml is set to false, some bytes will be shaved off of HTML
9713 output by omitting some things like quotation marks where HTML 5 allows.
9714 ** (bug 16921) maxlength enabled for page move comments
9715 * The description message in $wgExtensionCredits can be an array with parameters
9716 * New hook SpecialRandomGetRandomTitle allows extensions to modify the selection
9717 criteria used by Special:Random and subclasses, or substitute a custom result,
9718 deprecating the $wgExtraRandompageSQL config variable
9719 * (bug 20318) Distinct CSS classes for ISBN/RFC/PMID special links added
9720 * (bug 20404) Custom fields in the user creation form template can now have
9721 detail labels in prefsectiontip divs.
9722 * MakeSysop and MakeBot are now aliases for Special:UserRights
9723 * IndexPager->mLimitsShown can now be an associative array of limit => text-to-
9724 display-in-limit-form.
9725 * (bug 18880) LogEventsList::showLogExtract() can now take a string-by-reference
9726 and add its HTML to it, rather than having to go straight to $wgOut.
9727 * Added $wgShowDBErrorBacktrace, to allow users to easily gather backtraces for
9728 database connection and query errors.
9729 * Show change block / unblock link on Special:Contributions if user is blocked
9730 * Display note on Special:Contributions if the user is blocked, and provide an
9731 excerpt from the block log.
9732 * (bug 19646) New hook: ImgAuthBeforeStream for tests and functionality before
9733 file is streamed to user, but only when using img_auth
9734 * Note on non-existing user and user talk pages if user does not exist
9735 * New hook ShowMissingArticle so extensions can modify the output for
9736 non-existent pages.
9737 * Admins could disable some variants using $wgDisabledVariants now. ONLY apply
9738 on wikis enabled LanguageConverter.
9739 * (bug 16310) Credits page now lists IP addresses rather than saying the number
9740 of anonymous users that edited the page
9741 * New permission 'sendemail' added. Default right for all registered users. Can
9742 for example be used to prevent new accounts from sending spam.
9743 * (bug 16979) Tracking categories for __INDEX__ and __NOINDEX__
9744 * Two new hooks, ConfirmEmailComplete and InvalidateEmailComplete, which are
9745 called after a user's email has been successfully confirmed or invalidated.
9746 * (bug 19741) Moved the XCF files out of the main MediaWiki distribution, for
9747 a smaller subversion checkout.
9748 * (bug 13750) First letter capitalization can now be a per-namespace setting
9749 * (bug 21073) "User does not exist" message no longer displayed on sub-sub-pages
9750 of existing users
9751 * (bug 21095) Tracking categories produced by the parser (expensive parser
9752 function limit exceeded, __NOINDEX__ tracking, etc) can now be disabled by
9753 setting the system message ([[MediaWiki:expensive-parserfunction-category]]
9754 etc) to "-".
9755 * Added maintenance script sqlite.php for SQLite-specific maintenance tasks.
9756 * Rewrote Special:Upload to allow easier extension.
9757 * Upload errors that can be solved by changing the filename now do not require
9758 reuploading.
9759 * Added $wgRateLimitsExcludedIPs, to allow specific IPs to be whitelisted from
9760 rate limits.
9761 * (bug 21222) When $wgUseTeX is not enabled, <math> is no longer registered with
9762 the parser so extensions are free to implement their own <math> tag
9763 * (bug 21047) Wrap 'cannotdelete' into a div with the generic 'error' class and
9764 an own 'mw-error-cannotdelete' class
9765 * New hook AbortNewAccountAuto, called before account creation from AuthPlugin-
9766 or ExtUser-driven requests.
9767 * (bug 3480) The warning saying that the page has a history when deleting it now
9768 contains the number of revisions in the history
9769 * $wgStylePath and $wgLogo are now set in the default LocalSettings.php file.
9770 * (bug 20186) Allow filtering history for revision deletion.
9771 * New hook OtherBlockLogLink, called in Special:IPBlockList and Special:Block
9772 to show links to block logs of other blocking extensions, i.e. GlobalBlocking
9773 * Added search capabilities to SQLite backend
9774 * rebuildtextindex.php maintenance script now supports databases other than
9775 MySQL
9776 * upgrade1_5.php now requires to be run --update option to prevent confusion
9777 * (bug 17662) Customizable default preload/editintro for new sections in the
9778 respective addsection-preload and addsection-editintro messages
9779 * Added maintenance script checkSyntax.php that checks for PHP syntax errors
9780 and common coding mistakes
9781 * Updated Unicode normalization tables
9782 * (bug 21604) Spellcheck attribute for editsummary
9783 * New wgCategories JavaScript global variable for userscripts.
9784 * (bug 20717) Added checkboxes to hide users with bot and/or sysop group
9785 membership in SpecialActiveusers
9786 * Allow \pagecolor and \definecolor in texvc
9787 * $wgTexvcBackgroundColor contains background color for texvc call
9788 * (bug 21574) Redirects can now have "303 See Other" HTTP status
9789 * EditPage refactored to allow extensions to derive new edit modes much easier.
9790 * (bug 21826) Subsections of Special:Version now also have anchors
9791 * (bug 19791) Add URL of file source as comment to thumbs (for ImageMagick)
9792 * (bug 21946) Sorted wikitables do not properly handle minus signs
9793 * (bug 18885) Red links for media files do not support shared repositories
9794 * Added $wgFixArabicUnicode, to convert deprecated presentation forms in
9795 Arabic text to their modern equivalents, and $wgFixMalayalamUnicode, to
9796 convert ZWJ-based chillu sequences in Malayalam text to their Unicode 5.1
9797 equivalents.
9798 * (bug 22051) Returing false in SpecialContributionsBeforeMainOutput hook now
9799 stops normal output
9800 * Send new password e-mail in users preference language
9801 * LanguageConverter now support nested using of manual convert syntax like
9802 "-{-{}-}-"
9803 * Upload license preview now uses the API instead of action=ajax
9804 * (bug 7346) Add <guid> to RSS to avoid duplicates
9805 * (bug 19996) Added new hooks for Special:Search, which allow to further
9806 restrict/expand it.
9807 * (bug 21936) When a revision has been patrolled, there's now a link back to the
9808 article
9809 * (bug 22315) SpecialRecentChangesQuery hook now pass $query_options and checks
9810 the return value
9811 * Separate unit test suites under t/ and tests/ were merged and moved to
9812 maintenance/tests/.
9813 * importImages.php maintenance script can now use the original uploader and
9814 comment from another wiki.
9815 * Support for Turck MMCache was removed
9816 * (bug 14592) Warn users when they try to move their user page that their
9817 account will not be renamed
9818 * Show block log on non-existing user (talk) pages of currently blocked users
9819
9820 === Bug fixes in 1.16 ===
9821
9822 * (bug 18031) Make namespace selector on Special:Export remember the previous
9823 selection
9824 * The svn-version version numbers on Special:Version have been removed
9825 * (bug 17374) Special:Export no longer exports two copies of the same page
9826 * (bug 18190) Proper parsing in MediaWiki:Sharedupload message
9827 * (bug 17617) HTML cleanup for ImagePage
9828 * (bug 17964) namespaceDupes.php no longer fails on an empty interwiki table
9829 * Improved error handling for image moving
9830 * (bug 17974) On Special:SpecialPages, restricted special pages are now marked
9831 with <strong> tags, helps with text-based browsers
9832 * (bug 18259) Special:DeletedContributions now also uses
9833 MediaWiki:Sp-contributions-logs for the link to Special:Log
9834 * Don't add empty title="" attributes to links to anchors on the current page
9835 * (bug 18291) rebuildrecentchanges.php failed to add deletion log entries
9836 * (bug 18304) rebuildrecentchanges.php got size changes wrong
9837 * (bug 18170) Fixed a PHP warning in Parser::preSaveTransform() in PHP 5.3
9838 * (bug 18289) Database connection error page now returns correct HTML
9839 * "successbox", "errorbox" and related CSS classes are now available in all
9840 skins
9841 * (bug 18316) Removed superfluous name="fulltext" from Special:Search
9842 * (bug 18331) MediaWiki:Undelete-revision can now have wikitext
9843 * The "noautoblock" flag is no longer displayed in the block log when blocking
9844 an IP address
9845 * (bug 18009) $wgHooks and $wgExtensionFunctions now support closures
9846 * (bug 17948) Maintenance scripts now exit(0) or exit(1) as appropriate
9847 * (bug 18377) Time in Enhanced ChangesList lacking localisation
9848 * (bug 12998) Allow <sup>, <sub>, etc. in DISPLAYTITLE
9849 * (bug 1553) Lowercase navigation headings in German
9850 * (bug 7830) Pending transactions failed to commit on loginToUse() error
9851 * (bug 11613) session.save_handler being over-ridden
9852 * (bug 11381) session.save_handler being set twice (causes error)
9853 * (bug 17835) ForeignAPIRepo throwing error on first page load for file
9854 * (bug 18115) ForeignAPIRepo cache isn't working
9855 * Fixed a bug caused by LanguageConverter.php, which brings an abnormal '}-'
9856 after some parsed math syntax.
9857 * (bug 18441) rebuildrecentchanges.inc no longer ignores $wgLogRestrictions
9858 * (bug 18317) Bolded selections in 1 | 3 | etc days on RecentChanges now use
9859 <strong> instead of hardcoded styles
9860 * (bug 18449) Fixed items number per column on category pages when the total is
9861 divisible by 3
9862 * (bug 18121) maintenance/deleteArchivedRevisions.php no longer deletes
9863 revisions when --delete is not passed
9864 * (bug 13172) GPS coordinates in image Exif data are now actually displayed
9865 * Overhaul of preferences system, includes the following bug fixes:
9866 ** (bug 5363) Changes to default preferences now impact registered users.
9867 ** (bug 14806) Hook to enable putting preferences in existing tabs.
9868 ** (bug 17191) Registration date now listed on preferences page.
9869 ** The user_properties table (now used for storing preferences) has been added
9870 to $wgSharedTables.
9871 ** Note that this change will break some extensions which have not been adapted
9872 for it.
9873 * (bug 17020) Adding fallback encodings for Traditional and Simplified Chinese
9874 languages while the text is typed as URLs.
9875 * (bug 17614) Prev / Next links are not shown if all results are shown
9876 * (bug 18207) Strange spacing before [[irc:...]] links
9877 * Removed float from the user login form in RTL interface - caused display
9878 problems in FF2
9879 * (bug 15008) Redirect images are now subject to Bad image list rules
9880 * (bug 6802) profileinfo.php now also work on other database servers than MySQL
9881 * (bug 16925) Diffs no longer fail when $wgExternalDiffEngine is set to
9882 'wikidiff' or 'wikidiff2' but extension is not installed
9883 * (bug 18326) Chmod errors in file repos have been hidden
9884 * (bug 18718) Comma after a } create a error in IE
9885 * (bug 18716) Removed redundant class in Modern skin CSS for category links and
9886 tweaked spacing.
9887 * (bug 18656) Use proper directory separators in wfMkdirParents()
9888 * (bug 18549) Make Special:Blockip respect $wgEnableUserEmail and
9889 $wgSysopEmailBans
9890 * (bug 16912) Tooltips on images with link= disappear
9891 * (bug 18389) Localise numbers in EXIF data
9892 * (bug 18522) Wrap MediaWiki:Protect-cascadeon in a div for identification
9893 * (bug 18438) Tweak HTML for preview bar for consistency and accessibility
9894 * (bug 18432) Updated documentation for dumpBackup.php
9895 * Fix array logic in Sanitizer::removeHTMLtags so that it doesn't strip good
9896 tags that were redundantly defined.
9897 * (bug 14118) SpecialPage::getTitleFor does not return a localised name
9898 * (bug 18698) Renaming non entry point maintenance scripts from .inc.php to
9899 .inc
9900 * Deprecated methods Title::getInterwikiLink, Title::userCanCreate(),
9901 Title::userCanEdit() and Title::userCanMove() have been removed
9902 * Only show upload links on file description if $wgEnableUploads = true
9903 and user can upload
9904 * Don't say "You need to log in to upload/move", because it's possible that
9905 uploading/moving is disabled for registered users as well (e.g. only sysops)
9906 * (bug 18943) Handle invalid titles gracefully at Special:Mostlinked
9907 * (bug 8873) Enable variant conversion in text on 'alt' and 'title' attributes
9908 * (bug 10837) Introducing the StubUserVariant class to determine the variant
9909 variable instead of using this to overrule the user language preference.
9910 * (bug 19014) If user had deletedhistory right, but not undeleted right, then
9911 show "view" instead of "view/restore" on logs.
9912 * (bug 19017) TOC level calculation error in an odd case
9913 * (bug 18999) CSS update for RTL interwiki links
9914 * (bug 18925) history.js removes class names of list elements on initialization
9915 * Multiple whitespace in TOC anchors is now stripped, for consistency with the
9916 link from the edit comment
9917 * (bug 19112) Preferences now respects $wgUseExternalEditor
9918 * (bug 18173) MediaWiki now fails when unable to determine a client IP
9919 * (bug 19170) Special:Version should follow the content language direction
9920 * (bug 19160) maintenance/purgeOldText.inc is now compatible with PostgreSQL
9921 * Fixed performance regression in "bad image list" feature
9922 * Show user preference 'Use live preview' if $wgLivePreview is enabled only
9923 * (bug 17014) Blocked users can no longer use Special:UserRights unless they
9924 can add/remove *all* groups (have 'userrights' permission).
9925 * (bug 19294) Always show Sp-contributions-footer(-anon)
9926 * Attempts to restrict reading of pages while anonymous viewing is allowed
9927 via extensions not using the userCan hook and via $wgRevokePermissions now
9928 work.
9929 * (bug 8445) Multiple-character search terms are now handled properly for
9930 Chinese
9931 * (bug 19450) Use formatNum for "Number of edits" in Special:Preferences
9932 * (bug 11242) Check for MySQL storage engines during installation now checks
9933 whether the engines are actually available
9934 * (bug 19390) Omit the "printable version" link on the printable version
9935 * (bug 18394) img_auth.php now respects userCan
9936 * (bug 19509) Uploading to a file named '0' previously treated it as null input
9937 and attempted to upload with the source name. Now warns about not having an
9938 extension (since 0.ext is perfectly valid)
9939 * (bug 19468) Enotif preferences are now only displayed when they are turned on
9940 * (bug 19442) Show/hide options on watchlist only work once
9941 * (bug 19602) PubMed Magic links now use updated NIH url
9942 * (bug 19637) externallinks have links to self
9943 * Don't load Opera 9.5 RTL fixes for Opera 9.6
9944 * Remove five-year-old KHTMLFixes.css, which is unlikely to be relevant anymore
9945 and was causing problems.
9946 * Removed repetition of URIs in the title attributes of external links.
9947 * (bug 19693) User name is now escaped in "Contributions for ..." link on
9948 Special:BlockIP
9949 * (bug 19571) Override buildConcat for SQLite.
9950 * Log in and log out links no longer return to page view when clicked from
9951 history view, edit page, or something similar
9952 * (bug 19513) RTL fixes for new Search UI
9953 * (bug 16497) Special:Allmessages is paginated
9954 * (bug 18708) CSS plainlinks class now available to all skins
9955 * (bug 19590) Database error messages no longer have "MySQL" hardcoded as the
9956 database type
9957 * (bug 19759) successbox on Special:Preferences now correctly aligned on
9958 standard, nostalgia and cologneblue skin
9959 * (bug 19814) interwiki links from file links ([[File:Foo.jpg|link=de:Test]])
9960 are no longer recorded in the pagelinks table
9961 * (bug 19784) date option "ISO 8601" produced illegal id
9962 * (bug 19761) Removed autogenerated <meta keywords> tag with link data.
9963 Keyword set was not useful, and is ignored by modern search engines anyway.
9964 * (bug 19827) Special:SpecialPages title is "Upload file
9965 * (bug 19355) Added .xhtml, .xht to upload file extension blacklist
9966 * (bug 19287) Workaround for lag on history page in Firefox 3.5
9967 * (bug 19564) Updated docs/hooks.txt
9968 * (bug 18751) Fix for buggage in profiling setup for some extensions on PHP 5.1
9969 * (bug 17139) ts_resortTable inconsistent trimming makes date sorting fragile
9970 * (bug 19445) Change oldimage table to use ON UPDATE CASCADE for FK to image
9971 table.
9972 * (bug 14080) Short notation links to subpages didn't work in edit summaries
9973 * (bug 17374) Special:Export no longer exports multiple copies of pages
9974 * (bug 19818) Edits to user CSS/JS subpages can now be marked as patrolled by
9975 users who can't edit them
9976 * (bug 19839) Comments in log items are no more double escaped
9977 * (bug 18161) Fix inconsistent separators in watchlist link toolbars with
9978 "enhanced recent changes"
9979 * (bug 16877) Moving a page over a redirect no longer leaves an orphan entry in
9980 the recentchanges table
9981 * (bug 16009) Limit selection forms based on Pager now links to the correct page
9982 when using long urls
9983 * The display of the language list on the preferences is more comply with the
9984 BCP 47 standards.
9985 * (bug 19849) Custom X-Vary-Options header now disabled unless $wgUseXVO is set
9986 * (bug 19301) Duplicate entries in $wgAddGroups, $wgRemoveGroups,
9987 $wgGroupsAddToSelf and $wgGroupsRemoveFromSelf are no more displayed on
9988 Special:ListGroupRights
9989 * (bug 18799) Special:Userlogin now handles correctly the returnto parameter
9990 to not link back to Special:Userlogout when user's language isn't the same as
9991 content's language
9992 * (bug 19479) Show proper error message when unable to connect to PostgreSQL
9993 database with username/password in MediaWiki's setup
9994 * (bugs 18407, 18409) Special:Upload is now listed on Special:Specialpages only
9995 if uploads are enabled and the user can access it
9996 * (bug 17988) Spaces before [[Category:]] links are no longer ignored
9997 * (bug 19957) All known-failing tests now marked disabled; added --run-disabled
9998 option to parser test suite to run disabled tests if desired.
9999 * (bug 16311) Make recent change flags (n/m/b) <abbr>s instead of <span>s
10000 * (bug 15680) Split the edit tip message of user CSS/JS subpage into
10001 "usercssyoucanpreview" and "userjsyoucanpreview" respectively.
10002 * (bug 12110) Split the rights for editing users' CSS/JS subpage from
10003 "editusercssjs" into "editusercss" and "edituserjs" respectively.
10004 * (bug 19394) RecentChanges feed URLs for log items with no revisions
10005 (eg Newuser, Userrights) are no longer broken
10006 * (bug 17395) Remote file descriptions use user language ($wgLang), not wiki
10007 language ($wgContLang)
10008 * (bug 11867) Lock error on redirect table when running orphans.php
10009 * (bug 18930) initStats.php now refreshes active users count
10010 * (bug 18699) Using the nosummary URL option no longer triggers the "You have
10011 not provided a summary" warning for those who activated it in their
10012 preferences
10013 * (bug 18855) commandLine.inc and Maintenance.php are now properly included
10014 using the full path
10015 * (bug 18497) Fixed broken style sheets in Opera fullscreen mode
10016 * (bug 16084) Default memory limit has be increased to 50M, see $wgMemoryLimit
10017 * (bug 17864/19519) Added proper input normalization in Special:UserRights
10018 * (bug 20086) Add Hook to add extra statistics at the end of Special:Statistics
10019 * (bug 19289) importDump.php can now handle bzip2 and 7zip
10020 * (bug 20131) Fixed a PHP notice for users having the "rollback" right on
10021 Special:RecentChangesLinked
10022 * Do not transform EXIF fields with pure text to avoid results like
10023 foo,bar@example,com
10024 * (bug 20176) Fix login/logout links in skin CologneBlue
10025 * (bug 20203) "Powered by Mediawiki" now has height/width on image tag
10026 * (bug 20273) Fix broken output when no pages are found in the content
10027 namespaces
10028 * (bug 20265) Make AncientPages and UnusedFiles work on SQLite
10029 * Fixed XSS vulnerability for Internet Explorer clients (only pre-release
10030 versions of MediaWiki were affected).
10031 * (bug 14817) Moving a page to a subpage of itself moves it twice
10032 * (bug 20289) $wgMaximumMovedPages should only count pages actually moved
10033 * (bug 15248) Non-breaking spaces and certain other Unicode space characters
10034 are now normalized to ordinary spaces in titles; if your wiki has existing
10035 titles with such characters, run cleanupTitles.php and/or cleanupImages.php
10036 * (bug 11143) Links containing invalid UTF-8 percent-code sequences are now
10037 cleanly disabled instead of breaking parsing entirely on PHP 5.2.
10038 * (bug 20296) Fixed an PHP warning in Language::getMagic() in PHP 5.3
10039 * (bug 20358) Unprotect tab was missing accesskey; now same as protect tab.
10040 * (bug 20317) Cleaned up default main page link accesskey settings
10041 * (bug 20362) Special:Statistics now produces valid HTML when view counters are
10042 enabled
10043 * (bug 19857) maintenance/deleteRevision.php on last revision no longer breaks
10044 target page
10045 * (bug 20365) Page name with c/g/h/j/s/u + x are now correctly handled in
10046 Special:MovePage with Esperanto as content language
10047 * (bug 20364) Fixed regression in GIF metadata loading
10048 * (bug 20299) MediaWiki:Move-subpages and MediaWiki:Move-talk-subpages can now
10049 use wikitext
10050 * (bug 15475) DatabaseBase::setFlag(), DatabaseBase::clearFlag() and
10051 DatabaseBase::getFlag() now have documentation
10052 * (bug 19966) MediaWiki:License-header is now used for the licensing header in
10053 the file description page instead of MediaWiki:License
10054 * (bug 20380) Links to history/deleted edits at the top of
10055 Special:RevisionDelete are no more displayed when doing log suppression
10056 * (bug 8143) Localised parser function names are now correctly case insensitive
10057 if they contain non-ASCII characters
10058 * (bug 19055) maintenance/rebuildrecentchanges.php now purges
10059 Special:Recentchanges's RSS and Atom feed cache
10060 * The installer will now try to bypass PHP's max_execution_time
10061 * (bug 20260) SQLite no longer tries to automatically create the database at
10062 execution time, this now happens only at install time; if it is not available
10063 at script execution, it now throws an exception
10064 * Fixed EditFilterMerged hook so the hookError parameter serves a purpose
10065 (analogous to EditFilter hook)
10066 * (bug 2257) Tag extensions can expand template parameters provided to the tag,
10067 by using a new parameter added to the recursiveTagParse function
10068 * (bug 14900) __INDEX__ and __NOINDEX__ no longer override site config set in
10069 $wgArticleRobotPolicies.
10070 * (bug 20466) Hidden categories are no more displayed when printing
10071 * (bug 20446) When changing user rights with User@remotewiki and remotewiki is
10072 the local wiki, the user is now treated as the local user
10073 * (bug 20494) OutputPage::getArticleBodyOnly() no longer requires an useless
10074 argument
10075 * (bug 20136) Protection form JavaScript now synchronizes the expiry boxes on
10076 any change, in addition to onkeyup.
10077 * Don't link to "edit this page" on MediaWiki:Noarticletext if user is not
10078 allowed to create page. Done via new message
10079 MediaWiki:Noarticletext-nopermission
10080 * Improved compatibility between the Vector skin and addPortletLink() from
10081 wikibits.js: empty portlets are now present but hidden, adding an element to a
10082 portlet unhides it
10083 * (bug 19531) addPortletLink() now wraps inserted labels in a <span> element to
10084 be compatible with the CSS for the Vector skin
10085 * (bug 20578) Wrong localized image metadata - duplicated string?
10086 * (bug 20556) Stub threshold's "other" <input> in Special:Preferences now has a
10087 correct type="text" parameter
10088 * (bug 482) Don't include TOC in the printable version if it has been hidden
10089 * Adjust the time according to the user configuration on Special:Revisiondelete
10090 * (bug 20624) Installation no longer allows "qqq" as the chosen language
10091 * (bug 20634) The installer-created database user will now have all rights on
10092 the database so that upgrades will go more smoothly.
10093 * (bug 18180) Special:Export ignores limit, dir, offset parameters
10094 * User::getBlockedStatus() works for all kinds of user objects and doesn't
10095 assume the user object is equal to the current-user object ($wgUser)
10096 * (bug 20517) Cancel link from edit page now returns to the old version when
10097 editing an old version
10098 * (bug 16902) Installer no longer shows warnings when exec() has been disabled
10099 by disable_functions
10100 * (bug 20726) Title::getLatestRevID's documentation now says that the function
10101 returns false if the page doesn't exist
10102 * (bug 20751) ForeignApiRepo now urldecodes filenames when saving to local cache
10103 * (bug 20730) Fix to Special:Version ViewVC link for branch checkouts
10104 * (bug 20353) wfShellExec() was adding extra quotes on Windows Vista, causing
10105 command line scripts to fail
10106 * (bug 20702) Parser functions can now be used correctly in
10107 MediaWiki:Missing-article
10108 * (bug 14117) "redirected from" is now also shown on foreign file redirects
10109 * (bug 17747) Only display thumbnail column in file history if the image can
10110 be rendered.
10111 * (bug 3421) Live preview no longer breaks user CSS/JS previews
10112 * (bug 11264) The file logo on a file description page for documents (PDF, ...)
10113 now links to the file rather than the file description page
10114 * Password fields built with HTMLForm now still have the type="password"
10115 attribute if $wgHtml5=false.
10116 * (bug 20836) Preload now works for MediaWiki namespace
10117 * (bug 20885) Search box no longer suggests unavailable special pages
10118 * (bug 20948) "Create this page" on Special:Search is no longer displayed when
10119 searching for special pages
10120 * (bug 20524) Hideuser: Show nice error when trying to block hidden user without
10121 hideuser right
10122 * (bug 21026) Fixed file redirects on shared repos on non-English client wikis
10123 * (bug 21030) Fixed schema choices from being overwritten by defining unique
10124 field names per driver.
10125 * (bug 21115) wgCanonicalSpecialPageName javascript variable is now always
10126 false on non-special pages
10127 * (bug 21113) "Other statistics" header on Special:Statistics is no more
10128 displayed when there isn't any entry in it
10129 * (bug 21114) Special:Contributions no longer shows diff links for new
10130 revisions
10131 * (bug 21116) MediaWiki:Templatesused, MediaWiki:Templatesusedpreview and
10132 MediaWiki:Templatesusedsection now support plural
10133 * (bug 21079) There is no more line wrapping between label and field in
10134 Special:Log
10135 * (bug 20256) Fixed SQL errors on Special:Recentchanges and
10136 Special:Recentchangeslinked on SQLite backend
10137 * (bug 20880) Fixed updater failure on SQLite backend
10138 * (bug 21182) Fixed invalid HTML in Special:Listgrouprights
10139 * (bug 20242) Installer no longer promts for user credentials for SQLite
10140 databases
10141 * (bug 20911) Installer failed to create a SQLite database
10142 * (bug 20847) Deprecated deprecated akeytt() removed in wikibits.js leaving
10143 dummy
10144 * (bug 21161) Changing $wgCacheEpoch now always invalidates file cache
10145 * (bug 20268) Fixed row count estimation on SQLite backend
10146 * (bug 20275) Fixed LIKE queries on SQLite backend
10147 * (bug 21234) Moving subpages of titles containing \\ now works properly
10148 * (bug 21006) maintenance/updateArticleCount.php now works again on PostgreSQL
10149 * (bug 19319) Add activeusers-intro message at top of SpecialActiveUsers page
10150 * (bug 21255) Fixed hostname construction for DNSBL checking
10151 * (bug 18019) Users are now warned when moving a file to a name in use on a
10152 shared repository and only users with the 'reupload-shared' permission can
10153 complete the move.
10154 * (bug 18909) Add missing Postgres INSERT SELECT wrapper
10155 * User::isValidPassword now only returns boolean results,
10156 User::getPasswordValidity can be used to get an error message string
10157 * The error message shown in Special:ChangePassword now parses wiki markup
10158 * (bug 19859) Removed experimental HTMLDiff feature
10159 * Removed section edit links in edit conflict form
10160 * Allow SpecialActiveusers to work on non-MySQL databases
10161 * (bug 6579) Fixed protecting images from uploading only
10162 * (bug 18609) Search index was empty for some pages
10163 * (bug 13453) rebuildrecentchanges maintenance script works on PG again
10164 * (bug 16583) Reduce false positives when checking for PHP (on upload, etc.)
10165 * (bug 20112) Bitrotted tests in the t/ directory were failing.
10166 * (bug 21470) MediaWiki:Sp-contributions-explain is now wrapped in a <p> with
10167 id "mw-sp-contributions-explain"
10168 * (bug 19159) Fixed \overleftrightarrow in texvc
10169 * (bug 19391) Fix caching for Recent ChangesFeed.
10170 * (bug 21455) Fixed "Watch this page" checkbox appearing on some special pages
10171 even to non-logged in users
10172 * (bug 21551) Rewrote the Squid purge HTTP client to provide a more robust and
10173 general implementation of HTTP, allowing it to purge non-Squid caches such as
10174 Varnish.
10175 * Fixed corruption of long UDP debug log messages by using socket_sendto()
10176 instead of fsockopen() with fwrite().
10177 * (bug 16884) Fixed feed links in sidebar not complying with URL parameters
10178 of the displayed page
10179 * (bug 21403) memcached class renamed to MWMemecached to avoid conflict with
10180 PHP's memcached extension
10181 * (bug 21650) Both calls to SkinTemplateTabs hook are now compatible
10182 * (bug 21672) Add missing Accept-Language to both Vary and XVO headers
10183 * (bug 21679) "Edit block reasons" link at the bottom of Special:Blockip is now
10184 only displayed to the users that have "editinterface" right
10185 * (bug 21740) Attempting to protect a page that doesn't exist (salting) returns
10186 "unknown error"
10187 * (bug 18762) both redirects and links get fixed one after another if
10188 redirects-only switch is not present
10189 * (bug 20159) thumbnails rerendered if older than $wgThumbnailEpoch
10190 * Fixed a bug which in some situations causes the job queue to grow forever,
10191 due to an infinite loop of job requeues.
10192 * (bug 21523) File that can have multiple pages (djvu, pdf, ...) no longer have
10193 the page selector when they have only one page
10194 * (bug 21559) "logempty" message is now wrapped in a div with class
10195 "mw-warning-logempty" when used in log extract
10196 * (bug 20549) Parser tests were broken on SQLite backend
10197 * (bug 21776) Interwiki urls like http://en.wikibooks.org/wiki/cs: should give
10198 a redirect instead of a baderror.
10199 * (bug 21803) Special:MyContributions now keeps the query string parameters
10200 * Redirecting special pages now keep query string parameters set to "0" (e.g.
10201 for namespace)
10202 * (bug 20765) Special:ListGroupRights no longer misses addables and removables
10203 groups if there are duplicate entries
10204 * (bug 21814) Message shown when rolling back an edit with a deleted username
10205 now shows '(username deleted)' instead of broken user tool links
10206 * (bug 21536) Fixed JavaScript error on Special:Search caused by an incorrect ID
10207 * (bug 21535) RecentChanges RSS feed now always recognises the namespace filter,
10208 previously it sometimes didn't due to caching.
10209 * (bug 20388) ProfilerSimpleText no longer outputs comment on action=raw
10210 * refreshLinks.php now purges orphaned redirect table rows
10211 * (bug 2971) Swap links of hist & diff location on Special:Contributions for
10212 consistency with RC/WL
10213 * (bug 21986) Special page names are now capitalized by content language
10214 * If two log types have the same description, they're now both displayed in the
10215 type selector on Special:Log
10216 * (bug 20115) Special:Userlogin title says "Log in / create account" even if the
10217 user can't create an account
10218 * (bug 2658) Don't attempt to set the TZ environment variable.
10219 * (bug 9794) User rights log entries for foreign user now links to the foreign
10220 user's page if possible
10221 * (bug 14717) Don't load nonexistent CSS fix files for non-Monobook skins
10222 * (bug 22034) Use wfClientAcceptsGzip() in wfGzipHandler instead of
10223 reimplementing it.
10224 * (bug 19226) First line renders differently on many UI messages.
10225 * (bug 21303) Comments are no longer stripped from MediaWiki:Common.js and
10226 skin-specific JS pages
10227 * (bug 5061) Use the more precise thumbcaption thumbimage and thumbinner classes
10228 for image divs.
10229 * (bug 22096) IE50Fixes.css and IE55Fixes.css have been dropped from the Monobook
10230 and Chick skins
10231 * Fixed bug involving unclosed "-{" markup in the language converter
10232 * (bug 21870) No longer include Google logo from an external server on wiki error.
10233 * (bug 22181) Do not truncate if the ellipsis actually make the string longer
10234 * (bug 16039) Text disappearing after a bad image
10235 * (bug 18784) Internal links like [[File:Foo|caption]] should read 'caption',
10236 not 'File:Foo' when Foo is not an image
10237 * (bug 21518) Special:UserRights no longer displays the user name box for users
10238 that can only change their rights
10239 * (bug 21593) Special:UserRights now lists automatic groups membership
10240 * (bug 22364) Setting $wgUseExternalEditor to false no longer hides the reupload
10241 link from file pages
10242 * Fix bug introduced in MediaWiki 1.12: The author field in
10243 $wgExtensionCredits is no longer sorted with sort() but rather used
10244 as it appears in extensions as was the case before r30117 where it
10245 was unintentionally sorted along with other fields.
10246 * (bug 19334) Textarea no longer jumps when editing longer articles in IE8
10247 * Truncate summary of page moves in revision comment field to avoid broken
10248 multibyte characters
10249 * (bug 22540) ForeignApiRepos no longer try to store thumbnails that don't exist
10250 * (bug 22551) Special:Resetpass now has a "Cancel" button that sends the user to
10251 the page set in the &returnto parameter.
10252 * (bug 19194) Search box in Modern skin doesn't focus with Safari/Chrome
10253 * (bug 17790) Users instantly logged off on HughesNet
10254 * (bug 21549) Make foreign key constraints DEFERRABLE INITIALLY DEFERRED
10255 when using Postgres as the database backend.
10256
10257 == API changes in 1.16 ==
10258
10259 * Added uiprop=changeablegroups to meta=userinfo
10260 * Added usprop=gender to list=users
10261 * (bug 18311) action=purge now works for images too
10262 * Add parentid to prop=revisions output
10263 * (bug 17832) action=delete returns 'unknownerror' instead of 'permissiondenied'
10264 when the user is blocked
10265 * (bug 18546) Added timestamp of new revision to action=edit output
10266 * (bug 18554) Also list hidden revisions in list=usercontribs for privileged
10267 users
10268 * (bug 13049) "API must be accessed from the primary script entry point" error
10269 * (bug 16422) Don't display help for format=jsonfm unless specifically requested
10270 * Added PHP and database version to meta=siteinfo output
10271 * (bug 18533) Add readonly message to meta=siteinfo output
10272 * (bug 18518) Add clprop=hidden to prop=categories
10273 * (bug 18710) Fixed internal error with empty parameter in action=paraminfo
10274 * (bug 18709) Missing descriptions for some parameters in action=paraminfo
10275 output
10276 * (bug 18731) Show correct SVN links for extension modules in api.php?version
10277 * (bug 18730) Add version information to action=paraminfo output
10278 * (bug 18743) Add ucprop=size to list=usercontribs
10279 * (bug 18749) Add generator flag to action=paraminfo output
10280 * Make action=block respect $wgEnableUserEmail and $wgSysopEmailBans
10281 * Made deleting file description pages without files possible
10282 * (bug 18773) Add content flag to siprop=namespaces output
10283 * (bug 18785) Add siprop=languages to meta=siteinfo
10284 * (bug 14200) Added user and excludeuser parameters to list=watchlist and
10285 list=recentchanges
10286 * Added index, fromtitle and byteoffset fields to action=parse&prop=sections
10287 output
10288 * (bug 19313) action=rollback returns wrong revid on master/slave setups
10289 * (bug 19323) action=parse doesn't return section tree on pages with Cite
10290 warnings
10291 * (bug 18720) Add anchor field to action=parse&prop=sections output
10292 * (bug 19423) The initial file description page used caption in user lang
10293 rather than UI lang
10294 * (bug 17809) Add number of users in user groups to meta=siteinfo
10295 * (bug 18533) Add readonly reason to readonly exception
10296 * (bug 19528) Added XSLT parameter to API queries in format=xml
10297 * (bug 19040) Fix prependtext and appendtext in combination with section
10298 parameter in action=edit
10299 * (bug 19090) Added watchlist parameter, deprecated watch and unwatch
10300 parameter in action=edit
10301 * Added fields to list=search output: size, wordcount, timestamp, snippet
10302 * Where supported by backend, list=search adds a 'searchinfo' element with
10303 optional info: 'totalhits' count and 'suggestion' alternate query term
10304 * (bug 19907) $wgCrossSiteAJAXdomains added to allow specified (or all)
10305 external domains to access api.php via AJAX, if the browser supports the
10306 Access-Control-Allow-Origin HTTP header
10307 * (bug 19999) Made metadata and properties of search results optional. Added
10308 srprop and srinfo.
10309 * (bug 20700) Add amprop=default to meta=allmessages to list default value for
10310 customized messages
10311 * Don't parse magic words in meta=allmessages, output messages unparsed
10312 * (bug 21105) list=usercontribs can now list contribs for User:0
10313 * (bug 21085) list=deletedrevs no longer returns only one revision when
10314 drcontinue param is passed
10315 * (bug 21106) Deprecated parameters now tagged in action=paraminfo
10316 * (bug 19004) Added support for tags
10317 * (bug 21083) list=allusers no longer returns current timestamp for users
10318 without registration date
10319 * (bug 20967) action=edit allows creation of invalid titles
10320 * (bug 19523) Add inprop=watched to prop=info
10321 * (bug 21589) API: Separate summary and initial page text for uploads
10322 * (bug 21817) list=usercontribs returns empty result for empty ucuser
10323 * (bug 21441) meta=userinfo&uiprop=options no longer returns default options
10324 for logged-in users under certain circumstances
10325 * (bug 21945) Add chomp control in YAML
10326 * Expand the thumburl to an absolute url to make it consistent with url and
10327 descriptionurl
10328 * (bug 20233) ApiLogin::execute() doesn't handle LoginForm :: RESET_PASS
10329 * (bug 22061) API: add prop=headitems to action=parse
10330 * (bug 22240) API: include time in siteinfo
10331 * (bug 22241) Quick edit is still using the deprecated watch parameter (API: Setting default for watch/unwatch wrongly set)
10332 * (bug 22245) blfilterredirect=nonredirects in blredirect mode wrongly filtering
10333 * (bug 22248) Output extension URLs in meta=siteinfo&siprop=extensions
10334 * Support key-params arrays in 'descriptionmsg' in meta=siteinfo&siprop=extensions
10335 * (bug 21922) YAML output should quote asterisk when used as key
10336 * (bug 22297) safesubst: to allow substitution without breaking transclusion
10337 * (bug 18758) API read of watchlist's wl_notificationtimestamp
10338 * (bug 20809) Expose EditFormPreloadText via the API
10339 * (bug 18427) Comment (edit summary) parser option for API
10340 * (bug 18608) API should provide list of CSS styles to apply to rendered output
10341 * (bug 18771) List possible errors in action=paraminfo
10342
10343 === Languages updated in 1.16 ===
10344
10345 MediaWiki supports over 300 languages. Many localisations are updated
10346 regularly. Below only new and removed languages are listed, as well as
10347 changes to languages because of Bugzilla reports.
10348
10349 * Capiznon (cps) (new)
10350 * North Frisian (frr) (new)
10351 * Kirmanjki (kiu) (new)
10352 * Komi-Permyak (koi) (new)
10353 * Karachay-Balkar (krc) (new)
10354 * Hill Mari (mrj) (new)
10355 * Prussian (prg) (new)
10356 * Romagnol (rgn) (new)
10357 * Lower Silesian (sli) (new)
10358 * Picard (pcd) (new)
10359 * Uyghur (Arabic script) (ug-arab) (new)
10360 * Upper Franconian (vmf) (new)
10361 * Votic (vot) (new)
10362 * Eastern Yiddish (ydd) (removed)
10363 * Iriga Bicolano (bto) (removed)
10364 * Ladin (lld) (removed)
10365 * Laz (lzz) (removed)
10366 * Palembang (plm) (removed)
10367 * Megleno-Romanian (Greek script) (ruq-grek) (removed)
10368 * Tamazight (tzm) (removed)
10369 * Laz (lzz) (new)
10370
10371 * (bug 18474) Sorani (ckb - Central Kurdish) (renamed from ku-arab)
10372 * Add PLURAL function for Scots Gaelic (gd)
10373 * Add Estonian letters äöõšüž to linktrail (et)
10374 * (bug 18776) Native name of Burmese language (my)
10375 * (bug 18806) Use correct unicode characters in spelling of native Chuvash
10376 (Чӑвашла)
10377 * (bug 18864) Updated autonym for Zhuang language
10378 * (bug 18308) Updated date formatting in Occitan (oc)
10379 * (bug 19080) Added ăâîşţșțĂÂÎŞŢȘȚ to Romanion (ro) linktrail
10380 * (bug 19286) Correct commafying function in Polish (pl)
10381 * (bug 19441) Updated date formatting for Lithuanian
10382 * (bug 19630) Added ÄäÇçĞğŇňÖöŞşÜüÝýŽž to Turkmen (tk) linktrail
10383 * (bug 19949) New linktrail for Greek (el)
10384 * (bug 19809) Korean (North Korea) (ko-kp) (new)
10385 * (bug 19968) Fixed "Project talk" namespace name for Maltese (mt)
10386 * (bug 21168) Added áâãàéêçíóôõúü to Portuguese (pt) linktrail
10387 * (bug 21596) Change interwiki link for Kurdish (ku)
10388 * (bug 23767) PHP warning/error when REQUEST_URI returns blank (IIS issue).
10389
10390 == MediaWiki 1.15 ==
10391
10392 == MediaWiki 1.15.5 ==
10393 === Changes since 1.15.4 ===
10394
10395 * (bug 24565) Fixed Cache-Control headers sent from API modules, to protect
10396 user privacy in the case where an attacker can access the wiki through the
10397 same HTTP proxy as a logged-in user.
10398 * Fixed a minor cookie header parsing issue causing incorrect Cache-Control
10399 headers to be sent.
10400 * Fixed an XSS vulnerability in profileinfo.php for installations with
10401 $wgEnableProfileInfo = true (false by default)
10402 * For backwards compatibility with extensions from 1.14.x or before, restored
10403 the original function ApiMain::requestWriteMode().
10404 * In API login "need token" responses, added the cookieprefix and sessionid
10405 fields, as in MediaWiki 1.16.x. This is an improvement to the CSRF fix
10406 introduced in 1.15.3.
10407
10408 == MediaWiki 1.15.4 ==
10409 === Changes since 1.15.3 ===
10410
10411 * (bug 23534) Fixed SQL query error in API list=allusers.
10412 * (bug 23371) Fixed CSRF vulnerability in "e-mail me my password", "create
10413 account" and "create by e-mail" features of [[Special:Userlogin]]
10414 * (bug 23687) Fixed XSS vulnerability affecting IE clients only, due to a CSS
10415 validation issue.
10416
10417 == MediaWiki 1.15.3 ==
10418 === Changes since 1.15.2 ===
10419
10420 * (bug 22828) Fixed deletion on SQLite.
10421 * (bug 23076) Fixed login CSRF vulnerability. Logins now require a token to
10422 be submitted along with the user name and password.
10423
10424 == MediaWiki 1.15.2 ==
10425 === Changes since 1.15.1 ===
10426
10427 * The installer now includes a check for a data corruption issue with certain
10428 versions of libxml2 2.7 and PHP earlier than 5.2.9, and also for a PHP bug
10429 present in the official release of PHP 5.3.1.
10430 * (bug 20239) MediaWiki:Imagemaxsize does not contain anymore a <br /> tag which
10431 was displayed to the user
10432 * (bug 21150) SQLite no longer raise an error when deleting files
10433 * (bug 20880) Fixed updater failure on SQLite backend
10434 * upgrade1_5.php now requires to be run --update option to prevent confusion
10435 * Fixed a CSS validation issue which allowed external images to be included
10436 into wikis where that is disallowed by configuration.
10437 * Fixed a data leakage vulnerability for private wikis using img_auth.php or
10438 similar image access authentication schemes. Check user permissions before
10439 streaming out scaled images from thumb.php.
10440
10441 == MediaWiki 1.15.1 ==
10442 === Changes since 1.15.0 ===
10443 * Fixed fatal errors for unusual file repository configurations, such as
10444 ForeignAPIRepo.
10445 * Fixed the "change password" link on Special:Preferences to have the correct
10446 returnto parameter.
10447 * (bug 19693) Fixed cross-site scripting vulnerability in Special:Block
10448
10449 == MediaWiki 1.15.0 ==
10450 === Changes since 1.15.0rc1 ===
10451
10452 * Removed category redirect feature, implementation was incomplete.
10453 * (bug 18846) Remove update_password_format(), unnecessary, destroys all
10454 passwords if a wiki with $wgPasswordSalt=false is upgraded with the web
10455 installer.
10456 * (bug 19127) Documentation warning for PostgreSQL users who run update.php:
10457 use the same user in AdminSettings.php as in LocalSettings.php.
10458 * Fixed possible web invocation of some maintenance scripts, due to the use of
10459 include() instead of require(). A full exploit would require a very strange
10460 web server configuration.
10461 * Localisation updates.
10462
10463 === Configuration changes in 1.15 ===
10464
10465 * Added $wgNewPasswordExpiry, to specify an expiry time (in seconds) to
10466 temporary passwords
10467 * Added $wgUseTwoButtonsSearchForm to choose the Search form behavior/look
10468 * Added $wgNoFollowDomainExceptions to allow exempting particular domain names
10469 from rel="nofollow" on external links
10470 * (bug 12970) Brought back $wgUseImageResize.
10471 * Added $wgRedirectOnLogin to allow specifying a specific page to redirect users
10472 to upon logging in (ex: "Main Page")
10473 * Add $wgExportFromNamespaces for enabling/disabling the "export all from
10474 namespace" option (disabled by default)
10475
10476 === New features in 1.15 ===
10477
10478 * (bug 2242) Add an expiry time to temporary passwords
10479 * (bug 9947) Add PROTECTIONLEVEL parser function to return the protection level
10480 for the current page for a given action
10481 * (bug 17002) Add &minor= and &summary= as parameters in the url when editing,
10482 to automatically add a summary or a minor edit.
10483 * (bug 16852) padleft and padright now accept multiletter pad characters
10484 * When using 'UserCreateForm' hook to add new checkboxes into
10485 Special:UserLogin/signup, the messages can now contain HTML to allow
10486 hyperlinking to the site's Terms of Service page, for example
10487 * Add new hook 'UserLoadFromDatabase' that is called while loading a user
10488 from the database.
10489 * (bug 17045) Options on the block form are prefilled with the options of the
10490 existing block when modifying an existing block.
10491 * (bug 17055) "(show/hide)" links to Special:RevisionDelete now use a CSS class
10492 rather than hardcoded HTML tags
10493 * Added new hook 'WantedPages::getSQL' into SpecialWantedpages.php to allow
10494 extensions to alter the SQL query which is used to get the list of wanted
10495 pages
10496 * (bugs 16957/16969) Add show/hide to preferences for RC patrol options on
10497 specialpages
10498 * (bug 11443) Auto-noindex user/user talk pages for blocked user
10499 * (bug 11644) Add $wgMaxRedirects variable to control how many redirects are
10500 recursed through until the "destination" page is reached.
10501 * Add $wgInvalidRedirectTargets variable to prevent redirects to certain
10502 special pages.
10503 * Use HTML5 rel attributes for some links, where appropriate
10504 * Added optional alternative Search form look - Go button & Advanced search
10505 link instead of Go button & Search button
10506 * (bug 2314) Add links to user custom CSS and JS to Special:Preferences
10507 * More helpful error message on raw page access if PHP_SELF isn't set
10508 * (bug 13040) Gender switch in user preferences
10509 * (bug 13040) {{GENDER:}} magic word for interface messages
10510 * (bug 3301) Optionally sort user list according to account creation time
10511 * Remote description pages for foreign file repos are now fetched in the
10512 content language.
10513 * (bug 17180) If $wgUseFileCache is enabled, $wgShowIPinHeader is automatically
10514 set to false.
10515 * (bug 16604) Mark non-patrolled edits in feeds with "!"
10516 * (bug 16604) Show title/rev in IRC for patrol log
10517 * (bug 16854) Whether a page is being parsed as a preview or section preview
10518 can now be determined and set with ParserOptions.
10519 * Wrap message 'confirmemail_pending' into a div with CSS classes "error" and
10520 "mw-confirmemail-pending"
10521 * (bug 8249) The magic words for namespaces and pagenames can now be used as
10522 parser functions to return the desired namespace or normalized title/title
10523 part for a given title.
10524 * (bug 17110) Styled #mw-data-after-content in cologneblue.css to match the
10525 rest of the font
10526 * (bug 7556) Time zone names in signatures lack i18n
10527 * (bug 3311) Automatic category redirects
10528 * (bug 17236) Suppress 'watch user page link' for IP range blocks
10529 * Wrap message 'searchresulttext' (Special:Search) into a div with
10530 class "mw-searchresult"
10531 * (bug 15283) Interwiki imports can now fetch included templates
10532 * Treat svn:// URLs as external links by default
10533 * New function to convert namespace text for display (only applies on wiki with
10534 LanguageConverter class)
10535 * (bug 17379) Contributions-title is now parsed for magic words.
10536 * Preprocessor output now cached in memcached.
10537 * (bug 14468) Lines in classic RecentChanges and Watchlist have classes
10538 "mw-line-odd" and "mw-line-even" to make styling using css possible.
10539 * (bug 17311) Add a note beside the gender selection menu to tell users that
10540 this information will be public
10541 * Localize time zone regions in Special:Preferences
10542 * Add NUMBEROFACTIVEUSERS magic word, which is like NUMBEROFUSERS, but uses
10543 the active users data from site_stats.
10544 * Add a <link rel="canonical"> tag on redirected page views
10545 * Replace hardcoded '...' as indication of a truncation with the
10546 'ellipsis' message
10547 * Wrap warning message 'editinginterface' into a div with class
10548 'mw-editinginterface'
10549 * (bug 17497) Oasis opendocument added to mime.types
10550 * Remove the link to Special:FileDuplicateSearch from the "file history" section
10551 of image description pages as the list of duplicated files is shown in the
10552 next section anyway.
10553 * Added $wgRateLimitsExcludedIPs, to allow specific IPs to be whitelisted from
10554 rate limits.
10555 * (bug 14981) Shared repositories can now have display names, located at
10556 Mediawiki:Shared-repo-name-REPONAME, where REPONAME is the name in
10557 $wgForeignFileRepos
10558 * Special:ListUsers: Sort list of usergroups by alphabet
10559 * (bug 16762) Special:Movepage now shows a list of subpages when possible
10560 * (bug 17585) Hide legend on Special:Specialpages from non-privileged users
10561 * Added $wgUseTagFilter to control enabling of filter-by-change-tag
10562 * (bug 17291) MediaWiki:Nocontribs now has an optional $1 parameter for the
10563 username
10564 * Wrap special page summary message '$specialPageName-summary' into a div
10565 with class 'mw-specialpage-summary'
10566 * $wgSummarySpamRegex added to handle edit summary spam. This is used *instead*
10567 of $wgSpamRegex for edit summary checks. Text checks still use $wgSpamRegex.
10568 * New function to convert content text to specified language (only applies on wiki with
10569 LanguageConverter class)
10570 * (bug 17844) Redirect users to a specific page when they log in, see
10571 $wgRedirectOnLogin
10572 * Added a link to Special:UserRights on Special:Contributions for privileged users
10573 * (bug 10336) Added new magic word {{REVISIONUSER}}, which displays the editor
10574 of the displayed revision
10575 * LinkerMakeExternalLink now has an $attribs parameter for link attributes and
10576 a $linkType parameter for the type of external link being made
10577 * (bug 17785) Dynamic dates surrounded with a <span> tag, fixing sortable tables with
10578 dynamic dates.
10579 * (bug 4582) Provide preference-based autoformatting of unlinked dates with the dateformat
10580 parser function.
10581 * (bug 17886) Special:Export now allows you to export a whole namespace (limited to 5000 pages)
10582 * (bug 17714) Limited TIFF upload support now built in if 'tif' extension is
10583 enabled. Image width and height are now recognized, and when using ImageMagick,
10584 optional flattening to PNG or JPEG for inline display can be enabled by setting
10585 $wgTiffThumbnailType
10586 * Renamed two input IDs on Special:Log from 'page' and 'user' to 'mw-log-page' and
10587 'mw-log-user', respectively
10588 * Added $wgInvalidUsernameCharacters to disallow certain characters in
10589 usernames during registration (such as "@")
10590 * Added $wgUserrightsInterwikiDelimiter to allow changing the delimiter
10591 used in Special:UserRights to denote the user should be searched for
10592 on a different database
10593 * Add a class if 'missingsummary' is triggered to allow styling of the summary
10594 line
10595 * Title attributes are now always blank on framed and thumbnailed images, and default to blank
10596 on inline images instead of defaulting to the image's filename. Additionally, the alt
10597 attribute now defaults to the filename on framed and thumbnailed images if no caption or alt
10598 attribute is specified.
10599
10600 === Bug fixes in 1.15 ===
10601 * (bug 16968) Special:Upload no longer throws useless warnings.
10602 * (bug 17000) Special:RevisionDelete now checks if the database is locked
10603 before trying to delete the edit.
10604 * (bug 16852) padleft and padright now handle multibyte characters correctly
10605 * (bug 17010) maintenance/namespaceDupes.php now add the suffix recursively if
10606 the destination page exists
10607 * (bug 17035) Special:Upload now fails gracefully if PHP's file_uploads has
10608 been disabled
10609 * Fixing the caching issue by using -{T|xxx}- syntax (only applies on wiki with
10610 LanguageConverter class)
10611 * Improving the efficiency by using -{A|xxx}- syntax (only applies on wiki with
10612 LanguageConverter class)
10613 * (bug 17054) Added more descriptive errors in Special:RevisionDelete
10614 * (bug 11527) Diff on page with one revision shows "Next" link to same diff
10615 * (bug 8065) Fix summary forcing for new pages
10616 * (bug 10569) redirects to Special:Mypage and Special:Mytalk are no longer
10617 allowed by default. Change $wgInvalidRedirectTargets to re-enable.
10618 * (bug 3043) Feed links of given page are now preceded by standard feed icon
10619 * (bug 17150) escapeLike now escapes literal \ properly
10620 * Inconsistent use of sysop, admin, administrator in system messages changed
10621 to 'administrator'
10622 * (bug 14423) Check block flag validity for block logging
10623 * DB transaction and slave-lag avoidance tweaks for Email Notifications
10624 * (bug 17104) Removed [Mark as patrolled] link for already patrolled revisions
10625 * (bug 17106) Added 'redirect=no' and 'mw-redirect' class to redirects at
10626 "user contributions"
10627 * Rollback links on new pages removed from "user contributions"
10628 * (bug 15811) Re-upload form tweaks: license fields removed, destination locked,
10629 comment label uses better message
10630 * Whole HTML validation ($wgValidateAllHtml) now works with external tidy
10631 * Parser tests no longer fail when $wgExternalLinkTarget is set in
10632 LocalSettings
10633 * (bug 15391) catch DBQueryErrors on external storage insertion. This avoids
10634 error messages on save were the edit in fact is saved.
10635 * (bug 17184) Remove duplicate "z" accesskey in MonoBook
10636 * Parser tests no longer fail when $wgAlwaysUseTidy is set in LocalSettings.php
10637 * Removed redundant dupe warnings on reupload for the same title. Dupe warnings
10638 for identical files at different titles are still given.
10639 * Add 'change tagging' facility, where changes can be tagged internally with
10640 certain designations, which are displayed on various summaries of changes,
10641 and the entries can be styled with CSS.
10642 * (bug 17207) Fix regression breaking category page display on PHP 5.1
10643 * Categoryfinder utility class no longer fails on invalid input or gives wrong
10644 results for category names that include pseudo-namespaces
10645 * (bug 17252) Galician numbering format
10646 * (bug 17146) Fix for UTF-8 and short word search for some possible MySQL
10647 configs
10648 * (bug 7480) Internationalize database error message
10649 * (bug 16555) Number of links to mediawiki.org scaled back on post-installation
10650 * (bug 14938) Removing a section no longer leaves excess whitespace
10651 * (bug 17304) Fixed fatal error when thumbnails couldn't be generated for file
10652 history
10653 * (bug 17283) Remove double URL escaping in show/hide links for log entries
10654 and RevisionDeleteForm::__construct
10655 * (bug 17105) Numeric table sorting broken
10656 * (bug 17231) Transcluding special pages on wikis using language conversion no
10657 longer affects the page title
10658 * (bug 6702) Default system messages updated/improved
10659 * (bug 17190) User ID on preference page no longer has delimeters
10660 * (bug 17341) "Powered by MediaWiki" should be on the left on RTL wikis
10661 * (bug 17404) "userrights-interwiki" right was missing in User::$mCoreRights
10662 * (bug 7509) Separation strings should be configurable
10663 * (bug 17420) Send the correct content type from action=raw when the HTML file
10664 cache is enabled.
10665 * (bug 12746) Do not allow new password e-mails when wiki is in read-only mode
10666 * (bug 17478) Fixed a PHP Strict standards error in
10667 maintenance/cleanupWatchlist.php
10668 * (bug 17488) RSS/Atom links in left toolbar are now localized in classic skin
10669 * (bug 17472) use print <<<EOF in maintenance/importTextFile.php
10670 * Special:PrefixIndex: Move table styling to shared.css, add CSS IDs to tables
10671 use correct message 'allpagesprefix' for input form label, replace _ with ' '
10672 in next page link
10673 * (bug 17506) Exceptions within exceptions now respect $wgShowExceptionDetails
10674 * Fixed excessive job queue utilisation
10675 * File dupe messages for remote repos are now shown only once.
10676 * (bug 14980) Messages 'shareduploadwiki' and 'shareduploadwiki-desc' are now
10677 used as a parameter in 'sharedupload' for easier styling and customization.
10678 * (bug 17482) Formatting error in Special:Preferences#Misc (Opera)
10679 * (bug 17556) <link> parameters in Special:Contributions feeds (RSS and Atom)
10680 now point to the actual contributors' feed.
10681 * ForeignApiRepos now fetch MIME types, rather than trying to figure it locally
10682 * Special:Import: Do not show input field for import depth if
10683 $wgExportMaxLinkDepth == 0
10684 * (bug 17570) $wgMaxRedirects is now correctly respected when following
10685 redirects (was previously one more than $wgMaxRedirects)
10686 * (bug 16335) __NONEWSECTIONLINK__ magic word to suppress new section link.
10687 * (bug 17581) Wrong index name in PostgreSQL's updater: was rc_timestamp_nobot,
10688 changed to rc_timestamp_bot
10689 * (bug 17437) Fixed incorrect link to web-based installer
10690 * (bug 17538) Use shorter URLs in <link> elements
10691 * (bug 13778) Hidden input added to the search form so that using the Enter key
10692 on IE will do a fulltext search like clicking the button does
10693 * (bug 1061) CSS-added icons next to links display through the text and makes
10694 it unreadable in RTL
10695 * Special:Wantedtemplates now works on PostgreSQL
10696 * (bug 14414) maintenance/updateSpecialPages.php no longer throws error with
10697 PostgreSQL
10698 * (bug 17546) Correct Tongan language native name is "lea faka-Tonga"
10699 * (bug 17621) Special:WantedFiles has no link to Special:Whatlinkshere
10700 * (bug 17460) Client ecoding is now correctly set for PostgreSQL
10701 * (bug 17648) Prevent floats from intruding into edit area in previews if no
10702 toolbar present
10703 * (bug 17692) Added (list of members) link to 'user' in Special:Listgrouprights
10704 * (bug 17707) Show file destination as plain text if &wpForReUpload=1
10705 * (bug 10172) Moved setting of "changed since last visit" flags out of the job
10706 queue
10707 * (bug 17761) "show/hide" link in page history in now works for the first
10708 displayed revision if it's not the current one
10709 * (bug 17722) Fix regression where users are unable to change temporary passwords
10710 * (bug 17799) Special:Random no longer throws a database error when a non-
10711 namespace is given, silently falls back to NS_MAIN
10712 * (bug 17751) The message for bad titles in WantedPages is now localized
10713 * (bug 17860) Moving a page in the "MediaWiki" namespace using SuppressRedirect
10714 no longer corrupts the message cache
10715 * (bug 17900) Fixed User Groups interface log display after saving groups.
10716 * (bug 17897) Fixed string offset error in <pre> tags
10717 * (bug 17778) MediaWiki:Catseparator can now have HTML entities
10718 * (bug 17676) Error on Special:ListFiles when using Postgres
10719 * Special:Export doesn't use raw SQL queries anymore
10720 * (bug 14771) Thumbnail links to individual DjVu pages no longer have
10721 two "page" parameters
10722 * (bug 17972) Special:FileDuplicateSearch form now works correctly on wikis that
10723 don't use PathInfo or short urls
10724 * (bug 17990) trackback.php now has a trackback.php5 alias and works with
10725 $wgScriptExtension
10726 * (bug 14990) Parser tests works again with PostgreSQL
10727 * (bug 11487) Special:Protectedpages doesn't list protections with pr_expiry
10728 IS NULL
10729 * (bug 18018) Deleting a file redirect leaves behind a malfunctioning redirect
10730 * (bug 17537) Disable bad zlib.output_compression output on HTTP 304 responses
10731 * (bug 11213) [edit] section links in printable version no longer appear when you cut-and-paste article text
10732 * (bug 17405) "Did you mean" to mirror Go/Search behavior of original request
10733 * (bug 18116) 'edittools' is now output identically on edit and upload pages
10734 * (bug 17241) The diffonly URI parameter should cascade to "Next edit" and "Previous edit" diff links
10735 * (bug 16823) 'Sidebar search form should not use Special:Search view URL as target'
10736 * (bug 16343) Non-existing, but in use, category pages can be "go" match hits
10737 * Fixed a CSS validation issue which allowed external images to be included
10738 into wikis where that is disallowed by configuration.
10739 * Fixed a data leakage vulnerability for private wikis using img_auth.php or
10740 similar image access authentication schemes. Check user permissions before
10741 streaming out scaled images from thumb.php.
10742
10743 == API changes in 1.15 ==
10744 * (bug 16858) Revamped list=deletedrevs to make listing deleted contributions
10745 and listing all deleted pages possible
10746 * (bug 16844) Added clcategories parameter to prop=categories
10747 * (bug 17025) Add "fileextension" parameter to meta=siteinfo&siprop=
10748 * (bug 17048) Show the 'new' flag in list=usercontribs for the revision that
10749 created the page, even if it's not the top revision
10750 * (bug 17069) Added ucshow=patrolled|!patrolled to list=usercontribs
10751 * action=delete respects $wgDeleteRevisionsLimit and the bigdelete user right
10752 * (bug 15949) Add undo functionality to action=edit
10753 * (bug 16483) Kill filesort in ApiQueryBacklinks caused by missing parentheses.
10754 Building query properly now using makeList()
10755 * (bug 17182) Fix pretty printer so URLs with parentheses in them are
10756 autolinked correctly
10757 * (bug 17224) Added siprop=rightsinfo to meta=siteinfo
10758 * (bug 17239) Added prop=displaytitle to action=parse
10759 * (bug 17317) Added watch parameter to action=protect
10760 * (bug 17007) Added export and exportnowrap parameters to action=query
10761 * (bug 17326) BREAKING CHANGE: Changed output format for iiprop=metadata
10762 * (bug 17355) Added auwitheditsonly parameter to list=allusers
10763 * (bug 17007) Added action=import
10764 * BREAKING CHANGE: Removed rctitles parameter from list=recentchanges because
10765 of performance concerns
10766 * Listing (semi-)deleted revisions and log entries as well in prop=revisions
10767 and list=logevents
10768 * (bug 11430) BREAKING CHANGE: Modules may return fewer results than the
10769 limit and still set a query-continue in some cases
10770 * (bug 17357) Added movesubpages parameter to action=move
10771 * (bug 17433) Added bot flag to list=watchlist&wlprop=flags output
10772 * (bug 16740) Added list=protectedtitles
10773 * Added mainmodule and pagesetmodule parameters to action=paraminfo
10774 * (bug 17502) meta=siteinfo&siprop=namespacealiases no longer lists namespace
10775 aliases already listed in siprop=namespaces
10776 * (bug 17529) rvend ignored when rvstartid is specified
10777 * (bug 17626) Added uiprop=email to list=userinfo
10778 * (bug 13209) Added rvdiffto parameter to prop=revisions
10779 * Manual language conversion improve: Now we can include both ";" and ":" in
10780 conversion rules
10781 * (bug 17795) Don't report views count on meta=siteinfo if $wgDisableCounters
10782 is set
10783 * (bug 17774) Don't hide read-restricted modules like action=query from users
10784 without read rights, but throw an error when they try to use them.
10785 * Don't hide write modules when $wgEnableWriteAPI is false, but throw an error
10786 when someone tries to use them
10787 * BREAKING CHANGE: action=purge requires write rights and, for anonymous users,
10788 a POST request
10789 * (bug 18099) Using appendtext to edit a non-existent page causes an interface
10790 message to be included in the page text
10791 * Fixed the circular template inclusion check, was broken when the loop
10792 involved redirects. Without this, infinite recursion within the parser is
10793 possible.
10794 * (bug 18601) generator=backlinks returns invalid continue parameter
10795 * (bug 18597) Internal error with empty generator= parameter
10796 * (bug 18617) Add xml:space="preserve" attribute to relevant tags in XML output
10797 * (bug 17611) Provide a sensible error message on install when the SQLite data
10798 directory is wrong.
10799
10800 === Languages updated in 1.15 ===
10801
10802 MediaWiki supports over 300 languages. Many localisations are updated
10803 regularly. Below only new and removed languages are listed, as well as
10804 changes to languages because of Bugzilla reports.
10805
10806 * Austrian German (de-at) (new)
10807 * Swiss Standard German (de-ch) (new)
10808 * Simplified Gan Chinese (gan-hans) (new)
10809 * Traditional Gan Chinese (gan-hant) (new)
10810 * Literary Chinese (lzh) (new)
10811 * Uyghur (Latin script) (ug-latn) (renamed from 'ug')
10812 * Veps (vep) (new)
10813 * Võro (vro) (renamed from fiu-vro)
10814 * (bug 17151) Add magic word alias for #redirect for Vietnamese
10815 * (bug 17288) Messages improved for default language (English)
10816 * (bug 12937) Update native name for Afar
10817 * (bug 16909) 'histlegend' now reuses messages instead of copying them
10818 * (bug 17832) action=delete returns 'unknownerror' instead of 'permissiondenied' when
10819 the user is blocked
10820 * Traditional/Simplified Gan Chinese conversion support
10821
10822 == MediaWiki 1.14 ==
10823
10824 == MediaWiki 1.14.1 ==
10825 === Changes since 1.14.0 ===
10826
10827 * (bug 17737) Fixed russian URLs for Special:BookSources
10828 * (bug 17713) Using links with only an anchor no longer add an dummy entry in
10829 the pagelinks table
10830 * (bug 17897) Fixed string offset error in <pre> tags
10831 * (bug 17832) Fixed action=delete returning 'unknownerror' instead of
10832 'permissiondenied' when the user is blocked
10833 * Fixed performance regression when accessing deleted (archived) files
10834 * (bug 19693) Fixed cross-site scripting vulnerability in Special:Block
10835
10836 == MediaWiki 1.14.0 ==
10837 === Changes since 1.14.0rc1 ===
10838
10839 * Fixed the performance of the backlinks API module
10840 * (bug 17420) Send the correct content type from action=raw when the HTML file
10841 cache is enabled.
10842 * (bug 17437) Fixed incorrect link to web-based installer
10843 * (bug 17527) Fixed missing MySQL-specific options in installer
10844
10845 === Configuration changes in 1.14 ===
10846
10847 * $wgExemptFromUserRobotsControl is an array of namespaces to be exempt from
10848 the effect of the new __INDEX__/__NOINDEX__ magic words. (Default: null, ex-
10849 empt all content namespaces.)
10850 * $wgForwardSearchUrl has been removed entirely. Documented setting since 1.4
10851 has been $wgSearchForwardUrl.
10852 * (bug 15080) $wgOverrideSiteFeed has been added. Setting either
10853 $wgSiteFeed['rss'] or 'atom' to a URL will override the default Recent
10854 Changes feed that appears on all pages.
10855 * $wgSQLiteDataDirMode has been introduced as the default directory mode for
10856 SQLite data directories on creation. Note that this setting is separate from
10857 $wgDirectoryMode, which applies to all normal dirs created by MediaWiki.
10858 * $wgGroupsAddToSelf and $wgGroupsRemoveFromSelf now work more like
10859 $wgAddGroups and $wgRemoveGroups, where the user must belong to a specified
10860 group in order to add or remove those groups from themselves.
10861 Backwards compatibility is maintained.
10862 * $wgRestrictDisplayTitle controls if the use of the {{DISPLAYTITLE}} magic
10863 word is restricted to titles equivalent to the actual page title. This
10864 is true per default, but can be set to false to allow any title.
10865 * $wgSpamRegex may now be an array of multiple regular expressions.
10866 * $wgAjaxSearch has been removed; use $wgEnableMWSuggest instead.
10867 * Editing the MediaWiki namespace is now unconditionally restricted to people
10868 with the editinterface right, configuring this in $wgNamespaceProtection
10869 is not required.
10870 * $wgAllowExternalImagesFrom may now be an array of multiple strings.
10871 * Introduced $wgEnableImageWhitelist to toggle the on-wiki external image
10872 whitelist on or off.
10873 * Added $wgRenderHashAppend to append some string to the parser cache and the
10874 sitenotice cache keys.
10875 * $wgRCChangedSizeThreshold is now a positive integer by default,
10876 * (bug 16006) $wgEnableWriteAPI is now true by default. Authorized can perform
10877 write actions using the API.
10878 * Added $wgRC2UDPInterwikiPrefix which adds an interwiki prefix
10879 ($wgLocalInterwiki) onto the page names in the UDP feed.
10880 * Added $wgAllowUserSkin to let the wiki's owner disable user selectable skins
10881 on the wiki. If it's set to false, then the skin used will *always* be
10882 $wgDefaultSkin.
10883 * Added $wgEnotifUseRealName, which allows UserMailer to send out e-mails based
10884 on the user's real name if one is set. Defaults to false (use the username)
10885 * Removed the 'apiThumbCacheDir' option from $wgForeignFileRepos (only used in
10886 ForeignAPIRepo)
10887 * (bug 44) Image namespace and accompanying talk namespace renamed to File.
10888 For backward compatibility purposes, Image still works. External tools may
10889 need to be updated.
10890 * The constants NS_FILE and NS_FILE_TALK can now be used instead of NS_IMAGE and
10891 NS_IMAGE_TALK. The old constants are retained as aliases for compatibility,
10892 and should still be used in code meant to be compatible with v1.13 or older.
10893 * MediaWiki can be forced to use private IPs forwarded by a proxy server by
10894 using $wgUsePrivateIPs.
10895 * The 'BeforeWatchlist' hook has been removed due to internal changes in
10896 Special:Watchlist. 'SpecialWatchlistQuery' should now be used by extensions
10897 to customize the watchlist database query.
10898
10899 === Migrated extensions ===
10900 The following extensions are migrated into MediaWiki 1.14:
10901
10902 * Special:DeletedContributions to show deleted user contributions (was
10903 extension DeletedContributions)
10904 * Special:Log/newusers recording new users (was extension Newuserlog)
10905 * Special:LinkSearch to search for external links (was extension LinkSearch)
10906 * RenderHash
10907 * NoMoveUserPages
10908 * UniversalEditButton
10909
10910 === New features in 1.14 ===
10911
10912 * New URL syntaxes for Special:ListUsers - 'Special:ListUsers/USER' and
10913 'Special:ListUsers/GROUP/USER', in addition to the older syntax
10914 'Special:ListUsers/GROUP' where GROUP is a valid group name.
10915 * Configurable per-namespace and per-page notices for the edit form,
10916 respectively MediaWiki:Editnotice-# where # is the namespace number, and
10917 MediaWiki:Editnotice-#-PAGENAME where # is the page's namespace number and
10918 PAGENAME is the page name minus the namespace prefix.
10919 * (bug 8068) New __INDEX__ and __NOINDEX__ magic words allow user control of
10920 search engine indexing on a per-article basis.
10921 * Handheld stylesheet options
10922 * Added 'DoEditSectionLink' hook as a cleaner unified version of the old
10923 'EditSectionLink' and 'EditSectionLinkForOther' hooks. Note that the
10924 'EditSectionLinkForOther' hook has been removed, but 'EditSectionLink' is
10925 run in all cases instead, so extensions using the old hooks should still work
10926 if they ran roughly the same code for both hooks (as is almost certain).
10927 * Signature (~~~~) "cleaning", i.e. template removal, can be disabled with
10928 $wgCleanSignatures=false
10929 * Extensions can use the SkinBuildSidebar hook to modify the content of the
10930 sidebar and add custom portlets to it
10931 * Added 'MakeGlobalVariablesScript' hook for extensions to be able to add vari-
10932 ables into the output of Skin::makeVariablesScript
10933 * (bug 13846) Added $wgAddGroups and $wgRemoveGroups display on
10934 Special:ListGroupRights
10935 * (bug 14377) Add a date selector to history pages
10936 * (bug 15007) New 'pagetitle-view-mainpage' message allows the HTML <title> of
10937 the main page to be customized
10938 * Added $wgDisableTitleConversion to disabling the conversion for all pages on
10939 the wiki
10940 * Added 'noconvertlink' toggle that can be set per user preferences, also
10941 added 'convertlink=no|yes' on GET requests whether have the link titles
10942 being converted or not
10943 * (bug 14921) Special:Contributions/: add user name to <title>
10944 Patch by Emufarmers
10945 * Unescape more "safe" characters when producing URLs, for added prettiness
10946 * Introduced a new hook 'SkinAfterContent' that allows extensions to add text
10947 after the page content and article metadata. Updated all skins and skin
10948 templates to work with that hook.
10949 * (bug 14929) removeUnusedAccounts.php now supports 'ignore-touched' and
10950 'ignore-groups'. Patch by Louperivois
10951 * (bug 15127) Work around minor display glitch in Opera.
10952 * By default, reject file uploads that look like ZIP files, to avoid the
10953 so-called GIFAR vulnerability.
10954 * (bug 15141) Give ability to only list protected pages with the cascading
10955 option enabled on Special:ProtectedPages
10956 * (bug 15157) Special:Watchlist has the same options as Special:Watchlist:
10957 Show/Hide logged in users, Show/Hide anonymous, Invert namespace selection
10958 * Added hook 'UserrightsChangeableGroups' to allow modification of what
10959 groups may be added or removed via the Special:UserRights interface.
10960 * HTML entities like &nbsp; now work (are not escaped) in edit summaries.
10961 * (bug 13815) In the comment for page moves, use the colon-separator message
10962 instead of a hardcoded colon.
10963 * Allow <gallery> to accept image names without an Image: prefix
10964 * Add tooltips to rollback and undo links
10965 * BMP images are now displayed as PNG
10966 * (bug 13471) Added NUMBERINGROUP magic word
10967 * (bug 11884) Now support Flash EXIF attribute
10968 * Show thumbnails in the file history list, patch by User:Agbad
10969 * Added support of piped wikilinks using double-width brackets
10970 * Added an on-wiki external image whitelist. Items in this whitelist are
10971 treated as regular expression fragments to match for when possibly
10972 displaying an external image inline.
10973 * (bugs 15405, 15436) Sort more currency types correctly in sortable tables
10974 * (bug 15422) Sort more different types of numbers in sortable tables
10975 * (bug 2889) MediaWiki:Print.css applies to the printable version
10976 * Category counts (e.g. from {{PAGESINCATEGORY:}}) should be more accurate for
10977 small categories
10978 * After logging in, automatically redirect to wherever you logged in from
10979 * (bug 5619) Break messages used in Special:Statistics down further
10980 * (bug 11029) Add link to Special:Listusers?group=sysop etc at
10981 Special:Statistics
10982 * (bug 15514) Setting $wgRightsText without $wgRightsUrl now produces a
10983 plaintext copyright notice. Patch by Juliano F. Ravasi.
10984 * (bug 15551) Deletion log excerpt is now shown whenever a user vists a
10985 deleted page, even if they are unable to edit it.
10986 * Added Wantedfiles special pages, allowing users to find image links with no
10987 image.
10988 * (bug 12650) It is now possible to set different expiration times for
10989 different restriction types on the protection form.
10990 * (bug 8440) Allow preventing blocked users from editing their talk pages
10991 * Improved upload file type detection for OpenDocument formats
10992 * Added the ability to set the target attribute on external links with
10993 $wgExternalLinkTarget
10994 * api.php now sends "Retry-After" and "X-Database-Lag" HTTP headers if the
10995 maxlag check fails, just like index.php does
10996 * Added "link" parameter to image links, to allow images to link to an
10997 arbitrary title or URL. This should replace inaccessible and incomplete
10998 solutions such as CSS-based overlays and ImageMap.
10999 * (bug 368) Don't use caption for alt attribute; allow manual specification
11000 using new "alt=" parameter for images
11001 * (bug 44) The {{ns:}} core parser function now also accepts localized
11002 namespace names and aliases; also, its output now uses spaces instead of
11003 underscores to match the behavior of the {{NAMESPACE}} magic word
11004 * Added the ability to display user edit counts in Special:ListUsers. Off by
11005 default, enabled with $wgEdititis = true (named after the medical condition
11006 marked by unhealthy obsession with edit counts).
11007 * Added a file cache to the parser to improve page rendering time on pages with
11008 several uses of the same image.
11009 * (bug 1250) Users can still use "show preview" and "show changes" even if the
11010 wiki is set to read-only mode.
11011 * Added a call to the 'UnwatchArticleComplete' hook to the watchlist editor.
11012 This should make it so that ALL user-accessible methods of removing a page
11013 from a watchlist lead to this hook being called (it was previously only
11014 called from within Article.php
11015 * Maximum execution time for shell processes on linux is now configured with
11016 $wgMaxShellTime (180 seconds by default)
11017 * (bug 1306) 'Email user' link no longer shown on user page when emailing
11018 is not available due to lack of confirmed address or disabled preference
11019 * Special:Wanted templates special page added to display missing templates
11020 linked from articles
11021 * Make search matches bold only, not red as well
11022 * (bug 10080) Blocks can be modified without unblocking first
11023 * (bug 15820) Special:BlockIP shows a notice if the user being blocked is
11024 already directly blocked
11025 * (bug 13710) Allow to force "watch this" checkbox via URL using parameter
11026 "watchthis"
11027 * (bug 15125) Add Public Domain to default options when installing. Patch by
11028 Nathan Larson.
11029 * Set a special temporary directory for ImageMagick with $wgImageMagickTempDir
11030 * (bug 16113) Show/hide for redirects in Special:NewPages
11031 * (bug 15903) Upload link was added to Nostalgia skin
11032 * (bug 15761) Add user toggle to omit diff after rollback
11033 * Added the BitmapHandler_ClientOnly media handler, which allows server-side
11034 image scaling to be completely disabled for specific media types, via the
11035 $wgMediaHandlers configuration variable.
11036 * New 'AbortDiffCache' hook can be used to cancel the caching of a diff
11037 * (bug 15835) Added Content-Style-Type meta tag
11038 * (bug 11027) Add parameter to MW:Randompage-nopages so that user can see the
11039 namespace.
11040 * Add id="mw-user-domain-section" to <tr> tag in Userlogin.php template so that
11041 admins with a single domain can hide the domain section using CSS
11042 * Dropped old Paser_OldPP class. Only new parser with preprocessor is used.
11043 * Moved password reset form from Special:Preferences to Special:ResetPass
11044 * Added Special:ChangePassword as a special page alias for Special:ResetPass
11045 * Added complementary function for addHandler() called removeHandler() for removing events
11046 * Improved security of file uploads for IE clients, using a reverse-engineered
11047 algorithm very similar to IE's content detection algorithm.
11048 * Cascading protection no longer requires that both edit and move are restricted
11049 to sysop, just edit=sysop is enough
11050 * (bug 2391) A warning is now shown for invalid ISBN numbers on Special:Booksources.
11051 * Installer has been updated to reflect the release of the GFDL 1.3. The URL for 1.2
11052 has been updated, and the 1.3 URL has been given. 1.2 is still Wikipedia-compatible.
11053 RightsCode was changed from 'gfdl' to 'gfdl1_2', so we can now support 1.2 as well
11054 as 1.3 (gfdl1_3).
11055 * (bug 16293) PD URL was changed to the CreativeCommons site on PD (which auto-detects
11056 your language) instead of Wikipedia.
11057 * (bug 16635) The "view and edit watchlist" page (Special:Watchlist/edit) now
11058 includes a table of contents
11059 * File objects returned by wfFindFile() are now cached by default
11060 * (bug 7492) Rights can now be assigned to specific IP addresses and ranges by
11061 using $wgAutopromote (new defines: APCOND_ISIP and APCOND_IPINRANGE)
11062 * Add a 'change block' link to Special:IPBlockList and Special:Log
11063 * (bug 16459) Use native getElementsByClassName where possible, for better
11064 performance in modern browsers
11065 * Enable \cancel and \cancelto in texvc (recompile required)
11066 * Added 'UserCryptPassword' and 'UserComparePasswords' hooks to allow extensions to implement
11067 their own password hashing methods.
11068 * (bug 16760) Add CSS-class to action links of Special:Log
11069 * (bug 505) Time zones can now be specified by location in user preferences,
11070 avoiding the need to manually update for DST. Patch by Brad Jorsch.
11071 * (bug 2585) HTTP 404 return code is now given for a page view if the page
11072 does not exist, allowing spiders and link checkers to detect broken links.
11073 * Special:Log: Add 'change protection' link for unprotected pages too
11074 * Special:Log: Add log type specific CSS classes 'mw-logline-$logtype' to
11075 'li' elements
11076 * (bug 16754) Making arbitrary rows of sortable tables sticky:
11077 |- class="unsortable"
11078 * Show subversion too even if a "normal" version number is available
11079 * (bug 16121) Add a note that a page move was without creating a redirect in the
11080 move log
11081 * Image moving is now enabled for sysops by default
11082 * Make "Did you mean" search feature more noticeable
11083 * (bug 16720) Transcluded Special:NewPages processes "/username="
11084
11085 === Bug fixes in 1.14 ===
11086
11087 * (bug 14907) DatabasePostgres::fieldType now defined.
11088 * (bug 14659) Passing the default limit param to Special:Recentchanges no more
11089 falls back to the user option
11090 * (bug 14954) Fix regression in Modern and Simple skins
11091 * Recursion loop check added to Categoryfinder class
11092 * Fixed few performance troubles of large job queue processing
11093 * Not setting various parameters in Foreign Repos now fails more gracefully
11094 * (bug 2333) Redirects are properly rendered when previewing an edit.
11095 * (bug 14972) Use localized alias of Special:Search on all search forms
11096 * (bug 11035) Special:Search should have descriptive <title>
11097 * Special pages are now not subject to special handling for "self-links"
11098 * (bug 15053) Syntactically incorrect redirects with another link in them
11099 no longer redirect to the second link
11100 * (bug 15049) Fix for CheckUser extension's log search: usernames containing
11101 a "-" were incorrectly turned into bogus IP range searches.
11102 Patch by Max Semenik.
11103 * (bug 15055) Talk page notifications no longer attempt to send mail when
11104 user's e-mail address is invalid or unconfirmed
11105 * (bug 12370) Add throttle on password attempts. Defaults to max 5 attempts in
11106 5 minutes.
11107 * (bug 15016) 'Templates used on this page' list in view source should be
11108 wrapped in a div with class "templatesUsed"
11109 * (bug 14868) Setting $wgFeedDiffCutoff to 0 now disables generation of the
11110 diff entirely, not just the display of it.
11111 * (bug 6387) Introduced new setting $wgCategoryPrefixedDefaultSortkey which
11112 allows having the unprefixed page title as the default category sortkey
11113 * (bug 15079) Add class="ns-talk" / "ns-subject" to <body>. Also added
11114 ns-special to special pages.
11115 * (bug 15052) Skins should add their name as a class in <body>
11116 * (bug 14165, bug 14294) Wikimedia specific configuration in convertGrammar()
11117 for several languages was removed. The settings have been put in extension
11118 WikimediaMessages. Patch for Czech by Danny B.
11119 * (bug 15101) Displaying only bots edits in Special:Recentchanges now works
11120 again
11121 * (bug 13770) Fixed incorrect detection of PHP's DOM module
11122 * (bug 14790) Export of category pages when using Category: prefix now actually
11123 gives results
11124 * Avoid recursive crazy expansions in section edit comments for pages which
11125 contain '/*' in the title
11126 * Fix excessive memory usage when parsing pages with lots of links
11127 * $wgSpamRegex now matches the edit summary and page move descriptions in
11128 addition to body text.
11129 * Navigation links to images available from a shared repository (like Commons)
11130 from their local talk pages no longer appear as redlinks
11131 * Action=purge on ForeignApiFiles now works (purges their thumbnails and
11132 description pages).
11133 * (bug 15303) Title conversion for templates wasn't working in some cases.
11134 * (bug 15264) Underscores in Special:Search/Foo_bar parameters were taken
11135 literally; now converting them to spaces per expectation.
11136 * (bug 15342) "Invert" checkbox now works correctly when selecting main
11137 namespace in Special:Watchlist
11138 * (bug 15172) 'Go' button of Special:Recentchanges now on the same line as the
11139 last input element (like Special:Watchlist too)
11140 * (bug 15351) Fix fatal error for invalid section fragments in autocomments
11141 * Fixed intermittent deadlock errors involving objectcache table queries.
11142 Use a separate database connection for the objectcache table to avoid
11143 long-lasting locks on that table.
11144 * Respect file restrictions in the file history list
11145 * (bug 15399) Odd/even classes on sortable tables' rows could be slow for large
11146 tables, and have been disabled by default.
11147 * (bug 15482) Special:Recentchangeslinked has no longer two submit buttons
11148 * (bug 15292) New message notification for unregistred users now works again
11149 * (bug 14398) mwsuggest.js: Let width of container be configurable
11150 * (bug 15543) Only include user touched timestamp to generated CSS
11151 * (bug 15497) Removed encoding attribute from <?xml ?> tag
11152 * (bug 12284) Special:Preferences now sets a returnto parameter on the link to
11153 Special:UserLogin. Patch by Marooned.
11154 * Fixed the HTTP accept language string detection length in
11155 LanguageConverter.php, instead of the fixed length language codes.
11156 * Special:RecentChangesLinked no longer shows outgoing links for nonexistent
11157 pages even if there are broken link records with source article id 0 in the
11158 database
11159 * (bug 15598) Special:Newpages default limit uses user preference for
11160 recentchanges limit instead of hardcoded 50.
11161 * (bug 15617) $wgFeedClassesOutputPage::getHeadLinks() respects $wgFeedClasses,
11162 instead of hardcoding rss and atom. Patch by Juliano F. Ravasi.
11163 * (bug 14638) Special:Blockip now provides a link to the block log if the user
11164 has been blocked more than 10 times. Patch by Matt Johnston.
11165 * (bug 12678) Skins don't show Upload link if the user isn't allowed to upload.
11166 * Fixed incorrect usage of DB_LAST in Special:Export. Deprecated DB_LAST.
11167 * (bug 15642) Blocked sysops can no longer block other users
11168 * Http::request() now respects $wgHTTPtimeout when not using cURL
11169 * (bug 15158) Userinvalidcssjstitle not shown on preview
11170 * (bug 15196) Free external links should be numbered in a localised manner
11171 * (bug 15388) Title of Special:PrefixIndex
11172 * Links with no title but a curid parameter now use the curid to pick a page
11173 * (bug 10323) Special:Undelete should have "inverse selection" button
11174 * (bug 15831) Modern skin RTL support is bugous
11175 * (bug 15869) Nostalgia skin does not show page title in printable mode
11176 * (bug 15795) Special:Userrights is now listed on Special:SpecialPages when the
11177 user can only change his rights
11178 * (bug 15846) Categories "leak" from older revisions in certain circumstances
11179 * (bug 15928) Special pages dropdown should be inline in non-MonoBook skins
11180 * (bug 14178) Some uses of UserLoadFromSession hook cause segfault
11181 * (bug 15925) Postitive bytes added on recentchanges and watchlists are now
11182 bolded if above the threshold, previously it only worked for negatives
11183 * Specify apple-touch-icon before favicon in HTML head section to make the
11184 Konqueror browser correctly use the latter
11185 * (bug 15717) Set $separatorTransformTable for language 'eu'
11186 * (bug 15605) Enabled $datePreferences for language 'hr'. Added standard date
11187 preferences.
11188 * (bug 13701) {{NUMBEROFVIEWS}} magic word to show number of total views.
11189 * (bug 5101) Image from Commons doesn't show up when searched in Wikipedia
11190 search box
11191 * (bug 14609) User's namespaces to be searched default not updated after adding
11192 new namespace
11193 * Purge form uses valid XHTML
11194 * (bug 12764) Special:LonelyPages shows transcluded pages
11195 * (bug 16073) Enhanced RecentChanges uses onclick handler with better fallback
11196 if JavaScript is disabled
11197 * (bug 4253) Recentchanges IRC messages no longer include title in diff URLs
11198 * Allow '0' to be an accesskey.
11199 * (bug 8063) Use language-dependent sorting in client-side sortable tables
11200 * (bug 16160) Suggestions box should be resized from left for RTL wikis
11201 * (bug 11533) Fixed insane slowdown when in read-only mode for long periods
11202 of time with CACHE_NONE (default objectcache table configuration).
11203 * Trying to set two different default category sort keys for one page now
11204 produces a warning
11205 * (bug 16143) Fix redirect loop on special pages starting with lower case
11206 letters
11207 * (bug 15737) Fix notices while expanding using PPCustomFrame
11208 * (bug 15544) Non-index entry points cause the "Wiki not set up" message to
11209 have corrupt URLs
11210 * (bug 5101) Image from Commons doesn't show up when searched in Wikipedia
11211 search box
11212 * (bug 4362) [[MediaWiki:History copyright]] no more used with most recent
11213 revision when passing oldid parameter in the url
11214 * (bug 16265) When caching thumbs with the ForeignApiRepo, we now use the same
11215 filename as the remote site.
11216 * (bug 8345) Don't autosummarize where a redirect was left unchanged
11217 * Made thumb caching in ForeignApiFile objects integrated with normal thumb
11218 path naming (/thumbs/hash/file), retired 'apiThumbCacheDir' as a result.
11219 * (bug 5530) Consistency between character encoding in {{PAGENAMEE}},
11220 {{SUBPAGENAMEE}} and {{FULLPAGENAMEE}}
11221 * Safer handling of non-MediaWiki exceptions -- now obeys our settings for
11222 formatting and path exposure.
11223 * Less verbose errors from profileinfo.php when not configured
11224 * Blacklist redirects via Special:Filepath, hard to use.
11225 * Improved input validation on Special:Import form
11226 * Add a .htaccess to deleted images directory for additional protection
11227 against exposure of deleted files with known SHA-1 hashes on default
11228 installations.
11229 * Improved scripting safety heuristics for IE 5/6 content-type detection.
11230 * Improved scripting safety heuristics on SVG uploads.
11231 * (bug 11728) Unify layout of enhanced watchlist/recent changes
11232 * (bug 8702) Properly update stats when running nukePage maintenance script
11233 * (bug 7726) Searches for words less than 4 characters now work without
11234 requiring customization of MySQL server settings
11235 * Honour unchecked "Leave a redirect behind" for moved subpages
11236 * (bug 16440) Broken 0-byte math renderings are now deleted and re-rendered
11237 when page is re-parsed.
11238 * (bug 6100) Unicode BiDi embedding/override characters (U+202A - U+202E) are
11239 now automatically removed from titles; these characters can accidentally end
11240 up in copy-and-pasted titles, and, by overriding normal bidirectional text
11241 handling, can lead to annoying behavior such as text rendering backwards
11242 * Fixed minor bug where the memcached value for how many accounts an IP had
11243 created that day would be increased even if $wgAccountCreationThrottle was
11244 hit. This meant if an IP hit the throttle and then the throttle was raised
11245 later that day, the IP still couldn't create another account, because it
11246 had marked them as having created another account, when their last account
11247 creation had actually failed.
11248 * (bug 12647) Allow autogenerated edit summary messages to be blanked with '-'
11249 * (bug 16026) 'Revision-info' and 'revision-info-current' both accept wiki
11250 markup now.
11251 * (bug 16529) Fix for search suggestions with some third-party JS libraries
11252 * (bug 13342) importScript() generates more consistent URI encoding
11253 * (bug 16577) When a blocked user tries to rollback a page, the block message
11254 is now only displayed once
11255 * (bug 14268) SVG image sizes now extracted with proper XML parser
11256 * (bug 14365) RepoGroup::findFiles() no longer crashes if passed an invalid
11257 title via the API
11258 * (bug 4253, bug 16586) Revision ID is now given instead of title in URLs for
11259 new pages in the recent changes IRC feed
11260 * Ugly tooltips in Special:Statistics were phased out in favor of more direct
11261 information. Went ahead and rewrote SpecialStatistics to subclass SpecialPage
11262 * (bug 5506) Links to files on foreign repositories are now shown consistently
11263 as bluelinks e.g. in logs and edit summaries
11264 * (bug 16623) Add missing </p> tag in Special:LockDB
11265 * (bug 15849) Special:Movepage now throws a more specific error when trying to
11266 move a title to an interwiki target
11267 * (bug 16638) 8-bit URL fallback encoding now set on additional languages using
11268 Arabic script (Persian, Urdu, Sindhi, Punjabi)
11269 * (bug 16656) cleanupTitles and friends should now work in load-balanced
11270 DB environments when $wgDBserver isn't set.
11271 * (bug 3691) Aspect ratio from viewBox attribute is now preserved for SVG
11272 images which do not specify width and height attributes.
11273 * (bug 15027) Internet domain names and IP addresses can now be indexed and
11274 searched sensibly with the default MySQL search backend.
11275 * (bug 11733) Fixed parameter validation in importTextFile.php
11276 * (bug 16712) Special:NewFiles updated to use "newer"/"older" paging messages
11277 for clarity over "previous/next"
11278 * (bug 16612) Fixed "noprint" class for Modern skin print style
11279 * Section anchors now have an "id" attribute as well as a "name" attribute,
11280 even when Tidy is not used
11281 * (bug 16026) revision-info, revision-info-current, cannotdelete,
11282 redirectedfrom, historywarning and difference messages now use Wiki text
11283 rather than raw HTML markup
11284 * (bug 13835) Fix rendering of {{filepath:Wiki.png|nowiki}}
11285 * (bug 16772) Special:Upload now correctly rejects files with spaces in the
11286 file extension (e.g. Foo. jpg).
11287 * Image moving over an existing file no longer throws a database error
11288 * (bug 16786) Restored "redundant" links recently removed from Classic sidebar
11289 * (bug 16850) $wgActionPaths can have query strings now, previously, this broke
11290 local URLs
11291 * (bug 16376) Mention in deleteBatch.php and moveBatch.php maintenance scripts
11292 that STDIN can be used for page list
11293 * (bug 16560) Special:Random returns a page from ContentNamespaces, and no
11294 longer from NS_MAIN
11295
11296 === API changes in 1.14 ===
11297
11298 * Registration time of users registered before the DB field was created is now
11299 shown as empty instead of the current time.
11300 * API search now falls back to fulltext search by default when using Lucene
11301 or other engine which doesn't support a separate title search function.
11302 This means you can use API search on Wikipedia without explicitly adding
11303 &srwhat=text to the query.
11304 * Added iiprop=bitdepth to imageinfo and aiprop=bitdepth to allimages
11305 * (bug 14713) API-specific permissions (such as 'writeapi' and 'apihighlimits'
11306 are now listed on action=help
11307 * (bug 15044) Added requestid parameter to api.php to facilitate distinguishing
11308 between requests
11309 * (bug 15048) Added limit field for multivalue parameters to action=paraminfo
11310 output.
11311 * When the limit on multivalue parameters is exceeded, a warning is issued
11312 * list=search doesn't list missing pages any more
11313 * (bug 15178) Added clshow to prop=categories to allow filtering for hidden/
11314 non-hidden categories
11315 * (bug 15228) Combining revids= and redirects now throws a warning instead of
11316 an error, and still resolves redirects generated by the generator.
11317 * list={backlinks,embeddedin,imageusage} now return arrays with keys 0, 1, 2,
11318 etc. (AKA lists) instead of arrays with pageIDs as keys (AKA hash tables)
11319 for consistency with other list modules.
11320 * Added action=watch
11321 * (bug 15275) apprefix and related parameters ignore spaces at the end
11322 * action=edit no longer throws unknown error 228 when trying to create an
11323 empty section with section=new
11324 * Database replication lag doesn't cause all action=edit requests to return the
11325 nochange flag any more
11326 * (bug 15392) ApiFormatBase::formatHTML now uses $wgUrlProtocols.
11327 * (bug 15444) action=edit returns "Unknown error: ``AS_END''" where it should
11328 return just "Unknown error"
11329 * (bug 15448) YAML output returns empty values instead of 0
11330 * (bug 15445) Added action=patrol
11331 * (bug 15466) Added action=purge
11332 * (bug 15486) action=block ignores autoblock parameter
11333 * (bug 15492) added rcprop=loginfo to list=recentchanges
11334 * (bug 15527) action=rollback can now revert anonymous editors
11335 * (bug 15535) prop=info&inprop=protection doesn't list pre-1.10 protections
11336 if the page is also protected otherwise (1.10+ style or cascading)
11337 * list=random now has rnredirect parameter, to get random redirects.
11338 * Added APIAfterExecute, APIQueryAfterExecute and APIQueryGeneratorAfterExecute
11339 hooks which allow for extending core modules in a cleaner way
11340 * action=protect checks for invalid protection types and levels
11341 * (bug 15673) Added indentation to format=wddxfm output and improved built-in
11342 WDDX formatter to resemble PHP's more
11343 * (bug 15706) Empty values for apprtype and apprlevel are now silently ignored
11344 rather than causing an exception
11345 * Added uiprop=preferencestoken to meta=userinfo
11346 * (bug 15609) Add inprop=url and inprop=readable to prop=info
11347 * Add ApiDisabled and ApiQueryDisabled classes so individual modules can
11348 be disabled in LocalSettings.php
11349 * (bug 15653) Add prop=duplicatefiles
11350 * (bug 15768) Add list=watchlistraw
11351 * (bug 15647) action=edit with basetimestamp fails if the page has been deleted
11352 and undeleted since the last edit
11353 * (bug 15785) Allow for different expiry times for different protections in
11354 action=protect
11355 * Added allowsduplicates attribute to action=paraminfo output
11356 * (bug 15767) apfilterlanglinks returns duplicate results
11357 * (bug 15845) Added pageid/fromid parameter to action=delete/move, making
11358 manipulation of legacy pages with invalid titles possible
11359 * (bug 15881) Empty or invalid parameters cause database errors
11360 * The maxage and smaxage parameters are now properly validated
11361 * (bug 15945) list=recentchanges doesn't check $wgUseRCPatrol, $wgUseNPPatrol
11362 and patrolmarks right
11363 * (bug 15985) acfrom and aifrom parameters didn't work when sorting in
11364 descending order.
11365 * (bug 15995) Add cmstartsortkey and cmendsortkey parameters to
11366 list=categorymembers
11367 * (bug 16017) list=categorymembers sets invalid continue parameters for
11368 sortkeys containing pipes
11369 * (bug 16018) Added uccontinue parameter to list=usercontribs so paging
11370 works properly when multiple users are queried or a userprefix is used
11371 * (bug 16047) Added activeusers attribute to meta=siteinfo&siprop=statistics
11372 output
11373 * Added redirect resolution to action=parse
11374 * (bug 16074) rvprop=content combined with a generator with a high limit causes
11375 an error
11376 * (bug 16105) Image metadata attributes containing spaces result in invalid XML
11377 * (bug 16126) Added siprop=magicwords to meta=siteinfo
11378 * (bug 16159) Added wlshow=patrolled|!patrolled to list=watchlist
11379 * (bug 16225) Titles like Talk:Talk:Foo broke apfrom and friends
11380 * meta=siteinfo&siprop=interwikimap no longer throws an exception for empty
11381 sifilter parameter.
11382 * (bug 12760) meta=userinfo&uiprop=ratelimits doesn't list group-specific rate
11383 limits
11384 * (bug 16398) meta=userinfo&uiprop=rights lists some rights twice in some cases
11385 * (bug 16408) Added rvgeneratexml to prop=revisions
11386 * (bug 16421) Made list=logevents's leuser accept user names with underscores
11387 instead of spaces
11388 * (bug 16516) Made rvsection=T-2 work
11389 * (bug 16526) Added usprop=emailable to list=users
11390 * (bug 16548) list=search threw errors with an invalid error code
11391 * (bug 16515) Added pst and onlypst parameters to action=parse
11392 * (bug 16541) Added block expiry timestamp to list=logevents output
11393 * (bug 16613) action=protect doesn't tell when &cascade was set but cascading
11394 protection wasn't allowed
11395 * (bug 16626) action=delete now correctly handles empty "reason" param
11396 * (bug 15579) clshow considers all categories !hidden
11397 * (bug 16647) list=allcategories, prop=categories don't return "hidden"
11398 property for hidden categories
11399 * New siprop parameter of 'extensions' to list all installed extensions
11400 * (bug 16672) Include canonical namespace name in
11401 meta=siteinfo&siprop=namespaces.
11402 * (bug 16726) siprop=namespacealiases should also list localized aliases
11403 * (bug 16730) Added apprfiltercascade parameter to list=allpages to filter
11404 cascade-protected pages
11405
11406 === Languages updated in 1.14 ===
11407
11408 MediaWiki supports over 300 languages. Many localisations are updated
11409 regularly. Below only new and removed languages are listed.
11410
11411 * Bakhtiari (bqi) (new)
11412 * Fiji Hindi (Devanagari script) (hif-deva) (new)
11413 * Krio (kri) (new)
11414 * Lezghian (lez) (new)
11415 * Laz (lzz) (new)
11416 * Eastern Mari (mhr) (new)
11417 * Niuean (niu) (new)
11418 * Oromo (om) (new)
11419 * Plautdietsch (pdt) (new)
11420 * Western Punjabi (pnb) (new)
11421 * Tarantino (roa-tara) (new)
11422 * Serbo-Croatian (sh) (new)
11423 * Tulu (tcy) (new)
11424
11425
11426 == MediaWiki 1.13 ==
11427
11428 == MediaWiki 1.13.5 ==
11429
11430 February 22, 2009
11431
11432 This is a maintenance update to the Summer 2008 snapshot release of MediaWiki.
11433
11434 MediaWiki is now using a "continuous integration" development model with
11435 quarterly snapshot releases. The latest development code is always kept
11436 "ready to run", and in fact runs our own sites on Wikipedia.
11437
11438 Release branches will continue to receive security updates for about a year
11439 from first release, but nonessential bugfixes and feature developments
11440 will be made on the development trunk and appear in the next quarterly release.
11441
11442 Those wishing to use the latest code instead of a branch release can obtain
11443 it from source control: http://www.mediawiki.org/wiki/Download_from_SVN
11444
11445 == Changes since 1.13.4 ==
11446
11447 * (bug 17449) Fixed PostgreSQL installation
11448 * (bug 17527) Fixed missing MySQL-specific options in installer
11449
11450 == Changes since 1.13.3 ==
11451
11452 A number of cross-site scripting (XSS) security vulnerabilities were discovered
11453 in the web-based installer (config/index.php). These vulnerabilities all
11454 require a live installer -- once the installer has been used to install a wiki,
11455 it is deactivated.
11456
11457 Note that cross-site scripting vulnerabilities can be used to attack any website
11458 in the same cookie domain. So if you have an uninstalled copy of MediaWiki on
11459 the same site as an active web service, MediaWiki could be used to attack the
11460 active service.
11461
11462 If you are hosting an old copy of MediaWiki that you have never installed, you
11463 are advised to remove it from the web.
11464
11465 == Changes since 1.13.2 ==
11466
11467 David Remahl of Apple's Product Security team has identified a number of
11468 security issues in previous releases of MediaWiki. Subsequent analysis by the
11469 MediaWiki development team expanded the scope of these vulnerabilities. The
11470 issues with a significant impact are as follows:
11471
11472 * An XSS vulnerability affecting all MediaWiki installations between 1.13.0 and
11473 1.13.2. [CVE-2008-5249]
11474 * A local script injection vulnerability affecting Internet Explorer clients for
11475 all MediaWiki installations with uploads enabled. [CVE-2008-5250]
11476 * A local script injection vulnerability affecting clients with SVG scripting
11477 capability (such as Firefox 1.5+), for all MediaWiki installations with SVG
11478 uploads enabled. [CVE-2008-5250]
11479 * A CSRF vulnerability affecting the Special:Import feature, for all MediaWiki
11480 installations since the feature was introduced in 1.3.0. [CVE-2008-5252]
11481
11482 XSS (cross-site scripting) vulnerabilities allow an attacker to steal an
11483 authorised user's login session, and to act as that user on the wiki. The
11484 authorised user must visit a web page controlled by the attacker in order to
11485 activate the attack. Intranet wikis are vulnerable if the attacker can
11486 determine the intranet URL.
11487
11488 Local script injection vulnerabilities are like XSS vulnerabilities, except
11489 that the attacker must have an account on the local wiki, and there is no
11490 external site involved. The attacker uploads a script to the wiki, which another
11491 user is tricked into executing, with the effect that the attacker is able to act
11492 as the privileged user.
11493
11494 CSRF vulnerabilities allow an attacker to act as an authorised user on the wiki,
11495 but unlike an XSS vulnerability, the attacker can only act as the user in a
11496 specific and restricted way. The present CSRF vulnerability allows pages to be
11497 edited, with forged revision histories. Like an XSS vulnerability, the
11498 authorised user must visit the malicious web page to activate the attack.
11499
11500 These four vulnerabilities are all fixed in this release.
11501
11502 David Remahl also reminded us of some security-related configuration issues:
11503
11504 * By default, MediaWiki stores a backup of deleted images in the images/deleted
11505 directory. If you do not want these images to be publically accessible, make
11506 sure this directory is not accessible from the web. MediaWiki takes some steps
11507 to avoid leaking these images, but these measures are not perfect.
11508 * Set display_errors=off in your php.ini to avoid path disclosure via PHP fatal
11509 errors. This is the default on most shared web hosts.
11510 * Enabling MediaWiki's debugging features, such as $wgShowExceptionDetails, may
11511 lead to path disclosure.
11512
11513 Other changes in this release:
11514
11515 * Avoid fatal error in profileinfo.php when not configured.
11516 * Add a .htaccess to deleted images directory for additional protection against
11517 exposure of deleted files with known SHA-1 hashes on default installations.
11518 * Avoid streaming uploaded files to the user via index.php. This allows
11519 security-conscious users to serve uploaded files via a different domain, and
11520 thus client-side scripts executed from that domain cannot access the login
11521 cookies. Affects Special:Undelete, img_auth.php and thumb.php.
11522 * When streaming files via index.php, use the MIME type detected from the
11523 file extension, not from the data. This reduces the XSS attack surface.
11524 * Blacklist redirects via Special:Filepath. Such redirects exacerbate any
11525 XSS vulnerabilities involving uploads of files containing scripts.
11526 * Internationalisation updates.
11527
11528 == Changes since 1.13.1 ==
11529
11530 * Security: Work around misconfiguration by requiring strict comparisons for
11531 in_array in User::isAllowed().
11532 * (bug 14944) Added $wgShellLocale for configuration of an appropriate locale
11533 to use for LC_CTYPE during shell invocation. For servers that don't have
11534 en_US.utf8. Also added locale detection during install.
11535 * Localisation updates
11536 * Security: Fixed XSS vulnerability in useskin parameter.
11537
11538 == Changes since 1.13.0 ==
11539
11540 * (bug 15460) Fixed intermittent deadlock errors and poor concurrent
11541 performance for installations without memcached.
11542 * (bug 13770) Fixed DOM module detection for installations with both dom
11543 and domxml.
11544 * (bug 15148) Fixed Special:BlockIP for PostgreSQL
11545 * Fixed SQLite support for non-memcached installations
11546 * Localisation updates, Achinese (ace) added.
11547
11548 == Changes since 1.13.0rc2 ==
11549
11550 * (bug 13770) Fixed incorrect detection of PHP's DOM module
11551 * Fix regression from r37834: accesskey tooltip hint should be given for the
11552 minor edit and watch labels on the edit page.
11553 * Updated Chinese simplified/traditional conversion tables
11554
11555 == Changes since 1.13.0rc1 ==
11556
11557 * $wgForwardSearchUrl has been removed entirely. Documented setting since 1.4
11558 has been $wgSearchForwardUrl.
11559 * (bug 14907) DatabasePostgres::fieldType now defined.
11560 * (bug 14966) Fix SearchEngineDummy class for silently non-functional search
11561 on Sqlite instead of horribly fatal error breaky one.
11562 * (bug 14987) Only fix double redirects on page move when the checkbox is
11563 checked
11564 * (bug 13376) Use $wgPasswordSender, not $wgEmergencyContact, as return
11565 address for page update notification mails.
11566 * API: Registration time of users registered before the DB field was created is now
11567 shown as empty instead of the current time.
11568 * (bug 14904): fragments were lost when redirects were fixed.
11569 * Added magic word __STATICREDIRECT__ to suppress the redirect fixer
11570 * (bug 15035) Revert English linkTrail to /^([a-z]+)(.*)$/sD, as it was before
11571 r36253. Multiple reports of breakage due to old (pre-5.0) PCRE libraries,
11572 both bundled with PHP and packaged with distros such as RHEL.
11573 * (bug 14944) Shell invocation of external programs such as ImageMagick convert
11574 was broken in PHP 5.2.6, if the server had a non-UTF-8 locale.
11575
11576
11577 === Configuration changes in 1.13 ===
11578
11579 * New option $wgFeed can be set false to turn off syndication feeds
11580 * (bug 5745) Special:Whatlinkshere now shows up to $wgMaxRedirectLinksRetrieved
11581 links through each redirect instead of hardcoded 500
11582 * Set $wgUploadSizeWarning to false by default
11583 * Added $wgLBFactoryConf, for generic configuration of multi-master wiki farms
11584 * Removed $wgAlternateMaster, use $wgLBFactoryConf
11585 * (bug 13562) Misspelled option $wgUserNotifedOnAllChanges changed to
11586 $wgUserNotifiedOnAllChanges
11587 * (bug 12860) New option $wgSitemapNamespaces allows sitemaps to be generated
11588 for only some namespaces
11589 * Removed the emailconfirmed implicit group by default. To re-add it, use:
11590 $wgAutopromote['emailconfirmed'] = APCOND_EMAILCONFIRMED;
11591 in your LocalSettings.php.
11592 * (bug 2396) New shared database configuration variables. $wgSharedPrefix allows
11593 you to use a shared database with a different prefix. Or you can now use a local
11594 database and use prefixes to separate wiki and the shared tables. And the new
11595 $wgSharedTables variable allows you to specify a list of tables to share.
11596 * Automatic edit summaries can be disabled with $wgUseAutomaticEditSummaries
11597 * Duplicates of images are now shown on the image page
11598 * $wgRCFilterByAge allows for the list of dates in recent changes special pages to
11599 be filtered to only those within the range of $wgRCMaxAge
11600 * $wgRCLinkLimits and $wgRCLinkDays allow for customization of the list and limits
11601 displayed on the recent changes special pages
11602 * The "createpage" permission is no longer required when uploading if the target
11603 image page already exists
11604 * $wgMaximumMovedPages restricts the number of pages that can be moved at once
11605 (default 100) with the new subpage-move functionality of Special:Movepage
11606 * Hooks display in Special:Version is now disabled by default, use
11607 $wgSpecialVersionShowHooks = true; to enable it.
11608 * $wgActiveUserEditCount sets the number of edits that must be performed over
11609 a certain number of days to be considered active
11610 * $wgActiveUserDays is that number of days
11611 * $wgRateLimitsExcludedGroups has been deprecated in favor of
11612 $wgGroupPermissions[]['noratelimit']. The former still works, however.
11613 * New $wgGroupPermissions option 'move-subpages' added to control bulk-moving
11614 subpages along with pages. Assigned to 'user' and 'sysop' by default.
11615 * New $wgRC2UDPOmitBots allows user to omit bot edits from UDP output.
11616 Default: false
11617 * Removed $wgEnableCascadingProtection option. Disabling cascading protection
11618 is no longer possible.
11619 * $wgMessageCacheType defines now the type of cache used by the MessageCache class,
11620 previously it was choosen based on $wgParserCacheType
11621 * $wgExtensionAliasesFiles option to simplify adding aliases to special pages
11622 provided by extensions, in a similar way to $wgExtensionMessagesFiles
11623 * Added $wgXMLMimeTypes, an array of XML mimetypes we can check for
11624 with MimeMagic.
11625 * Added $wgDirectoryMode, which allows for setting the default CHMOD value when
11626 creating new directories.
11627 * (bug 14843) $wgCookiePrefix can be set by LocalSettings now, false defaults
11628 current behavior.
11629
11630 === New features in 1.13 ===
11631
11632 * __HIDDENCAT__ on a category page causes the category to be hidden on the
11633 article page
11634 * Do not show edit permissions errors on a red link click, just redirect to the
11635 article. This is so that readers who don't know what a red link is are not
11636 confused when they are told they are range-blocked.
11637 * Add a new hook ImageBeforeProduceHTML to allow extensions to modify wikitext
11638 image syntax output
11639 * (bug 13100) Added 'preloadtitle' parameter to action=edit&section=new that
11640 pre-fills the section title field
11641 * (bug 13112) Added Special:RelatedChanges alias to Special:RecentChangesLinked
11642 * (bug 13130) Moved edit token and autosummary fields above edit tools to
11643 reduce broken form submissions
11644 * Add --old-redirects-only option to maintenance/refreshLinks.php, to add old
11645 redirects to the redirect table
11646 * Add links to page and file deletion forms to edit predefined delete reasons
11647 * (bug 13269) Added MediaWiki:Uploadfooter to the bottom of Special:Upload
11648 * (bug 2815) Search results for media now use thumbnail instead of text extract
11649 * When a page doesn't exist, the tab should say "create", not "edit"
11650 * (bug 12882) Added a span with class "patrollink" around "Mark as patrolled"
11651 link on diffs
11652 * Magic word formatnum can now take raw suffix to undo formatting
11653 * Add updatelog table to reliably permit updates that don't change the schema
11654 * Add category table to allow better tracking of category membership counts
11655 ** (bug 1212) Give correct membership counts on the pages of large categories
11656 ** Use category table for more efficient display of Special:Categories
11657 * (bug 1459) Search for duplicate files by hash: Special:FileDuplicateSearch
11658 * (bug 9447) Added hooks for search result headings
11659 * Image redirects are now enabled by default
11660 * (bug 13450) Email confirmation can now be canceled before the expiration
11661 * (bug 13490) Show upload/file size limit on upload form
11662 * Redesign of Special:UserRights
11663 * Make rev_deleted log entries more intelligible
11664 * (bug 6943) Added PAGESINCATEGORY: magic word
11665 * (bug 13604) Added Special:ListGroupRights
11666 * (bug 6332, 8617) Added message 'mainpage-description' as duplicate of
11667 'mainpage' and added it to message 'sidebar'
11668 * Automatically add old redirects to the redirect table when needed
11669 * (bug 6934) Allow inclusions, links, redirects to be separately toggled on or
11670 off on Special:WhatLinksHere
11671 * Cache image redirects
11672 * (bug 10457) Organize Special:SpecialPages into sections
11673 * Add a new hook EditPageBeforeConflictDiff to allow extensions like FCKeditor
11674 to modify the output for edit conflicts
11675 * Add class="nested" for <fieldset>s so fieldsets inside fieldsets get
11676 a slightly less huge margin and padding
11677 * (bug 13527) Use sitemaps.org format 0.9 instead of a Google-specific format
11678 * Allow \C and \Q as TeX commands to match \R, \N, \Z
11679 * On Special:UserRights, when you can add a group you can't remove or remove
11680 one you can't add, a notice is printed to warn you
11681 * (bug 12698) Create PAGESIZE parser function, to return the size of a page
11682 * Allow the "log in / create account" link in the toolbar to have different
11683 text from Special:UserLogin title (new message 'nav-login-createaccount')
11684 * Say "log in / create account" if an anonymous user can create an account,
11685 otherwise just "log in", consistently across skins
11686 * Special:Shortpages and Special:Longpages now returns pages in all content
11687 namespaces, not just NS_MAIN.
11688 * (bug 889) Improve conflict-handling between shared upload repository
11689 and local one
11690 * Update documentation links in auto-generated LocalSettings.php
11691 * (bug 13584) The new hook SkinTemplateToolboxEnd was added.
11692 * (bug 709) Cannot rename/move images and other media files [EXPERIMENTAL]
11693 * Custom rollback summaries now accept the same arguments as the default message
11694 * (bug 12542) Added hooks for expansion of Special:Listusers
11695 * Drop-down AJAX search suggestions (turn on $wgEnableMWSuggest)
11696 * More relevant search snippets (turn on $wgAdvancedSearchHighlighting)
11697 * (bug 13950) Allow users to watch the user/talk pages of users they block.
11698 * (bug 13970) Allow MonoBook-based skins to specify their own print stylesheet
11699 * Show image links on Special:Whatlinkshere
11700 * Use rel="start", "prev", "next" appropriately on Pager-based pages
11701 * Add support for SQLite
11702 * AutoAuthenticate hook renamed to UserLoadFromSession
11703 * (bug 13232) importScript(), importStylesheet() funcs available to custom JS
11704 * (bug 13095) Search by first letters or digits in [[Special:Categories]]
11705 * Users moving a page can now move all subpages automatically as well
11706 * (bug 14259) Localisation message for upload button on Special:Import is now
11707 'import-upload' instead of 'upload'
11708 * Add information about user group membership to Special:Preferences
11709 * (bug 14146) Wrap usage section on imagepages into <div>s.
11710 * New layout for Special:Specialpages. Restricted pages are marked but not separated
11711 from other pages in their group.
11712 * (bug 14263) Show a diff of the revert on rollback notification page.
11713 * (bug 13434) Show a warning when hash identical files exist
11714 * Sidebar is now cached for all languages
11715 * The User class now contains a public function called isActiveEditor. Figures
11716 out if a user is active based on at least $wgActiveUserEditCount number of
11717 edits in the last $wgActiveUserDays days.
11718 * SpecialSearchResults hook now passes results by reference, so they can be
11719 changed by extensions.
11720 * Add a new hook LinkerMakeExternalLink to allow extensions to modify the output of
11721 external links.
11722 * (bug 14132) Allow user to disable bot edits from being output to UDP.
11723 * (bug 14328) jsMsg() within Wikibits now accepts a DOM object, not just a string
11724 * (bug 14558) New system message (emailuserfooter) is now added to the footer of
11725 e-mails sent with Special:Emailuser
11726 * Add support for Hijri (Islamic) calendar
11727 * Add a new hook LinkerMakeExternalImage to allow extensions to modify the output
11728 of external (hotlinked) images.
11729 * (bug 14604) Introduced the following features for the LanguageConverter:
11730 Multi-tag support, single conversion flag, remove conversion flag on a single
11731 page, description flag, variant name, multi-variant fallbacks.
11732 * Add zh-mo and zh-my variants for the zh language
11733 * (bugs 4832, 9481, 12890) Special:Recentchangeslinked now has all options that
11734 are in Special:Recentchanges
11735 * Allow an $error message to be passed to ArticleDelete hook
11736 * Allow extensions to modify the user creation form by calling addInputItem();
11737 * Add meta generator tag to HTML output
11738 * MediawikiPerformAction hook is now passed the Mediawiki object
11739 * Added blank special page Special:BlankPage for benchmarking, etc.
11740 * Foreign repo file descriptions and thumbnails are now cached.
11741 * (bug 11732) Allow localisation of edit button images
11742 * Allow the search box, toolbox and languages box in the Monobook sidebar to be
11743 moved around arbitrarily using special sections in [[MediaWiki:Sidebar]]:
11744 SEARCH, TOOLBOX and LANGUAGES
11745 * Add a new hook NormalizeMessageKey to allow extensions to replace messages before
11746 the database is potentially queried
11747 * (bug 9736) Redirects on Special:Fewestrevisions are now marked as such.
11748 * New date/time formats in Cs localization according to ČSN and PČP.
11749 * Special:Recentchangeslinked now includes changes to transcluded pages and
11750 displayed images; also, the "Show changes to pages linked" checkbox now works on
11751 category pages too, showing all links that are not categorizations
11752 * (bug 4578) Automatically fix redirects broken by a page move
11753
11754 === Bug fixes in 1.13 ===
11755
11756 * (bug 10677) Add link to the file description page on the shared repository
11757 * (bug 13084) Increase size of source/destination filename fields in upload form
11758 * (bug 13115) rebuildrecentchanges should print the current value of $wgRCMaxAge
11759 * (bug 13140) Show parent categories in category namespace
11760 * (bug 13149) Correctly format 'fileexists' message on Upload page
11761 * Make the default filepageexists message accurate
11762 * (bug 12988) $wgMinimalPasswordLength no longer breaks create user by email
11763 * (bug 13022) Fix upload from URL on PHP 5.0.x
11764 * (bug 13132) Unable to unprotect pages protected with earlier versions of MediaWiki
11765 * (bug 12723) OpenSearch description name now uses more compact language code
11766 to avoid passing the length limit as often, is customizable per site via
11767 'opensearch-desc' message.
11768 * (bug 13135) Special:Userrights now passes IDs through form submission
11769 to allow functionality on not-quite-right usernames
11770 * (bug 12575) Prevent duplicate patrol log entries from being created
11771 * (bug 13174) __HIDDENCAT__ now applies only to category pages
11772 * (bug 13031) Add links to user pages in e-mail form
11773 * (bug 13147) Description for categoriespagetext (used in Special:Categories) reworded
11774 * (bug 11561) Fix fatal error when calling action=revert to non-image page
11775 * (bug 12430) Fix call to private method LinkFilter::makeRegex fatal error in
11776 maintenance/cleanupSpam.php
11777 * All skins should have the "mediawiki" class on the body element
11778 * (bug 13019) Message cache for some extensions not loaded at time of editing
11779 * (bug 13247) Prettified ISBN links
11780 * maintenance/refreshLinks.php did not fix page_id 1 with the --new-only option
11781 * (bug 13110) Don't show "Permission error" page if the edit is already rolled
11782 back when using rollback
11783 * (bug 13012) Use content messages for block options when generating the
11784 recentchanges entry
11785 * (bug 13274) Change links for messages to ucfirst
11786 * (bug 13273) Un-hardcode some punctuation (add new messages colon-separator,
11787 autocomment-prefix)
11788 * Parse MediaWiki message translations with a correct language setting on preview
11789 * (bug 13281) Treat X-Forwarded-For, Client-ip and User-Agent headers as
11790 case-insensitive names.
11791 * Adding the fix for lists in RTL wikis to more skins, and fixing the image toc
11792 * (bug 8157) Remove redirects from Special:Unusedtemplates. Patch by WebBoy.
11793 * (bug 10721) Duplicate section anchors with differing case now disambiguated
11794 for Internet Explorer's sake and standards compliance
11795 * (bug 13298) Tighter limits on Special:Newpages limits when embedding
11796 * Email subject in content language instead of sending user's UI language
11797 * (bug 13251) Allow maintenance rebuild scripts to work with Postgres
11798 * (bug 2084) Fixed incorrect regex to match redirects
11799 * (bug 3131) Manually-specified upload destination filename is no longer
11800 overwritten by browsing for a file after you wrote it.
11801 * (bug 7251) Sidebars generated by MediaWiki:Sidebar now have the class
11802 'generated-sidebar'.
11803 * (bug 13265) Media handler is missing 'image/x-bmp'
11804 * (bug 13407) MediaWiki:Powersearch is used in two places
11805 * (bug 13403) Fix cache invalidation of history pages when old revisions change
11806 * (bug 11563) Deprecated SearchMySQL4 class; merged code to SearchMySQL
11807 * (bug 12801) Fix link in subtitle message in AJAX search
11808 * (bug 13428) Fix regression in protection form layout HTML validity
11809 * (bug 9403) Sanitize newlines from search term input
11810 * (bug 13429) Separate date and time in message sp-newimages-showfrom
11811 * (bug 13137) Allow setting 'editprotected' right separately from 'protect',
11812 so groups may optionally edit protected pages without having 'protect' perms
11813 * Disallow deletion of big pages by means of moving a page to its title and
11814 using the "delete and move" option.
11815 * (bug 13466, 13632) White space differences not shown in diffs
11816 * (bug 1953) Search form now honors namespace selections more reliably
11817 * (bug 12294) Namespace class renamed to MWNamespace for PHP 5.3 compatibility
11818 * PHP 5.3 compatibility fix for wfRunHooks() called with no parameters
11819 * (bug 6447) Trackbacks now work with transactional tables, if enabled
11820 * (bug 6892, 7147) Trackback error handling, optional fields more robust
11821 * (bug 6813) Don't break HTML validator when using trackbacks
11822 * Fix for size checks on SVG images with global 'stroke-width' attribute
11823 * (bug 11874) Inline CSS with !important no longer borken
11824 * (bug 1600) Strip extra == section markup == in new-comment field
11825 * (bug 11325) Wrapped page titles in MonoBook skin spaced more nicely
11826 * (bug 12077) Fix HTML nesting for TOC
11827 * (bug 344) Purge cache for talk/article pages when deleting the other tab
11828 * (bug 13436) Treat image captions correctly when they include option keywords
11829 (like ending with "px" or starting with "upright")
11830 * Trackback display formatting fixed
11831 * Don't die when single-element arrays are passed to SQL query constructors
11832 that have an array index other than 0
11833 * (bug 13522) Fix fatal error in Parser::extractTagsAndParams
11834 * (bug 13532) Use proper timestamp call when reverting images
11835 * (bug 13543) Updated FAQ link in the installer sidebar
11836 * (bug 13540) Date format in confirmation e-mail now matches message language
11837 * (bug 13554) PHP Notice in old pre-processor when list item is empty.
11838 * (bug 13556) Don't show a blank form if no image is attached in Special:Upload
11839 * (bug 13576) maintenance/rebuildrecentchanges.php fails
11840 * (bug 13441) Allow Special:Recentchanges to show bots only
11841 * (bug 13431) Show true message source in Special:Allmessages&ot=php / xml
11842 * (bug 13463) Login successful page doesn't use user's preferred interface language
11843 * (bug 13630) Fixed warnings for pass by reference at call time in
11844 Special:Revisiondelete when generating the log entry.
11845 * (bug 12064) BeforePageDisplay hook is now called for all skins
11846 * (bug 13624) Fix regression with manual thumb= parameter on images
11847 * (bug 11039) Add missing labels on protection form
11848 * (bug 13458) Preview/edit toolbar spacing now works consistently
11849 * (bug 13433) Fix action=render on Image: pages
11850 * (bug 13678) Fix CSS validation for Monobook
11851 * (bug 13684) Links in Special:ListGroupRights should be in content language
11852 * (bug 13690) Fix PHP notice on accessing some URLs
11853 * Hide (undo) link if user isn't able to edit page
11854 * Invalidate cache of pages that includes images via redirects on upload
11855 * (bug 13705) Don't show rollback link in page history on incorrect revisions
11856 * (bug 13708) Don't set "Search results" title when loading Special:Search
11857 without query
11858 * (bug 13736) Don't show MediaWiki:Anontalkpagetext on non-existent IP addresses
11859 * (bug 13728) Don't trim initial whitespace during section edits
11860 * (bug 13727) Don't delete log entries from recentchanges on page deletion
11861 * (bug 13752) Redirects to sections now work again
11862 * (bug 13725) Upload form watch checkbox state set correctly with wpDestFile
11863 * (bug 13756) Don't show the form and navigation links of Special:Newpages if
11864 the page is included
11865 * When hiding things on WhatLinksHere, generated URLs should hide them too
11866 * Properly escape search terms with regex chars so they appear highlighted in
11867 search results
11868 * (bug 13768) pt_title field encoding fixed
11869 * Do not display empty columns on Special:UserRights if all groups are
11870 changeable or all unchangeable
11871 * Fix fatal error on calling PAGESINCATEGORY with invalid category name
11872 * (bug 13793) Special:Whatlinkshere filters wrong - after paginating instead of before
11873 * (bug 13796) Show links to parent pages even if some of them are missing
11874 * (bug 13816) Filter by main namespace doesn't work on WhatLinksHere
11875 * (bug 13822) Fatal error on some pages when calculating subpage subtitle
11876 * (bug 13824) AJAX search suggestion now works with non-SkinTemplate skins
11877 * Added 'application/x-dia-diagram' MediaWiki's known MIME types
11878 * (bug 13866) skins/common/shared.css - invalid attribute fixing
11879 * Hide edit section links on Special:Undelete
11880 * (bug 13860) Fix "Justify paragraphs" option for Modern skin
11881 * (bug 13168) accessibility links in Modern skin link to wrong anchor id
11882 * (bug 13185) No line break after 'subpages' class in Modern skin
11883 * (bug 13583) No "poweredby" in Modern skin
11884 * (bug 13880) "Printable" link in Modern skin now formats as print mode
11885 * (bug 13885) Bump default $wgSVGMaxSize from 1024 to 2048 pixels
11886 * (bug 13891) Show categories box even if all categories are hidden and user has
11887 "show hidden categories" option on
11888 * (bug 13915) Undefined variable $wltsfield in includes/SpecialWatchlist.php
11889 * (bug 13913) Special:Whatlinkshere now has correct HTML markup
11890 * (bug 13905) Blacklist Mac IE from HttpOnly cookies; it eats them sometimes
11891 * (bug 13922) Fix bad HTML on empty Special:Prefixindex and Special:Allpages
11892 * (bug 13924) Fix bad HTML on power search form
11893 * (bug 13820) Fix updater for rev_parent_id population
11894 * (bug 13925) Fix bad HTML on search results list
11895 * (bug 13934) Fixing the link to GNU General Public License Version 2
11896 * Show correct accesskey prefix for Firefox 3 beta (Alt-Shift-, not Alt-)
11897 * (bug 13949) Special:PrefixIndex/AllPages paging links contain invalid XML
11898 * (bug 13770) Use Preprocessor_Hash by default to avoid missing DOM module errors
11899 * (bug 13982) Disable ccmeonemails preference when user-to-user mails disabled
11900 * (bug 13615) Update case mappings and normalization to Unicode 5.1.0
11901 Note that case mappings will only be used if mbstring extension is not present.
11902 * (bug 14044) Don't increment page view counters on views from bot users
11903 * (bug 14042) Calling Database::limitResult() misplaced the comment in the log file
11904 * (bug 14047) Fix regression in installer which hid DB-specific options
11905 Also makes SQLite path configurable in the installer.
11906 * (bug 13546) Follow image redirects on image page
11907 * (bug 12644) Template list on edit page now sorted on preview
11908 * (bug 14058) Support pipe trick for namespaces and interwikis with "-"
11909 * Message name filter on Special:Allmessages now case-insensitive
11910 * (bug 13943) Fix image redirect behavior on image pages
11911 * (bug 14093) Do 'sysop' => 'protect' magic in Title::isValidMoveOperation
11912 * (bug 14063) Power search form missing <label> for redirects check
11913 * (bug 14111) Similar filename warning links now lead to correct page
11914 * (bug 14082) Fix for complex text input vs AJAX suggestions on some browsers
11915 * (bug 13693) Categories sometimes claim to have a negative number of members
11916 * (bug 1701) Korean Hangul syllables now broken down properly in Category lists
11917 even if the wiki's overall content language is not Korean
11918 * (bug 12773) addOnloadHook() now calls functions immediately when scripts are
11919 loaded after the primary page completion, instead of dropping them
11920 * (bug 14199) Fix deletion form for image redirect pages
11921 * (bug 14220) Disabling $wgCheckFileExtensions now works without also
11922 disabling $wgStrictFileExtensions
11923 * (bug 14241) Pages can no longer be protected to levels you are not in
11924 * (bug 14296) Fix local name of ang: (Anglo-Saxon)
11925 * (bug 4871) Hardcoded superscript in time zone preferences moved to message
11926 * (bug 6957) E-mail confirmation links now using English special page name
11927 for better compatibility and keeping the links shorter. Avoids problem
11928 with corrupt links in Gmail on IE 6.
11929 * (bug 14273) Fix for HTTP Accept header parsing with spaces as from Konqueror
11930 * (bug 14312) Update LanguageKaa.php for handling transform issues with i to İ
11931 and I to ı
11932 * (bug 13826) MediaWiki:Defaultns accepts Wikicode
11933 * (bug 14324) Creating an account is again possible with $wgEmailConfirmToEdit
11934 set to true
11935 * (bug 13034) Interwiki pages can now be reached using Go search button
11936 * (bug 14362) Change interwiki names of Erzya and Moksha Wikipedias
11937 * (bug 14370) When a grouppage-x message does not exist the entry on the
11938 ListGroupRights special page now links to the project namespace page for it,
11939 not the main namespace page.
11940 * (bug 11659) Urldecode image names in galleries
11941 * (bug 14258, 14368) Fix for subpage renames in replication environments
11942 * (bug 14367) Failed block no longer adds phantom watchlist entry
11943 * (bug 14385) "Move subpages" option no longer tries to move to invalid titles
11944 * (bug 14386) Fix subpage namespace oddity when moving a talk page
11945 * (bug 11771) Signup form now not shown if in read-only mode.
11946 * (bug 12859) $wgRateLimitsExcludedGroups has been deprecated in favor of
11947 $wgGroupPermissions[]['noratelimit'].
11948 * (Bug 13828) Split parameter $1 of MediaWiki:Missingarticle into $1 (=title)
11949 and $2 (=revision numbers)
11950 * (bug 14401) Fix Safari access key tooltips for Windows and >3.1 Mac versions
11951 * (bug 14432) Fix notice regression in Special:Newpages feed mode
11952 * (bug 11951) EditPage::getEditToolbar() is now static.
11953 * (bug 14392) Fix regression breaking table prefix in installer
11954 * (bug 11084) $wgDBprefix replacement for updater SQL will now work for
11955 extension tables using uppercase letters or digits in their names.
11956 * (bug 12311) Fix regression with lists at start of undeletion preview
11957 * (bug 14496) Fix regression with parseinline on Special:Upload.
11958 * We no longer just give up on a missing upload base directory; it's now
11959 created automatically if we have sufficient permissions!
11960 * (bug 14479) MediaWiki:upload-maxfilesize should have a div id wrapper
11961 * (bug 14497) Throw visible errors in installer scripts when SQL files
11962 fail due to database permission or other error
11963 * (bug 14500) Site feed (Recentchanges) no longer shows up on the actual
11964 recent changes page.
11965 * (bug 14511) MediaWiki:Delete-legend is no longer double escaped
11966 * Generate correct section anchors for numeric headers
11967 * (bug 14520) Don't load nonexistent CSS files for Chick/Myskin/Simple skins
11968 * (bug 14551) Cancel upload no longer automatically suppresses warnings
11969 * (bug 13878) Deprecate Article::getDB() in favor of direct wfGetDB() calls
11970 * (bug 4977) Fix for possible squid purging errors when using HTTP purges
11971 and multiple servers
11972 * (bug 14572) Redirects listed on file links on image pages no longer redirect.
11973 * (bug 14537) Change interwiki name for Old Church Slavonic (cu)
11974 * (bug 14583) Fix regression in recent changes "limit to certain categories."
11975 * (bug 14515) HTML nesting cleanup on edit form
11976 * (bug 14647) Removed unused 'townBox' CSS classes
11977 * (bug 14687) OutputPage::addStyle() now adds type="text/css" like it should.
11978 * OpenSearch cleanup; Firefox now sends you to the search page for empty
11979 searches instead of the domain root (which may not even be a wiki).
11980 * (bug 3481) Pages moved shortly after creation are shown at their new title
11981 on Special:Newpages.
11982 * (bug 12716) Trying to unprotect a title that isn't protected no longer
11983 generates a log entry.
11984 * (bug 14088) Excessively long block expiry times are rejected as invalid,
11985 keeps the log page from being distorted.
11986 * (bug 14708) Emulate INSERT...IGNORE with standard SQL for Postgres backend.
11987 * (bug 14646) Fix some double-escaping of HTML in feed output
11988 * (bug 14709) Fix login success message formatting when using cookie check
11989 * (bug 14710) Remove "donate" link from default sidebar
11990 * (bug 14745) Image moving works on sites that transform thumbnails via 404
11991 * (bug 2186) Document.write() in wikibits caused failures when using
11992 application/xhtml+xml. The calls to this have been removed.
11993 * (bug 14764) Fix regression in from Article::lastModified(), failed to work
11994 on non-mySQL schemas.
11995 * (bug 14763) Child classes of Database (DatabasePostgres and DatabaseOracle)
11996 had strict standards issues with setFakeSlaveLag() and setFakeMaster().
11997 * (bug 451) Improve the phrase mappings of the Chinese converter arrays.
11998 * (bug 12487) Rights log is not fully internationalized
11999 * (bug 10837) Language variants no longer override other languages than base
12000 * (bug 14778) 'limit' parameter now applies to history feeds as well as
12001 history pages
12002 * (bug 14845) Bug in prefs javascript: Calling an array item without checking
12003 its existance.
12004 * Accesskeys for minor edit/watch checkboxes on edit now work in Firefox 3
12005 * (bug 12384) Comments in maintenance/*php
12006 * (bug 12441) ./maintenance/generateSitemap.php fix -fspath requiring
12007 a trailing slash.
12008 * (bug 12568) configuration script now produce valid XHTML.
12009 * The accesskey to edit a page is now disabled when editing the page, to pre-
12010 vent conflicts with Safari shortcuts.
12011
12012 === API changes in 1.13 ===
12013
12014 * Fixing main page display in meta=siteinfo
12015 * (bug 13128) Added patrolled flag to list=recentchanges
12016 * Implemented {bl,ei,iu}redirect (lists links through redirects as well)
12017 * (bug 13154) Introduced subpages flag to meta=siteinfo&siprop=namespaces
12018 * (bug 13157) Added ucuserprefix parameter to list=usercontribs
12019 * (bug 12394) Added rctitles parameter to list=recentchanges, making rcid
12020 retrieval easier
12021 * (bug 13218) Fix inclusion of " character in hyperlinks
12022 * Added watch and unwatch parameters to action=delete and action=move
12023 * Added action=edit
12024 * (bug 11401) Added xmldoublequote to xml formatter
12025 * Added rvsection parameter to prop=revisions to allow fetching the content of
12026 a certain section only
12027 * Introduced list=allimages
12028 * (bug 13371) Build page set from image hashes
12029 * Mark non-existent messages in meta=allmessages as missing
12030 * (bug 13390) One invalid title no longer kills an entire API query
12031 * (bug 13419) Fix gblredirect so it actually works
12032 * (bug 13418) Disable eiredirect because it's useless
12033 * (bug 13395) list=allcategories should use category table
12034 * (bug 13442) Missing pages in prop=langlinks and prop=extlinks are now
12035 handled properly.
12036 * (bug 13444) Add description to list=watchlist
12037 * (bug 13482) Disabled search types handled properly
12038 * Added inprop=talkid,subjectid to prop=info
12039 * Added help text message that specifies whether a module is POST-only
12040 * Added createonly parameter to action=edit
12041 * Replaced $wgAPIUCUserPrefixMinLength by the more generic $wgAPIMaxDBRows
12042 * (bug 11719) Remove trailing blanks in YAML output.
12043 * (bug 13541) Added siprop=specialpagealiases to meta=siteinfo
12044 * Added fallback8bitEncoding and readonly fields to
12045 meta=siteinfo&siprop=general output
12046 * (bug 13544) Added prop=revid to action=parse
12047 * (bug 13603) Added siprop=usergroups to meta=siteinfo
12048 * Cleaned up redirect resolution
12049 * Added possibility to obtain all external links through list=exturlusage
12050 * (bug 13606) Added archivename to iiprop
12051 * (bug 11633) Explicitly convert redirect titles to strings due to PHP's
12052 very weak typing on array keys.
12053 * (bug 12136) Extend allowed characters in JSON callback to ][.'"_A-Za-z0-9
12054 * (bug 11673) Return error 'unknown_action' in specified format
12055 * (bug 13618) Added rcprop=redirect and rcshow=redirect to list=recentchanges
12056 * (bug 13544) Added oldid parameter to action=parse to allow for parsing of old
12057 revisions
12058 * (bug 13718) Return the proper continue parameter for cmsort=timestamp
12059 * action=login now returns the correct waiting time in the details property
12060 * (bug 13792) Broken titles are now silently skipped in search results.
12061 * (bug 13819) exturlusage paging skipped an item
12062 * Fixed handling of usernames containing spaces in list=block
12063 * (bug 13836) Fixed fatal errors resulting from combining iiprop=metadata with
12064 format=xml
12065 * (bug 13735) Added prop=categoryinfo module
12066 * (bug 13945) Retrieve cascading protection sources via inprop=protection
12067 * (bug 13965) Hardcoded 51 limit on titles is too limiting
12068 * (bug 13993) apfrom doesn't work with apdir=descending
12069 * (bug 14018) Introduced alcontinue to list=alllinks to improve paging
12070 * (bug 14013) Added rcshow=patrolled to list=recentchanges
12071 * (bug 14028) Added language attribute to interwiki map in meta=siteinfo
12072 * (bug 14022) Added usprop=registration and auprop=blockinfo
12073 * (bug 14021) Removed titles= support from list=backlinks (has been obsolete
12074 for ages)
12075 * (bug 13829) Expose parse tree via action=expandtemplates
12076 * (bug 13606) Allow deletion of images
12077 * Added iiprop=mime and aiprop=metadata
12078 * Handled unrecognized values for parameters more gracefully
12079 * Handled requesting disallowed tokens more gracefully
12080 * (bug 14140) URL-encoded page titles are now decoded in edit summaries
12081 * (bug 14243) Only accept post requests in action=edit; patch by HardDisk
12082 * action=block now returns an ISO8601 timestamp, like all other modules do
12083 * Added md5 parameter to action=edit
12084 * (bug 14335) Logging in to unified account using API not possible
12085 * Added action=emailuser to send an email to a user
12086 * (bug 14471) Use HTMLTidy and generate limit report in action=parse
12087 * (bug 14459) Added prependtext and appendtext parameters to action=edit
12088 * (bug 14526) Unescaped SQL in list=backlinks
12089 * Added 'hidden' flag to list=allcategories and prop=categoryinfo output
12090 * Added nocreate parameter to action=edit
12091 * (bug 14402) Added maxage and smaxage parameters to api.php
12092 * Added bkip parameter to list=blocks
12093 * (bug 14651) apprefix and similar parameters are now canonicalized
12094 * Added clprop=timestamp to prop=categories
12095 * (bug 14678) API errors now respects $wgShowExceptionDetails and
12096 $wgShowSQLErrors
12097 * (bug 14723) Added time zone and writing direction to meta=siteinfo
12098 * Added APIQueryInfoTokens and APIQueryRevisionsTokens hooks so extensions
12099 can add their own tokens
12100 * Added block and unblock tokens to prop=info as well
12101 * Added paging (limit and continue parameters) to
12102 prop={links,templatelinks,langlinks,extlinks,categories,images}
12103 * Added flag "top" to list=usercontribs if the user is the last contributor to
12104 the page
12105 * list=exturlusage in "list all links" mode can now filter by protocol
12106
12107 == MediaWiki 1.12 ==
12108
12109 == MediaWiki 1.12.4 ==
12110
12111 February 7, 2009
12112
12113 A number of cross-site scripting (XSS) security vulnerabilities were discovered
12114 in the web-based installer (config/index.php). These vulnerabilities all
12115 require a live installer -- once the installer has been used to install a wiki,
12116 it is deactivated.
12117
12118 Note that cross-site scripting vulnerabilities can be used to attack any
12119 website in the same cookie domain. So if you have an uninstalled copy of
12120 MediaWiki on the same site as an active web service, MediaWiki could be used to
12121 attack the active service.
12122
12123 If you are hosting an old copy of MediaWiki that you have never installed, you
12124 are advised to remove it from the web.
12125
12126 == MediaWiki 1.12.3 ==
12127
12128 * Fixed packaging/distribution error. Many files were missing from the
12129 distributed tarball.
12130
12131 == MediaWiki 1.12.2 ==
12132
12133 David Remahl of Apple's Product Security team has identified a number of
12134 security issues in previous releases of MediaWiki. Subsequent analysis by the
12135 MediaWiki development team expanded the scope of these vulnerabilities. The
12136 issues with a significant impact are as follows:
12137
12138 * A local script injection vulnerability affecting Internet Explorer clients
12139 for all MediaWiki installations with uploads enabled. [CVE-2008-5250]
12140 * A local script injection vulnerability affecting clients with SVG scripting
12141 capability (such as Firefox 1.5+), for all MediaWiki installations with SVG
12142 uploads enabled. [CVE-2008-5250]
12143 * A CSRF vulnerability affecting the Special:Import feature, for all MediaWiki
12144 installations since the feature was introduced in 1.3.0. [CVE-2008-5252]
12145
12146 A local script injection vulnerability allows an attacker with a wiki account
12147 to steal another user's login session, and to act as that user on the wiki. The
12148 attacker uploads a malicious script file, and tricks the victim into executing
12149 it.
12150
12151 CSRF vulnerabilities allow an attacker to act as an authorised user on the
12152 wiki, but unlike an XSS vulnerability, the attacker can only act as the user in
12153 a specific and restricted way. The present CSRF vulnerability allows pages to
12154 be edited, with forged revision histories. Like an XSS vulnerability, the
12155 authorised user must visit the malicious web page to activate the attack.
12156
12157 These three vulnerabilities are all fixed in this release.
12158
12159 David Remahl also reminded us of some security-related configuration issues:
12160
12161 * By default, MediaWiki stores a backup of deleted images in the images/deleted
12162 directory. If you do not want these images to be publically accessible, make
12163 sure this directory is not accessible from the web. MediaWiki takes some steps
12164 to avoid leaking these images, but these measures are not perfect.
12165 * Set display_errors=off in your php.ini to avoid path disclosure via PHP fatal
12166 errors. This is the default on most shared web hosts.
12167 * Enabling MediaWiki's debugging features, such as $wgShowExceptionDetails, may
12168 lead to path disclosure.
12169
12170 Other changes in this release:
12171
12172 * Avoid fatal error in profileinfo.php when not configured.
12173 * Add a .htaccess to deleted images directory for additional protection against
12174 exposure of deleted files with known SHA-1 hashes on default installations.
12175 * Avoid streaming uploaded files to the user via index.php. This allows
12176 security-conscious users to serve uploaded files via a different domain, and
12177 thus client-side scripts executed from that domain cannot access the login
12178 cookies. Affects Special:Undelete, img_auth.php and thumb.php.
12179 * When streaming files via index.php, use the MIME type detected from the file
12180 extension, not from the data. This reduces the XSS attack surface.
12181 * Blacklist redirects via Special:Filepath. Such redirects exacerbate any XSS
12182 vulnerabilities involving uploads of files containing scripts.
12183 * Internationalisation updates.
12184
12185 == MediaWiki 1.12.1 ==
12186
12187 Changes since 1.12.0:
12188 * (bug [[bugzilla:13522|13522]]) Fix fatal error in Parser::extractTagsAndParams
12189 * (bug [[bugzilla:12077|12077]]) Fix HTML nesting for TOC
12190 * (bug [[bugzilla:13532|13532]]) Use proper timestamp call when reverting images
12191 * (bug [[bugzilla:13649|13649]], [[bugzilla:14084|14084]]) Bad call to
12192 wfTimestamp()
12193 * (bug [[bugzilla:13770|13770]]) Use Preprocessor_Hash by default to avoid
12194 missing DOM module errors
12195 * (bug [[bugzilla:13442|13442]]) API: Missing pages in prop=langlinks and
12196 prop=extlinks are now handled properly.
12197 * (bug [[bugzilla:13482|13482]]) API: Disabled search types handled properly
12198 * (bug [[bugzilla:13836|13836]]) API: Fixed fatal errors resulting from
12199 combining iiprop=metadata with format=xml
12200 * (bug [[bugzilla:11633|11633]]) API: Explicitly convert redirect titles to
12201 strings due to PHP's very weak typing on array keys.
12202 * API: Fixing main page display in meta=siteinfo
12203 * (bug [[bugzilla:11719|11719]]) API: Remove trailing blanks in YAML output.
12204 * (bug [[bugzilla:13718|13718]]) API: Return the proper continue parameter for
12205 cmsort=timestamp
12206 * Security: Work around misconfiguration by requiring strict comparisons for
12207 in_array in User::isAllowed().
12208 * Security: Fixed XSS vulnerability in useskin parameter.
12209
12210 == MediaWiki 1.12.0 ==
12211
12212 This is the quarterly branch release of [[MediaWiki]] for Winter 2008.
12213
12214 MediaWiki is now using a "continuous integration" development model with
12215 quarterly snapshot releases. The latest development code is always kept "ready
12216 to run", and in fact runs our own sites on [[wikipedia:|Wikipedia]].
12217
12218 Release branches will continue to receive security updates for about a year
12219 from first release, but nonessential bugfixes and feature developments will be
12220 made on the development trunk and appear in the next quarterly release.
12221
12222 Those wishing to use the latest code instead of a branch release can obtain it
12223 from source control: [[Download from SVN]].
12224
12225 Changes since 1.12.0rc1:
12226 *(bug [[bugzilla:13359|13359]]) Double-escaping in [[Special:Allpages]].
12227 *Localization updates.
12228
12229 == MediaWiki 1.12.0rc1 ==
12230
12231 This is a release candidate of the Winter 2008 quarterly snapshot release of
12232 [[MediaWiki]].
12233
12234 MediaWiki is now using a "continuous integration" development model with
12235 quarterly snapshot releases. The latest development code is always kept "ready
12236 to run", and in fact runs our own sites on [[wikipedia:|Wikipedia]].
12237
12238 Release branches will continue to receive security updates for about a year
12239 from first release, but nonessential bugfixes and feature developments will be
12240 made on the development trunk and appear in the next quarterly release.
12241
12242 Those wishing to use the latest code instead of a branch release can obtain it
12243 from source control: [[Download from SVN]].
12244
12245 This is the Winter 2007 quarterly release.
12246
12247 MediaWiki is now using a "continuous integration" development model with
12248 quarterly snapshot releases. The latest development code is always kept
12249 "ready to run", and in fact runs our own sites on Wikipedia.
12250
12251 Release branches will continue to receive security updates for about a year
12252 from first release, but nonessential bugfixes and feature developments
12253 will be made on the development trunk and appear in the next quarterly release.
12254
12255 Those wishing to use the latest code instead of a branch release can obtain
12256 it from source control: https://www.mediawiki.org/wiki/Download_from_SVN
12257
12258 === Configuration changes in 1.12 ===
12259 * Marking edits as bot edits with Special:Contributions?bot=1 now requires the
12260 markbotedit permission, rather than the rollback permission previously used.
12261 This permission is assigned by default to the sysop group.
12262 * MediaWiki now checks if serialized files are out of date. New configuration
12263 variable $wgCheckSerialized can be set to false to enable old behavior (i.e.
12264 to not check and assume they are always up to date)
12265 * The rollback permission can now be rate-limited using the normal mechanism.
12266 * New configuration variable $wgExtraLanguageNames
12267 * Behavior of $wgAddGroups and $wgRemoveGroups changed. New behavior:
12268 * * Granting the userrights privilege allows arbitrary changing of rights.
12269 * * Without the userrights privilege, a user will be able to add and/or
12270 remove the groups specified in $wgAddGroups and $wgRemoveGroups for
12271 any groups they are in.
12272 * New permission userrights-interwiki for changing user rights on foreign wikis.
12273 * $wgImplicitGroups for groups that are hidden from Special:Listusers, etc.
12274 * $wgAutopromote: automatically promote users who match specified criteria
12275 * $wgGroupsAddToSelf, $wgGroupsRemoveFromSelf: allow users to add or remove
12276 themselves from specified groups via Special:Userrights.
12277 * When $wgUseTidy has been enabled, PHP's Tidy module is now used if it is
12278 present, in preference to an external Tidy executable which may or may not
12279 be present. To force use of external Tidy even when the PHP module is
12280 available, set $wgTidyInternal to false.
12281
12282
12283 === New features in 1.12 ===
12284 * (bug 10735) Add a warning for non-descriptive filenames at Special:Upload
12285 * Add {{filepath:}} parser function to get full path to an uploaded file,
12286 complementing {{fullurl:}} for pages.
12287 * (bug 11136) If using Postgres, search path is explicitly set if wgDBmwschema
12288 is not set to 'mediawiki', allowing multiple mediawiki instances per user.
12289 * (bug 11151) Add descriptive <title> to revision history page
12290 * (bug 5412) Add feed links for the site to all pages
12291 * (bug 11353) Add ability to retrieve raw section content via action=raw
12292 * (bug 6909) Show relevant deletion log lines when uploading a previously
12293 deleted file
12294 * On SkinTemplate based skins (like MonoBook), omit confusing "edit"/"view
12295 source" tab entirely if the page doesn't exist and the user isn't allowed to
12296 create it
12297 * Clarify instructions given when an exception is thrown
12298 * AuthPlugin added strictUserAuth() method to allow per-user override
12299 of the strict() authentication behavior.
12300 * (bug 7872) Deleted revisions can now be viewed as diffs showing changes
12301 against the previous revision, whether currently deleted or live.
12302 * Added tooltips for the "Go" and "Search" buttons
12303 * (bug 11649) Show input form when Special:Whatlinkshere has no parameters
12304 * isValidEmailAddr hook added to User method of that name, to allow, e.g., re-
12305 stricting e-mail addresses to a specific domain
12306 * Removed "Clear" link in watchlist editor tools, as people were afraid to
12307 click it. Existing clear links will fall back to the raw editor, which is
12308 very easy to clear your watchlist with.
12309 * (bug 1405) Add wgUseNPPatrol option to control patroling for new articles
12310 on Special:Newpages
12311 * LogLine hook added to allow formatting custom entries in Special:Log.
12312 * Support for Iranian calendar
12313 * (bug 1401) Allow hiding logged-in users, bots and patrolled pages on
12314 Special:Newpages
12315 * ChangesListInsertArticleLink hook added for adding extra article info to RC.
12316 * MediaWikiPerformAction hook added for diverting control after the main
12317 globals have been set up but before any actions have been taken.
12318 * BeforeWatchlist hook added for filtering or replacing watchlist.
12319 * SkinTemplateTabAction hook added for altering the properties of tab links.
12320 * OutputPage::getRedirect public method added.
12321 * (bug 11848, 12506) Allow URL parameters 'section', 'editintro' and 'preload'
12322 in Special:Mypage and Special:Mytalk
12323 * Add ot=raw to Special:Allmessages
12324 * Support for Hebrew calendar
12325 * Support for Hebrew numerals in dates and times
12326 * (bug 11315) Signatures can be configured in [[MediaWiki:Signature]] and
12327 [[MediaWiki:Signature-anon]]
12328 * Signatures for anonymous users link to Special:Contributions page rather than
12329 user page
12330 * Added --override switch for disabled pages in updateSpecialPages.php
12331 * Provide a unique message (ipb_blocked_as_range) if unblock of a single IP
12332 fails
12333 because it is part of a blocked range.
12334 * (bug 3973) Use a separate message for the email content when an account is
12335 created by another user
12336 * dumpTextPass.php can spawn fetchText.php as a subprocess, which should restart
12337 cleanly if database connections fail unpleasantly.
12338 * (bug 12028) Add Special:Listbots as shortcut for Special:Listusers/bot
12339 * (bug 9633) Add a predefined list of delete reasons to the deletion form
12340 * Show a warning message when creating/editing a user (talk) page but the user
12341 does not exists
12342 * (bug 8396) Ignore out-of-date serialised message caches
12343 * (bug 12195) Undeleting pages now requires 'undelete' permission
12344 * (bug 11810) Localize displayed semicolons
12345 * (bug 11657) Support for Thai solar calendar
12346 * (bug 943) RSS feed for Recentchangeslinked
12347 * Introduced AbortMove hook
12348 * (bug 2919) Protection of nonexistent pages with regular protection interface.
12349 * Special:Upload now lists permitted/prohibited file extensions.
12350 * Split ambiguous filetype-badtype message into two new messages,
12351 filetype-unwanted-type and filetype-banned-type.
12352 * Added link to the old title in Special:Movepage
12353 * On Special:Movepage, errors are now more noticeable.
12354 * It is now possible to change rights on other local wikis without the MakeSysop
12355 extension
12356 * Add HTML ID's mw-read-only-warning and mw-anon-edit-warning to warnings when
12357 editing to allow CSS styling.
12358 * Parser now returns list of sections
12359 * When a user is prohibited from creating a page, a title of "View source"
12360 makes no sense, and there should be no "Return to [[Page]]" link.
12361 * (bug 12486) Protected titles now give a warning for privileged editors.
12362 * (bug 9939) Special:Search now sets focus to search input box when no existing
12363 search is active
12364 * For Special:Userrights, use GET instead of POST to search for users.
12365 * Allow subpage syntax for Special:Userrights, i.e., Special:Userrights/Name.
12366 * When submitting changes on Special:Userrights, show the full form again, not
12367 just the search box.
12368 * Added exception hooks
12369 * (bug 12574) Allow bots to specify whether an edit should be marked as a bot
12370 edit, via the parameter 'bot'. (Default: '1')
12371 * (bug 12536) User should be able to get MediaWiki version from any page
12372 * (bug 12622) A JavaScript constant to declare whether api.php is available
12373 * Add caching to the AJAX search
12374 * Add APCOND_INGROUPS
12375 * Add DBA caching to installer
12376 * (bug 12585) Added a bunch of parameters to the revertpage message
12377 * Support redirects in image namespace
12378 * (bug 10049) Prefix index search and namespaces in Special:Withoutinterwiki
12379 * (bug 12668) Support for custom iPhone bookmark icon via $wgAppleTouchIcon
12380 * Add option to include templates in Special:Export.
12381 * (bug 12655) Added $wgUserEmailUseReplyTo config option to put sender
12382 address in Reply-To instead of From for user-to-user emails.
12383 This protects against SPF problems and privacy-leaking bounce messages
12384 when using mailers that set the envelope sender to the From header value.
12385 * (bug 11897) Add alias [[Special:CreateAccount]] & [[Special:Userlogin/signup]]
12386 for Special:Userlogin?type=signup
12387 * (bug 12214) Add a predefined list of delete reasons to the file deletion form
12388 * Merged backends for OpenSearch suggestions and AJAX search.
12389 Both now accept namespace prefixes, handle 'Media:' and 'Special:' pages,
12390 and reject interwiki prefixes. PrefixSearch class centralizes this code,
12391 and the backend part can be overridden by the PrefixSearchBackend hook.
12392 * (bug 10365) Localization of Special:Version
12393 * When installing using Postgres, the Pl/Pgsql language is now checked for
12394 and installed when at the superuser level.
12395 * The default robot policy for the entire wiki is now configurable via the
12396 $wgDefaultRobotPolicy setting.
12397 * (bug 12239) Use different separators for autocomments
12398 * (bug 12857) Patrol link on new pages should clear floats
12399 * (bug 12968) Render redirect wikilinks in a redirect class for customization
12400 via user/site CSS.
12401 * EditPageBeforeEditButtons hook added for altering the edit buttons below the edit box
12402
12403 === Bug fixes in 1.12 ===
12404
12405 * Subpages are now indexed for searching properly when using PostgreSQL
12406 * (bug 3846) Suppress warnings from, e.g. open_basedir when scanning for
12407 ImageMagick, diff3 et al. during installation [patch by Jan Reininghaus]
12408 * (bug 7027) Shift handling of deletion permissions-checking to
12409 getUserPermissionsErrors.
12410 * Login and signup forms are now more correct for right-to-left languages.
12411 * (bug 5387) Block log items on RecentChanges don't make use of possible
12412 translations
12413 * (bug 11211) Pass, as a parameter to the protectedpagetext interface
12414 message, the level of protection.
12415 * (bug 9611) Supply the blocker and reason for the cantcreateaccounttext
12416 message.
12417 * (bug 8759) Fixed bug where rollback was allowed on protected pages for wikis
12418 where rollback is given to non-sysops.
12419 * (bug 8834) Split off permission for editing user JavaScript and CSS from
12420 editinterface to a new permission key editusercssjs.
12421 * (bug 11266) Set fallback language for Fulfulde (ff) to French
12422 * (bug 11179) Include image version deletion comment in public log
12423 * Fixed notice when accessing special page without read permission and whitelist
12424 is not defined
12425 * (bug 9252) Fix for tidy funkiness when using editintro mode
12426 * (bug 4021) Fix for MySQL wildcard search
12427 * (bug 10699) Fix for MySQL phrase search
12428 * (bug 11321) Fix width of gallerybox when option "width=xxx" is used
12429 * (bug 7890) Special:BrokenRedirects links deleted redirects to a non-existent
12430 page
12431 * Fix initial statistics when installing: add correct values
12432 * (bug 11342) Fix several 'returnto' links in permissions/error pages which
12433 linked to the main page instead of targetted page
12434 * Strike the link to the redirect rather than using an asterisk in
12435 Special:Listredirects
12436 * (bug 11355) Fix false positives in Safe Mode and other config detection
12437 when boolean settings are disabled with 'Off' via php_admin_value/php_value
12438 * (bug 11292) Fixed unserialize errors with Postgres by creating special Blob
12439 object.
12440 * (bug 11363) Make all metadata fields bytea when using Postgres.
12441 * (bug 11331) Add buildConcat() and use CASE not IF for DB compatibility. Make
12442 oldimage cascade delete via image table for Postgres, change fa_storage_key
12443 TEXT.
12444 * (bug 11438) Live Preview chops returned text
12445 * Show the right message on account creation when the user is blocked
12446 * (bug 11450) Fix creation of objectcache table on upgrade
12447 * Fix namespace selection after submit of Special:Newpages
12448 * Make input form of Special:Newpages nicer for RTL wikis
12449 * (bug 11462) Fix typo in LanguageGetSpecialPageAliases hook name
12450 * (bug 11474) Fix unintentional fall-through in math error handling
12451 * (bug 11478) Fix undefined method call in file deletion interface
12452 * (bug 278) Search results no longer highlight incorrect partial word matches
12453 * Compatibility with incorrectly detected old-style DJVU mime types
12454 * (bug 11560) Fix broken HTML output from weird link nesting in edit comments.
12455 Nested links (as in image caption text) still don't work _right_ but they're
12456 less wrong
12457 * (bug 9718) Remove unnecessary css from main.css causing spacing issues on
12458 some browsers.
12459 * (bug 11574) Add an interface message loginstart, which, similarly to loginend,
12460 appears just before the login form. Patch by MinuteElectron.
12461 * Do not cache category pages if using 'from' or 'until'
12462 * Created new hook getUserPermissionsErrors, to go with userCan changes.
12463 * Diff pages did not properly display css/js pages.
12464 * (bug 11620) Add call to User::isValidEmailAddr during accout creation.
12465 * (bug 11629) If $wgEmailConfirmToEdit is true, require people to supply an
12466 email address when registering.
12467 * (bug 11612) Days to show in recent changes cannot be larger than 7
12468 * (bug 11131) Change filearchive width/height columns to int for Postgres
12469 * Support plural in undeleted{revisions,revisions-files,files}
12470 * (bug 11343) If the database is read-only, ensure that undelete fails.
12471 * (bug 11690) Show revert link for page moves in Special:Log to allowed users
12472 only
12473 * Initial-lowercase prefix checks in namespaceDupes.php now actually work.
12474 * Fix regression in LinkBatch.php breaking PHP 5.0
12475 * (bug 11452) wfMsgExt uses sometimes wrong language object for parsing magic
12476 words when called with options ''parsemag'' or ''content''.
12477 * (bug 11727) Support plural in 'historysize' message
12478 * (bug 11744) Incorrect return value from Title::getParentCategories()
12479 * (bug 11762) Fix native language name of Akan (ak)
12480 * (bug 11722) Fix inconsistent case in unprotect tabs
12481 * (bug 11795) Be more paranoid about confirming accept-encoding header is
12482 present
12483 * (bug 11809) Use formatNum() for more numbers
12484 * (bug 11818) Fix native language name of Inuktitut (iu)
12485 * Remove all commas when parsing float numbers in sorted tables
12486 * Limit text field of deletion, protection and user rights changes reasons to
12487 255 characters (already restricted in the database)
12488 * In the deletion default reasons, calculate how much text to get from the
12489 article text, rather than getting 150 characters (which may be too much)
12490 * Add two messages for Special:Blockme which were used but undefined
12491 * (bug 11921) Support plural in message number_of_watching_users_pageview
12492 * If an IP address is blocked as part of a rangeblock, attempting to unblock
12493 the single IP should not unblock the entire range.
12494 * (bug 6695) Fix native language name of Southern Sotho (Sesotho) (st)
12495 * Make action=render follow redirects by default
12496 * If restricted read access was enabled, whitelist didn't work with special
12497 pages which had spaces in theirs names
12498 * If restricted read access was enabled, requests for non-existing special pages
12499 threw an exception
12500 * Feeds for recent changes now provide correct URLs for the change, not just
12501 the page
12502 * Check for if IP is blocked as part of a range when unblocking (see above bug-
12503 fix) was faulty. Now fixed.
12504 * Fixed wpReason URL parameter to action=delete.
12505 * Do not force a password for account creation by email
12506 * Ensure that rate-limiting is applied to rollbacks.
12507 * Make a better rate-limiting error message (i.e. a normal MW error,
12508 rather than an "Internal Server Error").
12509 * Do not present an image bigger than the source when 'frameless' option is used
12510 (to be consistent with the 'thumb' option now)
12511 * Support {{PLURAL}} for import log
12512 * Make sure that the correct log entries are shown on Special:Userrights even
12513 for users with special characters in their names
12514 * The number of watching users in watchlists was always reported as 1
12515 * namespaceDupes.php no longer dies when coming across an illegal title
12516 * (bug 12143) Do not show a link to patrol new pages for non existent pages
12517 * (bug 12166) Fix XHTML validity for Special:Emailuser
12518 * (bug 11346) Users who cannot edit a page can now no longer unprotect it.
12519 * (bug 451) Add a generic Traditional / Simplified Chinese conversion table,
12520 instead of a Traditional conversion with Taiwan variant, and a Simplified
12521 conversion with China variant.
12522 * (bug 12178) Fix wpReason parameter to action=delete, again.
12523 * Graceful behavior for updateRestrictions.php if a page already has records
12524 in the page_restrictions matching its old page_restrictions field.
12525 May help with odd upgrade issues or race condition.
12526 * (bug 11993) Remove contentsub "revision history"
12527 * (bug 11952) Ensure we quote_ident() all schema names as needed
12528 inside of the DatabasePostgres.php file.
12529 * (bug 12184) Exceptions now sent to stderr instead of stdout for command-line
12530 scripts, making for cleaner reporting during batch jobs. PHP errors will also
12531 be redirected in most cases on PHP 5.2.4 and later, switching 'display_errors'
12532 to 'stderr' at runtime.
12533 * (bug 12148) Text highlight wasn't applied to cleanly deleted and added
12534 lines in diff output
12535 * (bug 10166) Fix a PHP warning in Language::getMagic
12536 * Only mark rollback edits as minor if the user can normally mark edits minor
12537 * Escape page names in the move successful page (e.g. for pages with two
12538 apostrophes).
12539 * (bug 12145) Add localized names of kk-variants
12540 * (bug 12259) Localize the numbers in deleted pages on the sysop view
12541 * Set proper page title for successful file deletion
12542 * (bug 11221) Do not show 'Compare selected versions' button for a history page
12543 with one revision only
12544 * (bug 12267) Set the default date format to Thai solar calender for the Thai
12545 language
12546 * (bug 10184) Extensions' stylesheets and scripts should be loaded before
12547 user-customized ones (like Common.css, Common.js)
12548 * (bug 12283) Special:Newpages forgets parameters
12549 * (bug 12031) All namespaces doesn't work in Special:Newpages
12550 * (bug 585) Only create searchindex replica table for parser tests if db is
12551 MySQL
12552 * Allow --record option if parserTests.php to work when using Postgres
12553 * (bug 12296) Simplify cache epoch in default LocalSettings.php
12554 * (bug 12346) XML fix when body double-click and click handlers are present
12555 * Fix regression -- missing feed links in sidebar on Special:Recentchanges
12556 * (bug 12371) Handle more namespace case variants in namespaceDupes.php
12557 * (bug 12380) Bot-friendly EditPage::spamPage
12558 * (bug 8066) Spaces can't be entered in special page aliases
12559 * Hide undo link if user can't edit article
12560 * (bug 12416) Fix password setting for createAndPromote.php
12561 * (bug 3097) Inconsistently usable titles containing HTML character entities
12562 are now forbidden. A run of cleanupTitles.php will fix up existing pages.
12563 * (bug 12446) Permissions check fix for undelete link
12564 * (bug 12451) AJAX title normalization tweaks
12565 * When a user creating a page is not allowed to either create the page nor edit
12566 it, all applicable reasons are now shown.
12567 * (bug 11428) Allow $wgScript inside $wgArticlePath when emulating PATH_INFO
12568 Fixes 'root'-style rewrite configurations
12569 * (bug 12493) Removed hardcoded MAX_FILE_SIZE from Special:Import upload form
12570 * (bug 12489) Special:Userrights listed in restricted section again
12571 * (bug 12553) Fixed invalid XHTML in edit conflict screen
12572 * (bug 12505) Fixed section=0 with action=raw
12573 * (bug 12614) Do not log user rights change that didn't change anything
12574 * (bug 12584) Don't reset cl_timestamp when auto-updating sort key on move
12575 * (bug 12588) Fix selection in namespace selector on Special:Newpages
12576 * Use only default options when generating RSS and Atom syndication links.
12577 This should help prevent infinite link loops that some software may follow,
12578 and will generally keep feed behavior cleaner.
12579 * (bug 12608) Unifying the spelling of getDBkey() in the code.
12580 * (bug 12611) Bot flag ignored in recent changes
12581 * (bug 12617) Decimal and thousands separators for Romanian
12582 * (bug 12567) Fix for misformatted read-only messages on edit, protect.
12583 Also added proper read-only checks to several special pages.
12584 Have removed read-only checks from the general user permission framework.
12585 * Creating a site with a name containing '#' is no longer permitted, since the
12586 name will not work (but $wgSiteName is not checked if manually set).
12587 * (bug 12695) Suppress dvips verbiage from web server error log
12588 * (bug 12716) Unprotecting a non-protected page leaves a log entry
12589 * Log username blocks with canonical form of name instead of input form
12590 * (bug 11593, 12719) Fixes for overzealous invocation of thumb.php.
12591 Non-image handlers and full-size images may now decline it, fixing
12592 mystery failures when using $wgThumbnailScriptPath.
12593 * (bug 12327) Comma in username no longer disrupts mail headers
12594 * (bug 6436) Localization of Special:Import XML parser Error message(s).
12595 * Security fix for API on MSIE
12596 * (bug 12768) Database query syntax error in maintenance/storage/compressOld.inc
12597 * (bug 12753) Empty captions in MediaWiki:Sidebar result in PHP errors
12598 * (bug 12790) Page protection is not logged when edit-protection is used
12599 and move-protection is not
12600 * (bug 12793) Fix for restricted namespaces/pages in Special:Export
12601 * Fix for Special:Export so it doesn't ignore the page named '0'
12602 * Don't display rollback link if the user doesn't have all required permissions
12603 * The comment of a time-limited protection now contains the date in the default
12604 format
12605 * (bug 12880) wfLoadExtensionMessages does not use $fallback from MessagesXx.php
12606 * (bug 12885) Correction for Russian convertPlural function
12607 * (bug 12768) Make DatabasePostgres->hasContraint() schema aware.
12608 * (bug 12735) Truncate usernames in comments using mb_ functions.
12609 * (bug 12892) Poor tab indexing on "delete file" form
12610 * (bug 12660) When creating an account by e-mail, do not send the creator's IP
12611 address
12612 * (bug 12931) Fix wrong global variable in SpecialVersion
12613 * (bug 12919) Use 'deletedrevision' message as content when deleting an old file
12614 version
12615 * (bug 12952) Using Nosuchusershort instead of Nosuchuser when account creation
12616 is disabled
12617 * (bug 12869) Magnify icon alignment should be adjusted using linked CSS
12618 * Fixing message cache updates for MediaWiki messages moves
12619 * (bug 12815) Signature timestamps were always in UTC, even if the timezone code
12620 in parentheses after them claimed otherwise
12621 * (bug 12732) Fix installer and searching to handle built-in tsearch2 for Postgres.
12622 * (bug 12784) Change "bool" types to smallint to handle Postgres 8.3 strictness.
12623 * (bug 12301) Allow maintenance/findhooks.php to search hooks in multiple directories.
12624 * (bug 7681, 11559) Cookie values no longer override GET and POST variables.
12625 * (bug 5262) Fully-qualified $wgStylePath no longer corrupted on XML feeds
12626 * (bug 3269) Inaccessible titles ending in '/.' or '/..' now forbidden.
12627 * (bug 12935, 12981) Fully-qualify archive URLs in delete, revert messages
12628 * (bug 12938) Fix template expansion and 404 returns for action=raw with section
12629 * (bug 11567) Fix error checking for PEAR::Mail. UserMailer::send() now returns
12630 true-or-WikiError, which seems to be the calling convention expected by half
12631 its callers already
12632 * (bug 12846) IE rtl.css issue in RTL wikis special:Preferences when selecting an
12633 LTR user language
12634 * (bug 13005) DISPLAYTITLE does not work on preview
12635 * (bug 13004) Fix error on Postgres searches that return too many results.
12636
12637 == Parser changes in 1.12 ==
12638
12639 For help with migration to the MediaWiki 1.12 parser, please visit:
12640
12641 http://meta.wikimedia.org/wiki/Migration_to_the_new_preprocessor
12642
12643 The parser pass order has changed from
12644
12645 * Extension tag strip and render
12646 * HTML normalisation and security
12647 * Template expansion
12648 * Main section...
12649
12650 to
12651
12652 * Template and extension tag parse to intermediate representation
12653 * Template expansion and extension rendering
12654 * HTML normalisation and security
12655 * Main section...
12656
12657 The main effect of this for the user is that the rules for uncovered syntax
12658 have changed.
12659
12660 Uncovered main-pass syntax, such as HTML tags, are now generally valid, whereas
12661 previously in some cases they were escaped. For example, you could have "<ta" in
12662 one template, and "ble>" in another template, and put them together to make a
12663 valid <table> tag. Previously the result would have been "&lt;table&gt;".
12664
12665 Uncovered preprocessor syntax is generally not recognised. For example, if you
12666 have "{{a" in Template:A and "b}}" in Template:B, then "{{a}}{{b}}" will be
12667 converted to a literal "{{ab}}" rather than the contents of Template:Ab. This
12668 was the case previously in HTML output mode, and is now uniformly the case in
12669 the other modes as well. HTML-style comments uncovered by template expansion
12670 will not be recognised by the preprocessor and hence will not prevent template
12671 expansion within them, but they will be stripped by the following HTML security
12672 pass.
12673
12674 Bug 5678 has been fixed. This has a number of user-visible effects related to
12675 the removal of this double-parse. Please see the wiki page for examples.
12676
12677 Message transformation mode has been removed, and replaced with "preprocess"
12678 mode. This means that some MediaWiki namespace messages may need to be updated,
12679 especially ones which took advantage of the terribly counterintuitive behavior
12680 of the former message mode.
12681
12682 The header identification routines for section edit and for numbering section
12683 edit links have been merged. This removes a significant failure mode and fixes a
12684 whole category of bugs (tracked by bug #4899). Wikitext headings uncovered by
12685 template expansion will still be rendered into a heading tag, and will get an
12686 entry in the TOC, but will not have a section edit link. HTML-style headings
12687 will also not have a section edit link. Valid wikitext headings present in the
12688 template source text will get a template section edit link. This is a major
12689 break from previous behavior, but I believe the effects are almost entirely
12690 beneficial.
12691
12692 The main motivation for making these changes was performance. The new two-pass
12693 preprocessor can skip "dead branches" in template expansion, such as unfollowed
12694 #switch cases and unused defaults for template arguments. This provides a
12695 significant performance improvement in template-heavy test cases taken from
12696 Wikipedia. Parser function hooks can participate in this performance improvement
12697 by using the new SFH_OBJECT_ARGS flag during registration.
12698
12699 The pre-expand include size limit has been removed, since there's no efficient
12700 way to calculate such a figure, and it would now be meaningless for performance
12701 anyway. The "preprocessor node count" takes its place, with a generous default
12702 limit.
12703
12704 The context in which XML-style extension tags are called has changed, so
12705 extensions which make use of the parser state may need compatibility changes.
12706
12707 The new preprocessor syntax has been documented in Backus-Naur Form at:
12708
12709 https://www.mediawiki.org/wiki/Preprocessor_ABNF
12710
12711 The ExpandTemplates extension now has the ability to generate an XML parse
12712 tree from wikitext source. This parse tree corresponds closely to the grammar
12713 documented on that page.
12714
12715 === API changes in 1.12 ===
12716
12717 Full API documentation is available at https://www.mediawiki.org/wiki/API
12718
12719 * (bug 11275) Enable descending sort in categorymembers
12720 * (bug 11308) Allow the API to output the image metadata
12721 * (bug 11296) Temporary fix for escaping of ampersands inside links in
12722 pretty-printed
12723 help document.
12724 * (bug 11405) Expand templates implementation in the API
12725 * (bug 11218) Add option to feedwatchlist to display multiple revisions for each
12726 page.
12727 * (bug 11404) Provide name of exception caught in error code field of internal
12728 api error messages.
12729 * (bug 11534) rvendid doesn't work
12730 * Fixed rvlimit of the revisions query to only enforce the lower query limit if
12731 revision content is requested.
12732 * Include svn revision number (if install is checked-out from svn) in siteinfo
12733 query.
12734 * (bug 11173) Allow limited wikicode rendering via api.php
12735 * (bug 11572) API should provide interface for expanding templates
12736 * (bug 11569) Login should return the cookie prefix
12737 * (bug 11632) Breaking change: Specify the type of a change in the recentchanges
12738 list as 'edit', 'new', 'log' instead of 0, 1, 2, respectively.
12739 * Compatibility fix for PHP 5.0.x.
12740 * Add rctype parameter to list=recentchanges that filters by type
12741 * Add apprtype and apprlevel parameters to filter list=allpages by protection
12742 types and levels
12743 * Add apdir parameter to enable listing all pages from Z to A
12744 * (bug 11721) Use a different title for results than for the help page.
12745 * (bug 11562) Added a user_registration parameter/field to the list=allusers
12746 query.
12747 * (bug 11588) Preserve document structure for empty dataset in backlinks query.
12748 * Outputting list of all user preferences rather than having to request them by
12749 name
12750 * (bug 11206) api.php should honor maxlag
12751 * Make prop=info check for restrictions in the old format too.
12752 * Add apihighlimits permission, default for sysops and bots
12753 * Add limit=max to use maximal limit
12754 * Add action=parse to render parser output. Use it instead of action=render
12755 which has been removed
12756 * Add rvtoken=rollback to prop=revisions
12757 * Add meta=allmessages to get messages from site's messages cache.
12758 * Use bold and italics highlighting only in API help
12759 * Added action={block,delete,move,protect,rollback,unblock,undelete} and
12760 list={blocks,deletedrevs}
12761 * Fixed sessionid attribute in action=login
12762 * Standardized limits. Revisions and Deletedrevisions formerly using
12763 200 / 10000, now 500 / 5000, in line with other modules.
12764 * Added list=allcategories module
12765 * (bug 12321) API list=blocks reveals private data
12766 * Fix output of wfSajaxSearch
12767 * (bug 12413) meta=userinfo missing <query> tag
12768 * Add list of sections to action=parse output
12769 * Added action=logout
12770 * Added cascade flag to prop=info&inprop=protections
12771 * Added wlshow parameter to list=watchlist, similar to rcshow
12772 (list=recentchanges)
12773 * Added support for image thumbnailing to prop=imageinfo
12774 * action={login,block,delete,move,protect,rollback,unblock,undelete} now must be
12775 POSTed
12776 * prop=imageinfo interface changed: iihistory replaced by iilimit, iistart and
12777 iiend parameters
12778 * Added amlang parameter to meta=allmessages
12779 * Added apfilterlanglinks parameter to list=allpages, replacing
12780 query.php?what=nolanglinks
12781 * (bug 12718) Added action=paraminfo module that provides information about API
12782 modules and their parameters
12783 * Added iiurlwidth and iiurlheight parameters to prop=imageinfo
12784 * Added format=txt and format=dbg, imported from query.php
12785 * Added uiprop=editcount to meta=userinfo
12786 * Added list=users which fetches user information
12787 * Added list=random which fetches a list of random pages
12788 * Added page parameter to action=parse to facilitate parsing of existing pages
12789 * Added uiprop=ratelimits to meta=userinfo
12790 * Added siprop=namespacealiases to meta=siteinfo
12791 * Made multiple values for ucuser possible in list=usercontribs
12792 * (bug 12944) Added cmstart and cmend parameters to list=categorymembers
12793 * Allow queries to have a where range that does not match the range field
12794
12795 == MediaWiki 1.11 ==
12796
12797 == MediaWiki 1.11.2 ==
12798
12799 March 2, 2008
12800
12801 This is a security release of the Fall 2007 snapshot release of MediaWiki.
12802 Possible cross-site information leaks using the callback parameter for
12803 JSON-formatted results in the API are prevented by dropping user credentials.
12804
12805 MediaWiki release versions prior to 1.11 are not vulnerable, as they do not
12806 include the callback feature which allows client-side JavaScript on other sites
12807 to reach API data.
12808
12809 Changes in this release:
12810
12811 * User credentials are dropped for API JSON requests using a callback
12812 * Edit tokens are not reported for API JSON requests using a callback
12813
12814 == MediaWiki 1.11.1 ==
12815
12816 January 23, 2008
12817
12818 This is a security and bugfix release of the Fall 2007 snapshot release of
12819 MediaWiki. A potential XSS injection vector affecting api.php only for
12820 Microsoft Internet Explorer users has been closed.
12821
12822 Changes in this release:
12823 * (bug [[bugzilla:11450|11450]]) Fix creation of objectcache table on upgrade
12824 * (bug [[bugzilla:11462|11462]]) Fix typo in LanguageGetSpecialPageAliases hook
12825 name
12826 * Fix regression in LinkBatch.php breaking PHP 5.0
12827 * Security fix for API on MSIE
12828
12829 To work around the vulnerability without upgrading, you may disable the API if
12830 you don't need it:
12831 :[[Manual:$wgEnableAPI|$wgEnableAPI]] = false;
12832
12833 Not vulnerable versions:
12834 * 1.12 or later
12835 * 1.11 >= 1.11.1
12836 * 1.10 >= 1.10.3
12837 * 1.9 >= 1.9.5
12838 * 1.8 any version (if $wgEnableAPI has been left off)
12839
12840 Vulnerable versions:
12841 * 1.11 <= 1.11.0rc1
12842 * 1.10 <= 1.10.2
12843 * 1.9 <= 1.9.4
12844 * 1.8 any version (if $wgEnableAPI has been switched on)
12845
12846 MediaWiki 1.7 and below are not affected as they do not include the API
12847 functionality, however the BotQuery extension is similarly vulnerable unless
12848 updated to the latest SVN version.
12849
12850 == MediaWiki 1.11.0 ==
12851
12852 September 10, 2007
12853
12854 This is the Fall 2007 snapshot release of MediaWiki.
12855
12856 MediaWiki is now using a "continuous integration" development model with
12857 quarterly snapshot releases. The latest development code is always kept "ready
12858 to run", and in fact runs our own sites on Wikipedia.
12859
12860 Release branches will continue to receive security updates for about a year
12861 from first release, but nonessential bugfixes and feature developments will be
12862 made on the development trunk and appear in the next quarterly release.
12863
12864 Those wishing to use the latest code instead of a branch release can obtain it
12865 from source control: [[Download from SVN]]
12866
12867 This is the Summer 2007 branch release of MediaWiki.
12868
12869 MediaWiki is now using a "continuous integration" development model with
12870 quarterly snapshot releases. The latest development code is always kept
12871 "ready to run", and in fact runs our own sites on Wikipedia.
12872
12873 Release branches will continue to receive security updates for about a year
12874 from first release, but nonessential bugfixes and feature developments
12875 will be made on the development trunk and appear in the next quarterly release.
12876
12877 Those wishing to use the latest code instead of a branch release can obtain
12878 it from source control: https://www.mediawiki.org/wiki/Download_from_SVN
12879
12880 == Changes since 1.11.0rc1 ==
12881
12882 A possible HTML/XSS injection vector in the API pretty-printing mode has been
12883 found and fixed.
12884
12885 The vulnerability may be worked around in an unfixed version by simply
12886 disabling the API interface if it is not in use, by adding this to
12887 [[Manual:LocalSettings.php|LocalSettings.php]]:<br />
12888 <code>[[Manual:$wgEnableAPI|$wgEnableAPI]] = false;</code> <br />
12889 (This is the default setting in 1.8.x.)
12890
12891 Not vulnerable versions:
12892 * 1.11 >= 1.11.0
12893 * 1.10 >= 1.10.2
12894 * 1.9 >= 1.9.4
12895 * 1.8 >= 1.8.5
12896
12897 Vulnerable versions:
12898 * 1.11 <= 1.11.0rc1
12899 * 1.10 <= 1.10.1
12900 * 1.9 <= 1.9.3
12901 * 1.8 <= 1.8.4 (if [[Manual:$wgEnableAPI|$wgEnableAPI]] has been switched on)
12902
12903 MediaWiki 1.7 and below are not affected as they do not include the faulty
12904 function, however the [[Extension:BotQuery|BotQuery extension]] is similarly
12905 vulnerable unless updated to the latest SVN version.
12906
12907 == Configuration changes since 1.10 ==
12908
12909 * $wgThumbUpright - Adjust width of upright images when parameter 'upright' is
12910 used
12911 * $wgAddGroups, $wgRemoveGroups - Finer control over who can assign which
12912 usergroups
12913 * $wgEnotifImpersonal, $wgEnotifUseJobQ - Bulk mail options for large sites
12914 * $wgShowHostnames - Expose server host names through the API and HTML comments
12915 * $wgSaveDeletedFiles has been removed, the feature is now enabled
12916 unconditionally
12917
12918 == New features since 1.10 ==
12919
12920 * (bug 8868) Separate "blocked" message for autoblocks
12921 * Adding expiry of block to block messages
12922 * Links to redirect pages in categories are wrapped in
12923 <span class="redirect-in-category"></span>
12924 * Introduced 'ImageOpenShowImageInlineBefore' hook; see docs/hooks.txt for
12925 more information
12926 * (bug 9628) Show warnings about slave lag on Special:Contributions,
12927 Special:Watchlist
12928 * (bug 8818) Expose "wpDestFile" as parameter $1 to "uploaddisabledtext"
12929 * Introducing new image keyword 'upright' and corresponding variable
12930 $wgThumbUpright. This allows better proportional view of upright images
12931 related to landscape images on a page without nailing the width of upright
12932 images to a fix value which makes views for anon unproportional and user
12933 preferences useless
12934 * (bug 6072) Introducing 'border' keyword to the [[Image:]] syntax
12935 * Introducing 'frameless' keyword to [[Image:]] syntax which respects the
12936 user preferences for image width like 'thumb' but without a frame.
12937 * (bug 7960) Link to "what links here" for each "what links here" entry
12938 * Added support for configuration of an arbitrary number of commons-style
12939 file repositories.
12940 * Added a Content-Disposition header to thumb.php output
12941 * Improved thumb.php error handling
12942 * Display file history on local image description pages of shared images
12943 * Added $wgArticleRobotPolicies
12944 * (bug 10076) Additional parameter $7 added to MediaWiki:Blockedtext
12945 containing, the ip, ip range, or username whose block is affecting the
12946 * (bug 7691) Show relevant lines from the deletion log when re-creating a
12947 previously deleted article
12948 * Added variables 'wgRestrictionEdit' and 'wgRestrictionMove' for JS to header
12949 * (bug 9898) Allow viewing all namespaces in Special:Newpages
12950 * (bug 10139) Introduce 'EditSectionLink' and 'EditSectionLinkForOther' hooks;
12951 see docs/hooks.txt for details
12952 * (bug 9769) Provide "watch this page" toggle on protection form
12953 * (bug 9886) Provide clear example "stub link" in Special:Preferences
12954 * (bug 10055) Populate email address and real name properties of User objects
12955 passed to the 'AbortNewAccount' hook
12956 * Show result of Special:Booksources in wiki content language always, it's
12957 normally better maintained than the generic list from the standard message
12958 files
12959 * (bug 7997) Allow users to be blocked from using Special:Emailuser
12960 * (bug 8989) Blacklist 'mhtml' and 'mht' files from upload
12961 * (bug 8760) Allow wiki links in "protectexpiry" message
12962 * (bug 5908) Add "DEFAULTSORTKEY" and "DEFAULTCATEGORYSORT" aliases for
12963 "DEFAULTSORT" magic word
12964 * (bug 10181) Support the XCache object caching mechanism
12965 * (bug 9058) Introduce '--aconf' option for all maintenance scripts, to provide
12966 a path to the AdminSettings.php file
12967 * (bug 8781) Remind users to check file permissions for LocalSettings.php
12968 post-installation
12969 * Use shared.css for all skins and oldshared.css in place of common.css for
12970 pre-Monobook skins. As always, modifications should go in-wiki to MediaWiki:
12971 Common.css and MediaWiki:Monobook.css.
12972 * (bug 8869) Introduce Special:Uncategorizedtemplates
12973 * (bug 8734) Different log message when article protection level is changed
12974 * (bug 8458, 10338) Limit custom signature length to $wgMaxSigChars Unicode
12975 characters
12976 * (bug 10096) Added an ability to query interwiki map table
12977 * On reupload, add a null revision to the image description page
12978 * Group log output by date
12979 * Kurdish interface latin/arabic writing system with transliteration
12980 * Support wiki text in all query page headers
12981 * Add 'Orphanedpages' as an alias to Special:Lonelypages
12982 * (bug 9328) Use "revision-info-current" message in place of "revision-info"
12983 when viewing the current revision of a page, if available
12984 * (bug 8890) Enable wiki text for "license" message
12985 * Throw a showstopper exception when a hook function fails to return a value.
12986 Forgetting to give a 'true' return value is a very common error which tends
12987 to cause hard-to-track-down interactions between extensions.
12988 * Use $wgJobClasses to determine the correct Job to instantiate for a particular
12989 queued task; allows extensions to introduce custom jobs
12990 * (bug 10326) AJAX-based page watching and unwatching has been cleaned up and
12991 enabled by default.
12992 * Added option to install to MyISAM
12993 * (bug 9250) Remove hardcoded minimum image name length of three characters
12994 * Fixed DISPLAYTITLE behavior to reject titles which don't normalise to the
12995 same title as the current page, and enabled per default
12996 * Wrap site CSS and JavaScript in a <pre> tag, like user JS/CSS
12997 * (bug 10196) Add classes and dir="ltr" to the <pre>s on CSS and JS pages (new
12998 classes: mw-code, mw-css, mw-js)
12999 * (bug 6711) Add $wgAddGroups and $wgRemoveGroups to allow finer control over
13000 usergroup assignment.
13001 * Introduce 'UserEffectiveGroups' hook; see docs/hooks.txt for more information
13002 * (bug 10387) Detect and handle '.php5' extension environments at install time
13003 * Introduce 'ShowRawCssJs' hook; see docs/hooks.txt for more information
13004 * (bug 10404) Show rights log for the selected user in Special:Userrights
13005 * New javascript for upload page that will show a warning if a file with the
13006 "destination filename" already exists.
13007 * Add 'editsection-brackets' message to allow localization (or removal) of the
13008 brackets in the "[edit]" link for sections
13009 * (bug 10437) Move texvc styling to shared.css
13010 * Introduce "raw editing" mode for the watchlist, to allow bulk additions,
13011 removals, and convenient exporting of watchlist contents
13012 * Show "undo" links in page histories
13013 * Option to jump to specified time period in user contributions
13014 * Improved feedback on "rollback success" page
13015 * Show distinct 'namespaceprotected' message to users when namespace protection
13016 prevents page editing
13017 * (bug 9936) Per-edit suppression of preview-on-first edit with "preview=no"
13018 * Allow showing a one-off preview on first edit with "preview=yes"
13019 * (bug 9151) Remove timed redirects on "Return to X" pages for accessibility.
13020 * Link to user logs in toolbox when viewing a user page
13021 * (bug 10508) Allow HTML attributes on <gallery>
13022 * (bug 1962) Allow HTML attributes on <math>
13023 * (bug 10530) Introduce optional "sp-contributions-explain" message for
13024 additional explanation in Special:Contributions
13025 * (bug 10520) Preview licences during upload via AJAX (toggle with
13026 $wgAjaxLicensePreview)
13027 * New Parser::setTransparentTagHook for parser extension and template
13028 compatibility
13029 * Introduced 'ContributionsToolLinks' hook; see docs/hooks.txt for more
13030 information
13031 * Add a message if category is empty
13032 * Add CSS compatibility for Opera 9.5
13033 * Remove largely untested handheld stylesheet, which was causing more trouble
13034 than good. Proper handheld support will be added at a future date. For now,
13035 display should be acceptable either with CSS turned off or when using a so-
13036 phisticated handheld browser.
13037 * (bug 3173) Option to offer exported pages as a download, rather than displaying
13038 inline, as in most browsers
13039 * Pass the user as an argument to 'isValidPassword' hook callbacks; see
13040 docs/hooks.txt for more information
13041 * Introduce 'UserGetRights' hook; see docs/hooks.txt for more information
13042 * (bug 9595) Pass new Revision to the 'ArticleInsertComplete' and
13043 'ArticleSaveComplete' hooks; see docs/hooks.txt for more information
13044 * (bug 9575) Accept upload description from GET parameters
13045 * Skip the difference engine cache when 'action=purge' is used while requesting
13046 a difference page, to allow refreshing the cache in case of errors
13047 * (bug 10701) Link to Special:Listusers in default Special:Statistics messages
13048 * Improved file history presentation
13049 * (bug 10739) Users can now enter comments when reverting files
13050 * Improved handling of permissions errors
13051 * (bug 10793) "Mark patrolled" links will now be shown for users with
13052 patrol permissions on all eligible diff pages
13053 * (bug 10655) Show standard tool links for blocked users in block log messages
13054 * Show standard tool links for blocked users in Special:Ipblocklist
13055 * Miscellaneous aesthetic improvements to Special:Ipblocklist
13056 * (bug 10826) Added link trail with Cyrillic characters for Mongolian language
13057 * (bug 10859) Introduce 'UserGetImplicitGroups' hook; see docs/hooks.txt for
13058 more information
13059 * (bug 10832) Include user information when viewing a deleted revision
13060 * (bug 10872) Fall back to sane defaults when generating protection selector
13061 labels for custom restriction levels
13062 * Show edit count in user preferences
13063 * Improved support for audio/video extensions
13064 * (bug 10937) Distinguish overwritten files in upload log
13065 * Introduce 'ArticleUpdateBeforeRedirect' hook; see docs/hooks.txt for more
13066 information
13067 * Confirmation is now required when deleting old versions of files
13068 * (bug 7535) Users can now enter comments when deleting old versions of files
13069 * (bug 11001) Submit Special:Newpages as a GET, rather than a POST request
13070 * The <strong></strong> around links to watched pages in change lists now
13071 has a class - "mw-watched"
13072 * (bug 9002) Provide a "view/restore deleted edits" link on Special:Upload
13073 when a destination filename is provided that corresponds with previous
13074 deleted files
13075 * Make the "invalid special page" message clearer
13076 * Add accesskey 's' and tooltip to 'upload file' button at Special:Upload
13077 * Introduced 'SkinAfterBottomScripts' hook; see docs/hooks.txt for
13078 more information
13079 * (bug 11095) Honour "preview on first edit" preference when preloading
13080 text for a non-existent page
13081 * (bug 11022) Use a more accurate page title for Special:Whatlinkshere and
13082 Special:Recentchangeslinked
13083 * Add link to user contributions in normal watchlist edit mode
13084 * (bug 9426) Add 'newsectionheaderdefaultlevel' message to allow
13085 modification of the heading formatting for new sections when section=new
13086 argument is supplied
13087 * (bug 10836) Add 'newsectionsummary' message to allow modification of the
13088 text that prefixes a new section link in Recent Changes
13089
13090 == Bugfixes since 1.10 ==
13091
13092 * (bug 9712) Use Arabic comma in date/time formats for Arabic and Farsi
13093 * (bug 9670) Follow redirects when render edit section links to transcluded
13094 templates.
13095 * (bug 6204) Fix incorrect unindentation with $wgMaxTocLevel
13096 * (bug 3431) Suppress "next page" link in Special:Search at end of results
13097 * Don't show unblock form if the user doesn't have permission to use it
13098 (cosmetic change, no vulnerabilities existed)
13099 * Subtitle success message when unblocking a block ID instead of a pseudo link
13100 like [[User:#123|#123]]
13101 * Use the standard HTTP fetch functions when retrieving remote wiki pages
13102 through transwiki, so we can take advantage of cURL goodies if available
13103 * Disable user JavaScript on Special:Userlogin, Special:Resetpass and
13104 Special:Preferences, to avoid a compromised script sniffing passwords, etc.
13105 * (bug 9854, 3770) Clip overflow text in gallery boxes for visual cleanliness
13106 instead of letting it flow outside the box or trigger ugly scroll bars.
13107 * Tooltips for print version and permalink
13108 * Links to the MediaWiki namespace for system messages having their default
13109 values are no longer shown as nonexistent (e.g., in red)
13110 * Special:Ipblocklist differentiates between empty list and no search results.
13111 * (bug 5375) profiling does not respect read-only mode.
13112 * (bug 7070) monobook/user.gif has antialias artifacts
13113 * (bug 9123) Safer way when applying $wgLocalTZoffset
13114 * (bug 9896) Documentation for $wgSquidServers and X-FORWARDED-FOR
13115 * (bug 9417) Uploading new versions of images when using Postgres no longer
13116 throws warnings.
13117 * (bug 9908) Using tsearch2 with Postgres 8.1 no longer gives an error.
13118 * (bug 1438) Fix for diff table layout on very wide lines.
13119 Diff style rules have been broken out to common/diff.css,
13120 and the dupes removed from the default skin files.
13121 Skins can still override the default rules.
13122 * (bug 1229) Balance columns in diff display evenly
13123 * Right-align diff line numbers in RTL language display
13124 * (bug 9332) Fix instructions in tests/README
13125 * (bug 9813) Reject usernames containing '#' to avoid silent truncation
13126 of fragments during the normalisation process
13127 * (bug 7989) RSS feeds content now use black text when using white background.
13128 * (bug 9971) Typo in a french language message.
13129 * (bug 9973) Changed size was shown in advanced recentchanges collapsible items
13130 with $wgRCShowChangedSized = false.
13131 * Fix PHP strict standards warning in enhanced recent changes.
13132 * (bug 5850) Added hexadecimal html entities comments for $digitTransformTable
13133 entries.
13134 * (bug 7432) Change language name for Aromanian (roa-rup)
13135 * (bug 908) Unexistent special pages now generate a red link.
13136 * (bug 7899) Added \hline and \vline to the list of allowed TeX commands
13137 * (bug 7993) support mathematical symbol classes
13138 * (bug 10007) Allow Block IP to work with Postgrs again.
13139 * Add Google Wireless Transcoder to the Unicode editing blacklist
13140 * (bug 10083) Fix for Special:Version breakage on PHP 5.2 with some hooks
13141 * (bug 3624) TeX: \ker, \hom, \arg, \dim treated like \sin & \cos
13142 * (bug 10132, 10134) Restore back-compatibility Image::imageUrl() function
13143 * (bug 10113) Fix double-click for view source on protected pages
13144 * (bug 10117) Special:Wantedpages doesn't handle invalid titles in result
13145 set [now prints out a warning]
13146 * (bug 10118) Introduced Special:Mostlinkedtemplates, report which lists
13147 templates with a high number of inclusion links
13148 * (bug 10104) Fixed Database::getLag() for PostgreSQL and Oracle
13149 * (bug 9820) session.save_path check no longer halts installation, but
13150 warns of possible bad values
13151 * (bug 9978) Fixed session.save_path validation when using extended
13152 configuration format, e.g. "5;/tmp"
13153 * Don't generate a diff link in the patrol log if the page doesn't exist
13154 * (bug 10067) Translations for former skins removed from message files
13155 * (bug 9993) Force $wgShowExceptionDetails on during installation
13156 * (bug 9980) Validate administrator username and password during
13157 installation
13158 * (bug 9383) Don't set a default value for BLOB column in rc-deleted
13159 database patch
13160 * (bug 10149) Don't show full template list on section-0 edit
13161 * (bug 9909) Ensure access to binary fields in the math table use encodeBlob()
13162 and decodeBlob()
13163 * (bug 6743) Don't link broken image links to the upload form when uploads
13164 are disabled
13165 * (bug 9679) Improve documentation for $wgSiteNotice
13166 * (bug 10215) Show custom editing introduction when editing existing pages
13167 * (bug 10223) Fix edit link in noarticletext localizations for fr, oc
13168 * (bug 10247) Fix IP address regex to avoid false positive IPv6 matches
13169 * (bug 9948) Workaround for diff regression with old Mozilla versions
13170 * (bug 10265) Fix regression in category image gallery paging
13171 * (bug 8577) Fix some weird misapplications of time zones.
13172 {{CURRENT*}} functions now consistently use UTC as intended, while
13173 {{LOCAL*}} functions return local time per server config or $wgLocaltimezone.
13174 Signature dates for Japanese and other languages including weekday now show
13175 the correct day to match the rest of the time in local time.
13176 * Escape the output of magic variables that return page name or part of it
13177 * (bug 10309) Initialise parser state properly in extractSections(), fixes
13178 some cases where section edits broke because tags were improperly stripped
13179 * Avoid PHP notice errors when doing HTTP proxy purges for an empty list
13180 * As intended, *skip* the HTTP proxy purges when doing HTCP purges
13181 * (bug 9696) Fix handling of brace transformations in "pagemovedtext"
13182 * (bug 10325) Fix regression in form action on Special:Listusers
13183 * Fixed installation on MyISAM or old InnoDB with charset=utf8, was giving
13184 overlong key errors.
13185 * Fixed zero-padding issues with MySQL 5 binary schema
13186 * (bug 10344) Don't follow a redirect after changing its protection level
13187 * (bug 10333) Correct date format in Slovenian
13188 * (bug 10160) Show error message for unknown namespace on Special:Allpages and
13189 Special:Prefixindex; making forms prettier for RTL wikis.
13190 * (bug 10334) Replace normal spaces before percent (%) signs with non-breaking
13191 spaces
13192 * (bug 10372) namespaceDupes.php no longer ignores namespace aliases
13193 * (bug 10198) namespaceDupes.php no longer ignores interwiki prefixes
13194 * namespaceDupes.php should work better for initial-lowercase wikis
13195 * (bug 10377) "Permanent links" to revisions still work if the page is moved
13196 and the redirect deleted
13197 * (bug 7071) Properly handle an 'oldid' passed to view or edit that doesn't
13198 match the given title. Fixes inconsistencies with talk, history, edit links.
13199 * (bug 10397) Fix AJAX watch error fallback when we receive a bogus result
13200 * (bug 10396) Fix AJAX error when $wgScriptPath/index.php is not valid;
13201 using $wgScript now included in JS info
13202 * Use native XMLHttpRequest class in preference to ActiveX on IE 7; this
13203 avoids the "ActiveX "Do you want to allow ActiveX?" prompt when something
13204 security settings are cranked this way and AJAX-y gets used.
13205 * Delay AJAX watch initialization until click so IE 6 with ugly security
13206 settings doesn't prompt you until you use the link.
13207 * (bug 10401) Provide non-redirecting link to original title in Special:Movepage
13208 * Fix broken handling of log views for page titles consisting of one
13209 or more zeros, e.g. "0", "00" etc.
13210 * Fix read permission check for special pages with subpage parameters, e.g.
13211 Special:Confirmemail
13212 * Fix read permission check for unreadable page titles which are numerically
13213 equivalent to a whitelisted title
13214 * '?>' closing tag removed from all files to help avoid problems with extraneous
13215 whitespace (broken XML feeds, etc.)
13216 * Don't use garbled parser cache output when viewing custom CSS or JavaScript
13217 pages
13218 * (bug 10406) Fix Special:Listusers filter form for non-ASCII localizations
13219 * Fix empty message checks for message names containing &
13220 This corrects some odd behavior with sidebar items and custom namespaces
13221 containing ampersands.
13222 * (bug 10375) Change thousands separator character to &nbsp; for Latin (la)
13223 * (bug 10477) Fix AJAX watch for Farsi on Firefox: JavaScript encoding tweak
13224 * (bug 10496) Fix broken DISTINCT option logic in database backend
13225 * Fix CSS media declaration for "screen, projection"; was causing some
13226 validation issues
13227 * (bug 10495) $wgMemcachedDebug set twice in includes/DefaultSettings.php
13228 * (bug 10316) Prevent inconsistent cached skin settings in gen=js by setting
13229 the intended skin directly in the URL.
13230 * (bug 9903) Don't mark redirects in categories as stubs
13231 * (bug 6965) Cannot include "Template:R" with {{R}} (magic word conflict)
13232 * Padding parser functions now work with strings like '0' that evaluate to false
13233 * (bug 10332) Title->userCan( 'edit' ) may return false positive
13234 * Fix bug with <nowiki> in front of links for wikis where linkPrefixExtension is true
13235 * (bug 10552) Suppress rollback link in history for single-revision pages
13236 * (bug 10538) Gracefully handle invalid input on move success page
13237 * Fix for Esperanto double-x-encoding in move success page
13238 * (bug 10526) Fix toolbar/insertTags behavior for IE 6/7 and Opera (8+)
13239 Now matches the selection behavior on Mozilla / Safari.
13240 Patch by Alex Smotrov.
13241 * Don't show non-functional toolbar buttons on Opera 7 anymore
13242 * (bug 9151) Fix relative subpage links with section fragments
13243 * (bug 10560) Adding a space between category letter heading and "continues"
13244 * (bug 4650) Keep impossibly large/small counts off Special:Statistics
13245 * (bug 10608) PHP notice when installing with PostgreSQL
13246 * (bug 10615) Fix for transwiki import when CURL not available
13247 * (bug 8054) Return search page for empty search requests with ugly URLs
13248 * (bug 10572) Force refresh after clearing visitation timestamps on watchlist
13249 * (bug 10631) Warn when illegal characters are removed from filename at upload
13250 * Fix several JavaScript bugs under MSIE 5/Macintosh
13251 * (bug 10591) Use Arabic numerals (0,1,2...) for the Malayam language
13252 * (bug 10642) Fix shift-click checkbox behavior for Opera 9.0+ and 6.0
13253 * Work around Safari bug with pages ending in ".gz" or ".tgz"
13254 * Removed obsolete maintenance/changeuser.sql script; use RenameUser extension
13255 * (bug 2735) "Preview" shown in title bar for action=submit on special pages
13256 * Removed "restore" links from the deletion log embedded in Special:Undelete
13257 * Improved error reporting and robustness for file delete/undelete.
13258 * Improved speed of file delete by storing the SHA-1 hash in image/oldimage
13259 * Fixed leading zero in base 36 SHA-1 hash
13260 * Protection form no longer produces JavaScript errors
13261 * (bug 10741) File histories show "delete" links for non-sysops
13262 * (bug 10744) Treat "noarticletext" and "noarticletextanon" as wiki text when
13263 used on a non-existent page with "action=info"
13264 * Fix escaping of raw message text when used on a non-existent page with
13265 "action=info"
13266 * (bug 10683) Fix inconsistent handling of URL-encoded titles in links
13267 used in redirects (i.e. they now work)
13268 * (bug 8878) Changes to $dateFormats in German localization (removing unused,
13269 nonexistent formats, putting time after date)
13270 * (bug 10769) Database::update() should return boolean result
13271 * Fix preference checkbox display for right-to-left languages which caused
13272 them to be hidden in IE in some cases
13273 * Fix upload form display in right-to-left languages
13274 * Fixed regression in blocking of username '0'
13275 * (bug 9437) Don't overwrite edit form submission handler when setting up
13276 edit box scroll position preserve/restore behavior
13277 * (bug 10805) Fix "undo" link when viewing the diff of the most recent
13278 change to a page using "diff=0"
13279 * (bug 10765) img_auth.php will now refuse logged-out requests where
13280 $wgWhitelistRead is undefined, instead of (incorrectly) honouring them
13281 * Fixed img_auth.php file name extraction for whitelist checking
13282 * Tweak spacing of email preference display
13283 * Table sorting JavaScript prefers textContent over innerText to allow hidden
13284 sort keys to work on Safari
13285 * (bug 4530) Fix local name of Kurdish language
13286 * (bug 10830) Fix local name of Haitian Creole language
13287 * Fix invalid XHTML in Special:Protectedpages
13288 * Fix comments in contributions and log pages for right-to-left languages
13289 * Make installer include_path-independent, so it should work on hosts which
13290 disable user setting of PHP include_path setting
13291 * glob() is horribly unreliable and doesn't work on some systems, including
13292 free.fr shared hosting. No longer using it in Language::getLanguageNames()
13293 * (bug 10763) Fix multi-insert logic for PostgreSQL
13294 * Fix invalid XHTML when viewing a deleted revision
13295 * Fix syntax error in translations of magic words in Romanian language
13296 * (bug 8737) Fix warnings caused by incorrect use of `/dev/null` when piping
13297 process error output under Windows
13298 * (bug 7890) Don't list redirects to special pages in Special:BrokenRedirects
13299 * (bug 10783) Resizing PNG-24 images with GD no longer causes all alpha
13300 channel transparency to be lost and transparent pixels to be turned black
13301 * (bug 9339) General error pages were transforming messages and their parameters
13302 in the wrong order
13303 * (bug 9026) Incorrect heading numbering when viewing Special:Statistics with
13304 "auto-numbered headings" enabled
13305 * Fixed invalid XHTML in Special:Upload
13306 * (bug 11013) Make sure dl() is available before attempting to use it to check
13307 available databases in installer
13308 * Resizing transparent GIF images with GD now retains transparency by skipping
13309 resampling
13310 * (bug 11065) Fix regression in handling of wiki-formatted EXIF metadata
13311 * Double encoding broke Special:Newpages for some languages
13312 * Adding a newline before the statistics footer, to prevent parsing problems
13313 * Preventing the TOC from appearing in Special:Statistics
13314 * (bug 11082) Fix check for fully-specced table names in Database::tableName
13315 * (bug 11067) Fix regression in upload conflict thumbnail display
13316 * (bug 10985) Resolved cached entries on Special:DoubleRedirects were being
13317 suppressed, breaking paging - now strikes out "fixed" results
13318 * (bug 8393) <sup> and <sub> need to be preserved (without attributes) for
13319 entries in the table of contents
13320 * (bug 11114) Fix regression in read-only mode error display during editing
13321 * Force non-MySQL databases to use an ORDER BY in SpecialAllpages to ensure
13322 that the first page_title is truly the first page title.
13323 * (bug 10836) Change the summary on creating of new section
13324 * Inclusion of Special:Wantedpages now works again
13325
13326 == API changes since 1.10 ==
13327
13328 Full API documentation is available at https://www.mediawiki.org/wiki/API
13329
13330 * New properties: links, templates, images, langlinks, categories, external
13331 links
13332 * Breaking Change: imagelinks renamed into imageusage (il->iu)
13333 * Bug fix: incorrect generator behavior in some cases
13334 * JSON format allows an optional callback function to wrap the result.
13335 * Login module disabled until a more secure solution can be implemented
13336 * (bug 9938) Querying by revision identifier returns the most recent revision
13337 for the corresponding page, rather than the requested revision
13338 * (bug 8772) Filter page revision queries by user
13339 * (bug 9927) User contributions queries do not accept IP addresses
13340 * Watchlist feed now reports a proper feed item when the user is not logged in
13341 * Watchlist feed date bug fixed - automatically shows one last day
13342 * Watchlist feed now allows to specify number of hours to monitor
13343 * list=allpages now returns a list instead of a map in JSON format
13344 * Breaking Change: in json, revisions are now returned as a list, not as a map.
13345 * Add: prop=info can show page is new flag, current page length, and visit
13346 counter.
13347 * Change: Query watchlist now shows flags only when explicitly requested with
13348 wlparam=flags
13349 * rc_this_oldid (textid) is no longer accessible from query watchlist
13350 * action=usercontribs: additional filtering by ucshow=; selection of needed
13351 fields with ucprop=; the textid (rev_text_id) is no longer being exposed
13352 * (bug 9970) Breaking Change: backlinks, embeddedin and imageusage now return
13353 lists in JSON instead of a map, and do not return anything when titles do
13354 not exist
13355 * (bug 9121) Introduced indexpageids query parameter to list the page_id
13356 values of all returned page items
13357 * (bug 10147) Now interwiki titles are not processed but added to a separate
13358 "interwiki" section of the output.
13359 * Added categorymembers list to query for pages in a category.
13360 * (bug 10260) Show page protection status
13361 * (bug 10392) Include MediaWiki version details in version output
13362 * (bug 10411) Site language in meta=siteinfo
13363 * (bug 10391) action=help doesn't return help if format is fancy markup
13364 * backlinks, embeddedin and imageusage lists should use (bl|ei|iu)title parameter
13365 instead of titles. Titles for these lists is obsolete and might stop working soon.
13366 * Added prop=imageinfo - gets image properties and upload history
13367 * (bug 10211) Added db server replication lag information in meta=siteinfo
13368 * Added external url search within wiki pages (list=exturlusage)
13369 * Added link enumeration (list=alllinks)
13370 * Added registered users enumeration (list=allusers)
13371 * Added full text search in titles and content (list=search)
13372 * (bug 10684) Expanded list=allusers functionality
13373 * Possible breaking change: prop=revisions no longer includes pageid for rvprop=ids
13374 * Added rvprop=size to prop=revisions (The size will not be shown if it is NULL in the database)
13375 * list=allpages now allows to filter by article min/max size and protection status
13376 * Added site statistics (siprop=statistics for meta=siteinfo)
13377 * (bug 10902) Unable to fetch user contributions from IP addresses
13378 * `list=usercontribs` no longer requires that the user exist
13379 * (bug 10971) `aufrom` parameter doesn't work with spaces
13380 * Fix username handling issue with `auprefix` parameter
13381 * Treat underscores as spaces for `aufrom` and `auprefix` parameters
13382 * Added edit/delete/... token retrieval to prop=info
13383 * Added meta=userinfo - logged-in user information, group membership, rights
13384 * (bug 11072) Fix regression in API image history query
13385 * (bug 11115) Adding SHA1 hash to imageinfo query
13386 * (bug 10898) API does not return an edit token for non-existent pages
13387 * (bug 10890) Timestamp support for categorymembers query
13388 * (bug 10980) Add exclude redirects on backlinks
13389 * IPv6 titles in User namespace are normalized (run cleanupTitles.php to fix any old stray pages)
13390
13391 == Maintenance script changes since 1.10 ==
13392
13393 * Add support for wgMaxTocLevel option in parserTests
13394 * (bug 6823) Disable article view counter in maintenance/dumpHTML.php
13395 * Fix maintenance/importImages.php so it doesn't barf PHP errors when no
13396 suitable files are found, and make the list of extensions an option (defaults
13397 to $wgFileExtensions)
13398 * Add option to maintenance/createAndPromote.php to give the user bureaucrat
13399 permissions (--bureaucrat)
13400 * Allow overwriting existing files with a conflicting name using
13401 maintenance/importImages.php
13402 * (bug 10266) Use native newlines when rebuilding a messages file.
13403
13404 == Languages updated since 1.10 ==
13405
13406 * Afrikaans (af)
13407 * Arabic (ar)
13408 * Bikol (bcl)
13409 * Bulgarian (bg)
13410 * Catalan (ca)
13411 * Danish (da)
13412 * German (de)
13413 * Greek (el)
13414 * Esperanto (eo)
13415 * Spanish (es)
13416 * Estonian (et)
13417 * Extremaduran (ext)
13418 * Farsi (fa)
13419 * Finnish (fi)
13420 * Vöro (fiu-vro)
13421 * French (fr)
13422 * Français Cadien (frc) (new)
13423 * Franco-Provençal/Arpetan (frp)
13424 * Galician (gl)
13425 * Hakka (hak)
13426 * Hebrew (he)
13427 * Upper Sorbian (hsb)
13428 * Haitian (ht)
13429 * Indonesian (id)
13430 * Icelandic (is)
13431 * Italian (it)
13432 * Japanese (ja)
13433 * Georgian (ka)
13434 * Kabyle (kab)
13435 * Kazakh (kk)
13436 * Korean (ko)
13437 * Kinaray-a (krj) (new)
13438 * Kurdish (ku)
13439 * Latin (la)
13440 * Lao (lo)
13441 * Lithuanian (lt)
13442 * Latviešu (lv)
13443 * Malayalam (ml)
13444 * Bahasa Melayu (ms)
13445 * Burmese (my)
13446 * Low German (nds)
13447 * Dutch (nl)
13448 * Norwegian (no)
13449 * Occitan (oc)
13450 * Punjabi (Gurmukhi) (pa)
13451 * Polish (pl)
13452 * Piedmontese (pms)
13453 * Portuguese (pt)
13454 * Romani (rmy)
13455 * Romanian (ro)
13456 * Aromanian (roa-rup)
13457 * Russian (ru)
13458 * Sakha (sah)
13459 * Sango (se) (new)
13460 * Slovak (sk)
13461 * Slovenian (sl)
13462 * Shona (sn)
13463 * Somali (so)
13464 * Albanian (sq)
13465 * Sundanese (su)
13466 * Swedish (sv)
13467 * Tamil (ta)
13468 * Thai (th)
13469 * Tigrinya (ti)
13470 * Setswana (tn)
13471 * Tok Pisin (tpi)
13472 * Uyghur (ug)
13473 * Volapük (vo)
13474 * Winaray (war) (new)
13475 * Yiddish (yi)
13476 * Old Chinese / Late Middle Chinese (zh-classical)
13477 * Chinese (PRC) (zh-cn)
13478 * Chinese (Taiwan) (zh-tw)
13479 * Cantonese (zh-yue)
13480
13481 == MediaWiki 1.10 ==
13482
13483 == MediaWiki 1.10.4 ==
13484
13485 March 2, 2008
13486
13487 * Correction for API path fix, broken in 1.10.3
13488
13489 == MediaWiki 1.10.3 ==
13490
13491 January 23, 2008
13492
13493 This is a security update to the Winter 2007 quarterly release. A potential
13494 XSS injection vector affecting api.php only for Microsoft Internet Explorer
13495 users has been closed.
13496
13497
13498 To work around the vulnerability without upgrading, you may disable the API if
13499 you don't need it:
13500
13501 :[[Manual:$wgEnableAPI|$wgEnableAPI]] = false;
13502
13503 Not vulnerable versions:
13504 * 1.12 or later
13505 * 1.11 >= 1.11.1
13506 * 1.10 >= 1.10.3
13507 * 1.9 >= 1.9.5
13508 * 1.8 any version (if $wgEnableAPI has been left off)
13509
13510 Vulnerable versions:
13511 * 1.11 <= 1.11.0rc1
13512 * 1.10 <= 1.10.2
13513 * 1.9 <= 1.9.4
13514 * 1.8 any version (if $wgEnableAPI has been switched on)
13515
13516 MediaWiki 1.7 and below are not affected as they do not include the API
13517 functionality, however the BotQuery extension is similarly vulnerable unless
13518 updated to the latest SVN version.
13519
13520 == MediaWiki 1.10.2 ==
13521 September 10, 2007
13522
13523 This is a security fix update to the Spring 2007 quarterly release snapshot. A
13524 possible HTML/XSS injection vector in the API pretty-printing mode has been
13525 found and fixed.
13526
13527 The vulnerability may be worked around in an unfixed version by simply
13528 disabling the API interface if it is not in use, by adding this to
13529 LocalSettings.php:
13530 :[[Manual:$wgEnableAPI|$wgEnableAPI]] = false;
13531
13532 Not vulnerable versions:
13533 * 1.11 >= 1.11.0
13534 * 1.10 >= 1.10.2
13535 * 1.9 >= 1.9.4
13536 * 1.8 >= 1.8.5
13537
13538 Vulnerable versions:
13539 * 1.11 <= 1.11.0rc1
13540 * 1.10 <= 1.10.1
13541 * 1.9 <= 1.9.3
13542 * 1.8 <= 1.8.4 (if $wgEnableAPI has been switched on)
13543
13544 MediaWiki 1.7 and below are not affected as they do not include the faulty
13545 function, however the BotQuery extension is similarly vulnerable unless updated
13546 to the latest SVN version.
13547
13548 == MediaWiki 1.10.1 ==
13549 July 13, 2007
13550
13551 This is a bugfix update to the Spring 2007 quarterly release snapshot. A number
13552 of fixes to improve compatibility with PostgreSQL, some versions of MySQL, and
13553 some PHP configurations are included.
13554
13555 Changes since 1.10.0:
13556
13557 * (bug [[bugzilla:9417|9417]]) Uploading new versions of images when using
13558 Postgres no longer throws warnings.
13559 * (bug [[bugzilla:9908|9908]]) Using tsearch2 with Postgres 8.1 no longer gives
13560 an error.
13561 * (bug [[bugzilla:9973|9973]]) Changed size was shown in advanced recentchanges
13562 collapsible items with $wgRCShowChangedSized = false.
13563 * Fixed installation on MyISAM or old InnoDB with charset=utf8, was giving
13564 overlong key errors.
13565 * Fixed zero-padding issues with MySQL 5 binary schema
13566 * (bug [[bugzilla:9820|9820]]) session.save_path check no longer halts
13567 installation, but warns of possible bad values
13568 * (bug [[bugzilla:9978|9978]]) Fixed session.save_path validation when using
13569 extended configuration format, e.g. "5;/tmp"
13570
13571 == MediaWiki 1.10.0 ==
13572 May 9, 2007
13573
13574 This is the quarterly release snapshot for Spring 2007. See below for a full
13575 list of changes since the 1.9.x series.
13576
13577 Changes since 1.10.0rc2:
13578
13579 * (bug [[bugzilla:9808|9808]]) Fix regression that ignored user 'rclimit'
13580 option for Special:Contributions
13581
13582 == MediaWiki 1.10.0rc2 ==
13583 May 4, 2007
13584
13585 THIS IS A RELEASE CANDIDATE MADE AVAILABLE FOR TESTING!
13586 A FINAL 1.10.0 RELEASE WILL APPEAR WITHIN A FEW DAYS.
13587
13588 Changes since 1.10.0rc1:
13589 * Various l10n fixes and updates
13590 * Fix for upgrade of page_restrictions table
13591 * (bug [[bugzilla:9780|9780]]) Fix normalization of titles with initial colon
13592 followed by whitespace
13593 * Fix for regression in upload: wrong size info saved into image table
13594 * Avoid cyclic stub problems when authorization hooks do funny things with the
13595 user and the database at load time
13596
13597 == MediaWiki 1.10.0rc1 ==
13598 This is the Spring 2007 branch release of MediaWiki.
13599
13600 MediaWiki is now using a "continuous integration" development model with
13601 quarterly snapshot releases. The latest development code is always kept
13602 "ready to run", and in fact runs our own sites on Wikipedia.
13603
13604 Release branches will continue to receive security updates for about a year
13605 from first release, but nonessential bugfixes and feature developments
13606 will be made on the development trunk and appear in the next quarterly release.
13607
13608 Those wishing to use the latest code instead of a branch release can obtain
13609 it from source control: https://www.mediawiki.org/wiki/Download_from_SVN
13610
13611 == Configuration changes ==
13612
13613 * A new switch $wgCommandLineDarkBg used by maintenance scripts (parserTests.php).
13614 It lets you specify if your terminal use a dark background, the colorized
13615 output will be made lighter making things easier to read.
13616 * The minimum permissions needed to edit a page in each namespace can now be
13617 customized via the $wgNamespaceProtection array. By default, editing pages in
13618 the MediaWiki namespace requires "editinterface" permission, as before.
13619 * Allow restriction of autoconfirmed permission by edit count. New global setting
13620 $wgAutoConfirmCount (defaulting to zero, naturally).
13621 * Added rate limiter for Special:Emailuser
13622 * Private logs can now be created using $wgLogRestrictions
13623 * (Bug 8590) limited HTML is now always enabled ($wgUserHtml = true).
13624 * Deprecated $wgUseImageResize, thumbnailing will be enabled unconditionally.
13625
13626 == New features since 1.9 ==
13627
13628 * (bug 6937) Introduce "statistics-footer" message, appended to
13629 Special:Statistics
13630 * (bug 6638) List block flags in block log entries
13631 * (bugs 5051, 5376) Tooltips and accesskeys no longer require JavaScript
13632 * Added SkinTemplateOutputPageBeforeExec hook before SkinTemplate::outputPage()
13633 starts page output
13634 (http://lists.wikimedia.org/pipermail/wikitech-l/2007-January/028554.html)
13635 * Introduce "cascading protection" -- implicit protection on pages transcluded
13636 into a page protected with this option enabled
13637 * (bug 8567) Added hook RawPageViewBeforeOutput just before the text is blown
13638 out in action=raw, so extensions might influence the output.
13639 * (bug 3446) Add user preference to hide page content below diffs, can be
13640 overridden by adding diffonly=1 or diffonly=0 to the URL of the diff page
13641 * Add 'purge' privilege to replace the hardcoded check for login state in
13642 determining whether action=purge can be done via GET. Switching the
13643 permission on for anons can be helpful for benchmarking.
13644 * (bug 7842) Link back to deleted revision list from deleted revision preview
13645 * (bug 8619) Add user-aware "unblock" link to Special:Blockip
13646 * (bug 8522) Provide a "delete" link on Special:Brokenredirects for users with
13647 the appropriate permission
13648 * (bug 8628) Add user-aware block list link to Special:Blockip
13649 * (bug 8621) Log revisions marked as patrolled
13650 * Introduce "BookInformation" hook; see docs/hooks.txt for more details
13651 * Add title prefix search for Special:Undelete
13652 * Remove full-archive list from Special:Undelete
13653 * (bug 8136) Introduce 'ArticleUndelete' hook; see docs/hooks.txt for more info
13654 * (bug 8712) Expose user groups as a JavaScript global
13655 * Introduce 'CustomEditor' hook; see docs/hooks.txt for more information
13656 * New special page, Special:Protectedpages, which shows all protected pages
13657 and their protection status (full protection status is not pulled out due
13658 to performance considerations, so it just shows "full protected" or
13659 "semi protected".
13660 * (bug 4133) Allow page protections to be made with an expiry date, in the same
13661 format as block expiry dates. Existing protections are assumed to be infinite,
13662 as are protections made with the new field left blank.
13663 * (bug 8535) Allow certain vertical alignment attributes to be used as image
13664 keywords
13665 * (bug 6987) Allow perrow, widths, and heights attributes for <gallery>
13666 * (bug 3678) Allow disabling MediaWiki:Aboutsite in the same way as
13667 MediaWiki:Disclaimers; Also means that if any of the footer links are
13668 disabled in the wiki's default language (by setting to "-"), they'll also
13669 be disabled in other languages too (e.g. if the user specifies uselang=fr).
13670 * Sort log types in Special:Log
13671 * Added a classname ("mw-toolbar-editbutton") and unique IDs to the edit
13672 toolbar buttons
13673 * Hide irrelevant block options in Special:Blockip based on whether an
13674 IP address/range or username is listed. (Dynamic using JS.)
13675 * (bug 9032) Make quickbarSettings localizable through Special:Allmessages
13676 * (bug 7782) Standardisation of file info at image description pages.
13677 * (bug 1035) View contributions / recentchanges for an IP range.
13678 * (bug 8747) When unwatching pages from Special:Watchlist/edit, put the
13679 confirmation messages in a proper list with a CSS class and id.
13680 * (bug 9118) Show relevant log fragments on deletion confirmatio page
13681 * (bug 9009) Add username entry field to Special:Contributions
13682 * (bug 1723) Article size in history
13683 * (bug 9223) Disallow magic tilde sequences in page titles and usernames
13684 * (bug 6997) Link from Special:log/block to unblock form
13685 * (bug 9117) Link from Special:log/delete to undelete form
13686 * Link from Special:log/protect to change protection form
13687 * (bug 1196) Add IPv6 support added to blocks, more consistancy for IPv6 contribs
13688 * (bug 3984) Searching in logs by title%
13689 * Show thumbnail of existing image if image exists already under this filename
13690 * (bug 5546) Watchlist reflects logged actions like move, protection, undelete
13691 * Support protocols other than HTTP in LinkFilter, use $wgUrlProtocols
13692 * (bug 3069) Warning on upload of scaled down images
13693 * Warning on upload of images with uppercase extension if image with lowercase
13694 extension exists
13695 * (bug 4624) Namespace selection for Special:Whatlinkshere
13696 * Introduce PageHistoryBeforeList and PageHistoryLineEnding hooks; see docs/hooks.txt
13697 for more information
13698 * (bug 9397) Introduce "sp-contributions-footer" and "sp-contributions-footer-anon"
13699 messages, shown at the end of Special:Contributions as appropriate for the target
13700 * (bug 8421) Expose current action in JavaScript globals (as 'wgAction')
13701 * (bug 9069) Use galleries in query pages dedicated to images
13702 * (bug 9177) Installer now warns of various conditions affecting session.save_path
13703 which can lead to broken session storage
13704 * (bug 9046) Special page to list pages without language links
13705 * (bug 9508) Special page to list articles with the fewest revisions
13706 * Introduce 'FileUpload' hook; see docs/hooks.txt for more information
13707 * Introduce 'SearchUpdate' hook; see docs/hooks.txt for more information
13708 * Introduce 'mywatchlist' message; used on personal menu to link to watchlist page
13709 * Introduce magic word {{NUMBEROFEDITS}}
13710 * Introduced media handlers for file-type specific operations.
13711 * Improved error reporting for image thumbnailing
13712 * Added sharpening option for ImageMagick thumbnailing
13713 * (bug 9656) Autosummaries will be generated for deletion of pages longer than
13714 500 characters
13715 * Predefined block reasons added to Special:Blockip
13716 * (bug 9196) Installer now check that zend.ze1_compatibility_mode is off
13717 * (bug 9697) Introduce 'InternalParseBeforeLinks' hook; see docs/hooks.txt for more information
13718 * 'contribsub' message changed to 'contribsub2' with two parameters to permit
13719 better localization. Change is reverse-compatible and can be ignored for
13720 most wikis.
13721 * Adding a 'reason' field to Special:Userrights
13722
13723 == Bugfixes since 1.9 ==
13724
13725 * (bug 7292) Fix site statistics when moving pages in/out of content namespaces
13726 * (bug 8531) Correct local name of Lingála
13727 * Made the PLURAL: parser function return singular on -1 per default
13728 * Fixed up the AjaxSearch
13729 * Fix SpecialVersion->formatCredits input. Version and Url parameters should be
13730 null to be treated properly with isset.
13731 * Page restrictions moved into a new, dedicated table
13732 * Correct tooltip accesskey hint for Opera on the Macintosh
13733 (uses Shift-Esc-, not Ctrl-).
13734 * (bug 8002) Math should render left-to-right even in right-to-left wikis
13735 * Pass e-mail and real name fields to AuthPlugin::addUser, as additional
13736 optional fields, which may be considered useful at registration time.
13737 * PostgreSQL upgrade scripts fixed and updated
13738 * (bug 8613) Fix error when viewing "Recent Changes" and using Postgres.
13739 * Initialise site_stats table at upgrade time if data was missing
13740 * (bug 7250) Updated Unicode normalization tables to Unicode 5.0
13741 * Unmaintained Oracle support files have been removed.
13742 * Use browser default for printing size, don't force to 11pt
13743 * (bug 8632) Fix regression in page protection null edit update
13744 * (bug 8407) Disallow indexing of "printable" versions
13745 * (bug 8643) Correctly escape the page-specific CSS class for non-Monobook skins
13746 * (bug 8629) Document $wgFilterCallback
13747 * (bug 1000) Clarify warning about memory_limit in installer
13748 * Suppress PHP warning about set_time_limit in installer when safe mode is on
13749 * (bug 3000) Fall back to SCRIPT_NAME plus QUERY_STRING when REQUEST_URI is
13750 not available, as on IIS with PHP-CGI
13751 * Missing interwiki row for English Wikipedia restored (as "wikipedia:")
13752 * use configured cache servers for mctest.php
13753 * bucket details in mcc.php
13754 * fix input validation and remove debugging code in compressOld
13755 * full ID range for moveToExternal
13756 * fix resolveStubs.php for compatibility with older serialized data
13757 * maximum line length for bar graphs in getLagTimes.php
13758 * recognize specieswiki in rebuildInterwiki.inc
13759 * profile unicode cleanup in Xml
13760 * log slow parses in Article.php
13761 * profile wfMsgReal
13762 * log mkdir failures
13763 * profile AutoLoader
13764 * rebuild empty DjVu metadata containing ''
13765 * security fix for DjVu metadata retrieval
13766 * Undelete page list can use plural marker
13767 * (bug 8638) Fix update from 1.4 and earlier
13768 * (bug 8641) Fix order of updates to ipblocks table
13769 * (bug 8678) Fix detection of self-links for numeric titles in Parser
13770 * (bug 6171) Magically close tags in tables when not using Tidy.
13771 * Sanitizer now correctly escapes lonely '>' occurring before the first wikitag.
13772 * Ignore self closing on closing tags ( '</div />' now gives '</div>')
13773 * (bug 8673) Minor fix for web service API content-type header
13774 * Fix API revision list on PHP 5.2.1; bad reference assignment
13775 * (bug 8688) Handle underscores/spaces in Special:Blockip and Special:Ipblocklist
13776 in a consistent manner
13777 * (bug 8701) Check database lock status when blocking/unblocking users
13778 * ParserOptions and ParserOutput classes are now in their own files
13779 * (bug 8708) Namespace translations for Zealandic language
13780 * Renamed constructor methods to PHP 5 __construct reserved name
13781 * (bug 8715) Warn users when editing an interface message whether or not the
13782 message page exists
13783 * ar: fix the 'create a new page' on search page when no exact match found
13784 * (bug 8703) Corrected talk and image namespace name for Limburgish (li)
13785 * (bug 8671) Expose "wpDestFile" as a parameter to "uploadtext"
13786 * (bug 8403) Respect bad image list exceptions in galleries on wiki pages
13787 * Allow sending per-user contribution requests to "contributions" query group
13788 * (bug 3717) Update user count for AuthPlugin account autocreation
13789 * (bug 8719) Firefox release notes lie! Fix tooltips for Firefox 2 on x11;
13790 accesskeys default settings appear to be same as Windows.
13791 * Added an option to make Linker::userToolLinks() show the contribs link
13792 red when the user has no edits. Linker::userToolLinksRedContribs() is an
13793 alias to that which should be used to make it more self documentating.
13794 * (bug 8749) Bring MySQL 5 table defs back into sync
13795 * (bug 8751) Set session cookies to HTTPS-only to match other cookies
13796 * (bug 8652) Catch exceptions generated by malformed XML in multipage media
13797 * (bug 8782) Help text in Makefile
13798 * (bug 8777) Suppress 'previous' link on Special:Allpages when at first page
13799 * (bug 8774) Fix path for GNU FDL rights icon on new installs
13800 * Fix multipage selector drop-down for DjVu images to work when title
13801 is passed as a query string parameter; we have to pass the title as
13802 a form parameter or it gets dropped from the form submission URL
13803 * (bug 8819) Fix full path disclosure in with skins dependencies
13804 * Fixed bug affecting HTML formatting in sortable table column titles
13805 * Merged table sorting code into wikibits.js
13806 * (bug 8711) Stop floats in previews from spilling into edit area
13807 * (bug 8858) Safer handling when $wgImageLimits is changed. Added a note
13808 in DefaultSettings to make it clear.
13809 * (bug 4268) Fixed data-loss bug in compressOld batch text compression
13810 affecting pages which had null edits (move, protect, etc) as second
13811 edit in a batch group. Isolated and patched by Travis Derouin.
13812 * Fix for paths in 1.4->1.5 special-case updater script
13813 * (bug 8789) AJAX search: IE users can now use the return key
13814 * (bug 6844) Use <ins> and <del> tags to emphase the differences
13815 * (bug 6684) Fix improper javascript array iteration
13816 * (bug 4347) use MailAddress object for reply-to
13817 * Add AlphabeticPager abstract class
13818 * Use faster AlphabeticPager for Special:Categories
13819 * (bug 8875) Show printable link in MonoBook sidebar for locally nonexistent
13820 pages; perhaps useful for categories and shared images
13821 * Clean up session checks to better handle the case where the session was
13822 opened during the current request. May help with some caching corner
13823 cases.
13824 * (bug 8897) Fix whitespace removal for interlanguage links with link prefix
13825 * Add 'ParserTestTables' hook to expand the list of temporary tables copied
13826 by the parser test harness; use for extensions which require the presence
13827 of other tables while they work.
13828 * Message names changed for AlphabeticPager introduced with r19758
13829 for better localisations.
13830 * (bug 8944) The deprecated is_a() function is used in StubObjects.php
13831 * (bug 8992) Fix a remaining raw use of REQUEST_URI in history
13832 * (bug 8999) User.php gives "undefined user editcount" PHP notice.
13833 * (bug 8984) Fix a database error in Special:Recentchangeslinked
13834 when using the Postgres database.
13835 * Moved the main ob_start() from the default LocalSettings.php to WebStart.php.
13836 The ob_start() section should preferably be removed from older
13837 LocalSettings.php files.
13838 * Give Content-Length header for HTTP/1.0 clients.
13839 * Partial support for Flash cross-domain-policy filtering.
13840 * Lazy-initialize site_stats row on load when empty. Somewhat kinder to
13841 dump-based installations, avoiding PHP warnings when NUMBEROFARTICLES
13842 and such are used.
13843 * Add 'charset' to Content-Type headers on various HTTP error responses
13844 to forestall additional UTF-7-autodetect XSS issues. PHP sends only
13845 'text/html' by default when the script didn't specify more details,
13846 which some inconsiderate browsers consider a license to autodetect
13847 the deadly, hard-to-escape UTF-7.
13848 This fixes an issue with the Ajax interface error message on MSIE when
13849 $wgUseAjax is enabled (not default configuration); this UTF-7 variant
13850 on a previously fixed attack vector was discovered by Moshe BA from BugSec:
13851 http://www.bugsec.com/articles.php?Security=24
13852 * Trackback responses now specify XML content type
13853 * (bug 9044) Send a comment with action=raw pages in CSS/JS output mode
13854 to work around IE/Mac bug where empty pages time out verrrrryyyyy slowly,
13855 particularly with new keepalive-friendly HTTP on Wikipedia
13856 * (bug 8919) Suppress paging links and related messages where there are no
13857 rows to list for query pages
13858 * (bug 9057) Standardize MediaWiki: namespace for oc
13859 * (bug 8132) Suppress "Pages in this category" heading in categories when
13860 there are none
13861 * (bug 8958) Handle search operators better when using tsearch2 (Postgres)
13862 * (bug 8799) Use redirect table for Special:BrokenRedirects and
13863 Special:DoubleRedirects
13864 * (bug 8918) Enable PLURAL option for MediaWiki:showingresults and
13865 MediaWiki:showingresultsnum
13866 * (bug 9122) Fix minor display issue in RTL with section edit link margin
13867 * (bug 5805) Enable PLURAL option for some messages of watchlist and statistic
13868 * (bug 3953) Work around poor display of parenthesis in the in other
13869 languages section of MonoBook skin
13870 * (bug 8539) Enable PLURAL option for another message of recentchanges.
13871 * (bug 8728) MediaWiki:Badfiletype split into 3 messages
13872 * (bug 9131) Allow SpecialContributions to work with Postgres
13873 * (bug 9155) Allow footer info to wrap in Monobook
13874 * (bug 8847) Strip spurious #fragments from request URI to fix redirect
13875 loops on some server configurations
13876 * (bug 9097) column "pr_pagetype" does not exist
13877 * (bug 9217) Balance wfProfile calls in Skin::outputPage
13878 * (bug 9222) PostgreSQL updater should not be version-specific
13879 * Fix fallback implementation of mb_strlen so it works and isn't insanely
13880 slow for large strings, since it's used for page edit lengths
13881 * (bug 8815) Setting password in initUser() breaks LdapAuthentication plugin
13882 * (bug 9256) Add a quick note to index.php header comments
13883 * Make Special:Listusers caseinsensitive for first letter
13884 * Default tidy.conf has been moved from extensions module into includes.
13885 * Ignore lonely '''''
13886 * (bug 9244) When calling edit page for nonexistent section, generate error
13887 inside of just discarding edits, since edit links sometimes go to the wrong
13888 place.
13889 * (bug 9019) No warning during upload if image description page exists, but no
13890 image
13891 * (bug 8582) Allow thumbnailing when imagesize has a space.
13892 * (bug 8716) Change math_inputhash and math_outputhash to bytea for Postgres
13893 * (bug 9343) Correct internal name for Wolof language
13894 * (bug 9363) Fix Postgres error on Recentchangeslinked
13895 * (bug 5142) Fixed call of hook ArticleViewHeader
13896 * (bug 4777) Separate prev/next messages for Special:Whatlinkshere
13897 * Merge approx 15 missing Wikipedia language codes into wikipedia-interwiki.sql
13898 based on Jeff Merkey's mediawiki-1.9.3.WG-20070316.tar.gz.bz2 archive.
13899 * (bug 9411) Fix for shared image descriptions using query-string titles
13900 * (bug 4756) Add user tool links for self created accounts at special:log
13901 instead of sometimes broken block links from newuserlog extension
13902 * (bug 5817) Special:Recentchangeslinked now shows red link for nonexistent
13903 target page instead of silently redirecting
13904 * (bug 8914) Don't transform colons in {{anchorencode:}}
13905 * (bug 9241) Handle edit section links and include size links for cached
13906 templates the same as the first transclusion.
13907 * (bug 9466) "Rollback failed" page doesn't format edit comment
13908 * (bug 9472) Invalid XHTML on cached special pages
13909 * (bug 9472) Invalid XHTML on Special:Newpages
13910 * (bug 4764) "My contributions" not bold when viewing own contributions
13911 * (bug 9194) Add {{PLURAL:...}} to navigation bar of Special:Whatlinkshere
13912 * (bug 9033) Use a more specific error message when users are not able/allowed
13913 to edit page protection levels due to a block, database lock or permissions
13914 * Fixed $wgFeedLimit
13915 * (bug 9270) Corrected help namespace name for Dutch Lower Saxon (nds-nl)
13916 * (bug 929, 4215) Expose "rcdays" user preference in Special:Preferences
13917 * (bug 9554) Extension-provided group name messages not used
13918 * (bug 9565) Translate template namespace name for Hindi (hi)
13919 * (bug 8599) Correct localized names of zh-variants
13920 * (bug 3366) Require skins based on SkinTemplate to override the skinname
13921 property.
13922 * (bug 9220) Removed obsoletes functions in install-utils.inc.
13923 * Removed obsoletes Title::getRelatedCache and Title:touchArray
13924 * (bug 7285) Check MySQL username length during install
13925 * (bug 6910) Correct date/time formats in Vietnamese (vi)
13926 * (bug 9608) Correctly use ORDER BY in dumpLinks.php
13927 * (bug 9609) Correctly use ORDER BY in SpecialWhatlinkshere.php
13928 * Special:Random and Special:Randomredirect now try harder to send the user to
13929 a random page, and will give an error message if none really can be found
13930 instead of sending the user to the main page like they used to
13931 * Fix object variable used for displaying "not-patrolled" CSS class on list
13932 * Fixed interaction of page parameter to ImagePage with the HTML file cache
13933 * Fixed MIME type for SVG files, will be silently changed from image/svg
13934 to image/svg+xml after loading from the database.
13935 * Workaround for djvutoxml bug #1704049 (poor performance). Use djvudump
13936 instead.
13937 * Fixed odd behavior in ImagePage on DjVu thumbnailing errors
13938 * (bug 5439) "Go" title search will now jump to shared/foreign Image: and
13939 MediaWiki: pages that have not been locally edited.
13940 * (bug 9630) Limits links in Whatlinkshere forgot about namespace filter
13941 * Fixed upgrade for the non-standard MySQL schemas
13942 * Disable MySQL's strict mode at session start for MySQL 4.1+, to avoid the
13943 various problems that occur when it is on.
13944 * (bug 9585) Fix regression in tidy usage in Special:Undelete previews
13945 * (bug 3826) Normalize some invalid cookie name characters when setting
13946 up $wgCookiePrefix. Completes application of patch by Anders Kaseorg.
13947 * (bug 9649) Fix RTL form alignment for Special:Movepage
13948 * (bug 9582) Members of bot group now mark edits patrolled by default
13949 * (bug 9669) Fix limit ordering for rebuildrecentchanges; broken since
13950 converted from 1.4 to 1.5 schema
13951 * (bug 9682) Revert PHP 5.1 dependency on warning suppression for SVN info
13952 * (bug 5959) Anchors dropped from stub links
13953 * (bug 3348) Some additional weak password checks: password which is same
13954 as username will now be rejected.
13955 * (bug 8602) Converted Special:Contributions to use an IndexPager. The
13956 interpretation of the offset parameter has changed, and the go parameter
13957 has been removed.
13958 * (bug 6204) Fixes for indentation with $wgMaxTocLevel:
13959 - don't emit too many list close tags after an invisible header
13960 - don't emit too many final list close tags if last header is invisible
13961 - don't emit TOC when there are no visible headers
13962 * (bug 7629) Fix $wgBrowserBlackList to avoid false positive on MSIE
13963 when certain plugins are present which alter the user agent
13964
13965
13966 == Maintenance ==
13967
13968 * New script maintenance/language/checkExtensioni18n.php used to check i18n
13969 progress in the extension repository.
13970 * Running maintenance/parserTests.php with '--record' option, will now
13971 automatically attempt to create the required tables
13972 * --purge option to do additional parser-cache purging for purgeList.php
13973 * Fix hardcoded background color in parserTests.php
13974 * parserTests.php : removed the 'light' option for --color argument, replacing
13975 it with a new global switch : $wgCommandLineDarkBg
13976 * (bug 8780) Clarify message for command-line scripts if LocalSettings.php
13977 exists but is not readable
13978 * dumpBackup / importDump now work with PostgreSQL
13979 * (bug 8975) Use "Maintenance script" as the default username for importImages.php
13980 and importTextFile.php scripts
13981 * (bug 8933) Fix maintenance/reassignEdits.php script
13982 * (bug 9440) Added "mediawikiwiki" interwiki prefix to MediaWiki.org
13983 * (bug 2979) Import now gracefully skips invalid titles with a warning
13984 * Restore '--norc' option for maintenance/importTextFile.php
13985 * Help information for maintenance/importTextFile.php now easier to read on
13986 consoles
13987 * Doxygen documentation now show the revision number of each file, generate
13988 graphs using dot and include a search engine.
13989
13990
13991 == Languages updated ==
13992
13993 * Arabic (ar)
13994 * Aramaic (arc)
13995 * Aymara (ay)
13996 * Belarusian normative (be)
13997 * Belarusian alternative (be-x-old)
13998 * Bulgarian (bg)
13999 * Bihara (bh)
14000 * Breton (br)
14001 * Catalan (ca)
14002 * Czech (cs)
14003 * Danish (da)
14004 * German (de)
14005 * Greek (el)
14006 * Esperanto (eo)
14007 * Spanish (es)
14008 * Estonian (et)
14009 * Basque (eu)
14010 * Finnish (fi)
14011 * Võro (fiu-vro)
14012 * French (fr)
14013 * Hebrew (he)
14014 * Hindi (hi)
14015 * Upper Sorbian (hsb)
14016 * Hungarian (hu)
14017 * Armenian (hy)
14018 * Indonesian (id)
14019 * Italian (it)
14020 * Japanese (ja)
14021 * Javanese (jv)
14022 * Georgian (ka)
14023 * Kabyle (kab)
14024 * Kazakh (kk)
14025 * Korean (ko)
14026 * Kashmiri (ks)
14027 * Ripuarian (ksh)
14028 * Latin (la)
14029 * Luganda (lg)
14030 * Limburgish (li)
14031 * Lithuanian (lt)
14032 * Latvian (lv)
14033 * Marathi (mr)
14034 * Low Saxon (nds)
14035 * Dutch Lower Saxon (nds-nl)
14036 * Nepali (ne)
14037 * Nepal Bhasa (new)
14038 * Dutch (nl)
14039 * Occitan (oc)
14040 * Pali (pi)
14041 * Polish (pl)
14042 * Romanian (ro)
14043 * Russian (ru)
14044 * Sanskrit (sa)
14045 * Sicilian (scn)
14046 * Slovak (sk)
14047 * Sundanese (su)
14048 * Swedish (sv)
14049 * Tahitian (ty)
14050 * Ukrainian (uk)
14051 * Urdu (ur)
14052 * Uzbek (uz)
14053 * Vietnamese (vi)
14054 * Zealandic (zea)
14055 * Old Chinese / Late Middle Chinese (zh-classical)
14056 * Chinese (PRC) (zh-cn)
14057 * Chinese (Taiwan) (zh-tw)
14058 * Cantonese (zh-yue)
14059
14060 == Compatibility ==
14061
14062 MediaWiki 1.10 requires PHP 5 (5.1 recommended). PHP 4 is no longer supported.
14063
14064 PHP 5.0.x fails on 64-bit systems due to serious bugs with array processing:
14065 http://bugs.php.net/bug.php?id=34879
14066 Upgrade affected systems to PHP 5.1 or higher.
14067
14068 MySQL 3.23.x is no longer supported; some older hosts may need to upgrade.
14069 At this time we still recommend 4.0, but 4.1/5.0 will work fine in most cases.
14070
14071
14072 == Upgrading ==
14073
14074 1.10 has several database changes since 1.9, and will not work without schema
14075 updates.
14076
14077 If upgrading from before 1.7, you may want to run refreshLinks.php to ensure
14078 new database fields are filled with data.
14079
14080 If you are upgrading from MediaWiki 1.4.x or earlier, some major database
14081 changes are made, and there is a slightly higher chance that things could
14082 break. Don't forget to always back up your database before upgrading!
14083
14084 See the file UPGRADE for more detailed upgrade instructions.
14085
14086 = MediaWiki release notes =
14087 Security reminder: MediaWiki does not require PHP's register_globals
14088 setting since version 1.2.0. If you have it on, turn it *off* if you can.
14089
14090 = MediaWiki 1.9 =
14091
14092 == MediaWiki 1.9.6 ==
14093
14094 March 2, 2008
14095
14096 * Correction for API path fix, broken in 1.9.5
14097
14098 == MediaWiki 1.9.5 ==
14099
14100 January 23, 2008
14101
14102 This is a security update to the Winter 2007 quarterly release. A potential XSS
14103 injection vector affecting api.php only for Microsoft Internet Explorer users
14104 has been closed.
14105
14106
14107 To work around the vulnerability without upgrading, you may disable the API if
14108 you don't need it:
14109
14110 :[[Manual:$wgEnableAPI|$wgEnableAPI]] = false;
14111
14112 Not vulnerable versions:
14113 * 1.12 or later
14114 * 1.11 >= 1.11.1
14115 * 1.10 >= 1.10.3
14116 * 1.9 >= 1.9.5
14117 * 1.8 any version (if $wgEnableAPI has been left off)
14118
14119 Vulnerable versions:
14120 * 1.11 <= 1.11.0rc1
14121 * 1.10 <= 1.10.2
14122 * 1.9 <= 1.9.4
14123 * 1.8 any version (if $wgEnableAPI has been switched on)
14124
14125 MediaWiki 1.7 and below are not affected as they do not include the API
14126 functionality, however the BotQuery extension is similarly vulnerable unless
14127 updated to the latest SVN version.
14128
14129 == MediaWiki 1.9.4 ==
14130
14131 September 10, 2007
14132
14133 This is a security and bug fix update to the Winter 2007 quarterly release.
14134 Minor compatibility fixes for IIS 5 are included.
14135
14136 * (bug [[bugzilla:8847|8847]]) Strip spurious #fragments from request URI to
14137 fix redirect loops on some server configurations
14138 * A possible HTML/XSS injection vector in the API pretty-printing mode has been
14139 found and fixed.
14140
14141 The vulnerability may be worked around in an unfixed version by simply
14142 disabling the API interface if it is not in use, by adding this to
14143 LocalSettings.php:
14144
14145 :[[Manual:$wgEnableAPI|$wgEnableAPI]] = false;
14146
14147 Not vulnerable versions:
14148 * 1.11 >= 1.11.0
14149 * 1.10 >= 1.10.2
14150 * 1.9 >= 1.9.4
14151 * 1.8 >= 1.8.5
14152
14153 Vulnerable versions:
14154 * 1.11 <= 1.11.0rc1
14155 * 1.10 <= 1.10.1
14156 * 1.9 <= 1.9.3
14157 * 1.8 <= 1.8.4 (if $wgEnableAPI has been switched on)
14158
14159 MediaWiki 1.7 and below are not affected as they do not include the faulty
14160 function, however the BotQuery extension is similarly vulnerable unless updated
14161 to the latest SVN version.
14162
14163 == MediaWiki 1.9.3 ==
14164
14165 February 20, 2007
14166
14167 This is a security and bug-fix update to the Winter 2007 quarterly release.
14168 Minor compatibility fixes for IIS and PostgreSQL are included.
14169
14170 An XSS injection vulnerability based on Microsoft Internet Explorer's UTF-7
14171 charset autodetection was located in the AJAX support module, affecting MSIE
14172 users on MediaWiki 1.6.x and up when the optional setting $wgUseAjax is enabled.
14173
14174 If you are using an extension based on the optional Ajax module, either disable
14175 it or upgrade to a version containing the fix:
14176
14177 * 1.9: fixed in 1.9.3
14178 * 1.8: fixed in 1.8.4
14179 * 1.7: fixed in 1.7.3
14180 * 1.6: fixed in 1.6.10
14181
14182 There is no known danger in the default configuration, with ''$wgUseAjax'' off.
14183
14184 * ([[mediazilla:8992|8992]]) Fix a remaining raw use of REQUEST_URI in history
14185 * ([[mediazilla:8984|8984]]) Fix a database error in
14186 Special:Recentchangeslinked when using the PostgreSQL database.
14187 * Add ''charset'' to Content-Type headers on various HTTP error responses to
14188 forestall additional UTF-7-autodetect XSS issues. PHP sends only ''text/html''
14189 by default when the script didn't specify more details, which some
14190 inconsiderate browsers consider a license to autodetect the deadly,
14191 hard-to-escape UTF-7. This fixes an issue with the Ajax interface error message
14192 on MSIE when ''$wgUseAjax'' is enabled (not default configuration); this UTF-7
14193 variant on a previously fixed attack vector was discovered by Moshe BA from
14194 BugSec: [http://www.bugsec.com/articles.php?Security=24
14195 http://www.bugsec.com/articles.php?Security=24]
14196 * Trackback responses now specify XML content type
14197
14198 == MediaWiki 1.9.2 ==
14199
14200 February 4, 2007
14201
14202 This is a bug-fix update that fixes some installation and other minor issues
14203 with the 1.9.1 release as well as a security issue which was introduced in the
14204 1.9 branch.
14205
14206 JavaScript code which regenerated the "sortable tables" feature did not
14207 properly sanitize input, leading to an HTML injection vulnerability.
14208
14209 * ([[mediazilla:8774|8774]]) Fix path for GNU FDL rights icon on new installs
14210 * ([[mediazilla:8819|8819]]) Fix full path disclosure with skins dependencies
14211 * ([[mediazilla:8819|8819]]) Fixed data-loss bug in compressOld batch text
14212 compression affecting pages which had null edits (move, protect, etc) as second
14213 edit in a batch group. Isolated and patched by Travis Derouin.
14214 * Security fix for sortable tables JavaScript
14215
14216 == MediaWiki 1.9.1 ==
14217
14218 January 24, 2007
14219
14220 This is a bug-fix update that fixes some installation and upgrade issues with
14221 the original 1.9.0 release.
14222
14223 * ([[mediazilla:3000|3000]]) Fall back to SCRIPT_NAME plus QUERY_STRING when
14224 REQUEST_URI is not available, as on IIS with PHP-CGI
14225 * Security fix for DjVu images. (Only affects servers where .djvu file uploads
14226 are enabled and ''$wgDjvuToXML'' is set.)
14227 * ([[mediazilla:8638|8638]]) Fix update from 1.4 and earlier
14228 * ([[mediazilla:8641|8641]]) Fix order of updates to ipblocks table for updates
14229 from <=1.7
14230 * ([[mediazilla:8673|8673]]) Minor fix for web service API content-type header
14231 * Fix API revision list on PHP 5.2.1; bad reference assignment
14232 * Fixed up the AjaxSearch
14233 * Exclude settings files when generating documentation. That could expose the
14234 database user and password to remote users.
14235 * ar: fix the 'create a new page' on search page when no exact match found
14236 * Correct tooltip accesskey hint for Opera on the Macintosh (uses Shift-Esc-,
14237 not Ctrl-).
14238 * ([[mediazilla:8719|8719]]) Firefox release notes lie! Fix tooltips for
14239 Firefox 2 on x11; accesskeys default settings appear to be same as Windows.
14240
14241 == Changes since 1.8 ==
14242
14243 * (bug 8200) Make category lists sorted by name when using Postgres.
14244 * (bug 7841) Support 'IGNORE' inserts for Postgres, fixes watchlist
14245 adding problem.
14246 * (bug 6835) Removing the includes/Parser.php::getTemplateArgs() function,
14247 because it seems to be unused.
14248 * (bug 7139) Increasing the visual width of the edit summary field on larger
14249 screen sizes, for the default monobook skin.
14250 * Fix PHP notice and estimates for dumpBackup.php and friends
14251 * Improved register_globals paranoia checks
14252 * (bug 7545) Fix PHP version check on install
14253 * Disable PHP exception backtrace printing unless $wgShowExceptionDetails
14254 is set. Backtraces may contain sensitive information in function call
14255 parameters.
14256 * (bug 6164) Avoid smashing Cite state if message transformation triggers
14257 during bad image list check, by skipping message transformation.
14258 This isn't a good permanent fix.
14259 * (bug 6918) Stopped borders and backgrounds from showing through floated
14260 tables in Monobook
14261 * (bug 6868) Un-hardcode section edit link style
14262 * (bug 3205) Stop right floats from stacking horizontally in non-Monobook skins
14263 * Added global $wgStyleVersion to centralize bumping CSS and JS file versions
14264 for cache-friendly style and script updating
14265 * (bug 7562) Fix non-ASCII namespaces on Windows/XAMPP servers
14266 * Friendlier check for PHP 5 in command-line scripts; it's common for parallel
14267 PHP 4 and 5 installations to interfere on the command-line.
14268 * Fix regression in autoconfirm permission check
14269 * (bug 3015) Add CSS ids to subcategory and page sections on category pages
14270 * (bug 7587) Fix erroneous id for specialpage tab, enabling informative popup
14271 * (bug 7599) Fix thumbnail purging, PHP notices on HTCP image page purge
14272 * (bug 7581) Update language name for cbk-zam
14273 * (bug 7444) Update namespace translations for Telugu (te), kept old values as
14274 alias for compatibility
14275 * (bug 4525) Move section links down visually to same level as headings
14276 (editsection links are now inside the heading elements)
14277 * Workaround for http://bugs.php.net/bug.php?id=31892 , PATH_INFO and hence
14278 URLs of the style /index.php/Main_Page were broken on some CGI installations.
14279 * (bug 7623) Validate custom HTML id's correctly in Monobook interface
14280 * (bug 2241) Fix collision of 'w' and 'd' accesskeys
14281 * (bug 5795) CSS class added to body based on page name for page-specific
14282 styling
14283 * (bug 6276) Stopped search field from getting too large in Cologne Blue
14284 * (bug 7644) User creations that are aborted by hooks shouldn't be counted
14285 against account creations per day limit
14286 * (bug 7636) Show Firefox 2 users correct accesskey prefix
14287 * (bug 6427) Block blocked IPs from using the mail password function
14288 to allow blocking of flooders
14289 * Include common.css from classic-style skins in main HTML with the bump URL
14290 * (bug 7607) Add Karakalpak (kaa) to Names.php and stub message file for linktrail
14291 * (bug 7582) Add 'tog-nolangconversion' to MessagesEn.php.
14292 This key is need for languages with variants (zh, sr, kk)
14293 * (bug 7606) MediaWiki messages for "rss" and "atom" missing
14294 * (bug 7609) Add some more '*-summary' messages to MessagesEn.php with empty
14295 strings to allow better localisation via Special:Allmessages. Mark this new
14296 messages as optional for localisation.
14297 * Fix user_newpass upgrade for prefixed tables (reported by Fyren)
14298 * (bug 7663) Include language variant switcher links on Nostalgia skin
14299 * (bug 6531) Fix PHP fatal error on installation page with bad username input.
14300 * (bug 6977) Remove 404 link for autogenerated database documentation.
14301 * (bug 7369) Allow "Show Changes" without requiring edit token.
14302 * (bug 7687) Fix movetalk box checks itself when confirming a delete and move.
14303 * (bug 7684) Obey watchcreated preference for Special:Upload watch checkbox
14304 * (bug 7686) Include id attribute on delete form confirmation button
14305 * Allow compound interwiki prefixes in $wgImportSources
14306 * (bug 7304) Added redirect table to store redirect targets.
14307 * Added querycachetwo table (similar to querycache but has two titles)
14308 * PageArchive can now return a Revision object for more convenient processing
14309 of deleted revision data
14310 * Added 'UndeleteShowRevision' hook in Special:Undelete
14311 * Error message on attempt to view invalid or missing deleted revisions
14312 * Remove unsightly "_" from namespace in Special:Allpages, Special:Prefixindex
14313 * (bug 3224) Allow minor edits by bots to skip new message notification on
14314 user talk pages. This can be disabled by adjusting the 'nominornewtalk'
14315 permission. Patch by Werdna.
14316 * (bug 7741) MATH: fixed broken syntax of underbrace etc. Fixed arrays
14317 * Fix purging for updated SVG files
14318 * (bug 7745) Add id attribute to search button in Monobook
14319 * (bug 7749) MATH: added some more LaTeX symbols, e.g. parallel, diamond, ast, ...
14320 * (bug 7304) Added code in Article.php to keep redirect table up to date.
14321 * Made special page names case-insensitive and localisable. Care has been taken
14322 to maintain backwards compatibility.
14323 * Used special page subpages in a few more places, instead of query parameters.
14324 * (bug 7758) Added wrapper span to "templates used" explanation to allow CSS
14325 styling (class="mw-templatesUsedExplanation").
14326 * Added {{#special:}} parser function, to give the local default title for
14327 special pages
14328 * (bug 7766) Remove redundant / from AJAX requests, can break some servers
14329 * Add tab links from extensions to classic-based skins (SkinTemplateTab hook)
14330 Provides better cross-skin compatibility for extensions using the modern
14331 skin hooks, such as Oversight
14332 * Moved variant language links on Cologne Blue and Nostalgia to before the
14333 login/logout link
14334 * Fix for parser tests with MySQL 5 in strict mode
14335 * Added block option "enable autoblocks"
14336 * Amend Special:Ipblocklist to note when a block has autoblock DISABLED.
14337 * (bug 7780) Fix regression in editing redirects
14338 * Add whitespace above "templates included on this page" using CSS, not
14339 hardcoded line break.
14340 * Remove entries from redirect table on article deletion
14341 * (bug 7788) Force section headers in new section links for users who have
14342 'prompt for blank edit summaries' on.
14343 * (bug 1133) Special:Emailuser: add an option to send yourself a copy of your mail.
14344 * (bug 461) Allow "Categories:" link at bottom of pages to be customized via
14345 pagecategorieslink message.
14346 * Sort the list of skins in "My Preferences" -> Skins by alphabetical order.
14347 * (bug 7785) Postgres compatibility for timestamps in RC feeds
14348 * (bug 7550) Normalize user parameter normally on Special:Log
14349 * (bug 7294) Fix PATH search for diff3 on install
14350 * Various fixes related to the blocking change re: autoblocks. On inserting
14351 an IP block, the ipb_enable_autoblock field is now automagically blanked,
14352 because it doesn't make any sense for an IP. Additionally, IP blocks
14353 without the ipb_enable_autoblock option no longer show up as "autoblock
14354 disabled" on Special:Ipblocklist.
14355 * (bug 7774) MATH: aded more amstex functions
14356 * (bug 1182) MATH: fixed inconsistent rendering of upper case Greek letters in TeX
14357 * Fix regression in streaming page dump generation
14358 * (bug 7801) Add support for parser function hooks in parser tests
14359 * checkUsernames.php now uses wfDebugLog instead of hardcoded path to log
14360 * (bug 7810) Update talk namespaces for Occitan
14361 * Allow case-sensitive URLs to be used for uploading from URLs.
14362 * (bug 1109) Correct fix for compressed 304 responses when additional output
14363 buffers have been installed within the compression handler
14364 * (bug 7819) Move automatic redirect edit summary after pre-save transform
14365 to work properly with subst: fun
14366 * (bug 7826) Fix typos in two English messages.
14367 * (bug 5365) Stop users being prompted to enter an edit summary for null edits,
14368 if they have selected that option in preferences.
14369 * (bug 5936) Show an 'm' to the left of the edit summary on diff pages for minor edits.
14370 * (bug 7820) Improve error reporting for uploads via URL.
14371 * (bug 5149) When autoblocks are enabled, retroactively apply an autoblock to the most
14372 recently used IP of a user when they are blocked.
14373 * Add an index on (rc_user_text,rc_timestamp) on the recentchanges table. This will
14374 make CheckUser.php and the new retroactive autoblock functionality faster.
14375 * Fix regression in Special:Undelete for revisions deleted under MediaWiki 1.4
14376 with compression or legacy encoding
14377 * (bug 6737) Fixes for MySQL 5 schema in strict mode
14378 * Approximate height for client-side scaling fallback instead of passing -1
14379 into the HTML output.
14380 * Make the DNSBL to check for proxy blocking configurable via $wgSorbsUrl
14381 * Add experimental recording/reporting mode to parser tests runner, to
14382 compare changes against the previous run.
14383 Additional tables 'testrun' and 'testitem' are in maintenance/testRunner.sql,
14384 source this and pass --record option to parserTests.php
14385 * Make the set of default parser test input files extensible via
14386 $wgParserTestFiles. This can now be appended to by extensions or local
14387 configuration files so that extension or custom tests can be automatically
14388 run along with the main batch.
14389 * Run PHP install version checks on update.php so command-line updaters see
14390 new version requirements
14391 * Do a check for the PHP 5.0.x 64-bit bug, since this is much more disruptive
14392 as of MW 1.8 than it used to be. Install or upgrade now aborts with a
14393 warning and a request to upgrade.
14394 * (bug 6440) Updated indexes to improve backlinking queries (links, templates, images)
14395 * Switched 'anon-only' block mode to default for IP blocks
14396 * (bug 3687, 7892) Add distinct heading for media files in category display,
14397 with count.
14398 * (bug 1578) Add different icons for external links to audio, video, or PDF in
14399 Monobook.
14400 * Made autoblocks block account creation if the user block has that option enabled.
14401 * Add auto-summaries to blankings and large removals without summaries.
14402 * (bug 7811) Allow preview of edit summaries.
14403 * (bug 6839) Wikibits.js minor changes to make JS-lint happier.
14404 * (bug 7932) Make sure that edit toolbar clears floats so it appears correctly.
14405 * (bug 6873) When viewing old revisions, add link to diff to current version.
14406 * (bug 3315) Provide rollback link directly on history page.
14407 * Replace 'old-revision-navigation' message with 'revision-info' and
14408 'revision-nav' messages, wrapped in divs with appropriate id's.
14409 * (bug 4178) MediaWiki:Common.js will now be included for all users if
14410 $wgUseSiteJs is enabled, in addition to (if applicable) MediaWiki:Monobook.js
14411 and user JS subpages.
14412 * (bug 7918) "Templates used on this page" changes during preview to reflect
14413 any added or removed templates, and works as expected for section edits.
14414 * (bug 7919) "Templates used on this page" is now shown for read-only pages.
14415 * (bug 7688) When viewing diff, section anchors in autosummary jump to section
14416 on current page instead of loading the latest version.
14417 * (bug 7970) Use current connection explicitly on Database::getServerVersion
14418 * (bug 2001) Tables with class="sortable" can now be dynamically sorted via
14419 JavaScript.
14420 * Added autosummary for new pages with 500 or less characters, and refactor
14421 the autosummary code so it's all done in one function. doEdit is getting too
14422 big!
14423 * (bug 7554) The correct MIME type for SVG images is now displayed on the
14424 image page (image/svg+xml, not image/svg).
14425 * (bug 7883) Added autoblock whitelisting feature, using which specific ranges
14426 can be protected from autoblocking. These ranges are specified, in list format,
14427 in the autoblock_whitelist system message.
14428 * Added placeholders for text injection by hooks to EditPage.php
14429 * (bug 8009) Automatic edit summary for redirects is not filled for edits in existing pages
14430 * Installer support for experimental MySQL 4.1/5.0 binary-safe schema
14431 * Use INSERT IGNORE for db-based BagOStuff add/insert, for more memcache-like
14432 behavior when keys already exist on add (instead of dying with an error...)
14433 * Add a hook 'UploadForm:initial' before the upload form is generated, and two
14434 member variable for text injection into the form, which can be filled by the hooks.
14435 * (bug 6295) Add a "revision patching" functionality, where an edit can be undone
14436 (with a functionality similar to diff rev1 rev2 | patch -R rev3 -o rev3).
14437 This is triggered by including &undo=revid in an edit URL. A link to a URL
14438 that will undo a given edit is shown on NEW revision headers on diff pages.
14439 The link leads to a "Show Changes" page showing what will be done to undo the
14440 edit.
14441 * Fix display of link in "already rolled back" message for image/category pages
14442 * (bug 6016) Left-aligned images should stack vertically, like right-aligned
14443 images, not horizontally.
14444 * Patch from LeonWP: added UploadForm:BeforeProcessing hook in SpecialUpload.php
14445 * Add AuthPluginSetup hook to override $wgAuth after configuration
14446 * Fix regression in authentication hook auto-creation on login
14447 * (bug 8110) Allow spaces in ISBNs
14448 * (bug 8024) Introduce "send me copies of emails I send to others" preference
14449 * Added 'EditPage::attemptSave' hook before an article is saved.
14450 * (bug 8083) Applied patch for sk localisation
14451 * Add a backslash character to the edit token, to prevent edits via certain
14452 broken proxies that mangle such characters in form submissions
14453 * (bug 7461) Allow overwriting pages using importTextFile.php
14454 * (bug 7946) importTextFile.php doesn't perform pre-save transform
14455 * (bug 8117) {{REVISIONTIMESTAMP}} showed weird default if $wgLocalTZoffset set;
14456 now uses current time for previews and if timestamp can't be loaded from DB
14457 * {{REVISIONTIMESTAMP}} now uses site local timezone instead of user timezone
14458 to ensure consistent behavior
14459 * {{REVISIONTIMESTAMP}} and friends should now work on non-MySQL backends
14460 * (bug 7671) Observe canonical media namespace prefix in Linker::formatComment
14461 * Added js variable wgCurRevisionId to the output
14462 * (bug 8141) Cleanup of Parser::doTableStuff, patch by AzaTht
14463 * (bug 8042) Make miser mode caching limits settable via $wgQueryCacheLimit
14464 instead of hardcoding to 1000
14465 * Enable QueryPage classes to override list formatting
14466 * (bug 5485) Show number of intervening revisions in diff view
14467 * (bug 8100) Fix XHTML validity in Taiwanese localization
14468 * Added redirect to section feature. Use it wisely.
14469 * Added a configuration variable allowing the "break out of framesets" feature
14470 to be switched on and off ($wgBreakFrames). Off by default.
14471 * Allow Xml::check() $attribs parameter to override 'value' attribute
14472 * DB schema change: added two columns (rc_old_len and rc_new_len) to the recentchanges table to store
14473 the text lengths before and after the edit
14474 * (bug 1085) Made Special:Recentchanges show the character difference between the changed revisions
14475 * Removed a redundant <strong> tag from diff pages that was causing display issues for some users
14476 * (bug 8203) The keyboard shortcut for "log out" was removed, because users were pressing it
14477 when they intended to press the shortcut for "preview".
14478 * (bug 8148) Handle non-removable output buffers gracefully when cleaning
14479 buffers for HTTP 304 responses, StreamFile, and Special:Export.
14480 Duplicated code merged into wfResetOutputBuffers() and wfClearOutputBuffers()
14481 * Special:AllPages : 'next page' link now point to the first title of the next
14482 chunk instead of pointing to the last title of current chunk.
14483 * (bug 4673) Special:AllPages : add a 'previous' link (new message 'prevpage')
14484 * (bug 8121) wfRandom() was not between 0 and 1
14485 * Add static method Parser::createAssocArgs($args), so parser functions can
14486 use the same code to parse arguments as the templates do.
14487 * Change behavior of logins using the temporary e-mailed password (as stored
14488 in user_newpassword hash field). Instead of just logging in silently and
14489 leaving the previous user_password field in place indefinitely, the user
14490 is now prompted to set a new password.
14491
14492 The password-changing form is at Special:Resetpass; currently it's only
14493 usable for changing from the temporary password during login, but it
14494 could perhaps be generalized, replacing the subform in preferences.
14495
14496 Once the new password is set successfully, the temporary password is wiped
14497 so it cannot be used to login a second time, and the login process
14498 is completed.
14499 * Suppress 'mail new password' button on login form if $wgAuth forbids
14500 changing user passwords; it wouldn't work very well...
14501 * Consolidate password length checks and $wgAuth manipulation into
14502 User::setPassword() to avoid duplicate code in different places
14503 that set passwords.
14504 * User::setPassword() now throws PasswordError exceptions if the password
14505 is illegal or cannot be set via $wgAuth. These can be caught and a human-
14506 readable error message displayed by UI code.
14507 * Added Title::isSubpage()
14508 * (bug 8241) Don't consider user pages of User:Foo.css to be CSS subpages
14509 * Set an explicit class on framed thumbnail inner divs and images, changed some
14510 CSS to use these instead of using descendent selectors.
14511 * Accept null parameter to User::setPassword() as indicating the password
14512 field should be cleared to an unusable state. Login will only be possible
14513 after the password is reset, for instance by e-mail.
14514 * (bug 6394) Invalidate the password set for "by e-mail" account creations
14515 to avoid accidental empty password creations.
14516 * Made the show change size function work on page moves, page creations, and
14517 log entries. Also fixed it in the javascript recentchanges.
14518 * (bug 8239) correctly get 50 new contributions when clicking '(50 next)'
14519 * (bug 2259) Fix old regression where e-mail addresses were no longer
14520 confirmed on login with mailed password.
14521 * Add a notification about the confirmation mail sent during account
14522 creation, so people don't immediately go off to request a second one.
14523 * Add a warning on Special:Confirmemail if a code was already sent and has
14524 not yet expired.
14525 * Add user_editcount field to provide data for heuristics on account use.
14526 Incremented on edit, with lazy initialization from past revision data.
14527 Can batch-initialize with maintenance/initEditCount.php (not yet friendly
14528 to replication environments, this will do all accounts in one query).
14529 * Allow raw SQL subsections in Database::update() SET portion as well as
14530 for WHERE portion. Handy for increments and such.
14531 * User::getOption now accept a default value to override default user values
14532 this makes it consistent with WebRequest::get* methods. Corrected code in
14533 various places accordingly.
14534 * (bug 8264) Fix JavaScript global vars for XHTML mode
14535 * Make $wgSiteNotice value wikitext again, for consistency with editable
14536 MediaWiki:Sitenotice and MediaWiki:Anonnotice.
14537 * (bug 8044) When redirecting from the canonical name of the special page
14538 to the localised one, parameters/subpages are omitted
14539 * (bug 8164) Special:Booksources should use GET for form submission
14540 * Rewrite Special:Booksources to clean up interface and remove redundant code
14541 * (bug 7925) Change Special:Allmessages message name filter javascript to be
14542 a bit more responsive and easier on the CPU
14543 * (bug 4488) Support watching pages on deletion; introduces new user preference
14544 * Minor restructuring of Special:Preferences; "watch pages I edit" and "watch
14545 pages I create" options now accessible under "Watchlist" options
14546 * (bug 8153) <nowiki> doesn't work in site notice
14547 * (bug 6690) wfMsgNoTrans() transforms messages
14548 * (bug 8274) Wrap edit tools in a <div> with a specified class
14549 * Detect PHP 5.0.x 64-bit bug and abort in WebStart.php; too many things break
14550 mysteriously otherwise (detection code copied from install-utils.inc)
14551 * (bug 8295) Change handling of <center> tags in doBlockLevels() to match that
14552 of <div>
14553 * (bug 8110) Make magic ISBN linking stricter: only match ten-digit sequences
14554 (plus optional ISBN-13 prefix) with no immediately following alphanumeric
14555 character, disallow multiple consecutive internal redirects
14556 * (bug 2785) Accept optional colon prefix in links when formatting comments
14557 * Don't show "you can view and copy the source of this page" message for
14558 pages which don't exist
14559 * (bug 8310) Blank line added to top of 'post' when page is blank
14560 * (bug 8109) Template parameters ignored in "recentchangestext"
14561 * Gracefully skip redirect-to-fragment on WebKit versions less than 420;
14562 it messes up on current versions of Safari but is ok in the latest
14563 nightlies. Checking the version number will allow it to automatically
14564 work when new releases of Safari appear.
14565 * Fix regression in thumb styles; size and padding didn't match with
14566 new arrangement.
14567 * (bug 8333) Fix quick user data update on login password change on
14568 replication database setups. User data is now pulled from master
14569 instead of slave in User::loadFromDatabase, ensuring that it is
14570 fresh and accurate when read and then saved back into cache.
14571 This was breaking with the Special:Rename operation which
14572 automatically logs the user in with the new password after changing
14573 it; pulling from slave meant the record was often not the updated
14574 one.
14575 * (bug 8335) Set image width to the first valid parameter found.
14576 * (bug 8350) Fix watchlist viewing bug when using Postgres.
14577 * (bug 6603) When warning about invalid file extensions, output the bit
14578 of the extension we actually checked
14579 * (bug 7669) Drop defaults on BLOB/TEXT columns for better compatibility
14580 with MySQL's strict mode, often enabled by the Windows installer.
14581 The defaults are ignored anyway when strict mode is off...
14582 * (bug 7685) Use explicit values for ar_text and ar_flags when deleting,
14583 for better compatibility with MySQL's strict mode
14584 * Update default interwiki values to reflect changed location of ursine:
14585 * (bug 5411) Remove autopatrol preference
14586 * Users who have the "autopatrol" permission will have their edits marked as
14587 patrolled automatically
14588 * Users who do not have the "autopatrol" permission will no longer be able
14589 to mark their own edits as patrolled
14590 * Introduce 'PingLimiter' hook; see docs/hooks.txt for more information
14591 * (bug 532) Tweaked alt text for some interface messages
14592 * (bug 8231) Gave useful alt text to the main <img> on image pages
14593 * (bug 371) Remove alt text for "Enlarge" icon on thumbnails
14594 * Initialize user_editcount to 0 instead of NULL for newly created accounts
14595 * (bug 3696) Strip LRM and RLM characters from titles to work around the
14596 problem some people have where titles cut-and-pasted from lists include
14597 the bidi override characters appended to the lists.
14598 A more thorough blacklist for forbidden and translatable characters would
14599 be wise, though, as might a cleaner method for the lists in the first place.
14600 * Fix regression in email password resets on read-restricted sites
14601 * Set tabindex on fields in deletion form so you don't have to tab through
14602 the links in the sitenotice
14603 * (bug 8271) Show full time and date on viewer for individual deleted
14604 revisions
14605 * (bug 8214) Output file size limit and actual file size in appropriate units
14606 on Special:Upload
14607 * (bug 8016) Purge objectcache table during upgrade processes - use the --nopurge
14608 option to prevent this when running maintenance/update.php
14609 * (bug 7612) Remove superfluous link to Special:Categories from result items
14610 on Special:Mostcategories
14611 * {{PLURAL:}} now handles formatted numbers correctly
14612 * (bug 8331) Added the change size value to watchlists; therefore made
14613 watchlists use RecentChange::newFromRow() instead of newFromCurRow()
14614 * (bug 8351) Fix undo for simple reverts
14615 * (bug 6856) User::clearNotification() does not respect read-only mode
14616 * (bug 6853) Use a checkbox on the installer form to indicate that a superuser
14617 account should be used; this is clearer than the old check which relied on
14618 the password never being an obscure value
14619 * Remove old unused watchlist cache, which was a leftover from the old schema
14620 where watchlists were more expensive to generate
14621 * Minor cosmetic changes to Special:Userrights
14622 * Added wgCanonicalSpecialPageName to JavaScript variables
14623 * Fix image deleting when using Postgres.
14624 * Output both source and destination titles in maintenance/moveBatch.php
14625 * Added basic parser tests for language variants
14626 * Enable selflinks and categories to be written in some of the language variants
14627 * Prevent conversion of JavaScript code in language variants
14628 * Output software version number in maintenance/parserTests.php
14629 * (bug 7169) Use Ajax to watch/unwatch articles if enabled
14630 * Make variant table caching a little more robust, using main language code
14631 in cache key. Probably this is still a bit wonky, though. Was breaking
14632 parser tests when Chinese tables were getting loaded into Serbian code.
14633 * (bug 8380) Be nicer about blank lines in deleteBatch.php
14634 * (bug 8401) Fix regression in SORBS lookup for some DNS setups
14635 * Use raw file descriptor in posix_isatty() check to avoid warning on
14636 Linux systems with at least some versions of PHP
14637 * (bug 5908) Allow overriding the default category sort key for all items on
14638 a page using {{DEFAULTSORT}}
14639 * (bug 6449) Throw a more definitive error message when installation fails
14640 due to an invalid database name
14641 * (bug 5827) Use full text for option link labels on Special:Watchlist
14642 * (bug 8018) Allow hiding minor edits from the watchlist
14643 * (bug 8427) MonoBook RTL IE 7.0 tweaks failed when sidebar's navigation
14644 section is renamed; no longer relies on first section name
14645 * Stabilize client-side table sorting even if the underlying Javascript sort()
14646 implementation is unstable
14647 * Add hook for extensions to add user information to the panel in preferences,
14648 next to the user name and ID.
14649 * (bug 8392) Display protection status of transcluded pages in the edit page
14650 template list. Patch by Fyren, with i18n naming tweak.
14651 * Fix for interwiki transclusion where target wiki uses query string for title
14652 * Resolve namespaces on interwiki Title objects using canonical namespace names
14653 if possible (should not happen, though, outside interwiki transclusion... and
14654 maybe not even then, but it does)
14655 * (bug 8447) Fix SQL typo breaking non-default $wgHitcounterUpdateFreq
14656 * Do not allow previews of deleted images to be cached
14657 * Add global variable $wgDefaultLanguageVariant used to set the default language
14658 variant of a wiki to something different than the main language code
14659 * Add 'variant' option to parserTests - runs test with the given variant as
14660 preferred, utilize it for more parser tests of language variants code
14661 * (bug 6503) Fix bug that stopped certain irrelevant links from being hidden
14662 for printing
14663 * Avoid PHP warning in Creative Commons metadata when a creative commons
14664 license is not actually set up
14665 * (bug 8463) Don't print external link icons for Monobook
14666 * (bug 8461) Support watching pages on move
14667 * (bug 8041) Work around bug with debug_backtrace when Zend Optimizer is
14668 loaded by skipping the function. Use wfDebugBacktrace() wrapper function.
14669 * Reduce config file clutter by setting various script and upload paths
14670 based on $IP or $wgScriptPath in Setup.php. They can still be explicitly
14671 overridden in LocalSettings.php if desired...
14672 * Attempt to detect redirect loops for the canonical title redirect, and
14673 give some hints to the poor confused administrator.
14674 * Introduce new flag 'R' - raw output for language variant escape tags
14675 * Advise users when updates for a query page have been disabled using
14676 $wgDisableQueryPageUpdate
14677 * (bug 8413) Improve comments for $wgNamespaceRobotPolicies
14678 * (bug 8330) Show "bytes" suffix on recent changes diff counter
14679 optionally... if set in rc-changes-size message (default empty for now)
14680 * (bug 8489) Support basic links in <gallery> caption attribute
14681 * (bug 8485) Correct Lingala number formatting
14682 * The MediaWiki namespace is no longer pre-filled with default messages on
14683 install. All default messages will be removed from the MediaWiki namespace
14684 on upgrade.
14685 * Recentchanges RSS/Atom feeds now use a separate message for the description
14686 to avoid cluttering it with useless wiki formatting
14687 * (bug 8417) Handle EXIF unknown dates
14688 * (bug 8372) Return nothing on empty <math> tags.
14689 * New maintenance script to show the cached statistics : showStats.php.
14690 * Count deleted edits when regenerating total edits in maintenance/initStats.php
14691 * (bug 3706) Allow users to be exempted from IP blocks. The ipblock-exempt permission
14692 key has been added to enable this behavior, by default assigned to sysops.
14693 * (bug 7948) importDump.php now warn that Recentchanges need to be rebuild.
14694 * (bug 7667) allow XHTML namespaces customization
14695 * (bug 8531) Correct local name of Lingála (patch by Raymond)
14696 * Fix regression with default lock file and cache directories; threw visible
14697 warning with open_basedir
14698
14699
14700 == 1.8 Compatibility changes ==
14701
14702 === Zend Optimizer ===
14703
14704 A bug in some versions of PHP 5 and Zend Optimizer which was triggered under
14705 MediaWiki 1.8.x has been worked around by disabling some internal debugging
14706 features when Zend Optimizer is loaded. This should solve some common
14707 "blank page" problems.
14708
14709 === PHP 5.0 64-bit ===
14710
14711 MediaWiki now checks for a condition where PHP 5.0.x corrupts array data
14712 on 64-bit systems and warns you to upgrade PHP to solve the problem. This
14713 bug causes Special: pages to fail on affected systems under MediaWiki 1.8
14714 and higher, and subtler data corruption on earlier versions.
14715
14716 The only known workaround is to upgrade PHP to 5.1 or later, which you
14717 probably should do anyway for security reasons!
14718
14719 === MySQL 5 ===
14720
14721 MediaWiki should now install and run correctly on MySQL 5.0 and higher when
14722 MySQL's "strict mode" is enabled. (This is now the default for many Windows
14723 installations, though it seems to remain off by default on Unix.)
14724
14725 This fixes errors about "cannot default default value for BLOB/TEXT fields".
14726
14727 === ImageMagick ===
14728
14729 Note that ImageMagick older than 6.x may no longer work for image resizing
14730 due to use of the -thumbnail option.
14731
14732
14733 == 1.8 Behavior changes ==
14734
14735 === Localized special pages ===
14736
14737 The names of Special: pages can now be localized, so links and URLs to them
14738 are more legible in languages that aren't English.
14739
14740 Not all languages have included localized names yet.
14741
14742 === E-mail password ===
14743
14744 Users are now required to set a new password for themselves when they first
14745 log in with a newly generated e-mailed password.
14746
14747 Requesting passwords frequently is prevented to reduce abusive mailbombing.
14748
14749 === Undo revision ===
14750
14751 An "undo" link now appears in diff view for easier reverting of older edits.
14752 When GNU diff3 is available for edit conflict merging, this can make it much
14753 easier to "undo" the changes of an older edit when there are surrounding
14754 changes elsewhere in the page.
14755
14756 The changes must be manually reviewed and approved, as with conventional
14757 full-revision reverts.
14758
14759 === Blocking ===
14760
14761 User blocks can be set to disable the automatic blocking of IP addresses the
14762 account logs in with.
14763
14764
14765 == 1.8 Database changes ==
14766
14767 * new 'redirect' table stores data on page redirects
14768 * new 'querycachetwo' table used for some cached special pages
14769 * 'ipblocks' table adds 'ipb_enable_autoblock'
14770 * 'recentchanges' table adds 'rc_old_len', 'rc_new_len' for size tracking
14771 * 'user' table has added 'user_newpass_time' and 'user_editcount' fields
14772 * some indexes have been updated on 'recentchanges'
14773
14774 == 1.8 Configuration changes ==
14775
14776 Several configuration options have changed since 1.8:
14777
14778 === $wgEnableAPI ===
14779
14780 The experimental machine API interface is now enabled by default, read-only.
14781 You can disable it by setting $wgEnableAPI = false; in LocalSettings.php.
14782
14783 === $wgPathInfo ===
14784
14785 The use of PATH_INFO (the text after the script name in 'index.php/Blah')
14786 is controlled by the $wgUsePathInfo setting. This is now explicitly disabled
14787 for CGI, apache2filter, and ISAPI configurations of PHP, for more consistency
14788 with the autodetection from the installer.
14789
14790 In some rarer configurations you may have to switch $wgUsePathInfo from false
14791 to true or, perhaps, from true to false to make things work properly if bad
14792 PATH_INFO data comes through the server.
14793
14794 The wiki now tries to detect this condition and should show you an error
14795 message describing what to change instead of sending the browser into an
14796 infinite redirect loop.
14797
14798 === $wgScript and other path settings ===
14799
14800 The following configuration variables are now automatically set in Setup.php
14801 if they are not overridden in LocalSettings.php:
14802
14803 from $wgScriptPath:
14804 + $wgScript
14805 | \- $wgArticlePath
14806 + $wgRedirectScript
14807 + $wgStylePath
14808 + $wgUploadPath
14809 \- $wgLogo
14810 + $wgMathPath
14811
14812 from $IP:
14813 - $wgStyleDirectory
14814 + $wgUploadDirectory
14815 \- $wgMathDirectory
14816 + $wgTmpDirectory
14817
14818 Newly generated configuration files will by default include only $wgScriptPath
14819 (hardcoded from the installer) and $IP (detected at runtime).
14820
14821 Old configuration files which specify all these values explicitly should
14822 continue to work just fine, but if you use the defaults you can remove them
14823 to reduce clutter.
14824
14825 === $wgGroupPermissions ===
14826
14827 The sysop group now holds the "autopatrol" and "ipblock-exempt" rights by
14828 default.
14829
14830 "autopatrol" replaces the preference for marking ones own edits patrolled
14831 by default; users holding this permission will automatically have their
14832 edits patrolled, while others cannot mark their own edits as patrolled
14833 even if they have patrolling rights.
14834
14835 "ipblock-exempt" excludes the user from IP blocks; accounts which are blocked
14836 explicitly by name will still be blocked, however. This is given to sysops
14837 to minimize annoyance from accidental "collateral damage"; remember that a
14838 sysop will be able to lift the block if they desire.
14839
14840 The bot group now holds the "nominornewtalk" right. A user with this right
14841 will not trigger new message notifications when making minor edits to user
14842 talk pages. This is meant to minimize annoyance from maintenance bot
14843 processes.
14844
14845 === $wgUseWatchlistCache ===
14846
14847 Watchlist caching has been removed. The feature was not maintained, and has
14848 been unnecessary since switching to the 'recentchanges' database table
14849 reduced server pressure for Wikipedia's watchlists.
14850
14851 === $wgBreakFrames ===
14852
14853 MediaWiki in the past attempted to detect when it was embedded in a frameset
14854 and "break out" of it, assuming it to be hostile.
14855
14856 This behavior is now disabled by default, but can be reenabled by setting
14857 $wgBreakFrames to true in LocalSettings.php.
14858
14859
14860 == 1.8 New settings ==
14861
14862 === $wgVariantArticlePath ===
14863
14864 For languages with script variant support (Chinese, Serbian, and others),
14865 it's possible to use alternate URL paths to select the variant for article
14866 display, setting $wgVariantArticlePath.
14867
14868 Documentation for this setting would be useful.
14869
14870 === $wgMaxMsgCacheEntrySize ===
14871
14872 The message cache can now skip items larger than a given size; this allows
14873 it to better handle the primary caching case when large CSS and JS blobs are
14874 present.
14875
14876 === $wgStyleVersion ===
14877
14878 When making significant changes to skin stylesheets and JavaScript files,
14879 you can append a string to this variable to tweak the generated URLs,
14880 forcing newly rendered pages to bring in a fresh version despite server-
14881 or browser-side caching.
14882
14883 Normally this will be set in the course of MediaWiki development, but
14884 if doing development on a custom skin you may wish to poke it as well.
14885
14886 === $wgRCShowChangedSize ===
14887
14888 Special:Recentchanges and Special:Watchlist now show the number of bytes
14889 added or removed to an article to give an idea of the size of the edit.
14890 This information was previously available only in the IRC update feeds.
14891
14892 To disable this site-wide, set $wgRCShowChangedSize to false.
14893 (Individual users can suppress the data in custom CSS.)
14894
14895 Adjust $wgRCChangedSizeThreshold to trigger highlighting of particularly
14896 large changes.
14897
14898 The formatting of the size figure can be adjusted through the
14899 [[MediaWiki:Rc-change-size]] message.
14900
14901 === $wgQueryCacheLimit ===
14902
14903 The number of rows stored for "expensive" special pages in miser mode
14904 can now be adjusted up or down from the default 1000.
14905
14906 === $wgDisableQueryPageUpdate ===
14907
14908 Individual "expensive" special pages can be skipped in processing by
14909 updateSpecialPages if added to this list.
14910
14911 === $wgSorbsUrl ===
14912
14913 The base hostname for the DNS-based proxy blacklist can now be overridden
14914 when $wgEnableSorbs is set, to use a different blacklist instead of SORBS.
14915 The blacklist would need to respond the same was as SORBS; any positive
14916 response will be taken as a proxy.
14917
14918 === $wgAjaxWatch ===
14919
14920 Experimental AJAX mode for the watch/unwatch tabs to execute inline.
14921 Does not include the UI messages describing how to reach the watchlist,
14922 so you may not want it on a general-audience site just yet.
14923
14924 === $wgParserTestFiles ===
14925
14926 MediaWiki's parser test suite can now be expanded with additional test
14927 files. Custom extensions can add their test files to this array, and
14928 they will be run along with the main tests by maintenance/parserTests.php
14929
14930 = MediaWiki 1.8=
14931
14932 == MediaWiki 1.8.5 ==
14933
14934 September 10, 2007
14935
14936 This is a security fix update to the Fall 2006 quarterly release snapshot. A
14937 possible HTML/XSS injection vector in the API pretty-printing mode has been
14938 found and fixed.
14939
14940 The vulnerability may be worked around in an unfixed version by simply
14941 disabling the API interface if it is not in use, by adding this to
14942 LocalSettings.php:
14943
14944 :[[Manual:$wgEnableAPI|$wgEnableAPI]] = false;
14945
14946 (This is the default setting in 1.8.x.)
14947
14948 Not vulnerable versions:
14949 * 1.11 >= 1.11.0
14950 * 1.10 >= 1.10.2
14951 * 1.9 >= 1.9.4
14952 * 1.8 >= 1.8.5
14953
14954 Vulnerable versions:
14955 * 1.11 <= 1.11.0rc1
14956 * 1.10 <= 1.10.1
14957 * 1.9 <= 1.9.3
14958 * 1.8 <= 1.8.4 (if $wgEnableAPI has been switched on)
14959
14960 MediaWiki 1.7 and below are not affected as they do not include the faulty
14961 function, however the BotQuery extension is similarly vulnerable unless updated
14962 to the latest SVN version.
14963
14964 == MediaWiki 1.8.4 ==
14965
14966 February 20, 2007
14967
14968 This is a security and bug-fix update to the Fall 2006 quarterly release.
14969
14970 An XSS injection vulnerability based on Microsoft Internet Explorer's UTF-7
14971 charset autodetection was located in the AJAX support module, affecting MSIE
14972 users on MediaWiki 1.6.x and up when the optional setting
14973 [[Manual:$wgUseAjax|$wgUseAjax]] is enabled.
14974
14975 If you are using an extension based on the optional Ajax module, either disable
14976 it or upgrade to a version containing the fix:
14977 * 1.9: fixed in 1.9.3
14978 * 1.8: fixed in 1.8.4
14979 * 1.7: fixed in 1.7.3
14980 * 1.6: fixed in 1.6.10
14981
14982 There is no known danger in the default configuration, with $wgUseAjax off.
14983
14984 * (bug [[bugzilla:8819|8819]]) Fix full path disclosure with skins dependencies
14985 * Add 'charset' to Content-Type headers on various HTTP error responses to
14986 forestall additional UTF-7-autodetect XSS issues. PHP sends only 'text/html' by
14987 default when the script didn't specify more details, which some inconsiderate
14988 browsers consider a license to autodetect the deadly, hard-to-escape UTF-7.
14989 This fixes an issue with the Ajax interface error message on MSIE when
14990 [[Manual:$wgUseAjax|$wgUseAjax]] is enabled (not default configuration); this
14991 UTF-7 variant on a previously fixed attack vector was discovered by Moshe BA
14992 from BugSec: http://www.bugsec.com/articles.php?Security=24
14993 * Trackback responses now specify XML content type
14994
14995 == MediaWiki 1.8.3 ==
14996
14997 January 9, 2007
14998
14999 MediaWiki 1.8.3 fixes several issues in the Fall 2006 snapshot release:
15000
15001 * ([[mediazilla:7831|7831]]) Regression in AutoAuthenticate hook
15002 * Run PHP install version checks on update.php so command-line updaters see new
15003 version requirements
15004 * Do a check for the PHP 5.0.x 64-bit bug, since this is much more disruptive
15005 as of MW 1.8 than it used to be. Install or upgrade now aborts with a warning
15006 and a request to upgrade.
15007 * XSS fix in AJAX module
15008
15009 An XSS injection vulnerability was located in the AJAX support module,
15010 affecting MediaWiki 1.6.x and up when the optional setting $wgUseAjax is
15011 enabled.
15012
15013 There is no danger in the default configuration, with $wgUseAjax off.
15014
15015 If you are using an extension based on the optional AJAX module, either disable
15016 it or upgrade to a version containing the fix:
15017
15018 == MediaWiki 1.8.2 ==
15019
15020 October 13, 2006
15021
15022 MediaWiki 1.8.2 fixes several issues in the Fall 2006 snapshot release:
15023
15024 * ([[mediazilla:7565|7565]]) Fixed typos in German localisation
15025 * ([[mediazilla:7562|7562]]) Fix non-ASCII namespaces on Windows/XAMPP servers
15026
15027 == MediaWiki 1.8.1 ==
15028
15029 October 11, 2006
15030
15031 MediaWiki 1.8.1 fixes several issues in the Fall 2006 snapshot release:
15032
15033 * Fix PHP notice and estimates for dumpBackup.php and friends
15034 * Improved register_globals paranoia checks
15035 * ([[mediazilla:7545|7545]]) Fix PHP version check on install
15036 * Experimental web API disabled by default
15037 * Disable PHP exception backtrace printing unless $wgShowExceptionDetails is
15038 set. Backtraces may contain sensitive information in function call parameters.
15039
15040 == MediaWiki 1.8.0 ==
15041
15042 October 10, 2006
15043
15044 This is the quarterly release snapshot for Fall 2006. While the code has been
15045 running on Wikipedia for some time, installation and upgrade bits may be less
15046 well tested. Bug fix releases may follow in the coming days or weeks.
15047
15048 MediaWiki is now using a "continuous integration" development model with
15049 quarterly snapshot releases. The latest development code is always kept "ready
15050 to run", and in fact runs our own sites on Wikipedia.
15051
15052 Release branches will continue to receive security updates for about a year
15053 from first release, but nonessential bugfixes and feature development happen
15054 will be made on the development trunk and appear in the next quarterly release.
15055
15056 Those wishing to use the latest code instead of a branch release can obtain it
15057 from source control: [[Download from SVN]]
15058
15059 == Configuration changes ==
15060 * $wgUseETag, to enable/disable sending of HTTP ETag headers (default: disabled)
15061 * $wgLegalTitleChars now includes '+' by default for better compatibility with
15062 importing data dumps from Wikipedia
15063 * $wgDefaultUserOptions now includes all default option settings instead of
15064 only overrides.
15065
15066 == Major new features ==
15067 * ([[mediazilla:7098|7098]]) Add an option to disable/enable sending of HTTP
15068 ETag headers, as it seems to result in broken behaviour in combination with
15069 Squid 2.6 (disabled by default).
15070 * ([[mediazilla:550|550]]) Allow blocks on anonymous users only.
15071 * ([[mediazilla:6420|6420]]) Render thumbnails for DJVU images, support
15072 multipage DJVU display on image pages. Added new 'page=' thumbnail option to
15073 select a page from a multipage djvu for thumbnail generation.
15074 * Full Postgres support is now enabled. It requires version 8.1 or better, and
15075 needs to have both plpgsql and tsearch2 already installed.
15076 * ([[mediazilla:6386|6386]]) fix grammatical errors in danish naming of talk
15077 namespaces.
15078
15079 == Changes since 1.7 ==
15080
15081 * Introduced AjaxResponse object, superceding AjaxCachePolicy
15082 * Changes to sajax_do_call: optionally accept an element to fill instead of a
15083 callback function; take the target function or element as a third parameter;
15084 pass the full XMLHttpRequest object to the handler function, instead of just
15085 the resultText value; use HTTP response codes to report errors.
15086 * (bug 6562) Removed unmaintained ParserXml.php for now
15087 * History paging overlap bug fixed
15088 * (bug 6586) Regression in "unblocked" subtitle
15089 * Don't put empty-page message into view-source when page text is blank
15090 * (bug 6587) Remove redundant "allnonarticles" message
15091 * Block improvements: Allow blocks on anonymous users only. Optionally allow
15092 or disallow account creation from blocked IP addresses. Prevent duplicate
15093 blocks. Fixed the problem of expiry and unblocking erroneously affecting
15094 multiple blocks. Fixed confusing lack of error message when a blocked user
15095 attempts to create an account. Fixed inefficiency of Special:Ipblocklist in
15096 the presence of large numbers of blocks; added indexes and implemented an
15097 indexed pager.
15098 * (bug 6448) Allow filtering of Special:Newpages according to username
15099 * (bug 6618) Improve permissions/error detection in Special:Lockdb
15100 * Quick hack for extension testing: parser test doesn't create new message
15101 cache object.
15102 * (bug 6299) Maintain parser's revision ID across recursive calls to fix
15103 {{REVISIONID}} when Cite extension is used
15104 * (bug 6622) Removed deprecated function Image::newFromTitle
15105 * (bug 6627) Fix regression in Special:Ipblocklist with table prefix
15106 * Removed forced dereferencements (new() returns a reference in PHP5)
15107 * Note about $wgUploadSizeWarning using byte
15108 * (bug 6592) Add most viewed pages summary to Special:Statistics
15109 * Pre-strip characters ignored in IDNs from URLs so they can't be used
15110 to break the blacklists for regular URLs
15111 * Fix regression in blocking of user accounts
15112 * (bug 6635) Fix regression searching for range blocks on Ipblocklist
15113 * Fix regression searching Ipblocklist with ugly URLs
15114 * (bug 6639) Use a consistent default for upload directories
15115 * Preserve entered reason when reporting unconfirmed lock on Special:Lockdb
15116 * (bug 6642) Don't offer to unlock the database when it isn't locked
15117 * cleanupTitles.php changed from --dry-run option to --fix, so default
15118 behavior is now a non-invasive check as with namespaceDupes.php
15119 * (bug 6660) Fix behavior of EditPage::blockedPage() when the article does
15120 not exist; now doesn't show the source box if the user hasn't provided it
15121 (blocked mid-edit) and the page doesn't exist
15122 * Improve default value of "blockedtext"
15123 * (bug 6680) Added localisation for Dutch bookstore list (nl)
15124 * Renamed maintainace script redundanttrans.php to unusedMessages.php - clearer usage
15125 * Fix regression which allowed some blocked users to create additional accounts
15126 * (bug 6657) Fix Hungarian linktrail
15127 * (bug 6751) Fix preview of blanked section with edit on first preview option
15128 * (bug 5456) Separate MediaWiki:Search into messages for both noun and verb,
15129 introduced 'MediaWiki:Searchbutton'
15130 * Made lines from initialiseMessages() appear as list items during installation
15131 * Moved the bulk of the localisation data from the Language*.php files to the
15132 Messages*.php files. Deleted most of the Languages*.php files.
15133 * Introduced "stub global" framework to provide deferred initialisation of core
15134 modules.
15135 * Removed placeholder values for $wgTitle and $wgArticle, these variables will
15136 now be null during the initialisation process, until they are set by index.php
15137 or another entry point.
15138 * Added DBA cache type, for BDB-style caches.
15139 * Removed custom date format functions, replacing them with a format string in
15140 the style of PHP's date(). Used string identifiers instead of integer
15141 identifiers, in both the language files and user preferences. Migration should
15142 be transparent in most cases.
15143 * Simplified the initialisation API for LoadBalancer objects.
15144 * Removed the broken altencoding feature.
15145 * Moved default user options and toggles from Language to User. Language objects
15146 are still able to define default preference overrides and extra user toggles,
15147 via a slightly different interface.
15148 * Don't include the date option in the parser cache rendering hash unless
15149 $wgUseDynamicDates is enabled.
15150 * Merged LanguageUtf8 with Language. Removed LanguageUtf8.php.
15151 * Removed inclusion of language files from the bottom of Language.php. This is
15152 now consistently done from Language::factory().
15153 * Add the name of the executing maintenance script to the debug log. Start the
15154 profiler during maintenance scripts.
15155 * Added "serialized" directory, for storing precompiled data in serialized form.
15156 * Fix regression in auto-set NS_PROJECT_TALK namespace
15157 * Fix regression in ordering of namespaces
15158 * (bug 6806, 6030) Added several global JS variables for article path, user name,
15159 page title, etc.
15160 * hooks registered with addOnloadHook are now called at the one of the html body
15161 by all skins.
15162 * Split ajax aided search from core ajax framework. Use wgUseAjax to enable the
15163 framework and wgAjaxSearch to enable the suggest feature for the search box.
15164 * Added experimental installer for extensions.
15165 See maintenance/installExtension.php
15166 * Added Tajic (tg) language file.
15167 * (bug 6903) Added Cantonese localisation (zh-yue)
15168 * Fix regression in Korean and Japanese date formatting (day of week)
15169 * (bug 6919) Add English alias magic words for Tatar (tt) language file.
15170 * (bug 6753) Fixed broken Kazakh linktrail (kk)
15171 * (bug 6700) Added Kazakh language variants to Names.php
15172 * (bug 6827) some i18n specific maintenance scripts fails after merge of localisation-work branch
15173 * Throwed an exception for the deprecated functions OutputPage::sysopRequired and
15174 OutputPage::developerRequired - use OutputPage::permissionRequired instead.
15175 * Removed the deprecated functions User::isSysop, User::isBureaucrat and User::isDeveloper -
15176 use User::isAllowed instead.
15177 * (bug 769) OutputPage::permissionRequired() should suggest groups with the needed permission
15178 * (bug 6971) Fix regression in Special:Export history view
15179 * Revamped Special:Imagelist
15180 * (bug 7000) updated MessagesPl.php
15181 * (bug 6946) Fix unexpected behavior change with GET hits to Special:Export
15182 * (bug 1866) Improve navigation on Special:Listusers; user now a starting
15183 point as with Special:Allpages, rather than a pure limit.
15184 * Clean up tab order on Special:Blockip
15185 * (bug 5969) Clean up tab order on Special:Userlogin forms
15186 * (bug 3512) namespaceDupes now handles spaces and initial caps properly
15187 * (bug 7037) Fix regression in login tab order
15188 * (bug 7031) Report missing email on 'email password' instead of false success
15189 * (bug 7010) Don't send email notifications for watched talk pages when user
15190 has selected to receive only updates for their own talk page
15191 * Added {{CURRENTHOUR}}
15192 * Added [[:Image:Foo.png]] style links to the pagelinks table
15193 * Avoid duplicate revision imports with Special:Import
15194 * (bug 7054) Validate email address before sending email confirmation message
15195 * (bug 7061) Format title on "from (page)" links on Special:Allpages
15196 * (bug 7044) Introduce "padleft" and "padright" colon functions
15197 * Pass page title as parameters to "linkshere" and "nolinkshere" and update
15198 default message text
15199 * Allows to upload from publicy accessible URL. Set $wgAllowCopyUploads = true ; in LocalSettings.php
15200 Limited to $wgMaxUploadSize (default:100MB); URL upload is limited to sysops by default, and displayed as a second line if appropriate
15201 * (bug 832) Return to user page after emailing a user
15202 * (bug 366) Add local-system-timezone equivalents for date/time variables
15203 * (bug 7109) Fix Atom feed version number in header links
15204 * (bug 7075) List registered parser function hooks on Special:Version
15205 * (bug 7059) Introduce "anchorencode" colon function
15206 * Include SVN revision number in {{CURRENTVERSION}} output, where applicable
15207 * Fix bug in wfRunHooks which caused corruption of objects in the hook list
15208 * (bug 4979) Use simplified email addresses when running on Windows
15209 * (bug 4434) Show block log fragment on Special:Blockip
15210 * [[MediaWiki:Disambiguationspage]] may optionally contain wiki links to any number
15211 of disambiguation templates.
15212 * [[Special:Disambiguations]] now shows pages in NS:0 that link to any pages that embed
15213 any of the templates listed at [[MediaWiki:Disambiguationspage]].
15214 * Fix formatting of titles on Special:Undelete
15215 * (bug 7026) Fix action=raw&templates=expand
15216 * (bug 6976) Add namespace and direction classes to classic skins
15217 * (bug 7144) Don't "return to main" from OutputPage::loginToUse() if the user can't
15218 read the main page in the first place
15219 * (bug 7188) Fix minor borkage in HTMLForm
15220 * (bug 6675) Replaced message 'watchthis' with new message 'watchthisupload in Special:Upload
15221 * Add a quickie script dumpSisterSites.php for generating a page list in the
15222 format for WSR-1 SisterSites support
15223 * (bug 7223) Monobook.js is used for site content, should not be localized
15224 * Set default disabled values for DjVu render options
15225 * Added Xml::option() for generating <option>s easily
15226 * Localized page numbers in drop-down for DjVu page selection
15227 * Fixed linktrail for vi
15228 * (bug 6893) "Call to a member function exists() on a non-object" on trackback.php with bad input
15229 * (bug 6886) PHP undefined offset on bad input to Special:Revisiondelete
15230 * (bug 6887) PHP error for call to getId() on bad input to Special:Revisiondelete
15231 * (bug 6888) PHP error for call to getTimestamp() on bad input to Special:Revisiondelete
15232 * (bug 7252) Use dvipng support in texvc math rastrization. dvipng is required if texvc is rebuilt.
15233 * (bug 7279) Use wfBaseName in place of basename() in more places
15234 * Clear newtalk marker on diff links with explicit current revision number
15235 * (bug 7064) Replace hard-coded empty message checks with wfEmptyMsg calls
15236 * (bug 6777) Remove some PHP 4 compat cruft
15237 * Add --user, --comment, and --license options to importImages.php
15238 * (bug 6216) The immobile namespace message does not mention the source page
15239 * (bug 7299) Normalize username filter on Special:Newpages
15240 * (bug 7306) RTL text in an LTR wiki breaks appearance of Special:Recentchanges
15241 * (bug 7312) Don't emit SET NAMES utf8 if connection failed
15242 * (bug 7305) Proper compare for bot check on RC notify, should fix overrides
15243 that force edits by non-bot users to bot mode
15244 * Set Vary: Cookie on action=raw generated CSS and JS, to ensure that user
15245 preferences don't get stuck in proxy caches for other people
15246 * (bug 7324) Fix error message for failure of Database::sourceFile()
15247 * (bug 7309) Plurals: use singular form for zero in French and Brazilian Portuguese
15248 * Add page_no_title_convert field to support language variant conversion
15249 for page titles which shouldn't be converted on display/linking
15250 * Lazy extraction of text chunks in Revision objects, may reduce hits to
15251 external storage when actual text content is not used
15252 * Added experimental $wgRevisionCacheExpiry to cache extracted revision text
15253 in $wgMemc, to further reduce hits to external storage.
15254 Set to 0 (disabled) by default.
15255 * Minor changes to the installer.
15256 * Remove ":" for 'youremail' and 'yourrealname' in includes/templates/Userlogin.php
15257 so that ":" could be used in i18n for Special:Preferences (like 'username' and 'uid').
15258 * Fix layout for Special:Preferences->Date and Time (position for 'timezonetext').
15259 * Updates to language variant code for Serbian et al
15260 * (bug 6756) Enabling RTL direction for kk-cn
15261 * (bug 6701) Kazakh language variants in MessagesEn.php
15262 * (bug 7335) SVN revision check in Special:Version fails on SVN 1.4 working copy
15263 * (bug 6518) Replaced 'lastmodified' with 'lastmodifiedat' and 'lastmodifiedby' with 'lastmodifiedatby'
15264 with separated parameters for date and time to allow better localisation. Updated all message files
15265 to display the old format for compatibility.
15266 * (bug 7357) Make supposedly static methods of Skin actually static
15267 * Added info text to Special:Deadendpages and Special:Lonelypages
15268 * Fix regression in cachability of generated CSS and JS for MonoBook skin,
15269 while avoiding clobbering of different users' cached data
15270 * (bug 6849) Block @ from usernames; interferes with multi-database tools and
15271 was meant to be banned years ago... For now existing accounts will not be
15272 prevented fromm login.
15273 * (bug 6092) Introduce magic words {{REVISIONDAY}}, {{REVISIONDAY2}, {{REVISIONMONTH}},
15274 {{REVISIONYEAR}} and {{REVISIONTIMESTAMP}}
15275 * (bug 7425) Preceeding whitespace in [[...]] breaks subpages
15276 * Try to reconnect after transitory database errors in dumpTextPass.php
15277 * (bug 6023) Fixed mismatch of 0/NULL for wl_notificationtimestamp; now notification
15278 mails are working after 'Mark all pages visited' button on Special:Watchlist is clicked
15279 * Made {{INT:}} a core parser function instead of a special case. The syntax
15280 and behavior is largely unchanged.
15281 * (bug 7448) Fixing the native name for Ewe (ee)
15282 * (bug 6864) Replace message 'editing' with new message 'editinguser' in Special:Userrights
15283 to allow better localisation
15284 * Add '*-summary' for special pages to MessagesEn.php to allow customizing/translation
15285 directly through Special:Allmessages
15286 * (bug 6130, bug 5818) Replaced message 'go' with the new message 'searcharticle' in skins
15287 to allow better localisation
15288 * Add + to $wgLegalTitleChars by default. Some sites may have occasional
15289 problems with hard-to-reach pages, but it should be less trouble than
15290 "I can't import dumps from Wikipedia" complaints
15291 * (bug 7460) Revert broken patch for bug 7226 which slows down
15292 Special:Allmessages by a factor of 16
15293 * Committed a bunch of live hacks from Wikimedia servers
15294 * (bug 6889) PHP notices in thumb.php with missing params
15295 * Cleaner error behavior on thumb.php with invalid page selection
15296 * (bug 6617) Validate timestamps on Special:Undelete
15297 * Do fewer unnecessary full writes of user rows; only update user_touched
15298 for watch/unwatch, group membership change, and login operations
15299 * Restructured the languages directory, to avoid problems when people
15300 untar MW 1.8 over the top of a 1.7 installation.
15301 * (bug 6890) SQL query error on bad input to Pager lists
15302 due to negative LIMIT clause, caused by integer wraparound.
15303 * Fixed various bugs related to table prefixes, especially the interaction
15304 between table prefixes and memcached, which was formerly completely broken.
15305 * (bug 7004) PHP iconv() notice on bad password input to Special:Userlogin.
15306 * (bug 6826) Extend pre-save transform context link ("pipe trick")
15307 syntax to pages with commas in title
15308 * Use ImageMagick -thumbnail option instead of -resize to avoid including
15309 excessive metadata in thumbs (requires ImageMagick 6.0.0 or newer).
15310 * (bug 7499) Corrections to Swedish talk namespace names
15311 * (bug 7508) Added option to compress HTML pages by dumpHTML.php
15312 * (bug 7519) Add plural in SpecialWatchlist
15313 * (bug 7459) Magic word variables are always case sensitive
15314 * Replaced {{SERVER}}{{localurl:xxx}} with {{fullurl:xxx}} in localisation files
15315 * Fix regression in Special:Watchlist text header
15316 * (bug 7510) Update article counts etc on undelete
15317 * (bug 7520) Update article counts on XML import
15318 * (bug 7526) Make $wgDefaultUserOptions work again
15319 * (bug 7472) Localize Help namespace for Basque
15320 * (bug 7529) Including a non-existent category in an article places that article in the category
15321 * (bug 4528) Lack of important LaTeX functions stackrel, rightleftharpoon
15322 * (bug 6721) missing symbols ulcorner, urcorner, llcorner, lrcorner, twoheadrightarrow, twoheadleftarrow
15323 * (bug 7367) Hyphens sometimes erroneously appended to equations when not converted to PNG
15324 * Add "title" to the opensearch link to allow automatic adding of the search engine in Firefox 2
15325 * (bug 7537) Add php5 to $wgFileBlacklist
15326 * (bug 6929) Restore AutoAuthenticate hook
15327
15328 == Languages updated ==
15329 * Albanian (sq)
15330 * Bashkir (ba)
15331 * Bavarian (bar) stub file
15332 * Belarusian (be)
15333 * Bishnupriya (bpy) stub file
15334 * Brazilian Portuguese (pt-br)
15335 * Cantonese (zh-yue)
15336 * Catalan (ca)
15337 * Czech (cs)
15338 * Dutch (nl)
15339 * English (en)
15340 * Finnish (fi)
15341 * French (fr)
15342 * Georgian (ka)
15343 * German (de)
15344 * Hebrew (he)
15345 * Hungarian (hu)
15346 * Indonesian (id)
15347 * Japanese (ja)
15348 * Korean (ko)
15349 * Latin (la)
15350 * Lojban (jbo)
15351 * Macedonian (mk)
15352 * Mazandarani (mzn)
15353 * Polish (pl)
15354 * Portuguese (pt)
15355 * Ripuarian (ksh)
15356 * Romani (rmy)
15357 * Russian (ru)
15358 * Slovak (sk)
15359 * Spanish (es)
15360 * Tajic (tg)
15361 * Tatar (tt)
15362 * Telugu (te)
15363 * Uzbek (uz)
15364 * Yiddish (yi)
15365
15366 == Compatibility ==
15367 MediaWiki 1.8 requires PHP 5 (5.1 recommended). PHP 4 is no longer supported.
15368
15369 MySQL 3.23.x is no longer supported; some older hosts may need to upgrade. At
15370 this time we still recommend 4.0, but 4.1/5.0 will work fine in most cases.
15371
15372 == Upgrading ==
15373 Some minor database changes have been made since 1.7:
15374 * new fields and indexes on ipblocks
15375 * index change on recentchanges
15376
15377 Several changes from 1.5 and 1.6 do require updates to be run on upgrade. To
15378 ensure that these tables are filled with data, run refreshLinks.php after the
15379 upgrade.
15380
15381 If you are upgrading from MediaWiki 1.4.x or earlier, some major database
15382 changes are made, and there is a slightly higher chance that things could
15383 break. Don't forget to always back up your database before upgrading!
15384
15385 === Caveats ===
15386 Some output, particularly involving user-supplied inline HTML, may not produce
15387 100% valid or well-formed XHTML output. Testers are welcome to set $wgMimeType
15388 = "application/xhtml+xml"; to test for remaining problem cases, but this is not
15389 recommended on live sites. (This must be set for MathML to display properly in
15390 Mozilla.)
15391
15392 = MediaWiki 1.7=
15393
15394 == MediaWiki 1.7.3 ==
15395
15396 February 20, 2007
15397
15398 This is a security and bug-fix update to the Summer 2006 quarterly release.
15399
15400 An XSS injection vulnerability based on Microsoft Internet Explorer's UTF-7
15401 charset autodetection was located in the AJAX support module, affecting MSIE
15402 users on MediaWiki 1.6.x and up when the optional setting
15403 [[Manual:$wgUseAjax|$wgUseAjax]] is enabled.
15404
15405 If you are using an extension based on the optional Ajax module, either disable
15406 it or upgrade to a version containing the fix:
15407
15408 * 1.9: fixed in 1.9.3
15409 * 1.8: fixed in 1.8.4
15410 * 1.7: fixed in 1.7.3
15411 * 1.6: fixed in 1.6.10
15412
15413 There is no known danger in the default configuration, with
15414 [[Manual:$wgUseAjax|$wgUseAjax]] off.
15415
15416 * Add 'charset' to Content-Type headers on various HTTP error responses to
15417 forestall additional UTF-7-autodetect XSS issues. PHP sends only 'text/html' by
15418 default when the script didn't specify more details, which some inconsiderate
15419 browsers consider a license to autodetect the deadly, hard-to-escape UTF-7.
15420 This fixes an issue with the Ajax interface error message on MSIE when
15421 [[Manual:$wgUseAjax|$wgUseAjax]] is enabled (not default configuration); this
15422 UTF-7 variant on a previously fixed attack vector was discovered by Moshe BA
15423 from BugSec: http://www.bugsec.com/articles.php?Security=24
15424 * Trackback responses now specify XML content type
15425
15426 == MediaWiki 1.7.2 ==
15427
15428 January 9, 2007
15429
15430 * Note about $wgUploadSizeWarning using byte
15431 * Update to German bookstore list (de)
15432 * (bug [[bugzilla:6680|6680]]) Added localisation for Dutch bookstore list (nl)
15433 * (bug [[bugzilla:6708|6708]]) Minor updates to Russian translation (ru)
15434 * (bug [[bugzilla:6730|6730]]) Clearer usage of message 'titlematch' in German
15435 translation (de)
15436 * Added direction mark to Special:Listredirects
15437 * XSS fix in AJAX module
15438
15439 An XSS injection vulnerability was located in the AJAX support module,
15440 affecting MediaWiki 1.6.x and up when the optional setting
15441 [[Manual:$wgUseAjax|$wgUseAjax]] is enabled.
15442
15443 There is no danger in the default configuration, with
15444 [[Manual:$wgUseAjax|$wgUseAjax]] off.
15445
15446 If you are using an extension based on the optional AJAX module, either disable
15447 it or upgrade to a version containing the fix:
15448
15449 * 1.9: fixed in 1.9.0rc2
15450 * 1.8: fixed in 1.8.3
15451 * 1.7: fixed in 1.7.2
15452 * 1.6: fixed in 1.6.9
15453
15454
15455 == MediaWiki 1.7.1 ==
15456
15457 July 8, 2006
15458
15459 MediaWiki 1.7.1 is a security and bugfix maintenance release of the Summer 2006
15460 snapshot:
15461
15462 A potential HTML/JavaScript-injection vulnerability in a debugging script has
15463 been fixed. Only versions and configurations of PHP vulnerable to the $GLOBALS
15464 overwrite vulnerability are affected.
15465
15466 As a workaround for existing installs, profileinfo.php may simply be deleted if
15467 it's not being used.
15468
15469 * Fix for 'emailconfirmed' implicit user group
15470 * Fix for upgrades on some versions of MySQL 4.0.x
15471 * Fixed potential XSS in profileinfo.php
15472 * Installer now shows clear error message about old PHP versions rather than a
15473 confusing parse error
15474
15475 == MediaWiki 1.7.0 ==
15476 July 6, 2006
15477
15478 This is the quarterly release snapshot for Summer 2006. While the code
15479 has been running on Wikipedia for some time, installation and upgrade
15480 bits may be less well tested. Bug fix releases may follow in the coming
15481 days or weeks.
15482
15483 MediaWiki is now using a "[[w:en:Continuous_integration|continuous
15484 integration]]" development model with
15485 quarterly snapshot releases. The latest development code is always kept
15486 "ready to run", and in fact runs our own sites on Wikipedia.
15487
15488 Release branches will continue to receive security updates for about a year
15489 from first release, but nonessential bugfixes and feature development happen
15490 will be made on the development trunk and appear in the next quarterly release.
15491
15492 Those wishing to use the latest code instead of a branch release can obtain
15493 it from source control: [[Download from SVN]]
15494
15495 == Changes since 1.6 ==
15496
15497 * (bug 5458) Fix double-URL encoding in block log link in contribs and contribs
15498 link in block log
15499 * (bug 5462) Bogus missing patch warning in updater
15500 * (bug 5461) Use of deprecated "showhideminor" in Special:Recentchangeslinked
15501 * PHP warning when allow_call_time_pass_reference is off
15502 * Update to Finnish localization
15503 * (bug 5467) Link to page histories in watchlist edit mode
15504 * Further additions to Hebrew localisation
15505 * (bug 5476) Invalid xhtml in German localization
15506 * (bug 5479) Id translation for preferences tabs caption
15507 * (bug 5493) Id translation for special pages
15508 * Added skinname and style path parameters to CBT version of MonoBook
15509 * Include subversion revision number in Special:Version if available
15510 * (bug 5344) Fix regression that broke slashes in extension tag parameters
15511 * Improve Special:Log performance on big log sets
15512 * (bug 5507) Changed mediawiki:logouttext from plain to wikitext
15513 * (bug 4760) Prevent creation of entries in protection log when protection
15514 levels haven't changed
15515 * (bug 861) Show page protection/unprotection events in histories
15516 * (bug 5499) Don't clear the tag strip state when asked not to clear state.
15517 Fixes regression with use of <ref> in a template breaking <nowiki> etc.
15518 * Minor improvements to English language files
15519 * Display the anon talk page info message on anon talk pages again
15520 (moved outside the parser cache)
15521 * Optional {{DISPLAYTITLE|title with markup}} magic word
15522 Deactivated by default, set "$wgAllowDisplayTitle = true" in LocalSettings.php
15523 to activate
15524 * Cleaned SpecialContributions a bit
15525 * Added a table to track interlanguage links
15526 * (bug 5544) Fix redirect arrow in Special:Listredirects for right-to-left
15527 languages
15528 * Replace "doubleredirectsarrow" with a content language check that picks the
15529 appropriate arrow
15530 * (bug 5537) Add stub language file for Samogitian (bat-smg); inherits
15531 Lithuanian (lt)
15532 * Don't force edit summaries when a user is editing their own user/talk page
15533 * (bug 5510) Warning produced when using {{SUBPAGENAME}} in some namespaces
15534 * (bug 385) Installer support for PostgreSQL, fixes for PG compatibility
15535 * PersistentObject removed; it doesn't do anything and was broken besides.
15536 All extensions using it have been corrected.
15537 * Propagate ISBN number for Booksources in LanguageNo.php
15538 * (bug 5548) Improvements to Indonesian localisation [patch: Ivan Lanin]
15539 * Add TALKSPACE, SUBJECTSPACE, TALKPAGENAME, SUBJECTPAGENAME (and encoded forms
15540 for all) magic words
15541 * (bug 5403) Fix Special:Newpages RSS/Atom feeds
15542 * Reject malformed addresses in X-Forwarded-For entries
15543 * (bug 3359) Add hooks on completion of file upload
15544 * (bug 5559) Improve detection of ImageMagick [patch: Greg Turnquist]
15545 * (bug 5475) New pages feeds ignore "limit" argument
15546 * (bug 5184) CSS misapplied to elements in Special:Allmessages due to
15547 conflicting anchor identifiers
15548 * (bug 5519) Allow sidebar cache to be disabled; disable it by default.
15549 * Maintenance script to import the contents of a text file into a wiki page
15550 * Add $wgReservedUsernames configuration directive to block account creation/use
15551 * (bug 5576) Remove debugging hack in session check
15552 * (bug 5426) Lowercase treatment of titles in rights log leads to broken links
15553 on Special:Log
15554 * Minor improvements to French localisation files
15555 * (bug 5181) Update "nogomatch" for Slovak
15556 * (bug 5594) Id translation up to # Login and logout pages section
15557 * (bug 5536) Use content language for editing help link
15558 * Improvements to German localisation files
15559 * (bug 5570) Problems using <special page>/parameter link form for long titles
15560 * (bug 3884) Add $user parameter to AddNewUser hook, call it for by-email
15561 registrations as well as self-registrations.
15562 * (bug 4327) Report age of cached data sets in query pages
15563 * (bug 4662) Fix Safari check in wikibits.js
15564 * (bug 4663) Edit toolbar enabled in compatible versions of Safari
15565 * (bug 5572) Edit toolbar enabled in compatible versions of Konqueror (3.5+)
15566 * (bug 5235) Edit toolbar tooltips no longer show JavaScript junk in Opera
15567 * Edit toolbar now works in pure XHTML mode (application/xhtml+xml)
15568 * Add watchlist clear function to allow quick purging of all items
15569 * (bug 5625) Additional namespace translations for Welsh
15570 * Add meta tag and JavaScript variables to cached special pages which provides
15571 the timestamp of the last update, in YYYYMMDDHHMMSS format.
15572 * (bug 5628) More translations for MessagesHr.php
15573 * (bug 5595) Localisation for Bosnian language (bs)
15574 * (bug 2910) Default view preferences for watchlists
15575 * Add "hide bot edits from the watchlist" user preference
15576 * (bug 5250) Introduce Special:Unusedtemplates
15577 * Add user preference setting for an extended watchlist, showing all recent
15578 edits up to a certain edit, and not just the latest edit..
15579 * Made MessageRo.php more general
15580 * (bug 5640) Indonesian localisation improvements
15581 * (bug 5592) Actions are logged with the default language for the
15582 wiki, not the language of the user performing the operation.
15583 * (bug 5644) Error in LanguageBs.php file
15584 * (bug 5646) Compare for identical types in wfElement()
15585 * (bug 5472) Language::userAdjust()->minDiff not initialized on else condition
15586 * (bug 5386) LanguageMk.php: updated namespaces translations
15587 * (bug 5422) Stub for Romani (rmy) language which extends ro
15588 * Fix linktrail for LanguageSr
15589 * (bug 5664) Fix Bosnian linktrail
15590 * (bug 3825) Namespace filtering on Special:Newpages
15591 * (bug 1922) When Special:Wantedpages is cached, mark links to pages
15592 which have since been created
15593 * (bug 5659) Change grammar hacks for Bosnian Wikimedia namespaces.
15594 This sort of special casing should be removed and fixed properly.
15595 * Remove useless whitespace from Special:Brokenredirects header
15596 * Treat "allmessagesnotsupporteddb" as wikitext when echoing; change default
15597 text
15598 * (bug 5497) Regression in HTML normalization in 1.6 (unclosed <li>,<dd>,<dt>)
15599 * (bug 5709) Allow customisation of separator for categories
15600 * (bug 5684) Introduce Special:Randomredirect
15601 * (bug 5611) Add a name attribute to the text box containing source text in
15602 read-only pages
15603 * Indicate when a protected page is an interface message ("protectedinterface")
15604 * (bug 4259) Indicate when a protected page being edited is an interface message
15605 ("editinginterface")
15606 * (bug 4834) Fix XHTML output when using $wgMaxTocLevel
15607 * Pass login link to "whitelistedittext" containing 'returnto' parameter
15608 * (bug 5728): mVersion missing from User::__sleep() leading to constant cache
15609 miss
15610 * Updated maintenance/transstat.php so it can show duplicate messages
15611 * Improvements to update scripts; print out the version, check for superuser
15612 credentials before attempting a connection, and produce a friendlier error if
15613 the connection fails
15614 * (bug 5005) Fix XHTML <gallery> output.
15615 * (bug 5315) "Expires: -1" HTTP header made strictly valid (using 1970 date).
15616 * (bug 4825) note in DefaultSettings.php about 'profiling' table creation
15617 * Remove unneeded extra whitespace at top of Special:Categories
15618 * (bug 5679) time units are now using local numerals
15619 * (bug 5751) Updates to Portuguese localisation files
15620 * (bug 5741) Introduce {{NUMBEROFUSERS}} magic word
15621 * (bug 93) <nowiki> tags and tildes in templates
15622 * The returnto parameter is now actually used by SpecialUserlogin.php
15623 * Parser can now know that it is parsing an interface message
15624 * (bug 4737) MediaWiki:Viewcount supports {{PLURAL}} now
15625 * Fix bug in wfMsgExt under PHP 5.1.2
15626 * (bug 5761) Project talk namespace broken in Xal, Os, Udm and Cv
15627 * Rewrite reassignEdits script to be more efficient; support optional updates to
15628 recent changes table; add reporting and silent modes
15629 * Cleaned up formatNum usage in langfiles
15630 * (bug 5716) Warn when a user tries to upload a file which was previously
15631 deleted
15632 * (bug 5565) Add a class attribute to the table on Special:Allpages
15633 * "lang=xx" option for parser test cases to set content language
15634 * (bug 5764) Friulian translation updated
15635 * (bug 5757) Fix premature cutoff in LanguageConverter with extra end markers
15636 * (bug 5516) Show appropriate "return to" link on blocked page
15637 * (bug 5377) Do not auto-login when creating an account as another user
15638 * (bug 5284) Special redirect pages should remember parameters
15639 * Suppress 7za output on dumpBackup
15640 * (bug 5338) Reject extra initial colons in title
15641 * (bug 5487) Escape self-closed HTML pair tags
15642 * Add "raw suffix" magic word for some magic words, e.g. {{NUMBEROFUSERS|R}}
15643 will produce a count minus formatting
15644 * Fix Parser::cleanSig() to use Parser::startExternalParse() and choose an
15645 appropriate output format given the scope of the clean
15646 * (bug 5593) Change "bureaucrat log" to "rights log"
15647 * Show a boilerplate "(none)" in place of a blank within the log action text for
15648 user rights
15649 * (bug 137) Commented out translations for copyrightwarning which mention GNU FDL
15650 * (bug 5723) Don't count pages linked to from the MediaWiki namespace as "wanted"
15651 * (bug 5696) Add a third parameter, $3, to "rcnote", passing the current time
15652 formatted according to the current user's settings
15653 * (bug 5780) Thousands and decimal separators for Norwegian
15654 * Updated initStats maintenance script
15655 * (bug 5767) Fix date formats in Vietnamese locale
15656 * (bug 361) URL in URL, they were almost fixed. Now they are.
15657 * (bug 4876) Add __NEWSECTIONLINK__ magic word to force the "new section" link/tab to
15658 show up on specific pages on demand
15659 * Bidi-aid on list pages
15660 * (bug 5782) Allow entries in the bad image list to use canonical namespace names
15661 * (bug 5789) Treat "loginreqpagetext" as wikitext
15662 * Sanitizer: now handles nested <li> in <ul> or <ol>
15663 * (bug 5796) We require MySQL >=4.0.14
15664 * Add 'EmailConfirmed' hook
15665 * New findhooks.php script to find undocumented hooks.
15666 * Silently ignore errors on profiling table update.
15667 * (bug 5801) Correct handling of underscores in Special:Listusers
15668 * Clean up Special:Listusers; add an "(all)" label to the group selection box
15669 * (bug 5812) Use appropriate link colour in Special:Mostlinked
15670 * (bug 5802) {{CURRENTMONTHNAME}} variable broken in Vietnamese locale
15671 * (bug 5817) Appropriate handling for Special:Recentchangeslinked where the target
15672 page doesn't exist
15673 * Special:Randompage now additionally accepts English namespace name as parameter
15674 * (bug 2981) Really fixed linktrail for Tamil (ta)
15675 * Disallow substituting Special pages when included into a page
15676 * (bug 5587) Clean up the languages from references to the Groups special page
15677 * Added new group-X and group-X-member messages
15678 * Rewritten removeUnusedAccounts to be more efficient, print names of inactive
15679 accounts
15680 * Redirect Special:Userlist to Special:Listusers
15681 * Introduce $wgAllowTitlesInSVG, which allows the <title> attribute in uploaded files
15682 bearing the image/svg MIME type. Disabled by default due to the vast majority of
15683 web servers being hideously misconfigured. See DefaultSettings.php for more details.
15684 * Changed default LocalSettings.php to append the previous include path when setting it
15685 * (bug 5837) Use "members" for the value descriptor in Special:Categories,
15686 Special:Wantedcategories and Special:Mostlinkedcategories.
15687 * (bug 3309) Allow comments when undeleting pages
15688 * Clean up Special:Undelete a bit
15689 * (bug 5805) messages nbytes, ncategories can now use {{plural:}}
15690 * Clean up Special:Imagelist a bit
15691 * (bug 5838) Namespace names for Nds-NL
15692 * (bug 5749) Added Tyvan language files
15693 * (bug 5791) Fix SQL syntax in Special:BrokenRedirects, was causing incorrect data to show
15694 * (bug 5839) Prevent access to Special:Confirmemail for logged-out users
15695 * (bug 5853) Update for Portuguese messages (pt)
15696 * (bug 5851) Use Cyrillic for Kirghiz language name
15697 * (bug 5841) Allow the 'EditFilter' hook to return a non-fatal error message
15698 * (bug 5846) Link to individual group description pages in Special:Listusers
15699 * (bug 5857) Update for German localisation (de)
15700 * (bug 5858) Update for Russian language (ru)
15701 * (bug 5860) Update for Indonesian language (id)
15702 * (bug 1120) Update for Czech language (Cs)
15703 * Added many missing formatNum calls
15704 * Added grammar function to Belarusian (be)
15705 * (bug 5819) Add 'PersonalUrls' hook
15706 * (bug 5862) Update of Belarusian language (be)
15707 * (bug 5886) Update for Portuguese messages (pt)
15708 * (bug 5586) <gallery> treated text as links
15709 * (bug 5878) Update for Indonesian language (id)
15710 * (bug 5697) Update for Malay language (ms)
15711 * (bug 5890) Update for German language (de)
15712 * (bug 5889) Name for Sindhi language should appear as سنڌي
15713 * --force-normal parameter on dump scripts to force check for ICU extension
15714 * (bug 5895) Update for Dutch language (nl)
15715 * (bug 5891) Linktrail for Polish language (pl)
15716 * User::isBureaucrat , User::isDeveloper , User::isSysop deprecated in
15717 v1.6 now die with a backtrace. They will be removed in v1.8
15718 * dumpTextPass now skips goes to database for entries that were blank in the
15719 previous dump, as this may indicate a broken dump.
15720 * dumpTextPass progress includes percentage of items prefetched
15721 * dumpTextPass can now use 7zip files for prefetch
15722 * (bug 5915) Update to Indonesian localisation (id)
15723 * (bug 5913) Update for German localisation (de)
15724 * (bug 5905) Plural support for Bosnian localisation (bs)
15725 * Groups which won't hit the rate limiter now configurable with
15726 $wgRateLimitsExcludedGroups
15727 * (bug 5806) {{plural:}} support instead of "twin" MediaWiki messages
15728 * (bug 5931) Update for Polish language (pl)
15729 * Ignore the user and user talk namespaces on Special:Wantedpages
15730 * Introduce NUMBEROFPAGES magic word
15731 * (bug 5833) Introduce CURRENTVERSION magic word
15732 * (bug 5370) Allow throttling of password reminder requests with the rate limiter
15733 * (bug 5683) Respect parser output marked as uncacheable when saving
15734 * (bug 5918) Links autonumbering now work for all defined protocols
15735 * (bug 5935) Improvement to German localisation (de)
15736 * (bug 5937) Register links from gallery captions with the parent parser output
15737 object so that link tables receive those updates too
15738 * (bug 5845) Introduce BASEPAGENAME and BASEPAGENAMEE magic words
15739 * (bug 5941) Use content language when getting the administrator page title for
15740 Special:Statistics
15741 * (bug 5949) Update to Indonesian localisation (id)
15742 * (bug 5862) Update of Belarusian translation (be)
15743 * (bug 5950) Improvements to French localisation
15744 * (bug 5805) {{plural:}} support for counters in some special pages
15745 * (bug 5952) Improvement to German localisation (de)
15746 * Rename conflicting metadata help message to "metadata_help" (was "metadata")
15747 and treat it as wiki text
15748 * Improve preferences input filtering
15749 * Maintenance script to import multiple files into the wiki
15750 * (bug 5957) Update for Hebrew language (he)
15751 * (bug 5962) Update for Italian language (it)
15752 * (bug 5961) Update for Portuguese localisation (pt)
15753 * (bug 5849) Remove some hard-coded references to "Wikipedia" in messages
15754 * (bug 5967) Improvement to German localisation (de)
15755 * (bug 5962) Update for Italian language (it)
15756 * Suppress images in galleries which appear on the bad image list (when rendering
15757 for a wiki page; galleries in special pages and categories are unaffected)
15758 * Maintenance script to remove orphaned revisions from the database
15759 * (bug 5991) Update for Russian language (ru)
15760 * (bug 6001) PAGENAMEE and FULLPAGENAMEE don't work in FULLURL and LOCALURL magic
15761 words
15762 * (bug 5958) Switch Uzbek language name to use latin script
15763 * (bug 839) Add URLENCODE magic word
15764 * (bug 6004) Update for Polish language (pl)
15765 * (bug 5971) Improvement to German localisation (de)
15766 * (bug 4873) Don't overwrite the subtitle navigation when viewing a redirect page
15767 that isn't current
15768 * (bug 2203) Namespace updates for Thai
15769 * Fix breakage in parser test suite which caused incorrect reporting of the failure of
15770 {{NUMBEROFFILES}}. Now initialises the site_stats table with some dumb data. Updated
15771 the expected output for {{NUMBEROFARTICLES}} to reflect this.
15772 * (bug 6009) Use {{ns:project}} in messages where appropriate
15773 * (bug 6012) Update to Indonesian localisation (id)
15774 * (bug 6017) Update list of bookstores in German localisation files
15775 * (bug 5187) Allow programmatically bypassing username validation, for scripts
15776 * (bug 6025) SpecialImport: wrong message when no file selected
15777 * (bug 6015) EditPage: add spacing in the boxes "edit is minor" and "watch this"
15778 * (bug 6018) Userrights: new message when no user specified ('nouserspecified')
15779 * (bug 2015) Add "\sim" to ~ conversion for HTML rendering
15780 * (bug 6029) Improvement to German localisation (de)
15781 * (bug 5015) Update be: magic words
15782 * (bug 3974) Add parameter for site URL to "passwordremindertext"
15783 * (bug 6039) Update for Portuguese localisation (pt)
15784 * (bug 764) Add CREATE TEMPORARY TABLES to default database permissions
15785 * Big update to Swedish localisation (sv)
15786 * Use appropriate HTML functions to create the tool links on image pages, so they don't
15787 look garbled when tidy isn't on
15788 * (bug 5511) Fix URL-encoding of usernames in links on Special:Ipblocklist
15789 * (bug 6046) Update to Indonesian localisation (id) #15
15790 * (bug 5523) $wgNoFollowNsExceptions to allow disabling rel="nofollow" in
15791 specially-selected namespaces.
15792 * (bug 6055) Fix for HTML/JS injection bug in variable handler (found by Nick Jenkins)
15793 * Reordered wiki table handling and __TOC__ extraction in the parser to better
15794 handle some overlapping tag cases.
15795 * Only the first __TOC__ is now turned into a TOC
15796 * (bug 4610) Indicate patrolled status on watchlists and allow users to mark
15797 changes as patrolled using the diff links there
15798 * Add 'DiffViewHeader' hook called before diff page output
15799 * (bug 6051) Improvement to German localisation (de)
15800 * (bug 6054) Update to Indonesian localisation (id) #16
15801 * Add {{CURRENTTIMESTAMP}} magic word
15802 * (bug 6061) Improper escaping in some html forms
15803 * (bug 6065) Remove underscore when using NAMESPACE and TALKSPACE magics.
15804 * (bug 6074) Correct squid purging of offsite upload URLs
15805 * To simplify the lives of extension developers, the logging type arrays
15806 can now be appended to directly by an extension setup function. It is
15807 no longer necessary to write four separate functions just to add a
15808 custom log type.
15809 * (bug 6057) Count "licenses" as a message (and show it in Special:Allmessages)
15810 * Added $wgGrammarForms global
15811 * Fixed hardcoded 'done.' when removing watchlist entries.
15812 * (bug 5962) Update for Italian language (it)
15813 * (bug 6086) Remove vestigial attempt to call Article::validate()
15814 * wfHostname() function for consistent server hostname use in debug messages
15815 * Send thumbnailing error messages to 'thumbnail' log group
15816 * wfShellexec() now accepts an optional parameter to receive the exit code
15817 * Failed, but not zero-length, thumbnail renderings are now removed.
15818 Should help clean up when rsvg fails in weird ways.
15819 * (bug 6081) Change description for Turkmen language
15820 * Increase robustness of parser placeholders; fixes some glitches when
15821 adjacent to identifier-ish constructs such as URLs.
15822 * Shut up the parser test whining about files in a temp directory.
15823 * (bug 6098) Add Aragonese language support (an)
15824 * (bug 6101) Update for Russian language (ru)
15825 * Add $wgIgnoreImageErrors to suppress error messages for thumbnail rendering
15826 problems. If errors are transitory, this should reduce annoying messages
15827 making it into cached display.
15828 * (bug 6103) Wrap self-links in a CSS class ("selflink")
15829 * (bug 6102) For consistency with other markup, normalize all HTML-encoded
15830 character entities in URLs, not just ampersands. This allows use of eg
15831 &#61; when making URLs for template parameters.
15832 * Markup anality: escape </ as <\/ in toolbar javascript for pure correctness
15833 under HTML-compatible browsers.
15834 * (bug 5077) Added hook 'BeforePageDisplay' to SkinTemplate::outputPage
15835 * Replace fatally changed 'uploadnewversion' with 'uploadnewversion-linktext'
15836 * (bug 472) Syndication feeds for the last few edits of page history
15837 * Format edit comments in Recent Changes feed
15838 * Switch incorrectly ordered column headers on Recent Changes feed diffs
15839 * (bug 6117) Use message for history feed description, add German localization
15840 * (bug 1017) fixed thumbnails of animated gifs.
15841 * Add APC as object caching option
15842 * Update to Albanian localization (sq)
15843 * (bug 6099) Introduce {{DIRECTIONMARK}} magic word (with {{DIRMARK}} as an alias)
15844 * Use optimized php5-only microtime()
15845 * Add possibility to store local message cache as PHP executable script
15846 * Fix profiling table definition
15847 * (bug 6040) Run pre-save transform before calculating the diff. when doing a
15848 "show changes" operation in the editor
15849 * (bug 4033) Respect $wgStyleDirectory when checking available skins
15850 * Remove hideous backslashes from MessagesBr.php
15851 * Fix APC object cache issues, add functionality to installer
15852 * (bug 6133) Update strip state as we work. This mostly fixes extensions
15853 used in Cite.php <ref> tags when Tidy is on.
15854 * (bug 6139) Workaround for transclusion oddities in Vietnamese upload text
15855 * (bug 6136) Update to Catalan language (ca)
15856 * Update to Japanese localization (ja)
15857 * Add /usr/local/bin to the diff3 search paths in the installer
15858 * (bug 6106) Update to Indonesian localisation (id) #17
15859 * (bug 6125) Add links to edit old versions to diff views
15860 * (bug 5127) Auto edit summary when creating/editing redirect page
15861 * (bug 3926) Introduce {{#language:}} magic word
15862 * Fix section links from edit comments for [[:Image:Bla.jpg]] in section titles
15863 * (bug 6126) Allow fallback to customized primary language when user language
15864 message contains '-'; fixes licenses selector on Commons configuration after
15865 recent addition of the message to Messages.php
15866 * (bug 5527) Batch up job queue insertions for, hopefully, better survivability
15867 of lock contention etc. Duplicates are now removed at pop time instead of
15868 at insert time.
15869 * When showing the "blah has been undeleted" page, make sure it's a blue link
15870 * parserTests.php accepts a --file parameter to run an alternate test sutie
15871 * parser tests can now test extensions using !!hooks sections
15872 * Fix oddity with open tag parameters getting stuck on </li>
15873 * (bug 5384) Fix <!-- comments --> in <ref> extension
15874 * Nesting of different tag extensions and comments should now work more
15875 consistently and more safely. A cleaner, one-pass tag strip lets the
15876 'outer' tag either take source (<nowiki>-style) or pass it down to
15877 further parsing (<ref>-style). There should no longer be surprise
15878 expansion of foreign extensions inside HTML output, or differences
15879 in behavior based on the order tags are loaded.
15880 * (bug 885) Pre-save transform no longer silently appends close tags
15881 * Pre-save transform no longer changes the case of close tags
15882 * (bug 6164) Fix regression with <gallery> resetting <ref> state
15883 * Hackaround for IE 7 wrapping bug in MonoBook footer
15884 * New message sp-newimages-showfrom replaces rclistfrom on special:newimages
15885 * Improve handling of ;: definition list construct with overlapping or
15886 nested HTML tags
15887 * (bug 6171) Fix sanitizing of HTML-elements with an optional closing
15888 tag. The sanitizer still needs to learn how to make well-formed XML
15889 in this case.
15890 * Fix fatal error when specifying illegal name for manual thumbnail
15891 * (bug 6184) Use shinier Linker::userLink() to make user links in
15892 Special:Undelete
15893 * (bug 6170) Update for Kashubian translation (csb)
15894 * (bug 6191) Update to Indonesian translation (id) #18
15895 * (bug 6114) Update to Walloon localization (wa)
15896 * Added $wgNamespaceRobotPolicies to allow customisation of robot policies on a
15897 per-namespace basis.
15898 * Add <ol> to the list of block elements for doBlockLevels; avoids <p>s being
15899 interspersed into your ordered lists.
15900 * (bug 5021) Transcluding the same special page twice now works
15901 * Add 'SiteNoticeBefore' and 'SiteNoticeAfter' hooks
15902 * (bug 6182) Date passed in "sp-newimages-showfrom" not adjusted to user time
15903 preferences
15904 * (bug 2587) Fix for section editing with comment prefix
15905 * (bug 2607) Fix for section editing with mix of wiki and HTML headings
15906 * (bug 3342) Fix for section editing with headings wrapped in <noinclude>
15907 * (bug 3476) Fix for section editing with faux headings in extensions
15908 * (bug 5272) Fix for section editing with HTML-heading subsections
15909 * Fix for bogus wiki headings improperly detected with following text
15910 * Fix for HTML headings improperly not detected with preceding/following text
15911 * Section extraction and replacement functions merged into one implementation
15912 on the Parser object, so they can't get out of sync with each other.
15913 * Edit security precautions in raw HTML mode, etc
15914 * (bug 6197) Update to Indonesian translation (id) #19
15915 * (bug 6175) Improvement to German translation (de)
15916 * Redirect Special:Logs to Special:Log
15917 * (bug 6206) Linktrail for Swedish localization (se)
15918 * (bug 3202) Attributes now allowed on <pre> tags
15919 * Sanitizer::validateTagAttributes now available to discard illegal/unsafe
15920 attribute values from an array.
15921 * (bug 3837) Leave <center> as is instead of doing an unsafe text replacement
15922 to <div class="center">. <center> is perfectly valid in the target doctype
15923 (XHTML 1.0 Transitional), while the replacement didn't catch all cases and
15924 could even result in invalid output from valid input.
15925 * (bug 4280) Use 'noindex,nofollow' instead of 'noindex,follow' for default
15926 meta robots tag on diff view and special pages. Should reduce impact of
15927 robots on scrolling special pages, diffs etc on sites where robots.txt
15928 doesn't forbid access.
15929 * Regression fix: suppress warning about session failure when clicking to
15930 edit with 'preview on first edit' enabled.
15931 * (bug 6230) Regression fix: <nowiki> in [URL link text]
15932 * Added AutoLoader.php, which loads classes without need of require_once()
15933 * (bug 5981) Add plural function Slovenian (sl)
15934 * (bug 5945) Introduce {{CONTENTLANGUAGE}} magic word
15935 * {{PLURAL}} can now take up to five forms
15936 * (bug 6243) Fix email for usernames containing dots when using PEAR::Mail
15937 * Remove a number of needless {{ns:project}}-type transforms from messages files. These
15938 usages already have separate label text. Such transforms are wasteful on each page view.
15939 * Update to Yiddish localization (yi)
15940 * (bug 6254) Update to Indonesian translation (id) #20
15941 * (bug 6255) Fix transclusions starting with "#" or "*" in HTML attributes
15942 * Whitespace now normalized more or less properly in HTML attributes
15943 * Fix regression(?) in behavior of initial-whitespace-pre in <center>
15944 * (bug 6260) Update to Interlingua localization (ia)
15945 * Update to Vlax Romany localization (rmy)
15946 * Update to Latin translation (la)
15947 * Update to Dutch translation (nl)
15948 * Avoid some notices in page history with bad input
15949 * Use double quoted consistently on attributes in linker output; preparing
15950 for new normalization code when tidy not in use
15951 * Replace "nogomatch" with "noexactmatch" and place the magic colon in the messages
15952 themselves. Some minor tweaks to the actual message content.
15953 * Introduce $wgContentNamespaces which allows for articles to exist in namespaces other
15954 than the main namespace, and still be counted as valid content in the site statistics.
15955 * (bug 5932) Introduce {{PAGESINNAMESPACE}} magic word
15956 * Disable $wgAllowExternalImages by default.
15957 * (bug 2700) Nice things like link completion and signatures now work in <gallery> tags.
15958 * Cancel output buffering in StreamFile; when used inside gzip buffering this
15959 could cause funny timeout behavior as the Content-Length was wrong.
15960 * Return correct content-type header with 304 responses for StreamFile;
15961 it confuses Safari if you let it return "text/html".
15962 * (bug 6280) Correct GRAMMAR for Slovenian localisation (sl)
15963 * (bug 6162) Change date format for Dutch Low Saxon (nds-nl)
15964 * (bug 6296) Update to Indonesian localisation (id) #21
15965 * Introduce EditFormPreloadText hook, see docs/hooks.txt for more information
15966 * (bug 4054) Add "boteditletter" to recent changes flags
15967 * Update to Catalan localization (ca)
15968 * (bug 2099) Deleted image files can now be archived and undeleted.
15969 Set $wgSaveDeletedFiles on and an appropriate directory path in
15970 $wgFileStore['deleted']['directory']
15971 * (bug 6324) Fix regression in enhanced RC alignment
15972 * Introduce {{NUMBEROFADMINS}} magic word
15973 * Update to Slovak translation (sk)
15974 * Update to Alemannic localization (gsw)
15975 * (bug 6300) Bug fixes for sr: variants
15976 * namespaceDupes.php can now accept an arbitrary prefix, for checking rogue
15977 interwikis and such. Not yet fully automated.
15978 * (bug 6344) Add Special:Uncategorizedimages page
15979 * (bug 6357) Update to Russian translation (ru)
15980 * Workaround possible bug in Firefox nightlies by properly removing the
15981 Content-Encoding header instead of sending explicit 'identity' value
15982 in StreamFile
15983 * (bug 6304) Show timestamp for current revision in diff pages
15984 * Vertically align current version with old version header in diff display
15985 * (bug 6174) Remove redundant "emailforlost" message
15986 * (bug 6189) Show an error to an unprivileged user trying to create account
15987 * (bug 6365) Show user information in the "old revision" navigation links
15988 * Introduce 'FetchChangesList' hook; see docs/hooks.txt for more information
15989 * (bug 6345) Update to Indonesian localisation (id) #22
15990 * (bug 6279) Add genitive month names to Slovenian localisation
15991 * (bug 6351) Update to German translation (de)
15992 * Respect language directionality when displaying arrow in Special:Brokenredirects
15993 * Remove unused "validation" table definitions from the schema files
15994 * (bug 6398) Work around apparent PCRE bug breaking section editing when
15995 massively-indented preformatted text immediately followed a header
15996 * (bug 6392) Fix misbehaving <br /> in preferences form
15997 * Add translated magic words to Hebrew localization
15998 * (bug 6396) Change name for Chuvash language
15999 * Introduce optional (off by default) language selector bar for user login
16000 and registration. Customisable via the "loginlanguagelinks" message, the
16001 links will preserve "returnto" values. If the user creates an account while
16002 using such a link, then the language in use will be saved as their language
16003 preference.
16004 * Make sure '~~~' '~~~~' '~~~~~' are removed in Nickname preference.
16005 * Rename "ipusuccess" to "unblocked", change the format (now wiki text)
16006 * (bug 2316) Add "caption" attribute to <gallery> tag
16007 * Allow setting the skin object that ImageGallery will use; needed during parse
16008 operations (the skin must come from the ParserOptions, not $wgUser)
16009 * Fix notice in MacBinary detection debug data for files of certain lengths
16010 * (bug 6131) Add type detection for DjVu files, allowing them to be uploaded
16011 with validity checking and size detection. No inline thumbnailing yet,
16012 but could be added in the future.
16013 * (bug 6423) Don't update newtalk flag if page content didn't change (null edits
16014 were causing the newtalk flag to trigger inappropriately)
16015 * Parser functions are now set using magic words.
16016 * (bug 6428) Incorrect form action URL on Special:Newimages with hidebots = 0 set
16017 * (bug 4990) Show page source to blocked users on edits, or their modified version
16018 if blocked during an edit
16019 * (bug 5903) When requesting the raw source of a non-existent message page,
16020 return blank content (as opposed to the message key)
16021 * Improve default blank content of MediaWiki:Common.css and MediaWiki:Monobook.css
16022 * (bug 6434) Allow customisation of submit button text on Special:Export
16023 * (bug 6314) Add user tool links on page histories
16024 * Fix display of file-type icons in galleries when $wgIgnoreImageErrors is off
16025 * (bug 6438) Update to Indonesian translation (id) #23
16026 * Adding the language code parameter to the hook "LanguageGetMagic", to allow
16027 localizble extensions magic words.
16028 * Update to Romanian translation (ro)
16029 * Update to Esperanto translation (eo)
16030 * Check for preg_match() existence when installing and die out whining about PCRE
16031 if it's not there, instead of throwing a fatal error
16032 * (bug 672) Add MathAfterTexvc hook
16033 * Update to Piedmontese localization (pms)
16034 * dumpBackup can optionally compress via dbzip2
16035 * (bug 2483) Run link updates on change via XML import
16036 * (bug 2481) List imported pages during Special:Import
16037 * (bug 2482) Log and RC entries for Special:Import events
16038 * Allow fetching all revisions from transwiki Special:Import
16039 * Allow fetching all revisions from Special:Export GET request
16040 * Disable output buffering on Special:Export; should help with streaming
16041 large numbers of history items.
16042 * Allow setting a maximum number of revisions for history Special:Export;
16043 pages with more than $wgExportMaxHistory revisions are excluded from
16044 export when history is requested.
16045 * Fix transwiki import of pages with space in name
16046 * Save null edit when importing pages through Special:Import
16047 * Update to Korean translation (ko)
16048 * Show a more specific message when an anonymous user tries to access Special:Watchlist
16049 * (bug 3278) Paging links in Special:Prefixindex
16050 * Added Latvian localization (lv)
16051 * (bug 6472) Fix regression in Special:Export with multiple pages
16052 * Update to Macedonian translation (mk)
16053 * Allow page moves over historyless self-redirects. Such are usually created
16054 as part of namespace rearrangements, and it's easier to clean them up if
16055 we can move over them.
16056 * Show some error results in moveBatch.php
16057 * (bug 6479) Allow specification of the skin to use during HTML dumps
16058 * (bug 6461) Link to page histories in Special:Newpages
16059 * (bug 6484) Don't do message transformations when preloading messages for editing
16060 * (bug 6201) Treat spaces as underscores in parameters to {{ns:}}
16061 * (bug 6006) Allow hiding the password change fields using an authentication plugin
16062 * (bug 6489) Use appropriate link colour on Special:Shortpages
16063 * Added formatnum magic word
16064 * Added Javanese localization (jv)
16065 * (bug 6491) Apply bad image list in category galleries
16066 * (bug 6488) Show relevant log fragment in Special:Movepage
16067 * Fix potential PHP notice in Special:Blockme when $wgBlockOpenProxies is true
16068 * Use mysql_real_escape_string instead of addslashes for string escaping in
16069 the MySQL Database class. This may fix some rare breakage with binary fields.
16070 Note that MediaWiki does not support the multibyte character sets where a
16071 "dumb" byte replacement can be actively dangerous; UTF-8 is always safe
16072 in this regard due to the bit patterns which make head and tail bytes
16073 distinct.
16074 * (bug 6497) Use $wgMetaNamespaceTalk for Esperanto if set
16075 * (bug 6498) Use localized forms for image size in Special:Undelete
16076 * (bug 6485) Update to Indonesian translation (id) #24
16077 * Extension messages translation is now possible.
16078 * Add target namespace override selector for transwiki imports.
16079 $wgImportTargetNamespace specifies the default, to be used for
16080 Wiktionary's 'Transwiki:' namespace etc.
16081 * (bug 6506) Update to German localisation (de)
16082 * (bug 502) Avoid silly tabs on bad title by using virtual special page
16083 * (bug 6511) Add diff links to old revision navigation bar
16084 * (bug 6511) Replace 'oldrevisionnavigation' message with 'old-revision-navigation'
16085 * Fix regression in Polish genitive month forms
16086 * (bug 4037) Make input handling in Special:Allpages and Special:Prefixindex
16087 more consistent: Accept just a namespace prefix and a colon, reject input
16088 with interwiki prefixes, otherwise do what Title::makeTitleSafe() does.
16089 * (bug 6516) Update to Russian translation
16090 * New 'allpagesbadtitle' message for Special:Allpages, based on 'badtitletext'.
16091 * Rename "searchquery" to "searchsubtitle" and support wiki text in it
16092 * Introduce updateArticleCount maintenance script which uses a better check that
16093 reflects what Article::isCountable() tests for
16094 * Introduce 'BadImage' hook; see docs/hooks.txt for more information
16095 * Add "searchsubtitleinvalid" message for searches that are not valid titles.
16096 * (bug 5962) Update to Italian localisation
16097 * (bug 6530) Update to Indonesian localisation (id) #25
16098 * (bug 6523) Fix SVG issue in rebuildImages.php
16099 * (bug 6512) Link to page-specific logs on page histories
16100 * (bug 6504) Allow configuring session name with $wgSessionName
16101 * (bug 6185) Add standard user tool links to log page views
16102 * Update to Venetian translation (vec)
16103 * Update to Slovenian translation (sl)
16104 * Add standard user tool links to deleted revision list
16105 * Separate out EditPage's getContent bits from regular Article getContent.
16106 Cleans up read-only-mode warning on empty pages and neats up some code.
16107 * (bug 6565) Strict JavaScript writing
16108 * (bug 6570) Update to Indonesian localisation (id) #26
16109 * Added Telugu translation (te)
16110 * Update to Catalan translation (ca)
16111 * (bug 6560) Avoid PHP notice when trimming ISBN whitespace
16112 * Added namespace translation to Kannada (ka)
16113 * (bug 6566) Improve input validation on timestamp conversion
16114 * Implicit group "emailconfirmed" for all users whose email addresses are confirmed
16115 * (bug 6577) Avoid multiline parser breakage on <pre> with newline in attribute
16116 * (bug 6771) Make old revisions of MediaWiki pages available with action=raw
16117
16118
16119 == Compatibility ==
16120 MediaWiki 1.7 requires PHP 5 (5.1 recommended). PHP 4 is no longer supported.
16121
16122 If you are unable to run PHP 5, you may have to stick with 1.6 for now.
16123
16124 MySQL 3.23.x is no longer supported; some older hosts may need to upgrade.
16125 At this time we still recommend 4.0, but 4.1/5.0 will work fine in most cases.
16126
16127 Experimental Oracle support has been dropped as it is unmaintained.
16128
16129 == Upgrading ==
16130 Several changes to the database have been made from 1.6:
16131
16132 * A new "langlinks" table tracks interlanguage links
16133 * A new "filearchive" table stores information on deleted files
16134 * A new "querycache_info" table stores information on query page updates
16135
16136 To ensure that these tables are filled with data, run refreshLinks.php after
16137 the upgrade.
16138
16139 If you are upgrading from MediaWiki 1.4.x or earlier, some major database
16140 changes are made, and there is a slightly higher chance that things could
16141 break. Don't forget to always back up your database before upgrading!
16142
16143 == Configuration changes ==
16144
16145 Some configuration options have changed:
16146 * $wgAllowExternalImages now defaults to off for increased security.
16147 * $wgLocalTZoffset was in hours, it is now using minutes.
16148 * Extensions may register special pages via the $wgSpecialPages array without
16149 forcing an early load of the SpecialPage.php class file.
16150
16151 == Major new features ==
16152
16153 * Deleted files can now be archived and undeleted, if you set up an appropriate
16154 non-web-accessible directory. Set $wgSaveDeletedFiles on and an appropriate
16155 directory path in $wgFileStore['deleted']['directory']
16156 * Experimental PostgreSQL support has been updated. It may or may not be in
16157 usable shape; those interested in PostgreSQL are encouraged to follow 1.8
16158 development.
16159
16160 === Caveats ===
16161 Some output, particularly involving user-supplied inline HTML, may not
16162 produce 100% valid or well-formed XHTML output. Testers are welcome to
16163 set $wgMimeType = "application/xhtml+xml"; to test for remaining problem
16164 cases, but this is not recommended on live sites. (This must be set for
16165 MathML to display properly in Mozilla.)
16166
16167 = MediaWiki 1.6 =
16168
16169 == MediaWiki 1.6.12 ==
16170
16171 February 7, 2009
16172
16173 This is a security update to the Spring 2006 quarterly release.
16174
16175 A number of cross-site scripting (XSS) security vulnerabilities were discovered
16176 in the web-based installer (config/index.php). These vulnerabilities all
16177 require a live installer -- once the installer has been used to install a
16178 wiki, it is deactivated.
16179
16180 Note that cross-site scripting vulnerabilities can be used to attack any
16181 website in the same cookie domain. So if you have an uninstalled copy of
16182 MediaWiki on the same site as an active web service, MediaWiki could be used to
16183 attack the active service.
16184
16185 If you are hosting an old copy of MediaWiki that you have never installed, you
16186 are advised to remove it from the web.
16187
16188 == MediaWiki 1.6.11 ==
16189
16190 December 15, 2008
16191
16192 This is a security update to the Spring 2006 quarterly release.
16193
16194 David Remahl of Apple's Product Security team has identified a number of
16195 security issues in previous releases of MediaWiki. Subsequent analysis by the
16196 MediaWiki development team expanded the scope of these vulnerabilities. The
16197 issues with a significant impact are as follows:
16198
16199 * An XSS vulnerability affecting Internet Explorer clients for all MediaWiki
16200 installations with uploads enabled. [CVE-2008-5250]
16201 * An XSS vulnerability affecting clients with SVG scripting capability (such as
16202 Firefox 1.5+), for all MediaWiki installations with SVG uploads enabled.
16203 [CVE-2008-5250]
16204 * A CSRF vulnerability affecting the Special:Import feature, for all MediaWiki
16205 installations since the feature was introduced in 1.3.0. [CVE-2008-5252]
16206
16207 XSS (cross-site scripting) vulnerabilities allow an attacker to steal an
16208 authorised user's login session, and to act as that user on the wiki. The
16209 authorised user must visit a web page controlled by the attacker in order to
16210 activate the attack. Intranet wikis are vulnerable if the attacker can
16211 determine the intranet URL, even if the attacker cannot access it.
16212
16213 CSRF vulnerabilities allow an attacker to act as an authorised user on the
16214 wiki, but unlike an XSS vulnerability, the attacker can only act as the user in
16215 a specific and restricted way. The present CSRF vulnerability allows pages to
16216 be edited, with forged revision histories. Like an XSS vulnerability, the
16217 authorised user must visit the malicious web page to activate the attack.
16218
16219 Rather than backport our SVG validation code to this ancient branch, we have
16220 instead disabled SVG uploads. To enable SVG uploads, please upgrade to
16221 MediaWiki 1.13.3 or later.
16222
16223 The other two issues have been fixed.
16224
16225 == MediaWiki 1.6.10 ==
16226
16227 February 20, 2007
16228
16229 This is a security and bug-fix update to the Spring 2006 quarterly release.
16230
16231 An XSS injection vulnerability based on Microsoft Internet Explorer's UTF-7
16232 charset autodetection was located in the AJAX support module, affecting MSIE
16233 users on MediaWiki 1.6.x and up when the optional setting $wgUseAjax is enabled.
16234
16235 If you are using an extension based on the optional Ajax module, either disable
16236 it or upgrade to a version containing the fix:
16237
16238 * 1.9: fixed in 1.9.3
16239 * 1.8: fixed in 1.8.4
16240 * 1.7: fixed in 1.7.3
16241 * 1.6: fixed in 1.6.10
16242
16243 There is no known danger in the default configuration, with $wgUseAjax off.
16244
16245 * ([[mediazilla:8819|bug 8819]]) Fix full path disclosure with skins
16246 dependencies
16247 * Add 'charset' to Content-Type headers on various HTTP error responses to
16248 forestall additional UTF-7-autodetect XSS issues. PHP sends only 'text/html' by
16249 default when the script didn't specify more details, which some inconsiderate
16250 browsers consider a license to autodetect the deadly, hard-to-escape UTF-7.
16251 This fixes an issue with the Ajax interface error message on MSIE when
16252 $wgUseAjax is enabled (not default configuration); this UTF-7 variant on a
16253 previously fixed attack vector was discovered by Moshe BA from BugSec:
16254 http://www.bugsec.com/articles.php?Security=24
16255 * Trackback responses now specify XML content type
16256
16257 == MediaWiki 1.6.9 ==
16258
16259 January 9, 2007
16260
16261 * ([[mediazilla:6621|bug 6621]]) Backported German translation for
16262 'eauthentsent'
16263
16264 * ([[mediazilla:6680|bug 6680]]) Added localisation for Dutch bookstore list
16265 (nl)
16266 * ([[mediazilla:6730|bug 6730]]) Clearer usage of message 'titlematch' in
16267 German translation (de)
16268 * XSS fix in AJAX module
16269
16270 An XSS injection vulnerability was located in the AJAX support module,
16271 affecting MediaWiki 1.6.x and up when the optional setting $wgUseAjax is
16272 enabled.
16273
16274 There is no danger in the default configuration, with $wgUseAjax off.
16275
16276 If you are using an extension based on the optional AJAX module, either disable
16277 it or upgrade to a version containing the fix:
16278
16279 * 1.9: fixed in 1.9.0rc2
16280 * 1.8: fixed in 1.8.3
16281 * 1.7: fixed in 1.7.2
16282 * 1.6: fixed in 1.6.9
16283
16284 == MediaWiki 1.6.8 ==
16285
16286 July 8, 2006
16287
16288 MediaWiki 1.6.8 is a security and bugfix maintenance release of the Spring 2006
16289 snapshot:
16290
16291 A potential HTML/JavaScript-injection vulnerability in a debugging script has
16292 been fixed. Only versions and configurations of PHP vulnerable to the $GLOBALS
16293 overwrite vulnerability are affected.
16294
16295 As a workaround for existing installs, profileinfo.php may simply be deleted if
16296 it's not being used.
16297
16298 * ([[mediazilla:5957|bug 5957]]) Updates to Hebrew translation (he)
16299 * Respect language directionality when displaying arrow in
16300 Special:Brokenredirects
16301 * ([[mediazilla:6415|bug 6415]]) Typo in Parser.php
16302 * Fixed potential XSS in profileinfo.php
16303
16304 == MediaWiki 1.6.7 ==
16305
16306 June 6, 2006
16307
16308 MediaWiki 1.6.7 is a security and bugfix maintenance release of the Spring 2006
16309 snapshot:
16310
16311 An HTML/JavaScript-injection vulnerability in the edit form has been closed.
16312 This vulnerability was new in 1.6.0; MediaWiki versions 1.5.x or earlier are
16313 not affected.
16314
16315 Extensions, comments, and <nowiki><nowiki></nowiki> sections are now handled in
16316 a one-pass way which is more reliable and safer. Under earlier versions of
16317 MediaWiki, certain extensions could be abused to inject HTML/JavaScript into
16318 the page.
16319
16320 Additional precautions are made against offsite form submissions when the
16321 restricted raw HTML mode is enabled.
16322
16323 Some small localization and user interface updates are also included.
16324
16325 *([[MediaZilla:6051|bug 6051]]) Improvement to German localisation (de)
16326 *([[MediaZilla:6017|bug 6017]]) Update bookstore list for German language (de)
16327 *([[MediaZilla:6138|bug 6138]]) Minor grammar tweak in "loginreqlink"
16328 *([[MediaZilla:5957|bug 5957]]) Update for Hebrew language (he)
16329 *Increase robustness of parser placeholders; fixes some glitches when adjacent
16330 to identifier-ish constructs such as URLs.
16331 *([[MediaZilla:5384|bug 5384]]) Fix <nowiki><!-- comments --> in <ref></nowiki>
16332 extension
16333 *Nesting of different tag extensions and comments should now work more
16334 consistently and more safely. A cleaner, one-pass tag strip lets the 'outer'
16335 tag either take source (<nowiki><nowiki></nowiki>-style) or pass it down to
16336 further parsing (<nowiki><ref></nowiki>-style). There should no longer be
16337 surprise expansion of foreign extensions inside HTML output, or differences in
16338 behavior based on the order tags are loaded.
16339 *([[MediaZilla:885|bug 885]]) Pre-save transform no longer silently appends
16340 close tags
16341 *Pre-save transform no longer changes the case of close tags
16342 *Edit security precautions in raw HTML mode, etc
16343
16344 == MediaWiki 1.6.6 ==
16345
16346 May 23, 2006
16347
16348 MediaWiki 1.6.6 is a security and bugfix maintenance release.
16349
16350 An XSS injection vector in brace replacement has been fixed, as have some
16351 potential problems with table parsing. Upgrading is strongly recommended for
16352 all users of 1.6. MediaWiki versions 1.5 and earlier are not affected.
16353
16354 Additionally some localization and user interface updates are included.
16355
16356 * Correct "revertpage" message in English
16357 * ([[MediaZilla:5507|bug 5507]]) Logouttext now uses wiki markup
16358 * (bugs [[MediaZilla:5857|5857]], [[MediaZilla:5957|5957]]) Update for German
16359 localisation (de)
16360 * ([[MediaZilla:5586|bug 5586]]) <nowiki><gallery></nowiki> treated text as
16361 links
16362 * ([[MediaZilla:5957|bug 5957]]) Update for Hebrew language (he)
16363 * ([[MediaZilla:6025|bug 6025]]) SpecialImport: wrong message when no file
16364 selected
16365 * ([[MediaZilla:6015|bug 6015]]) EditPage: add spacing in the boxes "edit is
16366 minor" and "watch this"
16367 * ([[MediaZilla:6018|bug 6018]]) Userrights: new message when no user specified
16368 ('nouserspecified')
16369 * ([[MediaZilla:6055|bug 6055]]) Fix for HTML/JS injection bug in variable
16370 handler (found by Nick Jenkins)
16371 * Reordered wiki table handling and <nowiki>__TOC__</nowiki> extraction in the
16372 parser to better handle some overlapping tag cases.
16373 * Only the first <nowiki>__TOC__</nowiki> is now turned into a TOC.
16374 * ([[MediaZilla:361|bug 361]]) URL in URL, they were almost fixed. Now they are.
16375
16376 == MediaWiki 1.6.5 ==
16377
16378 May 2, 2006
16379
16380 * Rolled back the buggy patch for [[MediaZilla:5497|bug 5497]].
16381
16382 == MediaWiki 1.6.4 ==
16383
16384 May 2, 2006
16385
16386 * Further improvements to Hebrew localisation
16387 * ([[MediaZilla:5544|bug 5544]]) Fix redirect arrow in Special:Listredirects
16388 for right-to-left languages
16389 * Replace "doubleredirectsarrow" with a content language check that picks the
16390 appropriate arrow
16391 * Remove live debugging hack which caused errors with certain database names
16392 * ([[MediaZilla:5510|bug 5510]]) Warning produced when using
16393 <nowiki>{{SUBPAGENAME}}</nowiki> in some namespaces
16394 * ([[MediaZilla:5548|bug 5548]]) Improvements to Indonesian localisation
16395 [patch: Ivan Lanin]
16396 * ([[MediaZilla:5403|bug 5403]]) Fix Special:Newpages RSS/Atom feeds
16397 * ([[MediaZilla:3359|bug 3359]]) Add hooks on completion of file upload
16398 * ([[MediaZilla:5184|bug 5184]]) CSS misapplied to elements in
16399 Special:Allmessages due to conflicting anchor identifiers
16400 * ([[MediaZilla:5519|bug 5519]]) Allow sidebar cache to be disabled; disable it
16401 by default.
16402 * Add $wgReservedUsernames configuration directive to block account creation/use
16403 * ([[MediaZilla:5576|bug 5576]]) Remove debugging hack in session check
16404 * ([[MediaZilla:5181|bug 5181]]) Update "nogomatch" for Slovak
16405 * ([[MediaZilla:5594|bug 5594]]) Id translation up to '# Login and logout
16406 pages' section
16407 * ([[MediaZilla:5536|bug 5536]]) Use content language for editing help link
16408 * Minor improvements to English language files
16409 * Improvements to German localisation files
16410 * ([[MediaZilla:5628|bug 5628]]) Translations for MessagesHr.php
16411 * (bugs [[MediaZilla:5595|5595]], [[MediaZilla:5644|5644]]) Localisation for
16412 Bosnian language (bs)
16413 * ([[MediaZilla:5592|bug 5592]]) Actions are logged with the default language
16414 for the wiki, not the language of the user performing the operation.
16415 * ([[MediaZilla:5646|bug 5646]]) Compare for identical types in wfElement()
16416 * Fix for concurrency problem in job queue (image description page invalidation)
16417 * ([[MediaZilla:5497|bug 5497]]) regeression in HTML normalization in 1.6
16418 (unclosed <nowiki><li>,<dd>,<dt></nowiki>)
16419 * ([[MediaZilla:5709|bug 5709]]) Allow customisation of separator for categories
16420 * ([[MediaZilla:4834|bug 4834]]) Fix XHTML output when using $wgMaxTocLevel
16421 * Improvements to update scripts; print out the version, check for superuser
16422 credentials before attempting a connection, and produce a friendlier error if
16423 the connection fails
16424 * ([[MediaZilla:5005|bug 5005]]): Fix XHTML <nowiki><gallery></nowiki> output.
16425 * ([[MediaZilla:5315|bug 5315]]) "Expires: -1" HTTP header made strictly valid
16426 (using 1970 date).
16427 * ([[MediaZilla:4825|bug 4825]]): note in DefaultSettings.php about 'profiling'
16428 table creation
16429 * Remove unneeded extra whitespace at top of Special:Categories
16430 * Rewrite reassignEdits script to be more efficient; support optional updates
16431 to recent changes table; add reporting and silent modes
16432 * Updated initStats maintenance script
16433 * ([[MediaZilla:5723|bug 5723]]) Don't count pages linked to from the MediaWiki
16434 namespace as "wanted"
16435 * ([[MediaZilla:5789|bug 5789]]) Treat "loginreqpagetext" as wikitext
16436 * ([[MediaZilla:5796|bug 5796]]) We require MySQL >=4.0.14
16437
16438 == MediaWiki 1.6.3 ==
16439
16440 April 10, 2006
16441
16442 * Fix disappearing red-linked items in the watchlist editing view
16443 * ([[MediaZilla:5512|bug 5512]]) Spacing in "page has a history" deletion
16444 warning
16445 * ([[MediaZilla:5508|bug 5508]]) Switch ENGINE in table statements back to
16446 TYPE; fixes regression where some versions of MySQL 4.0.x wouldn't work
16447 * Added note about [[Manual:$wgUrlProtocols|$wgUrlProtocols]] format change
16448
16449 == MediaWiki 1.6.2 ==
16450
16451 April 8, 2006
16452
16453 * Further improvements to Hebrew localisation
16454 * Fix 'copyright' message for Romanian
16455 * ([[MediaZilla:5476|bug 5476]]) Invalid xhtml in German localization
16456 * ([[MediaZilla:5479|bug 5479]]) Id translation for preferences tabs caption
16457 * ([[MediaZilla:5493|bug 5493]]) Id translation for special pages
16458 * Additional path fixes in the updater
16459 * ([[MediaZilla:5344|bug 5344]]) Fix regression that broke slashes in extension
16460 tag parameters
16461
16462 == MediaWiki 1.6.1 ==
16463
16464 April 5, 2006
16465
16466 Some minor issues in the 1.6.0 release have been corrected:
16467 * ([[MediaZilla:5458|bug 5458]]) Fix double-URL encoding in block log link in
16468 contribs and contribs link in block log
16469 * ([[MediaZilla:5462|bug 5462]]) Bogus missing patch warning in updater
16470 * ([[MediaZilla:5461|bug 5461]]) Use of deprecated "showhideminor" in
16471 Special:Recentchangeslinked
16472 * PHP warning when allow_call_time_pass_reference is off
16473 * Update to Finnish localization
16474
16475 == MediaWiki 1.6.0 ==
16476
16477 April 5, 2006
16478
16479 MediaWiki is now using a "continuous integration" development model with
16480 quarterly snapshot releases. The latest development code is always kept "ready
16481 to run", and in fact runs our own sites on Wikipedia.
16482
16483 Release branches will continue to receive security updates for about a year
16484 from first release, but nonessential bugfixes and feature development will take
16485 place on the development trunk and will appear in the next quarterly release.
16486
16487 Those wishing to use the latest code instead of a branch release can [[Download
16488 from SVN|obtain it from source control]].
16489
16490 === What's new in 1.6 ===
16491
16492 '''User interface:'''
16493 * The account creation form has been separated from the user login form.
16494 * Page protection/unprotection uses a new, expanded form
16495
16496 '''Templates:'''
16497 * Categories and "what links here" now update as expected when adding or
16498 removing links in a template.
16499 * Template parameters can now have default values, as <nowiki>{{{name|default
16500 value}}}</nowiki>
16501
16502 '''Uploads:'''
16503 * Optional support for rasterizing SVG images to PNG for inline display
16504
16505 '''Feeds:'''
16506 * Feed generation upgraded to Atom 1.0
16507 * Diffs in RSS and Atom feeds are now colored for improved readability.
16508
16509 '''Database:'''
16510 * MySQL 3.23.x support dropped; 4.0 or later required
16511 * Experimental support for Unicode mode of MySQL 4.1/5.0 (moderately tested)
16512 * Experimental Oracle support (not well tested!)
16513
16514 '''Anti-spam extension support:'''
16515 * [[meta:SpamBlacklist extension|SpamBlacklist extension]] now has support for
16516 automated cleanup.
16517 * Support for a [[meta:ConfirmEdit extension|captcha extension]] to restrict
16518 automated spam edits.
16519
16520 Numerous bug fixes and other behind-the-scenes changes have been made; see the
16521 file HISTORY for a complete change list.
16522
16523 == Changes since 1.5 ==
16524
16525 * (bug 2885) More PHP 5.1 fixes: skin, search, log, undelete
16526
16527 Code quality:
16528 * Use strval() to make sure we don't accidentally get null on bad revision
16529 text loads or other fields mucking up XML export output
16530 * Clean up duplicate code for selection of changeslist style
16531 * Correct blob caching to reduce redundant blob loads on backups
16532 * (bug 3182) Clear link cache during import to prevent memory leak
16533 * Fixed possible infinite loop in formatComment
16534 * Wrap message page insertions in a transaction to speed up installation
16535 * Avoid notice warning on edit with no User-Agent header
16536 * (bug 3649) Remove obsolete, broken moveCustomMessages script
16537 * Avoid numerous redundant latest-revision lookups in history
16538 * Require PHP 4.3.2 or higher strictly now.
16539 * Tweak infinite-template-handling loop for PHP 5.1.1 string handling change
16540 * Remove unused OutputPage::addCookie()
16541 * Fix for short_open_tag off again; please don't break this, guys
16542 * (bug 4507) Adjust FULLPAGENAMEE escaping to standard form
16543 * (bug 5302) Merge the two #p-search .pBody statements in monobook css.
16544
16545 Database:
16546 * Finally dropped MySQL 3.23.x support
16547 * Oracle support
16548 * (bug 3056) MySQL 3 compatibility fix: USE INDEX instead of FORCE INDEX
16549 * Update all stats fields on recount.sql
16550 * (bug 3227) Fix SQL injection introduced in experimental code
16551 * Fix table prefix usage in Block::enumBlocks
16552 * (bug 3448) Set page_len on undelete
16553 * (bug 3506) Avoid MySQL error when Listusers returns no results
16554 * Skip update of disused 'rc_cur_time' field (todo: discard the field)
16555 * (bug 3735) Fix to run under MySQL 5's strict mode
16556 * (bug 3786) Experimental support for MySQL 4.1/5.0 utf8 charset mode
16557 NOTE: Enabling this may break existing wikis, and still doesn't
16558 work for all Unicode characters due to MySQL limitations.
16559 * MySQL 5.0 strict mode fix for moving unwatched pages
16560 * Ability to set the table name for external storage servers
16561 * Update ipblocks table in MySQL 5 table defs
16562 * Removed FulltextStoplist.php, no longer used (was for MySQL 3.x workaround)
16563 * Added templatelinks table, to track template inclusions. User-visible effects
16564 will be:
16565 * (inclusion) tag for inclusions in Special:Whatlinkshere
16566 * More accurate list of used templates on the edit page
16567 * More reliable cache invalidation when templates outside the template
16568 namespace are changed
16569 * Respect database prefix in dumpHTML.inc
16570 * Removed read-only check from Database::query()
16571 * Added externallinks table, to track links to arbitrary URLs
16572 * Added job table, for deferred processing of jobs. The immediate application is
16573 to complete the link table refresh operation when templates are changed.
16574 * Don't change the password of the MySQL root user.
16575
16576 Documentation:
16577 * (bug 3306) Document $wgLocalTZoffset
16578
16579 Hooks:
16580 (list not complete)
16581 * Move ArticleSave hook execution into Article insert/update functions,
16582 so they get called on non-EditPage actions that use these functions
16583 to create or update pages.
16584 * Added EditFilter hook, and output callback on EditPage::showEditForm()
16585 for a place to add in captcha-type extensions in the edit flow
16586 * (bug 3684) Fix typo in fatal error backtraces in Hooks.php
16587 * Fix for hook callbacks on objects containing no fields
16588 * Add a hook for additional user creation throttle / limiter extensions
16589 * Use $wgOut->parse() in wfGetSiteNotice() instead of creating a new parser
16590 instance. This allows use of extension hooks if required.
16591 * Added AutoAuthenticate hook for external User object suppliers
16592 * Added 'PageRenderingHash' hook for changing the parser cache hash key
16593 from an extension that changes rendering based on nonstandard options.
16594 * Add 'GetInternalURL' hook to match the GetFullURL and GetLocalURL ones
16595 * (bug 4456) Add hook for marking article patrolled
16596 * Add UserRights hook, fires after a user's group memberships are changed
16597
16598 Images:
16599 * Support SVG rendering with rsvg
16600 * Cap arbitrary SVG renders to given image size or $wgSVGMaxSize pixels wide
16601 * (bug 3127) Render large SVGs at image page size correctly
16602 * Fix scaling of non-integer SVG unit sizes
16603 * (bug 2800) Don't scale up small images on |thumb| without explicit size
16604 * Use the real file link instead of the default-size rasterized version for
16605 large SVG images on image description page
16606 * Include the file name/type/size line for non-resized images
16607 * (bug 3489) PHP 5.1 compat problem with captioned images
16608 * (bug 3643) Fix image page display of large images with resizing disabled
16609 * Added a limit to the size of image files which can be thumbnailed
16610 * (bug 3806) Gracefully fall back to client-side scaling on |thumb| image
16611 that passes $wgMaxImageArea
16612 * (bug 153) Adjust thumbnail size calculations to match consistently;
16613 patch by David Benbennick
16614 * (bug 4162) Add $wgThumbnailEpoch timestamp to force old thumbs to
16615 be rerendered on demand, sitewide
16616 * (bug 1850) Additional fixes so existing local and remote images
16617 get a blue link even if there's no local description page
16618 * Avoid FATAL ERROR when creating thumbnail of non-existing image
16619 * (bug 4207) Wrong image size when using 100x200px syntax to scale image up
16620 patch by David Benbennick
16621 * Don't delete thumbnails when refreshing exif metadata. This caused thumbs
16622 to vanish mysteriously from time to time for files that didn't have metadata.
16623 * (bug 4426) Add link to user_talk page on image pages
16624 * Support a custom convert command for thumbnailing. See DefaultSettings.php
16625 and the comments for $wgCustomConvertCommand, for more information.
16626 * UserCan hook now allows advisory return values, rather than mandatory ones.
16627
16628 Installer:
16629 * (bug 3782) Throw fatal installation warning if mbstring.func_overload on.
16630 Why do people invent these crazy options that change language semantics?
16631 * Fixed installer bugs 921 and 3914 (issues with using root and so forth)
16632 * (bug 4258) Use ugly urls for ISAPI by default
16633 patch by Rob Church
16634 * Improve installer
16635 * Use a superuser account (such as root), if specifed, to create tables
16636 * Don't overwrite conservative permissions on the mySQL user with ALL
16637 permissions, if said user exists
16638 * Changes to some of the wording of explanations for fields
16639 * (bug 1734) granting db permissions failed with db usernames containg '-'
16640 * Add basic check for session support in PHP and die if not present
16641
16642 Maintenance:
16643 * Fix problem reported on mailing list where re-initialising stats didn't work (can't insert
16644 duplicate rows with the same id field)
16645 * Added --conf option to command line scripts, allowing the user to specify a
16646 different LocalSettings.php.
16647 * Maintenance script to delete unused text records
16648 * Maintenance script to delete non-current revisions
16649 * Maintenance script to wipe a page and all revisions from the database
16650 * Maintenance script to reassign edits from one user to another
16651 * Maintenance script to find and remove links to a given domain (cleanupSpam.php)
16652 * Fix --report interval option for dumpTextPass
16653
16654 i18n / Languages:
16655 * Partial support for Basque language (from wikipedia and meta)
16656 * (bug 3141) Partial support for Breton language (thanks Fulup).
16657 * Support for venitian language
16658 * (bug 1334) LanguageGa.php update
16659 * Finnish date format was hardcoded, now implemented properly
16660 * (bug 3190) Added some date format choices for language sr
16661 * (bug 2753) Some namespaces were not translated in LanguageTa.php (Tamil)
16662 * (bug 3204) Fix typo breaking special pages in fy localization
16663 * (bug 3177) Estonian date formats not implemented in LanguageEt.php
16664 * (bug 1020) Changing user interface language does not work immediately
16665 * (bug 3271) Updated LanguageNn.php for HEAD
16666 * Experimental feature to allow translation of block expiry times
16667 Implementation only for Finnish currently
16668 * (bug 3304) Language file for Croatian (LanguageHr.php)
16669 * (bug 2143) Update Vietnamese interface
16670 * (bug 3063) Remove some hardcodings from Hebrew localisation
16671 * (bug 3408) Bulgarian formatNum corrected
16672 * (bug 1512) Disable x-code interp on Esperanto URLs for now, it does more
16673 harm than good under current system by breaking incoming URLs with "ux".
16674 (Editing is not affected, just URLs.)
16675 * (bug 1423) LanguageJa.php update
16676 * Fix language name for dv
16677 * (bug 3503) Update LanguageSq.php from sq.wikipedia.org messages
16678 * (bug 3629) Fix date & time format for Frisian
16679 * (bug 3334) Namespace changes for Polish
16680 * (bug 3580) Change default Dutch language file to more neutral
16681 * (bug 3656) LanguageHr.php - added convertPlural
16682 * (bug 3414) LanguageBe.php - added convertPlural
16683 * (bug 3163) Full translation of LanguageBr
16684 * (bug 3617) Update for portuguese language (pt)
16685 * Namespaces hacks on LanguagePl
16686 * (bug 3682) LanguageSr.php - added convertPlural
16687 * (bug 3694) LanguageTr.php update
16688 * (bug 3711) Removed invisible unicode characters from LanguageHu
16689 * (bug 2981) Linktrail for Tamil (ta)
16690 * (bug 3722) Update of Arabic language (ar) Namespace changes
16691 * Removed hardcoded Norwegian (no) project namespaces
16692 * (bug 2324) image for redirects should be without text and oriented according to content language
16693 * (bug 3666) Don't spew PHP warnings in prefs on unrecognized site language
16694 * (bug 3817) Use localized date formats in preferences; 'no preference' option
16695 localizable as 'datedefault' message. Tweaked lots of languages files...
16696 * (bug 2721) Regression: Use European number separators for vi: wikis
16697 * (bug 3961) minor languageDe changes
16698 * (bug 1984) LanguageKo.php (Korean) update
16699 * (bug 3804) update of LanguageWa.php file
16700 * (bug 3886) Update for Portuguese language (pt)
16701 * (bug 4020) Update namespaces for ms
16702 * (bug 3922) bidi embedding overrides on category links
16703 * (bug 4061) Update of Slovene namespace names (LanguageSl.php)
16704 * (bug 4064) LanguageDe comma changes
16705 * (bug 3922) Further tweaks to bidi overrides in category list for old
16706 versions of Safari and Konqueror
16707 * Fix custom namespaces on wikis set for Portuguese
16708 * (bug 4153) Fix block length localizations in Greek
16709 * (bug 3844) ab: av: ba: ce: & kv: now inherit from LanguageRu.php
16710 ii: & za: now inherit from LanguageZn_cn.php
16711 * (bug 4165) Correct validation for user language selection (data taint)
16712 * (bug 4192) Remove silly 'The Free Encyclopedia' default sitesubtitle
16713 * Use content-lang for sitenotice
16714 * (bug 4233) Update LanguageJa.php
16715 * (bug 4279) Small correction to LanguageDa.php
16716 * (bug 4108, 4336) Remove trailing whitespace from various messages, which
16717 mucks up message updating to create dupe entries
16718 * (bug 4389) Fix math options on zh-hk and zh-tw (but not localized)
16719 * (bug 4392) Update of LanguageSr.php
16720 * (bug 4382) Frisian numeric format
16721 * (bug 4424) Update for Spanish language (es) 100% messages translated
16722 * (bug 4425) Typos in Polish translation
16723 * (bug 4436) Update for Turkish language (tr)
16724 * (bug 4413) Update of Farsi language file (LanguageFa.php)
16725 * Update for LanguageSr (Serbian): magic words
16726 * (bug 137) MediaWiki:Copyrightwarning hardcoding
16727 * (bug 4457) Update for Portuguese language (pt)
16728 * convertPlural breakage fixed a little
16729 * (bug 4144) Support for Sudanese language (Basa Sunda)
16730 * Big cleanup:
16731 - Removed obsolote, badly or untranslated messages
16732 - Removed references to wikipedia/wikimedia etc in messages
16733 - Other cleanup, like removing html and javascript and extension calls
16734 - Removed hardcoded namespaces: Tt, Ms, Ia, Ga, Fo, Bn, Csb, He, Nv, Oc, Tlh
16735 - Removed some useless backwards compatibility hacks
16736 - Fixed formatnum on many languages
16737 * wgAmericanDates check produced incorrect results in languages that don't have
16738 a such distinction
16739 * (bug 4548) Update for Portuguese language (pt): time format
16740 * (bug 4530) Use consistent name for Kurdish
16741 * Tweak default "upload disabled" text
16742 * (bug 4504) Use site language for namespace name resolution
16743 * (bug 4510) Correct Barnes & Noble bookstore URLs
16744 * (bug 3991) Allow the operation of wikicode on Protect move only text
16745 * (bug 4267) Switch dv sd ug ks arc languages to RTL
16746 * Default main page content improved per bug 4690
16747 * (bug 4615) Update for Portuguese language (pt)
16748 * Separated MessagesSl.php as the other languages.
16749 * (bug 4960) Add additional namespaces variants to Yiddish for compatibility
16750 * (bug 4805) Removed more wikipedia-references from MessagesUk.php
16751 * (bug 5015) Update magic words translation in LanguageBe.php
16752 * (bug 4859) Update for Portuguese messages (pt)
16753 * (bug 4788) One string for MessagesPl
16754 * Restriction types now use restriction-* messages instead of ui messages
16755 * (bug 4685) Slovenian LanguageSl.php hardcodes project namespace
16756 * (bug 5097) Fix Hungarian language (hu): thousands separator
16757 * (bug 5098) Update for Portuguese messages (pt)
16758 * (bug 5113) Spelling error in French language file
16759 * (bug 5105) Magic words for LanguageAr.php
16760 * (bug 3993) Variants for Serbian language
16761 * Typo in English messages file
16762 * (bug 4114) Spacing in watchlist rows (in editing mode)
16763 * Update default "exporttext" to reflect that Special:Import exists
16764 * (bug 4960) Add additional namespaces variants to Yi projects: Yiddish Wikinews fix
16765 * (bug 5357) Add the icon near the user name also in RTL interfaces
16766 * (bug 5156) Update for Hebrew language (he)
16767 * (bug 4497,4704,5010) Added some new language codes.
16768 * (bug 5362) Piedmontese added
16769 * (bug 5349) Update for Portuguese messages (pt)
16770 * (bug 3573) Finished full Greek translation: namespaces
16771 * (bug 5288) Initial localisation for Az
16772 * (bug 4361) Fix "allmessagesnotsupportedui" so it doesn't refer to nonexisting
16773 page
16774 * Tweak wording of "allmessagesnotsupporteddb"
16775
16776 Parser:
16777 * (bug 2522) {{CURRENTDAY2}} now shows the current day number with two digits
16778 * (bug 3210) Fix Media: links with remote image URL path
16779 * (bug 3405) Don't use raw letters as aliases of MSGNW: and SUBST:
16780 * (bug 3412) Clean up date format handling so ~~~~-sigs work with default
16781 format as designed. Documentation comments updated.
16782 * Fix Parser::unstrip on PHP 5.1.0RC4
16783 * (bug 3797) Don't expand variables and sigs in comments
16784 * Allow parser cache on redirect targets
16785 * Run wikitext-escaping on plaintext sigs (no wiki markup, just name)
16786 * Check for unbalanced HTML tags on raw sigs (markup allowed, but show
16787 a warning in prefs and use default sig if not balanced)
16788 * Respect <noinclude> and <includeonly> during {{subst:}} expansion as well as
16789 ordinary templates.
16790 * Support <includeonly> in templates loaded through preload= parameter
16791 * (bug 3979) Save correct {{REVISIONID}} into parser cache on edit
16792 * Substitute {{REVISIONID}} correctly in diff display
16793 * (bug 1850) Allow red-links on image pages linked with [[:image:foo]]
16794 * Fix XML validity checks in parser tests on PHP 5.1
16795 * (bug 4377) "[" is not valid in URLs
16796 * (bug 4453) fix for __TOC__ dollar-number breakage
16797 * Convert unnecessary URL escape codes in external links to their equivalent
16798 character before doing anything with them. This prevents certain kinds of
16799 spam filter evasion.
16800 * (bug 4783) : Fix for "{{ns:0}} does not render"
16801 * Improved support for interwiki transclusion
16802 * (bug 1850) Image link to nonexistent file fixed.
16803 * (bug 5167) Add {{SUBPAGENAME}} and {{SUBPAGENAMEE}} variables
16804 * (bug 4949) Missing : in "addedwatchtext" for English and Spanish
16805 * Allow user-defined functions, which work in a similar way to {{GRAMMAR:}}
16806 etc. Registered via an interface similar to tag hooks.
16807
16808 Upload:
16809 * (bug 2527) Always set destination filename when new file is selected
16810 * (bug 3076) Support MacBinary-encoded uploads from IE/Mac
16811 * (bug 2554) Tell users they are uploading too large file
16812 * Support for a license selection box on Special:Upload, configurable from MediaWiki:Licenses
16813 * Add 'reupload' and 'reupload-shared' permission keys to restrict new uploads
16814 overwriting existing files; default is the old behavior (allowed).
16815
16816 Security:
16817 * (bug 3244) Fix remote image loading hack, JavaScript injection on MSIE
16818 * (bug 3280) Respect 'move' group permission on page moves
16819 * (bug 2613) Clear saved passwords from the form
16820 * IP privacy fix for blocklist search on autoblocks
16821 * Security fix for <math>
16822 * Security fix for tables
16823 * Security fix for Special:Upload license selection list
16824 * Add UploadVerification hook for custom file upload validation/security checks
16825 * Blacklist additional MSIE CSS safety tricks
16826 * Fix meta robots tag on Special:Version again to avoid listing vulnerable
16827 versions for convenient harvesting by automated worms
16828 * Sanitizer CSS comment processing order fix
16829 * Forbid usernames that can be interpreted as titles with namespaces, as that
16830 leads to hard-to-manage names.
16831 * (bug 4071) Generate passwords long enough for $wgMinimalPasswordLength
16832 * Add createpage and createtalk permission keys, allowing a quick
16833 switch to disable page creation for anonymous users.
16834 * (bug 675) Add page protection level for unregistered/new accounts
16835 * User::isNewbie now uses the registration date and $wgAutoconfirmAge
16836 * Add 'deletedhistory' permission key for ability to view deleted history
16837 list via Special:Undelete. Default is off, replicating the 1.5 behavior,
16838 but it can be turned back on for random users to replicate the previous
16839 1.6 dev behavior.
16840 * Set cookies to secure mode based on use of HTTPS or $wgCookieSecure
16841 * (bug 4371) Disallow tilde character in signatures
16842 * Removed broken wgAllowAnonymousMinor and added new group right minoredit
16843 * Added detection for WMF files (application/x-msmetafile), added this
16844 MIME type to the default blacklist. Prevented inline display of images
16845 which are not of known image types. This is in response to
16846 http://en.wikipedia.org/wiki/Windows_Metafile_vulnerability
16847 * Blocked users can no longer roll back, change the protection of, or delete/undelete pages
16848 * Protect against spoofing of X-Forwarded-For header
16849 * XSS issue : now sanitize search query input (fixed in 1.5rc3)
16850 * Remove deprecated $wgOnlySysopsCanPatrol references; use User::isAllowed( 'patrol' )
16851 per bug 5282. Patch by Alan Harder.
16852 * Prevent registration/login with the username "MediaWiki default"
16853
16854 Special Pages:
16855 * Rearranged Special:Movepage form to reduce confusion between destination
16856 title and reason input boxes
16857 * (bug 1956) Hide bot uploads from Special:Newimages
16858 * (bug 3220) Fix escaping of block URLs in Recentchanges
16859 * (bug 3284) Ipblocklist paging, substring search
16860 * Allow filtering of robot edits in Special:Watchlist by setting
16861 $wgFilterRobotsWL = true.
16862 * Fix interlanguage links on special pages when extra namespaces configured
16863 * (bug 3475) anon contrib links on Special:Newpages
16864 * Special:Import/importDump fixes: report XML parse errors, accept <minor/>
16865 * (bug 2369) Add separate message for input box on Special:Prefixindex
16866 * (bug 3798) DoubleRedirects no longer has hard coded arrows
16867 * (bug 3803) Fix links on Special:Wantedcategories with miser mode off
16868 * Fix Special:BrokenRedirects on MySQL 5.0
16869 * (bug 3807) Fix 'all' in namespaces drop-down on contribs, rc
16870 * Fail gracefully on invalid namespace in Special:Newpages
16871 * (bug 3762) Define missing Special:Import UI messages
16872 * (bug 3761) Avoid deprecation warnings in Special:Import
16873 * (bug 2894) Enhanced Recent Changes link fixes
16874 * (bug 4059) fix 'hide minor edits' on Recentchangeslinked
16875 * (bug 146) List number of category members in Special:Categories
16876 (patch by Joel Nothman)
16877 * (bug 4090) Fix diff links in Special:Recentchangeslinked
16878 * (bug 4093) '&bot=1' in Special:Contributions now propagate to other links
16879 * Fix display of old recentchanges records for page moves
16880 * (bug 360) Let Whatlinkshere track [[:image:foo]] links
16881 * (bug 3073) Keep search parameter on paging in Special:Newimages
16882 * Removed Special:Validate, it's been superseded by the Review extension
16883 * (bug 4359) red [[user:#id]] links generated in [[special:Log]]
16884 * (bug 1996) Special page to list redirects
16885 * (bug 4334) Add "watch" links to Special:Unwatchedpages
16886 * Generate target user page links in Special:Ipblocklist where appropriate
16887 (i.e. not an autoblock)
16888 * Generate link to talk page of the blocker in Special:Ipblocklist, move
16889 contribs. link of the target next to their name
16890 * (bug 2714) Backlink from special:whatlinkshere was hard set as 'existing'
16891 * Move parentheses out of <a> link in Special:Contributions
16892 * (bug 3192): properly check 'limit' parameter on Special:Contributions
16893 * (bug 3187) watchlist text refer to unexistent "Stop watching" action
16894 * Add block, block log and general log links to Special:Contributions
16895 * Add contributions link to block log items
16896 * Added optional "hide own edits" feature to Special:Recentchanges
16897 * (bug 5018) Anchors for each message in Special:Allmessages
16898 * Introduce $wgWantedPagesThreshold per bug 5011; Special:Wantedpages will not
16899 list pages with less than this number of links. Defaults to 1.
16900 * (bug 4319) Don't show a "create account" link on the login form when
16901 account creation is disabled.
16902 * JavaScript filter for Special:Allmessages
16903 * (bug 3047) Don't mention talk pages on Special:Movepage when there isn't one
16904 * Show links to user page, talk page and contributions page on Special:Newpages
16905 * Special:Export can now export a list of all contributors to an article (off by default)
16906 * (bug 5372) Add number of files to Special:Statistics
16907 * (bug 2871) Links to talk pages in watchlist editing view
16908 * (bug 5385) Allow hiding anonymous edits on Special:Recentchanges
16909 * (bug 2544) Illogical error reporting order in Special:Userlogin
16910 * (bug 5409) Hide "show/hide patrolled edits" in Special:Recentchanges if patrolling
16911 is disabled
16912 * (bug 5447) Convert first letter of username to uppercase before searching in Special:Listusers
16913 * (bug 759) Wrap redirects on the watchlist editing page in a span, class "watchlistredir"
16914 * (bug 1862) Namespace filtering in watchlists
16915
16916 Misc.:
16917 * PHP 4.1 compatibility fix: don't use new_link parameter to mysql_connect
16918 if running prior to 4.2.0 as it causes the call to fail
16919 * (bug 3117) Fix display of upload size and type with tidy on
16920 * (bug 2323) Remove "last" tabindex from history page
16921 * (bug 3116) Division by zero on [[Image:Foo.png|123x123px|]]
16922 * Fix display of read-only lockfile message
16923 * Include software-visible client IP address in Special:Version comment
16924 as a proxy debugging aid
16925 * (bug 3170) Page Title failed to obey MediaWiki:Pagetitle.
16926 wikititlesuffix was removed
16927 * Add ability to break off certain debug topics into additional log files;
16928 use $wgDebugLogGroups to configure and wfDebugLog() to log.
16929 * Edit conflict on recreation of deleted page
16930 * (bug 3216) Don't show empty warning page when no warnings.
16931 * (bug 3218) Use proper quoting on history Compare Revisions button
16932 * Fix upgrade from 1.4 due to version number check breakage [for rc future]
16933 * Fix upgrade from 1.4 with no old revisions
16934 * Remove "info" editing toolbar that was shown in browsers which do not
16935 fully support the editing toolbar, but was found to be too confusing.
16936 * Don't override edit conflict suppression on section edits; section merging
16937 should provide the expected transparency here and fits usage patterns better.
16938 * (bug 3292) Fix move-over-redirect test when current entries are not plaintext
16939 * (bug 2078) Don't hide watch tab on preview
16940 * Fix regressions in ChangesList traditional layout
16941 * Fix edit on double-click for move-protected pages in Classic skin
16942 * (bug 3485) Fix bogus warning about filename capitalization when off
16943 * (bug 2570) Add 'watch this page' checkbox on uploads, watch uploads
16944 by default when 'watchdefault' option is on
16945 * Add options to dumpBackup.php for making split/partial dumps by page id
16946 * Added filter options, compression piping, and multiple output streams for
16947 dumpBackup.php
16948 * (bug 3595) Warn and abort if importDump.php called in read-only mode.
16949 * (bug 3598) Update message cache on message page deletion, patch by Tietew
16950 * Added separate noarticletext and newarticletext messages for logged in and anon users.
16951 * (bug 3332) Installation now uses Monobook, validates, plus usability improvements.
16952 * (bug 3660) Update diff3 detection to work with Windows/Cygwin
16953 * (bug 2330) Don't do funny thinks with "links" in MediaWiki:Undeletedtext
16954 * Two-pass data dump for friendliness to the DB (--stub, then dumpTextPass.php)
16955 * Data dump 'prefetch' mode to read normalized text from a prior dump
16956 (requires PHP 5, XMLReader extension)
16957 * (bug 2773) Print style sheet no longer overrides RTL text direction
16958 * (bug 2938) Update MediaWiki:Exporttext to be more general
16959 * Various fixes
16960 * Fix wfMsg*() replacements; args containing literal $[2-9] were wiped
16961 * Added @import for [[MediaWiki:Common.css]] to all skins
16962 * Edit box now remembers scrollbar position on preview
16963 * (bug 3816) Throw edit conflict instead of fatal error when a page is
16964 moved or deleted during section edit
16965 * (bug 3771) Handle internal functions in backtrace in wfAbruptExit()
16966 * (bug 3291) 'last' diff link for last history line when not at end
16967 * (bug 3667) Add missing global in page move code
16968 * (bug 2885) Remove unnecessary reference parameter which broke classic skin
16969 talk notification on PHP 5.0.5
16970 * (bug 3852) "Redirected from" link no longer obscured on double-redirects
16971 * changed directory hierarchy in images/math/. System upgrades from old to
16972 new hierarchy on the fly.
16973 * (bug 3487) Fix category edit preview with preview-on-bottom
16974 * (bug 918) Search index incorrectly joined words at == headings ==
16975 * (bug 3877) Render math images into temp directory, then move to hashed
16976 subdir so you can render new math images and have them work
16977 * (bug 2392) Fix Atom items content type, upgrade to Atom 1.0
16978 * Allow $wgFeedCacheTimeout of 0 to disable feed caching
16979 * Fix WebRequest::getRequestURL() to strip off the host bits squid prepends
16980 * Require POST for action=purge, to stop bots from purging the cache
16981 * Added local message cache feature ($wgLocalMessageCache), to reduce bandwidth
16982 requirements to the memcached server.
16983 * (bug 3562) for go search, try Caps-Variants-Broken-At-Non-Whitespace
16984 * (bug 2569) Use PATH_SEPARATOR instead of trying to guess based on
16985 DIRECTORY_SEPARATOR (was wrong on NetWare)
16986 * (bug 2740) Accept image deletions on 'enter' submit from MSIE
16987 * (bug 3939) Don't try to load text for interwiki redirect target
16988 * (bug 3948) Avoid notice warning in debug statement in bad search
16989 * Recognize Special:Search consistently so read whitelist works
16990 * (bug 3999) Change atom 1.0 feed id; had been unnecessarily complex due to
16991 unclear language in the spec. Now using the URL, same as the permalink,
16992 which someone else will probably whine about because it's not 'perma'
16993 enough or something.
16994 * (bug 4014) Fix include mode for Allpages on small page sets
16995 * (bug 3996) Fix text for new entries in RC RSS/Atom feed
16996 * (bug 3065) Update both watched namespaces when renaming pages
16997 * Changed mail form to have a bigger message entry box (like for editing
16998 a page
16999 * Fix ulimit parameters for wfShellExec when memory_limit is specified in 'm'
17000 * (bug 2111) Collapsable exif metadata table, clean up display
17001 * Reduce fractions in display of exif exposure time
17002 * (bug 4048) Optional footer link to site privacy policy
17003 * Don't die() when update.php reaches the end of the warning count
17004 * (bug 1915) Fix edit links when 'direction' used with 'oldid';
17005 using revision ID reported via OutputPage; Skin::editUrlOptions()
17006 * Remove obsolete 'redirect=no' on some edit links
17007 * Include oldid for the second revision on edit link on diff view
17008 * (bug 4035) Fix prev/next revision links on edit page
17009 * (bug 4100, 3049) Add 'edittools' message to hold edit tools, put it
17010 on Special:Upload as well as edit, rearrange edit page pieces a bit.
17011 Copyright warning now above the buttons to ensure it's visible,
17012 template list at the bottom so it can grow.
17013 * Optional summary parameter to action=rollback, for user javascript
17014 * (bug 4167) Fix regression caused by patch for bug 153
17015 * (bug 4169) Use $wgLegalTitleChars in pipe trick conversions
17016 * (bug 4170) Decode HTML character escapes in sort key
17017 * (bug 4201) Fix user-talk mode for Enotif, and general code cleanup
17018 * (bug 4214) Skip redundant action text inserts into the HTML <title>
17019 * (bug 4212) Skip redundant meta-robots tag for default settings
17020 * Fix regression: old version missing from edit links in Nostalgia skin
17021 * (bug 1600) Trigger edit conflict on duplicate section=new submissions
17022 * (bug 4001) Use local variables properly in wikibits.js akeytt()
17023 * Fix regression: old version missing from edit links on CSS/JS pages
17024 * (bug 3211) Include Date, To mail headers when using PEAR::Mail
17025 * (bug 3407) Fix encoding of subject and from/to headers on notification
17026 mails; userMailer() now takes a MailAddress wrapper object instead of
17027 a raw string to abstract things a level.
17028 * Fixed --server override on dumpTextPass.php
17029 * Added plugin interface for dumpBackup, so additional filters and output
17030 sink types can be registered at runtime from an extension
17031 * (bug 349) Fix for some numeric differences not being highlighted
17032 patch by Andrius Ramanauskas
17033 * (bug 4298) Include rc_id on enhanced RC singleton diff links for patrolling
17034 * Did some refactoring on ChangesList.php merging dupe code
17035 * (bug 1586) Fix interwiki generator for wikimedia obscure domains
17036 * (bug 3493) Mark edits patrolled when they are reverted
17037 patch by Leon Planken
17038 * Removed experimental Amethyst skin from default set
17039 * Upgrade old skin preferences properly at Special:Preferences
17040 (used to spontaneously switch to Classic skin for old numeric pref records)
17041 * (bug 3424) Update page_touched for category members on category page creation
17042 * Log views show message when no matches
17043 * Fix raw sitenotice display on database error
17044 * Fix autoconfirm check for old accounts
17045 * (bug 4368) Don't show useless empty preview on new section creation
17046 * Don't show useless empty preview on new page creation
17047 * (bug 4411) Fix messages diff link for classic skin
17048 * (bug 4385) Separate parser cache entries for non-editing users, so section
17049 edit links don't vanish / appear unwanted on protected pages
17050 * (bug 2726, 3397) Fix [[Special:]] and [[:Image]] links in action=render
17051 * (bug 4419) Remove obsolete magnify.png.old
17052 * Removed $wgUseCategoryMagic option, categories are now enabled unconditionally
17053 * (bug 3318) UI workarounds for disabled items in license selector
17054 MSIE/Win: items now grayed out, JS will revert to 'non selected' if clicked
17055 Safari: JS will revert to 'non selected' if clicked (but not gray)
17056 MSIE/Mac: indented items now visible (JS hack)
17057 * (bug 714) "plainlinks" class issues in IE, Opera
17058 * (bug 4317) Inconsistent "broken redirects" messages
17059 * Default interface text for "selflinks" tweaked
17060 * (bug 3194) default implementation of translateBlockExpiry
17061 which uses ipboptions
17062 * (bug 4446) $wgExportAllowHistory option to explicitly disable history in
17063 Special:Export form, 'exportnohistory' message to translate live hack.
17064 * Maintenance script to delete unused user accounts
17065 * (bug 912) Search box easier to reach in text browsers (lynx, links)
17066 * $wgParserCacheExpireTime added
17067 * Skip loading of RecentChange.php except where needed
17068 * Enforce $wgSVGMaxSize when rendering, even for SVGs with a very large source
17069 size. This is necessary to limit server memory usage.
17070 * Cleanup and error checking on Special:Listredirects
17071 * Clear up some instances of old OutputPage::sysopRequired() function usage
17072 * Improve "upload disabled" notice
17073 * Move parts of index.php to include/Wiki.php in an attempt to both cleanup index.php
17074 and create a MediaWiki-class mediaWiki base object
17075 * (bug 4104) Added OutputPageBeforeHTML hook for tweaking primary wiki output
17076 HTML on final output (cached or not)
17077 * Avoid PHP notice on command-line scripts if empty argument is passed ('')
17078 * (bug 4571) Partial fix hack for {{fulllurl:}} in action=render
17079 * (bug 3502) Bowtie symbol for TeX
17080 * (bug 4000) Support for \textstyle et al. in <math>
17081 * (bug 1663) support color in TeX formulas
17082 * (bug 2026) missing glue around \not= (TeX)
17083 * (bug 4576) Missing '>' broke license selector's first option in IE, Opera
17084 * Override $wgLocaltimezone in parser tests for us outside Iceland and UK
17085 * Fix extra whitespace at end of Wiki.php, DESTROYS XML OUTPUT
17086 * Remove redundant 'echo' statements from MonoBook.php
17087 * (bug 1103) Fix up redirect handling for images, categories
17088 Redirects are now followed from the top-level, outside of the Article
17089 content loading and viewing, for clarity and consistency.
17090 * (bug 4104) 'OutputPageBeforeHTML' hook to postprocess article HTML on
17091 page view (comes after parser cache, if used). Patch by ThomasV.
17092 * Linker::formatComment corrupted the passed title object on PHP 5
17093 if the comment included a section link. Use clone() to make a safe copy.
17094 * Add wfClone() wrapper since we're still using PHP 4 on some servers.
17095 * Remove obsolete killthread.php
17096 * Added wfDie() wrapper, and some manual die(-1), to force the return code
17097 to the shell to return nonzero when we crap out with an error.
17098 * Allow input of the stub from a compressed file instead of stdin
17099 for dumpTextPass.php; easier to get errors back on the shell
17100 * Added an attractive space on the namespace selector on contribs
17101 * Move PHP 5-friendly XHTML doctype hack to Sanitizer, use for sig checks.
17102 Fixes use of named entities in sigs on PHP 5
17103 * (bug 4482) Include move comment on the null edit as well as the redirect
17104 * (bug 3990) Use existing session name if session.auto_start is on
17105 Fixes checks for open sessions, such as the cookie warning on login.
17106 Patch by Zbigniew Braniecki.
17107 * Add cache-safe alternate sitenotice for anonymous users. (MediaWiki:Anonnotice)
17108 This is displayed instead of the regular sitenotice, if it exists. If not, the
17109 regular sitenotice shows. If that doesn't exist, the value of $wgSiteNotice is used,
17110 and if that's null, then nothing is shown.
17111 * Spit the generated LocalSettings code out during the installer as an aid
17112 to debugging issues. (Keep this?)
17113 * Use __FILE__ to form path in new LocalSettings.php, so it stays accurate
17114 when the directory is relocated for typical usage.
17115 * Auto-update $wgCacheEpoch when LocalSettings.php changes on new installs.
17116 For typical usage this will be a light burden and should reduce confusion
17117 when the configuration is edited.
17118 * Fix $wgCacheEpoch's effect on client-side caching.
17119 * (bug 1122) gray out 'older revision' when viewing first article revision.
17120 * Clearer message in DefaultSettings.php: edit LocalSettings.php instead
17121 * MonoBook skin top link id changed from "contentTop" to "top" (shared with
17122 name attribute)
17123 * (bug 3350) Missing label for move talk page checkbox.
17124 * (bug 2108) Sort entries when using category browser
17125 * (bug 2393) Fix MIME type for Atom feeds ( application/rss+atom )
17126 * Add ".deps.php" include-file preloaders for some dynamically-loaded
17127 language and skin classes. Should help with the broken base-class
17128 problem under PHP 5 with APC as opcode cache. See details:
17129 http://mail.wikipedia.org/pipermail/wikitech-l/2006-January/033660.html
17130 * Small changes to tabs in Monobook skin c/o Chris Ware
17131 * (bug 4679) Work around buggy basename() function in PHP5, which breaks
17132 uploads of files starting with multibyte characters on Linux.
17133 wfBaseName() doesn't suffer this bug, and understands backslash on
17134 both Unix and Windows.
17135 * (bug 3603) headscripts variable not hooked up to MonoBook skin
17136 * Allow local cdb-based interwiki cache
17137 * Use the "block", not the "protect" permission, when determining whether to
17138 show a "block user" link in the toolbox
17139 * Fix backup dump text prefetch for XMLReader constant changes in PHP 5.1
17140 * Suppress useless percentage indicator on output from 7za during dumps
17141 * (bug 4633) Add (previous 200) (next 200) also above catlinks
17142 * (bug 4686) Fix regression where ?diff=0&oldid=0 caused fatal error on
17143 pages with only one revision. Fixes message diff link on first edit.
17144 * Fix dependence on hardcoded UNIQ_PREFIX in LanguageConverter.php
17145 * Do not check lag on external storage servers
17146 * Do not tidy interface messages (unless full tidy is set)
17147 * Do not trust equality propagation and give more hints to MySQL
17148 optimizer for revision fetches (avoids index scans)
17149 * Use revision rate for ETA in dump generation; it tends to be more stable
17150 than the per-page count for full-history dumps.
17151 * Include timestamp in wfDebugLog breakouts
17152 * (bug 4469) Namespace-specific notice to be displayed below site-notice
17153 Edit messages like "MediaWiki:Namespacenotice-" plus namespace name
17154 which is blank for main namespace, or like e.g. "User_talk"
17155 * Adjust user login/creation form hooks to work with a captcha plugin
17156 * (bug 1284) Inline styles for diffs in Recent Changes RSS/Atom feeds
17157 * (bug 4824) IE7 beta 2 broke compatibility with PNG logo workarounds,
17158 and seems to work ok with other bits. No longer including the IE
17159 workarounds JavaScript for IE 7 and above.
17160 * Fix extra namespace for Bulgarian
17161 * (bug 4303) Add $wgFavicon to change the shorticon icon link from
17162 the default /favicon.ico or disable it (if set to false)
17163 * (bug 3347) strip linebreaks in math error source
17164 * (bug 4841) Warning for non-logged-in edits
17165 * (bug 4867) Leave invalid EXIF date fields unformatted instead of
17166 showing a bogus current timestamp
17167 * Reset $wgActionPaths during parser test; corrects some false failures
17168 in the automated test report.
17169 * (bug 4875) Define a div containing the shared image description
17170 * (bug 4860) Expose Title->userCan() as Hooks
17171 * (bug 4828) Fix genitive month-name variable for cs, pl, uk
17172 * (bug 4842) Fix 'show number of watching users' with enhanced RC
17173 * (bug 4889) Fix image talk namespace for Tamil
17174 * (bug 4147) Added cleanupWatchlist.php to clear out bogus watchlist entries
17175 * (partial bug 3456) Disable auto redirect to Main Page after account creation
17176 * (bug 4824) Separate out IE7 CSS compat hacks, fix for RTL pages
17177 * Added support for wikidiff2 and similar external diff engines.
17178 * Allow cookies to be shared between multiple wikis with a shared user database
17179 * Blocking some Unicode whitespace characters in usernames. Should check
17180 if some or all should be blocked from all page titles.
17181 * Unknown log types no longer throw notices everywhere in RecentChanges
17182 * (bug 4502, 5017) Don't render potentially hostile deleted page contents
17183 on Special:Undelete by default; show source, with an optional preview.
17184 The revisions list no longer shows the latest text by default, so it can
17185 still be operated if the text is hostile.
17186 * (bug 5013) Check for existence on "return to" links
17187 * Removed trailing whitespace on a bunch more messages.
17188 * Fix missing bad title check in Special:Booksources
17189 * Remove empty booksources string in fy
17190 * Avoid corrupting <gallery> inside <!-- comment -->
17191 * Remove legacy PHPTal code, hasn't been maintained in ages.
17192 * Tweak Userlogin include order for APC issue
17193 * Don't try to link to current page on protection tab
17194 * More exact checking in Title::equals() to fox moves of numerically similar
17195 page titles. (Odd hex title bug on 64-bit.)
17196 * Fix explicit s-maxage=0 on raw pages; should help with proxy issues in
17197 generated stylesheets... hopefully...
17198 * (bug 4685) More fixes for Slovenian project namespace
17199 * Fixed and enhanced a little the Live Preview, which had been broken for some time
17200 * Added article size limit, $wgMaxArticleSize
17201 * (bug 4974) Don't follow redirected talk page on "new messages" link
17202 * (bug 4970) Make category paging limits configurable
17203 * (bug 4535) Warn user when editing CSS or JS subpage of a skin that doesn't exist
17204 * Make Live Preview an user preference, still controllable by the global variable
17205 * Rename the stub LanguageAls / LanguageGem_alsation to LanguageGsw to follow
17206 updated language code assignments
17207 * (bug 5081) Remove bogus fix for invalid characters in links which simply
17208 broke use of legitimate multiple whitespace characters in bracketed link.
17209 * (bug 4838) Add relative oldids (prev, next, cur) for raw pages
17210 Patch by Lupin
17211 * (bug 5086) Force image resize dimensions on ImageMagick, as for instance
17212 "-resize 100x35!"; some thumbs were off due to differences in rounding and
17213 would be generated smaller than expected.
17214 * (bug 5062) Width sometimes one pixel short when using maximum heights
17215 * Purge thumbnails and metadata cache for action=purge on an image page
17216 * (bug 4273) Bounce back with a message when attempting to submit a new comment
17217 with an empty main textbox (user probably hit Enter in subject field)
17218 * (bug 5141) Gracefully handle the new account link when createaccount off
17219 * (bug 5150 and related) Fix missing ID attribute in HTML namespace selector
17220 * (bug 5152) Proper HTML escaping on subpage breadcrumbs
17221 * (bug 4855) Section edit links now have the section name in the title attribute.
17222 * (bug 2115) Support shift-selecting multiple checkboxes with JavaScript.
17223 * (bug 5161) Don't try to load template list for nonexistent pages
17224 * (bug 5228) Workaround for broken LanguageConverter title overrides; avoid
17225 unnecessary hidden UI work when watch/unwatch is performed on edit
17226 * Fixed bogus master fallback in external storage
17227 * (bug 5246) Add speak:none to "hiddenStructure" class in main.css
17228 * Further work on rev_deleted; changed to a bitfield with several data-hiding
17229 options. Not yet ready for production use; Special:Revisiondelete is
17230 incomplete, and the flags are not preserved across page deletion/undeletion.
17231 To try it; add the 'deleterevision' permission to a privileged group.
17232 * (bug 5270) Fix broken linktrail for br, cv, fr, hr, nn, oc, ta, wa
17233 * Add a clickable contribs link in user tool links (rc, watchlist, diff view)
17234 to see how people like it. (There was one in the old hacked-up diff view.)
17235 * (bug 5236) Load wikibits.js before site-customized javascript
17236 * (bug 4119) Workaround for <nowiki> following link in Walloon; remove capitals
17237 from linktrail, as they're not used anywhere else.
17238 * (bug 4781) Output links with the percent-encoding they're supplied with;
17239 save the normalization for internal link storage. The normalization is a bit
17240 buggy and can make incorrect foldings in the query string and such, so isn't
17241 reliable beyond the hostname where it's used for the spam bulk checker.
17242 * Don't URL-decode in the title attribute for URL links; it can produce false
17243 results that don't code back to their original values.
17244 * (bug 4611) Add user preference (default on) to add new pages to creators's watchlist
17245 * (bug 5286) Fix regression in display of missing/bad revision IDs
17246 * (bug 4729) Add user preference that marks a user's edits as patrolled if user is able to
17247 * (bug 4630) Add user preference to prompt users when entering blank edit summaries
17248 * Added optional suggest feature for the search box. Set wgUseAjax to true to
17249 enable it.
17250 * (bug 5277) Use audio/midi rather that audio/mid
17251 * (bug 5410) Use namespace name when a custom namespace's nstab-NS message is nonexistent
17252 * (bug 5432) Fix inconsistencies in cookie names when using table prefixes
17253 * Additional protections against HTML breakage in table parsing
17254 * (bug 5355) Include skin name and style JS settings in page source;
17255 fixes regression where Opera 6/7 and KHTML CSS fixes weren't applied
17256 when wikibits.js was moved up before user JS inclusion.
17257 * Added $wgColorErrors: if set, database error messages will be highlighted
17258 when running command-line scripts in a Unix terminal.
17259 * (bug 5195) rebuildrecentchanges.php works again; Database::insertSelect now
17260 has a parameter for select options.
17261 * Fix updateSearchIndex.php for new schema
17262 * Fix bogus "filename too short" error when uploading files with a period in the base
17263 name, e.g. "Mr. Zee.png"
17264 * (bug 2139) Show page title in subtitle when viewing "read only" page
17265 * (bug 5452) Update language name for Cree
17266
17267 == Compatibility ==
17268
17269 Older PHP 4.2 and 4.1 releases are no longer supported; PHP 4 users must
17270 upgrade to 4.3 or later.
17271
17272 MediaWiki 1.6 is the last major version to support PHP 4; future versions will
17273 require PHP 5.
17274
17275 MySQL 3.23.x is no longer supported; some older hosts may need to upgrade.
17276 At this time we still recommend 4.0, but 4.1/5.0 will work fine in most cases.
17277
17278 == Upgrading ==
17279
17280 Several changes to the database have been made from 1.5; these are relatively
17281 minor but do require that the update process be run before the new code will
17282 work properly:
17283
17284 * A new "templatelinks" table tracks template inclusions.
17285 * A new "externallinks" table tracks URL links; this can be used by a mass
17286 spam-cleanup tool in the SpamBlacklist extension.
17287 * A new "jobs" table stores a queue of pages to update in the background; this
17288 is used to update links in including pages when templates are edited.
17289
17290 To ensure that these tables are filled with data, run refreshLinks.php after
17291 the upgrade.
17292
17293 If you are upgrading from MediaWiki 1.4.x or earlier, some major database
17294 changes are made, and there is a slightly higher chance that things could
17295 break. Don't forget to always back up your database before upgrading!
17296
17297 === Caveats ===
17298
17299 Some output, particularly involving user-supplied inline HTML, may not produce
17300 100% valid or well-formed XHTML output. Testers are welcome to set $wgMimeType
17301 = "application/xhtml+xml"; to test for remaining problem cases, but this is not
17302 recommended on live sites. (This must be set for MathML to display properly in
17303 Mozilla.)
17304
17305
17306 = MediaWiki 1.5 =
17307
17308 == MediaWiki 1.5.9 ==
17309 * (bug 3359) Add hooks on completion of file upload
17310
17311 == MediaWiki 1.5.8 ==
17312
17313 March 26, 2006
17314
17315 MediaWiki 1.5.8 is a security and bugfix maintenance release.
17316
17317 A bug in decoding of certain encoded links could allow injection of raw
17318 HTML into page output; this could potentially lead to XSS attacks.
17319
17320 Some minor UI fixes were also made, see the change log at the bottom of
17321 this file.
17322
17323
17324 == MediaWiki 1.5.7 ==
17325
17326 March 2, 2006
17327
17328 MediaWiki 1.5.7 is a bugfix maintenance release.
17329
17330 Most importantly, a security issue in the installer has been fixed. The bug
17331 affects new installations of 1.5.6 only. If the user specified the MySQL root
17332 password, to allow the installer to create an unprivileged account, the
17333 installer would not only create the new account but also change the root
17334 password to be equal to the password of the new account.
17335
17336 Anyone affected by this bug will need to change the root password back
17337 manually. For information about how to change passwords in MySQL please see:
17338 http://dev.mysql.com/doc/refman/5.1/en/passwords.html
17339
17340 This version includes fixes for compatibility with Internet Explorer 7
17341 beta 2, and various other bugs; see the full changelog at the end of
17342 the release notes.
17343
17344
17345 == MediaWiki 1.5.6 ==
17346
17347 January 19, 2006
17348
17349 MediaWiki 1.5.6 is a security and bugfix maintenance release.
17350
17351 A bug in edit comment formatting could send PHP into an infinite loop
17352 if certain malformed links were included. In most installations, this
17353 would cause the script to fail after PHP's 30-second failsafe timeout.
17354
17355 Some improvements have been made to the installer which should make
17356 installation possible on a system with a broken MySQL "root" account.
17357
17358 For several other minor fixes, see the complete changelog at the end
17359 of this file.
17360
17361
17362 == MediaWiki 1.5.5 ==
17363
17364 January 5, 2006
17365
17366 MediaWiki 1.5.5 is a security and bugfix maintenance release.
17367
17368 Detection for uploads of Windows Metafile (.wmf) images has been added
17369 to help protect against a client-side vulnerability in unpatched Microsoft
17370 Windows operating systems.
17371
17372 Sites which have enabled uploads and added non-standard file types
17373 (such as .ogg, .doc, or .pdf) should upgrade to this release to ensure
17374 that malicious .wmf files can't be uploaded with a fake extension;
17375 such files could put visitors to the site at risk.
17376
17377 For more details on this, see:
17378 http://en.wikipedia.org/wiki/Windows_Metafile_vulnerability
17379
17380 Additionally, a maintenance script removeUnusedAccounts.php has been added;
17381 this replaces an older Perl script which had not been updated for the new
17382 schema in 1.5.
17383
17384
17385 == MediaWiki 1.5.4 ==
17386
17387 December 21, 2005
17388
17389 MediaWiki 1.5.4 is a security and bugfix maintenance release.
17390
17391 A hardcoded internal placeholder string has been replaced with a random
17392 one. This closes a hole where security checks in inline style attributes
17393 could be bypassed, injecting JavaScript code that could execute in
17394 Microsoft Internet Explorer.
17395
17396 Other browsers would not be vulnerable.
17397
17398 Several minor fixes are included in this release, most notably a fix
17399 to clear the "you have new messages" flag properly for usernames
17400 containing spaces when e-mail notification is enabled.
17401
17402 See the changelog at the end of the release notes for a full list of
17403 fixes.
17404
17405
17406 == MediaWiki 1.5.3 ==
17407
17408 December 4, 2005
17409
17410 MediaWiki 1.5.3 is a security and bugfix maintenance release.
17411
17412 Validation of the user language option was broken by a code change in
17413 May 2005, opening the possibility of remote code execution as this
17414 parameter is used in forming a class name dynamically created with
17415 eval().
17416
17417 The validation has been corrected in this version. All prior 1.5 release
17418 and prelease versions are affected; 1.4 and earlier and not affected.
17419
17420 Additionally several bugs have been fixed; see the changelog later in
17421 this file for a complete list.
17422
17423
17424 == MediaWiki 1.5.2 ==
17425
17426 November 2, 2005
17427
17428 MediaWiki 1.5.2 is a bugfix maintenance release.
17429
17430 A change in PHP 4.4.1 and PHP 5.1.0RC broke handling of extension and
17431 <pre> sections, causing garbage data to be inserted in output and saved
17432 edits. This version works around the change.
17433
17434 Several other glitches with MySQL 5.0 and PHP 5.0.5 were also fixed;
17435 see the change log below for a complete list.
17436
17437
17438 == MediaWiki 1.5.1 ==
17439
17440 October 26, 2005
17441
17442 MediaWiki 1.5.1 is a bugfix and security maintenance release, and is a
17443 recommended upgrade for all installations.
17444
17445 This release includes further corrections to the inline CSS style sanitation
17446 which works around a JavaScript "feature" on Microsoft Internet Explorer.
17447 Users of Microsoft Internet Explorer for Windows may be vulnerable to
17448 XSS injections on prior versions; users of standards-compliant browsers
17449 are not vulnerable.
17450
17451 Major fixes include:
17452 * Image pages work again with resizing disabled
17453 * Works in MySQL 5.0 strict mode
17454
17455 There is experimental support in this release for explicitly declaring
17456 the UTF-8 charset in the database; this has been tested with MySQL 5.0.15
17457 but should work on 4.1 as well.
17458
17459 IMPORTANT: Changing this setting on an existing wiki may produce interesting
17460 data corruption, depending on server configuration. Page contents should,
17461 usually, be unaffected, but page titles and other items may be. Limitations
17462 in MySQL's Unicode support mean that characters outside the BMP cannot be used
17463 in page titles or various other fields when using this mode.
17464
17465 Table definitions are in maintenance/mysql5/tables.sql, and the runtime
17466 option to send 'SET NAMES utf8' is set by $wgDBmysql5 = true.
17467
17468 (MySQL 3.23.x and 4.0.x do not support character set declarations; on these
17469 versions MediaWiki simply works with UTF-8 data and MySQL is blissfully
17470 unaware of it.)
17471
17472
17473
17474 == MediaWiki 1.5.0 final ==
17475
17476 October 5, 2005
17477
17478 MediaWiki 1.5.0 is the new stable release branch of MediaWiki, and is
17479 recommended for all new installations.
17480
17481 Any wikis running a 1.5 beta or release candidate are strongly recommended
17482 to upgrade to the final release, which includes a number of bug fixes and
17483 a security fix for CSS bugs in Microsoft Internet Explorer.
17484
17485 IMPORTANT: Running a 1.3 or 1.4 wiki and don't want to jump to 1.5 yet?
17486 Be sure to upgrade to 1.3.17 or 1.4.11, also released today. Versions
17487 prior to 1.3.16 and 1.4.10 have a serious data corruption bug which is
17488 triggered by a spambot known to operate in the wild.
17489
17490
17491 === What's new in 1.5? ===
17492
17493 Schema:
17494 The core table schema has changed significantly. This should make better
17495 use of the database's cache and disk I/O, and make significantly speed up
17496 rename and delete operations on pages with very long edit histories.
17497
17498 Unfortunately this does mean upgrading a wiki of size from 1.4 will require
17499 some downtime for the schema restructuring, but future storage backend
17500 changes should be able to integrate into the new system more easily.
17501
17502 Permalinks:
17503 The current revision of a page now has a permanent 'oldid' number assigned
17504 immediately, and the id numbers are now preserved across deletion/undeletion.
17505 A permanent reference to the current revision of a page is now just a matter
17506 of going to the 'history' tab and copying the first link in the list.
17507
17508 Page move log:
17509 Renames of pages are now recorded in Special:Log and the page history.
17510 A handy revert link is available from the log for sysops.
17511
17512 Editing diff:
17513 Ever lost track of what you'd done so far during an edit? A 'Show diff'
17514 button on the edit page now makes it easy to remember.
17515
17516 Uploads:
17517 It's now possible to specify the final filename of an upload distinct
17518 from the original filename on your disk.
17519
17520 An image link for a missing file will now take you straight to the upload page.
17521
17522 More metadata is pre-extracted from uploaded images, which will ease pressure
17523 on disk or NFS volumes used to store images. EXIF metadata is displayed on
17524 the image description page if PHP is configured with the necessary module.
17525
17526 If .svg files are added to the upload whitelist, you can choose to render
17527 them to rasterized .png images for inline display using one of several
17528 external helper programs. See DefaultSettings.php for SVG options.
17529
17530 User accounts:
17531 There are some changes to the user permissions system, with assignable
17532 groups. Note that this does *not* allow you to make pages which are only
17533 accessible to certain groups.
17534
17535 For details see: https://www.mediawiki.org/wiki/Manual:User_rights
17536
17537 E-mail:
17538 User-to-user e-mail can now be restricted to require a mail-back confirmation
17539 first to reduce potential for abuse with false addresses.
17540
17541 Updates to user talk pages and watchlist entries can optionally send e-mail
17542 notifications.
17543
17544 External hooks:
17545 A somewhat experimental interface for hooking in an external editor
17546 application is included.
17547
17548 And...
17549 A bunch of stuff we forgot to mention.
17550
17551
17552 === What's gone? ===
17553
17554 Latin-1:
17555 Wikis must now be encoded in Unicode UTF-8; this has been the default for
17556 some time, but some languages could optionally be installed in Latin-1 mode.
17557 This is no longer supported.
17558
17559 You can check if your current wiki is in Latin-1 mode by using your browser's
17560 "view source"; look for a line like this:
17561
17562 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
17563
17564 If it says charset=utf-8, you're ready. If it says charset=iso8859-1,
17565 you may need to convert your data. (English-language wikis avoiding
17566 any accented characters may be able to get away without conversion.)
17567
17568 MySQL 3.x:
17569 Some optimization hacks for MySQL 3.x have been removed as part of the schema
17570 clean-up (specifically, the inverse_timestamp fields).
17571
17572 MediaWiki 1.5 may still run on 3.x, but wikis of non-trivial size should
17573 very seriously consider upgrading to a more modern release. MySQL 3.x support
17574 will probably be entirely dropped in the next major release.
17575
17576 Special:Maintenance
17577 These tools were, ironically enough, not really maintained. This special
17578 page has been removed; insofar as some of its pieces were useful and haven't
17579 already been supplanted by other special pages they should be rewritten in
17580 an efficient and safe manner in the future.
17581
17582
17583 === Caveats ===
17584
17585 Upgrade:
17586 Wikis in Latin-1 encoding are no longer supported; only Unicode UTF-8.
17587 A new option $wgLegacyEncoding is provided to allow on-the-fly recoding of
17588 old page text entries, but other metadata fields (titles, comments etc) need
17589 to be pre-converted. The standard upgrade process does not yet fully automate
17590 this, but you can try the alternate partial-upgrader in upgrade1_5.php.
17591
17592 The upgrade from 1.4 to 1.5 schema has not been tested for all cases, so
17593 it's possible you may experience problems in some combinations.
17594
17595 Backups:
17596 The text entries of deleted pages are no longer removed from the main
17597 text table on deletion. If you provide public backup dumps of your databases,
17598 you will probably want to use the new XML-format dump generator, available
17599 as maintenance/dumpBackup.php.
17600
17601 For more information on how we run our own public data dumps at Wikimedia,
17602 see http://meta.wikimedia.org/wiki/Data_dumps
17603
17604 PostgreSQL:
17605 The table definitions for PostgreSQL install are out of date. PostgreSQL
17606 support may return in later releases, pending appropriate patches.
17607
17608 MySQL 4.1+:
17609 Some users may encounter installation problems with MySQL 4.1 or higher
17610 due to strange charset encoding / collation configurations. Try setting
17611 to 'latin1' or 'utf8' if you encounter problems.
17612
17613
17614
17615 == MediaWiki 1.5 release candidate 4 ==
17616
17617 August 29, 2005
17618
17619 MediaWiki 1.5rc4 is a preview release of the new 1.5 release series.
17620 It fixes compatibility with PHP 5.1, and corrects two cross-site scripting
17621 security bugs:
17622
17623 * <math> tags were handled incorrectly when TeX rendering support is off,
17624 as in the default configuration.
17625 * Extension or <nowiki> sections in Wiki table syntax could bypass HTML
17626 style attribute restrictions for cross-site scripting attacks against
17627 Microsoft Internet Explorer
17628
17629 Wikis where the optional math support has been *enabled* are not vulnerable
17630 to the first, but are vulnerable to the second.
17631
17632
17633
17634 == MediaWiki 1.5 release candidate 3 ==
17635
17636 August 24, 2005
17637
17638 MediaWiki 1.5rc3 is a preview release of the new 1.5 release series.
17639 It fixes several major problems in 1.5rc2:
17640
17641 * Fixed a cross-site scripting injection in the search form
17642 (broken since 1.5beta1)
17643
17644 * Fixed upgrades from 1.4 database schema
17645 (broken since 1.5rc2)
17646
17647 1.3 and 1.4 releases are not vulnerable to the XSS bug, but anyone
17648 running an earlier 1.5 beta or release candidate should upgrade
17649 immediately.
17650
17651
17652 == MediaWiki 1.5 release candidate 2 ==
17653
17654 August 23, 2005
17655
17656 MediaWiki 1.5rc2 is a preview release of the new 1.5 release series.
17657 Numerous bug fixes since last beta, plus a security fix; see change
17658 log below for full details.
17659
17660 A flaw in the interaction between extensions and HTML attribute
17661 sanitization was discovered which could allow unauthorized use
17662 of offsite resources in style sheets, and possible exploitation
17663 of a JavaScript injection feature on Microsoft Internet Explorer.
17664
17665 This version expands the returned text and properly checks it
17666 before output.
17667
17668 A 1.5rc1 release was mistakenly made from the incorrect source code
17669 branch; 1.5rc2 is identical to the actual 1.5rc1 in revision control
17670 except for version number.
17671
17672
17673 == MediaWiki 1.5 beta 4 ==
17674
17675 July 30, 2005
17676
17677 MediaWiki 1.5 beta 4 is a preview release of the new 1.5 release series.
17678 A number of bugs have been fixed since beta 3; see the full changelist below.
17679
17680
17681 == MediaWiki 1.5 beta 3 ==
17682
17683 July 7, 2005
17684
17685 MediaWiki 1.5 beta 3 is a preview release of the new 1.5 release
17686 series, with a security update over beta 2.
17687
17688 Incorrect escaping of a parameter in the page move template could
17689 be used to inject JavaScript code by getting a victim to visit a
17690 maliciously constructed URL. Users of vulnerable releases are
17691 recommended to upgrade to this release.
17692
17693 Vulnerable versions:
17694 * 1.5 preview series: n <= 1.5beta2 vulnerable, fixed in 1.5beta3
17695 * 1.4 stable series: 1.4beta6 <= n <= 1.4.5 vulnerable, fixed in 1.4.6
17696 * 1.3 legacy series: not vulnerable
17697
17698 This release also includes several bug fixes and localization updates.
17699 See the changelog at the end of this file for a detailed list.
17700
17701
17702
17703 == MediaWiki 1.5 beta 2 ==
17704
17705 July 5, 2005
17706
17707 MediaWiki 1.5 beta 2 is a preview release of the new 1.5 release series.
17708 While most exciting new bugs should have been ironed out at this point,
17709 third-party wiki operators should probably not run this beta release
17710 on a public site without closely following additional development.
17711
17712 Anyone who _has_ been running beta 1 is very very strongly advised to
17713 upgrade to beta 2, as it fixes many bugs from the previous beta including
17714 a couple of HTML and SQL injections.
17715
17716 This release should be followed by one or two release candidates and
17717 a 1.5.0 final within the next few weeks.
17718
17719 Beta upgraders, note there are some minor database changes. For upgrades
17720 from 1.4, see the file UPGRADE for details on significant database and
17721 configuration file changes.
17722
17723 Beta 2 includes a preliminary command-line XML wiki dump importer tool,
17724 maintenance/importDump.php, paired with maintenance/dumpBackup.php.
17725 These use the same format as Special:Export and Special:Import, able
17726 to package a wiki's entire page set independent of the backend database
17727 and compression format.
17728
17729
17730 == MediaWiki 1.5 beta 1 ==
17731
17732 June 26, 2005
17733
17734 MediaWiki 1.5 beta 1 is a preview release, pretty much feature complete,
17735 of the new 1.5 release series. There are several known and likely a number
17736 of unknown bugs; it is not recommended to use this release in a production
17737 environment but would be recommended for testing in mind of an upcoming
17738 deployment.
17739
17740 A number of significant changes have been made since the alpha releases,
17741 including database changes and a reworking of the user permissions settings.
17742 See the file UPGRADE for details of upgrading and changing your prior
17743 configuration settings for the new system.
17744
17745
17746
17747 == MediaWiki 1.5 alpha 2 ==
17748
17749 June 3, 2005
17750
17751 MediaWiki 1.5 alpha 2 includes a lot of bug fixes, feature merges,
17752 and a security update.
17753
17754 Incorrect handling of page template inclusions made it possible to
17755 inject JavaScript code into HTML attributes, which could lead to
17756 cross-site scripting attacks on a publicly editable wiki.
17757
17758 Vulnerable releases and fix:
17759 * 1.5 prerelease: fixed in 1.5alpha2
17760 * 1.4 stable series: fixed in 1.4.5
17761 * 1.3 legacy series: fixed in 1.3.13
17762 * 1.2 series no longer supported; upgrade to 1.4.5 strongly recommended
17763
17764
17765 == MediaWiki 1.5 alpha 1 ==
17766
17767 May 3, 2005
17768
17769 This is a testing preview release, being put out mainly to aid testers in
17770 finding installation bugs and other major problems. It is strongly recommended
17771 NOT to run a live production web site on this alpha release.
17772
17773 ** WARNING: USE OF THIS ALPHA RELEASE MAY INFEST YOUR HOUSE WITH **
17774 ** TERMITES, ROT YOUR TEETH, GROW HAIR ON YOUR PALMS, AND PASTE **
17775 ** INNUENDO INTO YOUR C.V. RIGHT BEFORE A JOB INTERVIEW! **
17776 ** DON'T SAY WE DIDN'T WARN YOU, MAN. WE TOTALLY DID RIGHT HERE. **
17777
17778
17779 === Smaller changes since 1.4 ===
17780
17781 Various bugfixes, small features, and a few experimental things:
17782
17783 * 'live preview' reduces preview reload burden on supported browsers
17784 * support for external editors for files and wiki pages:
17785 https://www.mediawiki.org/wiki/Manual:External_editors
17786 * Schema reworking: https://www.mediawiki.org/wiki/Proposed_Database_Schema_Changes/October_2004
17787 * (bug 15) Allow editors to view diff of their change before actually submitting an edit
17788 * (bug 190) Hide your own edits on the watchlist
17789 * (bug 510): Special:Randompage now works for other namespaces than NS_MAIN.
17790 * (bug 1015) support for the full wikisyntax in <gallery> captions.
17791 * (bug 1105) A "Destination filename" (save as) added to Special:Upload Upload.
17792 * (bug 1352) Images on description pages now get thumbnailed regardless of whether the thumbnail is larger than the original.
17793 * (bug 1662) A new magicword, {{CURRENTMONTHABBREV}} returns the abbreviation of the current month
17794 * (bug 1668) 'Date format' supported for other languages than English, see:
17795 http://mail.wikipedia.org/pipermail/wikitech-l/2005-March/028364.html
17796 * (bug 1739) A new magicword, {{REVISIONID}} give you the article or diff database
17797 revision id, useful for proper citation.
17798 * (bug 1998) Updated the Russian translation.
17799 * (bug 2064) Configurable JavaScript mimetype with $wgJsMimeType
17800 * (bug 2084) Fixed a regular expression in includes/Title.php that was accepting invalid syntax like #REDIRECT [[foo] in redirects
17801 * It's now possible to invert the namespace selection at Special:Allpages and Special:Contributions
17802 * No longer using sorbs.net to check for open proxies by default.
17803 * What was $wgDisableUploads is now $wgEnableUploads, and should be set to true if one wishes to enable uploads.
17804 * Supplying a reason for a block is no longer mandatory
17805 * Language conversion support for category pages
17806 * $wgStyleSheetDirectory is no longer an alias for $wgStyleDirectory;
17807 * Special:Movepage can now take parameters like Special:Movepage/Page_to_move
17808 (used to just be able to take parameters via a GET request like index.php?title=Special:Movepage&target=Page_to_move)
17809 * (bug 2151) The delete summary now includes editor name, if only one has edited the article.
17810 * (bug 2105) Fixed from argument to the PHP mail() function. A missing space could prevent sending mail with some versions of sendmail.
17811 * (bug 2228) Updated the Slovak translation
17812 * ...and more!
17813
17814
17815 === Changes since 1.5alpha1 ===
17816
17817 * (bug 73) Category sort key is set to file name when adding category to
17818 file description from upload page (previously it would be set to
17819 "Special:Upload", causing problems with category paging)
17820 * (bug 419) The contents of the navigation toolbar are now editable through
17821 the MediaWiki namespace on the MediaWiki:navbar page.
17822 * (bug 498) The Views heading in MonoBook.php is now localizable
17823 * (bug 898) The wiki can now do advanced sanity check on uploaded files
17824 including virus checks using external programs.
17825 * (bug 1692) Fix margin on unwatch tab
17826 * (bug 1906) Generalize project namespace for Latin localization, update namespaces
17827 * (bug 1975) The name for Limburgish (li) changed from "Lèmburgs" to "Limburgs
17828 * (bug 2019) Wrapped the output of Special:Version in <div dir='ltr'> in order
17829 to preserve the correct flow of text on RTL wikis.
17830 * (bug 2067) Fixed crash on empty quoted HTML attribute
17831 * (bug 2075) Corrected namespace definitions in Tamil localization
17832 * (bug 2079) Removed links to Special:Maintenance from movepagetext message
17833 * (bug 2094) Multiple use of a template produced wrong results in some cases
17834 * (bug 2095) Triple-closing-bracket thing partly fixed
17835 * (bug 2110) "noarticletext" should not display on Image page for "sharedupload" media
17836 * (bug 2150) Fix tab indexes on edit form
17837 * (bug 2152) Add missing bgcolor to attribute whitelist for <td> and <th>
17838 * (bug 2176) Section edit 'show changes' button works correctly now
17839 * (bug 2178) Use temp dir from environment in parser tests
17840 * (bug 2217) Negative ISO years were incorrectly converted to BC notation
17841 * (bug 2234) allow special chars in database passwords during install
17842 * Deprecated the {{msg:template}} syntax for referring to templates, {{msg: is
17843 now the wikisyntax representation of wfMsgForContent()
17844 * Fix for reading incorrectly re-gzipped HistoryBlob entries
17845 * HistoryBlobStub: the last-used HistoryBlob is kept open to speed up
17846 multiple-revision pulls
17847 * Add $wgLegacySchemaConversion update-time option to reduce amount of
17848 copying during the schema upgrade: creates HistoryBlobCurStub reference
17849 records in text instead of copying all the cur_text fields. Requires
17850 that the cur table be left in place until/unless such fields are migrated
17851 into the main text store.
17852 * Special:Export now includes page, revision, and user id numbers by
17853 default (previously this was disabled for no particular reason)
17854 * dumpBackup.php can dump the full database to Export XML, with current
17855 revisions only or complete histories.
17856 * The group table was renamed to groups because "group" is a reserved word in
17857 SQL which caused some inconveniances.
17858 * New fileicons for c, cpp, deb, dvi, exe, h, html, iso, java, mid, mov, o,
17859 ogg, pdf, ps, rm, rpm, tar, tex, ttf and txt files based on the KDE
17860 crystalsvg theme.
17861 * Fixed a bug in Special:Newimages that made it impossible to search for '0'
17862 * Added language variant support for Icelandic, now supports "Íslenzka"
17863 * The #p-nav id in MonoBook is now #p-navigation
17864 * Putting $4 in msg:userstatstext will now give the percentage of
17865 admnistrators out of normal users.
17866 * links and brokenlinks tables merged to pagelinks; this will reduce pain
17867 dealing with moves and deletes of widely-linked pages.
17868 * Add validate table and val_ip column through the updater.
17869 * Simple rate limiter for edits and page moves; set $wgRateLimits
17870 (somewhat experimental; currently needs memcached)
17871 * (bug 2262) Hide math preferences when TeX is not enabled
17872 * (bug 2267) Don't generate thumbnail at the same size as the source image.
17873 * Fix rebuildtextindex.inc for new schema
17874 * Remove linkscc table code, no longer used.
17875 * (bug 2271) Use faster text-only link replacement in image alt text
17876 instead of rerunning expensive link lookup and HTML generation.
17877 * Only build the HTML attribute whitelist tree once.
17878 * Replace wfMungeToUtf8 and do_html_entity_decode with a single function
17879 that does both numeric and named chars: Sanitizer::decodeCharReferences
17880 * Removed some obsolete UTF-8 converter functions
17881 * Fix function comment in debug dump of SQL statements
17882 * (bug 2275) Update search index more or less right on page move
17883 * (bug 2053) Move comment whitespace trimming from edit page to save;
17884 leaves the whitespace from the section comment there on preview.
17885 * (bug 2274) Respect stub threshold in category page list
17886 * (bug 2173) Fatal error when removing an article with an empty title from the watchlist
17887 * Removed -f parameter from mail() usage, likely to cause failures and bounces.
17888 * (bug 2130) Fixed interwiki links with fragments
17889 * (bug 684) Accept an attribute parameter array on parser hook tags
17890 * (bug 814) Integrate AuthPlugin changes to support Ryan Lane's external
17891 LDAP authentication plugin
17892 * (bug 2034) Armor HTML attributes against template inclusion and links munging
17893
17894 === Changes since 1.5alpha2 ===
17895
17896 * (bug 2319) Fix parse hook tag matching
17897 * (bug 2329) Fix title formatting in several special pages
17898 * (bug 2223) Add unique index on user_name field to prevent duplicate accounts
17899 * (bug 1976) fix shared user database with a table prefix set
17900 * (bug 2334) Accept null for attribs in wfElement without PHP warning
17901 * (bug 2309) Allow templates and template parameters in HTML attribute zone,
17902 with proper validation checks. (regression from fix for 2304)
17903 * Disallow close tags and enforce empty tags for <hr> and <br>
17904 * Changed user_groups format quite a bit.
17905 * (bug 2368) Avoid fatally breaking PHP 4.1.2 in a debug line
17906 * (bug 2367) Insert correct redirect link record on page move
17907 * (bug 2372) Fix rendering of empty-title inline interwiki links
17908 * (bug 2384) Fix typo in regex for IP address checking
17909 * (bug 650) Prominently link MySQL 4.1 help page in installer if a possible
17910 version conflict is detected
17911 * (bug 2394) Undo incompatible breakage to {{msg:}} compatibility includes
17912 * (bug 1322) Use a shorter cl_sortkey field to avoid breaking on MySQL 4.1
17913 when the default charset is set to utf8
17914 * (bug 2400) don't send confirmation mail on account creation if
17915 $wgEmailAuthentication is false.
17916 * (bug 2172) Fix problem with nowiki beeing replaced by marker strings
17917 when a template with a gallery was used.
17918 * Guard Special:Userrights against form submission forgery
17919 * (bug 2408) page_is_new was inverted (whoops!)
17920 * Added wfMsgHtml() function for escaping messages and leaving params intact
17921 * Fix ordering of Special:Listusers; fix groups list so it shows all groups
17922 when searching for a specific group and can't be split across pages
17923 * (bug 1702) Display a handy upload link instead of a useless blank link
17924 for [[media:]] links to nonexistent files.
17925 * (bug 873) Fix usage of createaccount permission; replaces $wgWhitelistAccount
17926 * (bug 1805) Initialise $wgContLang before $wgUser
17927 * (bug 2277) Added Friulian language file
17928 * (bug 2457) The "Special page" href now links to the current special page
17929 rather than to "".
17930 * (bug 1120) Updated the Czech translation
17931 * A new magic word, {{SCRIPTPATH}}, returns $wgScriptPath
17932 * A new magic word, {{SERVERNAME}}, returns $wgServerName
17933 * A new magic word, {{NUMBEROFFILES}}, returns the number of rows in the image table
17934 * Special:Imagelist displays titles with " " instead of "_"
17935 * Less gratuitous munging of content sample in delete summary
17936 * badaccess/badaccesstext to supercede sysop*, developer* messages
17937 * Changed $wgGroupPermissions to more cut-n-paste-friendly format
17938 * 'developer' group deprecated by default
17939 * Special:Upload now uses 'upload' permission instead of hardcoding login check
17940 * Add 'importupload' permission to disable direct uploads to Special:Import
17941 * (bug 2459) Correct escaping in Special:Log prev/next links
17942 * (bug 2462 etc) Taking out the experimental dash conversion; it broke too many
17943 things for the current parser to handle cleanly
17944 * (bug 2467) Added a Turkish language file
17945 * Fixed a bug in Special:Contributions that caused the namespace selection to
17946 be forgotten between submits
17947 * Special:Watchlist/edit now has namespace subheadings
17948 * (bug 1714) the "Save page" button now has right margin to separate it from
17949 "Show preview" and "Show changes"
17950 * Special:Statistics now supports action=raw, useful for bots designed to
17951 harwest e.g. article counts from multiple wikis.
17952 * The copyright confirmation box at Special:Upload is now turned off by default
17953 and can be turned back on by setting $wgCopyrightAffirmation to a true value.
17954 * Restored prior text for password reminder button and e-mail, replacing
17955 the factually inaccurate text that was there.
17956 * (bug 2178) Fix temp dir check again
17957 * (bug 2488) Format 'deletedtext' message as wikitext
17958 * (bug 750) Keep line endings consistent in LocalSettings.php
17959 * (bug 1577) Add 'printable version' tab in MonoBook for people who don't
17960 realize you can just hit print to get a nicely formatted printable page.
17961 * Trim whitespace from option values to weather line-ending corruption problems
17962 * Fixed a typo in the Romanian language file (NS_MESIA => NS_MEDIA)
17963 * (bug 2504) Updated the Finnish translation
17964 * (bug 2506, 2512) Updated the Nynorsk translation
17965 * (bug 996) Replace $wgWhitelistEdit with 'edit' permission; fixup UPGRADE
17966 documentation about edit and read whitelists.
17967 * (bug 2515) Fix incremental link table update
17968 * Removed some wikipedia-specifica from LanguageXx.php's
17969 * (bug 2496) Allow MediaWiki:edithelppage to point to external page
17970 * Added a versionRequired() function to OutputPage, useful for extension
17971 writers that want to control what version of MediaWiki their extension
17972 can be used with.
17973 * Serialized user objects now checked for versioning
17974 * Fix for interwiki link regression
17975 * Printable link shorter in monobook
17976 * Experimental Latin-1-and-replication-friendly upgrader script
17977 * (bug 2520) Don't show enotif options when disabled
17978
17979 == Changes since 1.5beta1 ==
17980
17981 * (bug 2531) Changed the interwiki name for sh (Serbocroatian) to
17982 Srpskohrvatski/Српскохрватски (was Српскохрватски (Srbskohrvatski))
17983 * Nonzero return code for command-line scripts on wfDebugDieBacktrace()
17984 * Conversion fix for empty old table in upgrade1_5.php
17985 * Try reading revisions from master if no result on slave
17986 * (bug 2538) Suppress notice on user serialized checks
17987 * Fix paging on Special:Contributions
17988 * (bug 2541) Fix unprotect tab
17989 * (bug 1242) category list now show on edit page
17990 * Skip sidebar entries where link text is '-'
17991 * Convert non-UTF-8 URL parameters even if referer is local
17992 * (bug 2460) <img> width & height properly filled when resizing image
17993 * (bug 2273) deletion log comment used user interface language
17994 * Try reading revision _text_ from master if no result on slave
17995 * Use content-language message cache for raw view of message pages
17996 * (bug 2530) Not displaying talk pages on Special:Watchlist/edit
17997 * Fixed a bug that would occour if $wgCapitalLinks was set to false, a user
17998 agent could create a username that began with a lower case letter that was
17999 not in the ASCII character set ( now user $wgContLang->ucfirst() instead of
18000 PHP ucfirst() )
18001 * Moved the user name / password validity checking from
18002 LoginForm::addNewAccountInternal() to two new functions,
18003 User::isValidUserName() and User::isValidPassword(), extensions can now do
18004 these checks without rewriting code.
18005 * Fix $wgSiteNotice when MediaWiki:Sitenotice is set to default '-'
18006 * Fixed a bug where the watchlist count without talk pages would be off by a
18007 factor of two.
18008 * upgrade1_5.php uses insert ignore, allows to skip image info initialization
18009 * Fix namespaces in category list.
18010 * Add rebuildImages.php to update image metadata fields
18011 * Special:Ancientpages is expensive in new schema for now
18012 * (bug 2568) Fixed a logic error in the Special:Statistics code which caused
18013 the displayed percentage of admins to be totally off.
18014 * (bug 2560) Don't show blank width/height attributes for missing size
18015 * Don't show bogus messages about watchlist notifications when disabled
18016 * Don't show old debug messages in watchlist
18017 * (bug 2576) Fix recording of transclusion links
18018 * (bug 2577) Allow sysops to enter non-standard block times
18019 * Fixed a bug where Special:Contributions wouldn't remember the 'invert'
18020 status between next/previous buttons.
18021 * Move MonoBook printable link from tab to sidebar
18022 * (bug 2567) Fix HTML escaping on category titles in list
18023 * (bug 2562) Show rollback link for current revisions on diff pages
18024 * (bug 2583) Add --missinig option on rebuildImages.php to add db entries
18025 for uploaded files that don't have them
18026 * (bug 2572) Fix edit conflict handling
18027 * (bug 2595) Show "Earlier" and "Latest" links on history go to the first/last
18028 page in the article history pager.
18029 * Don't show empty-page text in 'Show changes' on new page
18030 * (bug 2591) Check for end, fix limits on Whatlinkshere
18031 * (bug 2584) Fix output of subcategory list
18032 * (bug 2597) Don't crash when undeleting an image description page
18033 * (bug 2564) Don't show "editingold" warning for recent revision
18034 * Various code cleanup and HTML escaping fixlets
18035 * Copy IRC-over-UDP update option from REL1_4
18036 * (bug 2548) Keep summary on 'show changes' of section edit
18037 * Move center on toc to title part to avoid breaking .toc style usage
18038 * HTML sanitizer: correct multiple attributes by keeping last, not first
18039 * (bug 2614) Fix section edit links on diff-to-current with oldid set
18040 Also fix navigation links on current-with-oldid view.
18041 * (bug 2620) Return to prior behavior for some more things (such as
18042 subpage parent links) on current-diff view.
18043 * (bug 2618) Fix regression from another fix; show initial preview for
18044 categories only if the page does not exist.
18045 * (bug 2625) Keep group & user settings when paging in Listusers
18046 * (bug 2627) Fix regression: diff radio button initial selection
18047 * Copy fix for old search URLs with Lucene search plugin from REL1_4
18048 * (bug 619) Don't use incompatible diff3 executable on non-Linux systems.
18049 * (bug 2631) Fix Hebrew namespaces.
18050 * (bug 2630) Indicate no-longer-valid cached entries in BrokenRedirects list
18051 * (bug 2644, 2645) "cur" diff links in page history, watchlist and
18052 recentchanges should specify current ID explicitly.
18053 * (bug 2609) Fix text justification preferenced with MonoBook skin.
18054 * (bug 2594) Display article tab as red for non-existent articles.
18055 * (bug 2656) Fix regression: prevent blocked users from reverting images
18056 * (bug 2629) Automatically capitalize usernames again instead of
18057 rejecting lowercase with a useless error message
18058 * (bug 2661) Fix link generation in contribs
18059 * Add support for &preload=Page_name (load text of an existing page into
18060 edit area) and &editintro=Page_name (load text of an existing page instead
18061 of MediaWiki:Newpagetext) to &action=edit, if page is new.
18062 * (bugs 2633, 2672, 2685, 2695) Fix Estonian, Portuguese, Italian, Finnish and
18063 Spanish numeric formatting
18064 * Fixed Swedish numeric formatting
18065 * (bug 2658) Fix signature time, localtime to match timezone offset again
18066 * Files from shared repositories (e.g. commons) now display with their
18067 image description pages when viewed on local wikis.
18068 * Restore compatibility namespace aliases for French Wikipedia
18069 * Fix diff order on Enhanced RC 'changes' link
18070 * (bug 2650) Fix national date type display on wikis that don't support
18071 dynamic date conversion.
18072 * FiveUpgrade: large table hacks, install iw_trans update before links
18073 * (bug 2648) Rename namespaces in Afrikaanse
18074 * Special:Booksources checks if custom list page exists before using it
18075 * (bug 1170) Fixed linktrail for da: and ru:
18076 * (bug 2683) Really fix apostrophe escaping for toolbox tips
18077 * (bug 923) Fix title and subtitle for rclinked special page
18078 * (bug 2642) watchdetails message in several languages used <a></a> instead of [ ]
18079 * (bug 2181) basic CSB language localisation by Tomasz G. Sienicki (thanks for the patch)
18080 * Fix correct use of escaping in edit toolbar bits
18081 * Removed language conversion support from Icelandic
18082 * (bug 2616) Fix proportional image scaling, giving correct height
18083 * (bug 2640) Include width and height attributes on unscaled images
18084 * Workaround for mysterious problem with bogus epoch If-Last-Modified reqs
18085 * (bug 1109) Suppress compressed output on 304 responses
18086 * (bug 2674) Include some site configuration info in export data:
18087 namespaces definitions, case-sensitivity, site name, version.
18088 * Use xml:space="preserve" hint on export <text> elements
18089 * Make language variant selection work again for zh
18090
18091 == Changes since 1.5beta2 ==
18092
18093 * Escaped & correctly in Special:Contributions
18094 * (bug 2534) Hide edit sections with CSS to make right click to edit section work
18095 * (bug 2708) Avoid undefined notice on cookieless login attempt
18096 * (bug 2188) Correct template namespace for Greek localization
18097 * Fixed number formatting for Dutch
18098 * (bug 1355) add class noprint to commonPrint.css
18099 * (bug 2350) Massive update for Limburgish (li) language using Wikipédia
18100 * Massive update for Arab (ar) language using Wikipédia
18101 * (bug 1560) Massive update for Kurdish (ku) language using Wikipédia
18102 * (bug 2709) Some messages were not read from database
18103 * (bug 2416) Don't allow search engine robots to index or follow nonexisting articles
18104 * Fix escaping in page move template.
18105 * (bug 153) Discrepancy between thumbnail size and <img> height attribute
18106
18107 == Changes since 1.5beta3 ==
18108
18109 * Fix talk page move handling
18110 * (bug 2721) New language file for Vietnamese with the Vietnamese number notation
18111 * (bug 2749) &nbsp; would appear as a literal in image galleries for Cs, Fr, Fur, Pl and Sv
18112 * (bug 787) external links being rendered when they only have one slash
18113 * Fixed a missing typecast in Language::dateFormat() that would cause some
18114 interesting errors with signitures.
18115 * (bug 2764) Number format for Nds
18116 * (bug 1553) Stop forcing lowercase in Monobook skin for German language.
18117 * (bug 1064) Implements Special:Unusedcategories
18118 * (bug 2311) New language file for Macedonian
18119 * Fix nohistory message on empty page history
18120 * Fix fatal error in history when validation on
18121 * Cleaned up email notification message formatting
18122 * Finally fixed Special:Disambiguations that was broke since SCHEMA_WORK
18123 * (bug 2761) fix capitalization of "i" in Turkish
18124 * (bug 2789) memcached image metadata now cleared after deletion
18125 * Add serialized version number to image metadata cache records
18126 * (bug 2780) Fix thumbnail generation with GD for new image schema
18127 * (bug 2791) Slovene numeric format
18128 * (bug 655) Provide empty search form when searching for nothing
18129 * Nynorsk numeric format fix
18130 * (bug 2825) Fix regression in newtalk notifications for anons w/ enotif off
18131 * (bug 2833) Fix bug in previous fix
18132 * With $wgCapitalLinks off, accept off-by-first-letter-case in 'go' match
18133 * Optional parameters for [[Special:Listusers]]
18134 * (bug 2832) [[Special:Listadmins]] redirects to [[Special:Listusers/sysop]]
18135 * (bug 785) Parser did not get out of <pre> with list elements
18136 * Some shared upload fixes
18137 * (bug 2768) section=new on nonexistent talk page does not add heading
18138 * support preload= parameter for section=new
18139 * show comment subject in preview when using section=new
18140 * use comment form when creating a new talk page
18141 * (bug 460) Properly handle <center> tags as a block.
18142 * Undo inconsistent editing behavior change
18143 * (bug 2835) Back out fix for bug 2802, caused regressions in category sort
18144 * PHP 4.1.2 compatibility fix: define floatval() equivalent if missing
18145 * (bug 2901) Number format for Catalan
18146 * Special:Allpages performance hacks: index memcached caching, removed
18147 inverse checkbox, use friendlier relative offsets in index build
18148 * Bring back "Chick" skin for mobile devices. It needs testing.
18149 * Fix spelling of $wgForwardSearchUrl in DefaultSettings.php
18150 * Specify USE INDEX on Allpages chunk queries, sometimes gets lost
18151 due to bogus optimization
18152 * (bug 275) Section duplication fix
18153 * Remove unused use of undefined variable in UserMailer
18154 * Fix notice on search index update due to non-array
18155 * (bug 2885) Fix fatal errors and notices in PHP 5.1.0beta3
18156 * (bug 2931) Fix additional notices on reference use in PHP 4.4.0
18157 * (bug 2774) Add three new $wgHooks to LogPage which enable extensions to add
18158 their own logtypes, see extensions/Renameuser/SpecialRenameuser.php for an
18159 example of this.
18160 * (bug 740) Messages from extensions now appear in Special:Allmessages
18161 * (bug 2857) fixed parsing of lists in <pre> sections
18162 * (bug 796) Trackback support
18163 * Fix 1.5 regression: weird, backwards diff links on new pages in enhanced RC
18164 are now suppressed as before.
18165 * New skin: Simple
18166 * "uselang" and "useskin" URL parameters can now be used in the URL when
18167 viewing a page, to change the language and skin of a page respectively.
18168 * Skins can now be previewed in preferences
18169 * (bug 2943) AuthPlugin::getCanonicalName() name canonicalization hook,
18170 patch from robla
18171 * Wrap revision insert & page update in a transaction, rollback on late
18172 edit conflict.
18173 * (bug 2953) 'other' didn't work in Special:Blockip when localized
18174 * (bug 2958) Rollback and delete auto-summary should be in the project's
18175 content language
18176 * Removed useless protectreason message
18177 * Spelling fix: $wgUrlProtcols -> $wgUrlProtocols
18178 * Switch Moldovan local name to cyrillic
18179 * Fix typo in undefined array index access prevention
18180 * (bug 2947) Update namespaces for sr localization
18181 * (bug 2952) Added Asturian language file with translated namespaces
18182 * (bug 2676) Apply a protective transformation on editing input/output
18183 for browsers that hit the Unicode blacklist. Patch by plugwash.
18184 * (bug 2999) Fix encoding conversion of pl_title in upgrade1_5.php
18185 * compressOld.php disabled, as it's known to be broken.
18186
18187
18188 === Changes since 1.5beta4 ===
18189
18190 * Fix Special:Allmessages under PHP 5
18191 * (bug 2911) Special:Watchlist allowed only one type of limit at a time
18192 * (bug 693) Special:Allmessages is excessively wide and redundant
18193 * (bug 3001) Updated and applied live hack for recentchanges-based watchlist
18194 * (bug 145) Finish 'exclude redirect' implementation in search form
18195 * Rearranged Special:Movepage form to reduce confusion between destination
18196 title and reason input boxes
18197 * (bug 2527) Always set destination filename when new file is selected
18198 * (bug 3056) MySQL 3 compatibility fix: USE INDEX instead of FORCE INDEX
18199 * PHP 4.1 compatibility fix: don't use new_link parameter to mysql_connect
18200 if running prior to 4.2.0 as it causes the call to fail
18201 * (bug 3117) Fix display of upload size and type with tidy on
18202 * (bug 1487) invalid html on empty list in banlist
18203 * (bug 3017) Hotkey conflict for delete and show changes
18204 * made pixel unit translateable and blocklistline now eats infiniteblock
18205 and expiringblock
18206 * (bug 3092) Wrong numerical separator for big numbers in Serbian.
18207 * (bug 2855) Credit for a uniq author showed its realname even with
18208 $wgAllowRealName=false.
18209 * New special page: SpecialMostlinked
18210 * (bug 2393) Fix MIME type for Atom feeds ( application/rss+atom )
18211 * Fix display of read-only lockfile message
18212 * Added a new hook, 'AddNewAccount', which is run after account creation
18213 * Update all stats fields on recount.sql
18214 * Include software-visible client IP address in Special:Version comment
18215 as a proxy debugging aid
18216 * (bug 3162) Fix 'undefined property page_is_new' error on watchlist
18217 * (bug 1734) granting db permissions failed with db usernames containg '-'
18218 * (bug 3170) wikititlesuffix was removed, use pagetitle instead
18219 * (bug 3187) watchlist text refer to unexistent "Stop watching" action
18220 * (bug 3190) Added some date format choices for language sr
18221 * (bug 1334) LanguageGa.php update
18222 * (bug 1020) Changing user interface language does not work immediately
18223 * (bug 2753) Some namespaces were not translated in LanguageTa.php (Tamil)
18224 * (bug 3204) Fix typo breaking special pages in fy localization
18225 * (bug 3210) Fix Media: links with remote image URL path
18226 * (bug 3220) Fix escaping of block URLs in Recentchanges
18227 * (bug 3238): Updated LanguageNn.php for 1_5 branch
18228 * (bug 3192): properly check 'limit' parameter on Special:Contributions
18229 * (bug 3244) Fix remote image loading hack, JavaScript injection on MSIE
18230 * Fix URL sanitization in HTML attributes, which broke in this branch
18231 * (bug 3475) anon contrib links on Special:Newpages
18232
18233
18234 === Changes since 1.5rc2 ===
18235
18236 * Fix upgrade from 1.4 due to version number check breakage
18237 * Fix upgrade from 1.4 with no old revisions
18238 * (bug 2108) Sort entries when using category browser
18239 * XSS issue : now sanitize search query input
18240
18241
18242 === Changes since 1.5rc3 ===
18243
18244 * (bug 3280) Respect 'move' group permission on page moves
18245 * (bug 2885) More PHP 5.1 fixes: skin, search, log, undelete
18246 * Security fix for <math>
18247 * Security fix for tables
18248
18249
18250 === Changes since 1.5rc4 ===
18251
18252 * (bug 3292) Fix move-over-redirect test when current entries are not plaintext
18253 * (bug 2078) Don't hide watch tab on preview
18254 * (bug 3306) Document $wgLocalTZoffset
18255 * Support SVG rendering with rsvg
18256 * Cap arbitrary SVG renders to given image size or $wgSVGMaxSize pixels wide
18257 * (bug 3127) Render large SVGs at image page size correctly
18258 * (bug 3448) Set page_len on undelete
18259 * (bug 2800) Don't scale up small iamges on |thumb| without explicit size
18260 * Use the real file link instead of the default-size rasterized version for
18261 large SVG images on image description page
18262 * Include the file name/type/size line for non-resized images
18263 * (bug 3412) Clean up date format handling so ~~~~-sigs work with default
18264 format as designed. Documentation comments updated.
18265 * (bug 1423) LanguageJa.php update
18266 * (bug 3405) Don't use raw letters as aliases of MSGNW: and SUBST:
18267 * (bug 3485) Fix bogus warning about filename capitalization when off
18268 * (bug 2792) Update rebuildrecentchanges.inc for new schema
18269 * Special:Import/importDump fixes: report XML parse errors, accept <minor/>
18270 * (bug 3489) PHP 5.1 compat problem with captioned images
18271 * (bug 3350) Missing label for move talk page checkbox.
18272 * (bug 2570) Add 'watch this page' checkbox on uploads, watch uploads
18273 by default when 'watchdefault' option is on
18274 * (bug 3182) Clear link cache during import to prevent memory leak
18275 * (bug 3573) Full Greek Translation
18276 * (bug 3595) Warn and abort if importDump.php called in read-only mode.
18277 * (bug 3598) Update message cache on message page deletion, patch by Tietew
18278 * Blacklist additional MSIE CSS safety tricks
18279
18280
18281 === Changes since 1.5.0 ===
18282
18283 * (bug 3629) Fix date & time format for Frisian
18284 * (bug 3641) Fix handling of unrecognized file uploads with known extensions
18285 * (bug 3643) Fix image page display of large images with resizing disabled
18286 * Fix meta robots tag on Special:Version again to avoid listing vulnerable
18287 versions for convenient harvesting by automated worms
18288 * (bug 3684) Fix typo in fatal error backtraces in Hooks.php
18289 * Backport fix for reference usage notice in Special:Search on PHP 4.4.0
18290 * Backport database connect error display fix from HEAD
18291 * (bug 2773) Print style sheet no longer overrides RTL text direction
18292 * MonoBook skin top link id changed from "contentTop" to "top" (shared with
18293 name attribute)
18294 * Wrap message page insertions in a transaction to speed up installation
18295 * Fix Special:MovePage invalid HTML attribute for reason textarea
18296 * Avoid notice warning on edit with no User-Agent header
18297 * (bug 3734) Swapped out obsolete recount.sql with initStats.php
18298 * (bug 3735) Fix to run under MySQL 5's strict mode
18299 * (bug 3786) Experimental support for MySQL 4.1/5.0 utf8 charset mode
18300 NOTE: Enabling this may break existing wikis, and still doesn't
18301 work for all Unicode characters due to MySQL limitations.
18302 * Sanitizer CSS comment processing order fix
18303
18304
18305 === Changes since 1.5.1 ===
18306
18307 * Fix Special:BrokenRedirects on MySQL 5.0
18308 * (bug 3809) Backport fix for detecting diff3 failure
18309 * MySQL 5.0 strict mode fix for moving unwatched pages
18310 * (bug 3782) Throw fatal installation warning if mbstring.func_overload on.
18311 Why do people invent these crazy options that change language semantics?
18312 * (bug 3762) Define missing Special:Import UI messages
18313 * (bug 3771) Handle internal functions in backtrace in wfAbruptExit()
18314 * (bug 3649) Remove obsolete, broken moveCustomMessages script
18315 * (bug 3667) Add missing global in page move code
18316 * (bug 3761) Avoid deprecation warnings in Special:Import
18317 * (bug 2885) Remove unnecessary reference parameter which broke classic skin
18318 talk notification on PHP 5.0.5
18319 * (bug 3845) Update attribute.php for 1.5 schema
18320 * Fix Parser::unstrip on PHP 4.4.1 and PHP 5.1.0RC4
18321
18322
18323 === Changes since 1.5.2 ===
18324
18325 * (bug 3612) Remove old broken version of maintenance/compressOld.php
18326 The working version is in maintenance/storage/compressOld.php
18327 * (bug 2740) Accept image deletions on 'enter' submit from MSIE
18328 * (bug 3933) specify XML namespace for Atom 0.3 feeds
18329 * (bug 3939) Don't try to load text for interwiki redirect target
18330 * (bug 3948) Avoid notice warning in debug statement in bad search
18331 * Recognize Special:Search consistently so read whitelist works
18332 * (bug 4013) typo in fr
18333 * (bug 3996) Fix text for new entries in RC RSS/Atom feed
18334 * (bug 2894) Enhanced Recent Changes link fixes
18335 * (bug 3065) Update both watched namespaces when renaming pages
18336 * Move parentheses out of <a> link in Special:Contributions
18337 * (bug 4071) Generate passwords long enough for $wgMinimalPasswordLength
18338 * (bug 4035) Fix prev/next revision links on edit page
18339 * (bug 4165) Correct validation for user language selection (data taint)
18340 * Clearer message in DefaultSettings.php: edit LocalSettings.php instead
18341
18342
18343 === Changes since 1.5.3 ===
18344
18345 * (bug 3805) Clear 'new messages' flag properly in enotif mode
18346 for usernames containing spaces
18347 * (bug 2714) Backlink from special:whatlinkshere was hard set as 'existing'
18348 * (bug 4249) Typo in entities2literals.pl
18349 * (bug 4233) Update for japanese language
18350 * (bug 4279) Small correction to LanguageDa.php
18351 * (bug 4267) Switch dv sd ug ks arc languages to RTL
18352 * (bug 3991) Allow the operation of wikicode on Protect move only text
18353 * Added AutoAuthenticate hook for external User object suppliers
18354 * Parser internal placeholder string now fully randomized for safety
18355
18356 === Changes since 1.5.4 ===
18357
18358 * Maintenance script to delete unused user accounts
18359 * Added detection for WMF files (application/x-msmetafile), added this
18360 MIME type to the default blacklist. Prevented inline display of images
18361 which are not of known image types. This is in response to
18362 http://en.wikipedia.org/wiki/Windows_Metafile_vulnerability
18363
18364 === Changes since 1.5.5 ===
18365
18366 * (bug 4258) When installing under IIS, $wgArticlePath = "$wgScript?title=$1"
18367 should be set
18368 * (bug 4510) Correct Barnes & Noble bookstore URLs
18369 * (bug 4504) Use site language for namespace name resolution
18370 * Installer fixes from HEAD backported; now uses a more sensible method of
18371 establishing which mySQL user to use, which clears up bug 921 et al. Minor
18372 changes to installer.
18373 * Fix problem reported on mailing list where re-initialising stats didn't work
18374 (can't insert duplicate rows with the same id field)
18375 * (bug 1122) gray out 'older revision' when viewing first article revision.
18376 * Respect database prefix in dumpHTML.inc
18377 * Minor improvements to removeUnusedAccounts.php maintenance script
18378 * Fix for single-digit week numbers from {{CURRENTWEEK}}, broken by PHP 4.4.1
18379 * Removed read-only check from Database::query()
18380 * Added --conf option to command line scripts, allowing the user to specify a
18381 different LocalSettings.php.
18382
18383 === Changes since 1.5.6 ===
18384
18385 * Default main page content improved per bug 4690
18386 * Fix dependence on hardcoded UNIQ_PREFIX in LanguageConverter.php
18387 * Fixed Special:Unlockdb
18388 * Maintenance script to delete unused text records
18389 * Maintenance script to delete non-current revisions
18390 * Maintenance script to wipe a page and all revisions from the database
18391 * (bug 4768) Wrong Russian translation (typo)
18392 * Performance bugfix: propagate equality manually for Revision fetches
18393 * (bug 4773) PHP fatal error when invalid title passed to Special:Export
18394 * Added missing table defs. for transcache to installer schemas
18395 * (bug 4824) IE7 beta 2 broke compatibility with PNG logo workarounds,
18396 and seems to work ok with other bits. No longer including the IE
18397 workarounds JavaScript for IE 7 and above.
18398 * (bug 2532) Image directory structure migration bug
18399 * (bug 4881) Correction to the fix for 1487; Ipblocklist showed 'no blocks'
18400 message at the end of the list even if there were blocks.
18401 * (bug 4805) Removed more wikipedia-references from LanguageUk.php
18402 * Introduce $wgWantedPagesThreshold per bug 5011; Special:Wantedpages will not
18403 list pages with less than this number of links. Defaults to 1.
18404 * Allow customisation of paging limits for items in categories using the
18405 $wgCategoryPagingLimit global, per bug 4970.
18406 * Improve "nogomatch" text to make it more obvious that a page can be created.
18407 * (bug 5113) Spelling error in French language file
18408 * Don't change the password of the MySQL root user.
18409
18410 === Changes since 1.5.7 ===
18411
18412 * (bug 5180) User login page shows inappropriate email blurb
18413 * Add the "AbortNewAccount" hook on account creation; see hooks.txt for more info.
18414 * Update default "exporttext" to reflect that Special:Import exists
18415 * Add links to useful material to the default main page content
18416 * Fix fragment HTML injection
18417
18418 === Changes since 1.5.8 ===
18419
18420 * Fixed obvious mistakes in Finnish (fi) translation
18421 * Fixed obvious mistakes in Kurdish (ku) translation
18422 * Merge two #p-search .pBody statements i monobook/main.css
18423 * (bug 5156) Update for Hebrew language (he) translation
18424 * Add the "UserRights" hook on user group changes; see hooks.txt for more info.
18425 * Translated "listingcontinuesabbrev" for German
18426
18427 === Caveats ===
18428
18429 Some output, particularly involving user-supplied inline HTML, may not
18430 produce 100% valid or well-formed XHTML output. Testers are welcome to
18431 set $wgMimeType = "application/xhtml+xml"; to test for remaining problem
18432 cases, but this is not recommended on live sites. (This must be set for
18433 MathML to display properly in Mozilla.)
18434
18435 = MediaWiki 1.4 =
18436
18437 == MediaWiki 1.4.15 ==
18438
18439 (released March 26, 2006) MediaWiki 1.4.15 is a security maintenance release. A
18440 bug in decoding of certain encoded links could allow injection of raw HTML into
18441 page output; this could potentially lead to XSS attacks. Additionally, this
18442 release may display more correctly in IE7 betas.
18443
18444 == MediaWiki 1.4.14 ==
18445 (released January 19, 2006) MediaWiki 1.4.14 is a security and bugfix
18446 maintenance release. A bug in edit comment formatting could send PHP into an
18447 infinite loop if certain malformed links were included. In most installations,
18448 this would cause the script to fail after PHP's 30-second failsafe timeout. For
18449 several other minor fixes, see the complete changelog at the end of this file.
18450
18451 == MediaWiki 1.4.13 ==
18452 (released January 5, 2006) MediaWiki 1.4.13 is a security maintenance
18453 release.Detection for uploads of Windows Metafile (.wmf) images has been added
18454 to help protect against a client-side vulnerability in unpatched Microsoft
18455 Windows operating systems. Sites which have enabled uploads and added
18456 non-standard file types (such as .ogg, .doc, or .pdf) should upgrade to this
18457 release to ensure that malicious .wmf files can't be uploaded with a fake
18458 extension; such files could put visitors to the site at risk. For more details
18459 on this, see: http://en.wikipedia.org/wiki/Windows_Metafile_vulnerability
18460
18461 == MediaWiki 1.4.12 ==
18462 (released 2005-11-02) MediaWiki 1.4.12 is a bugfix and security maintenance
18463 release. A change in PHP 4.4.1 broke handling of extension and
18464 <nowiki><pre></nowiki> sections, causing garbage data to be inserted in output
18465 and saved edits. This version works around the change. This release includes
18466 further corrections to the inline CSS style sanitation which works around a
18467 JavaScript "feature" on Microsoft Internet Explorer. Users of Microsoft
18468 Internet Explorer for Windows may be vulnerable to XSS injections on prior 1.4
18469 releases; users of standards-compliant browsers are not vulnerable.
18470
18471 == MediaWiki 1.4.11 ==
18472 (released 2005-10-05) MediaWiki 1.4.11 is a security maintenance release.
18473 Unsafe handling of CSS by Microsoft Internet Explorer could be exploited to
18474 produce cross-site scripting attacks by JavaScript injection to clients running
18475 that browser. This release blacklists several additional variants from use in
18476 HTML inline style attributes. All publicly accessible wikis are recommended to
18477 upgrade to reduce the risk to visitors using Microsoft web browsers. Note: the
18478 MediaWiki 1.4.x series is not compatible with PHP 5.0.5 or higher. Upgrade to
18479 the 1.5.0 release if you require this version of PHP 5.
18480
18481 == MediaWiki 1.4.10 ==
18482 (released 2005-09-21) MediaWiki 1.4.10 is a security maintenance release. A bug
18483 in edit submission handling could cause corruption of the previous revision in
18484 the database if an abnormal URL was used, such as those used by some spambots.
18485 Affected releases:
18486 * 1.4.x <= 1.4.9; fixed in 1.4.10
18487 * 1.3.x <= 1.3.15; fixed in 1.3.16
18488 1.5 release candidates are not affected by this problem. All publicly editable
18489 wikis are strongly recommended to upgrade immediately.
18490 1.4 releases can be manually patched by changing this bit in EditPage.php:
18491
18492 <syntaxhighlight lang="php">
18493 function importFormData( &$request ) {
18494 if( $request->wasPosted() ) {
18495 </syntaxhighlight>
18496 to:
18497 <syntaxhighlight lang="php">
18498 function importFormData( &$request ) {
18499 if( $request->getVal( 'action' ) == 'submit' && $request->wasPosted() )
18500 {
18501 </syntaxhighlight>
18502 == MediaWiki 1.4.9 ==
18503 (released 2005-08-29) MediaWiki 1.4.9 is a security maintenance release. It
18504 corrects two cross-site scripting security bugs:
18505 * <nowiki><math></nowiki> tags were handled incorrectly when TeX rendering
18506 support is off, as in the default configuration.
18507 * Extension or <nowiki><nowiki></nowiki> sections in Wiki table syntax could
18508 bypass HTML style attribute restrictions for cross-site scripting attacks
18509 against Microsoft Internet Explorer Wikis where the optional math support has
18510 been *enabled* are not vulnerable to the first, but are vulnerable to the
18511 second.
18512
18513 == MediaWiki 1.4.8 ==
18514 (released 2005-08-23) MediaWiki 1.4.8 is a bug fix and security maintenance
18515 release. A flaw in the interaction between extensions and HTML attribute
18516 sanitization was discovered which could allow unauthorized use of offsite
18517 resources in style sheets, and possible exploitation of a JavaScript injection
18518 feature on Microsoft Internet Explorer. This version expands the returned text
18519 and properly checks it before output. Additionally, an update to
18520 skins/MonoBook.php ensures that sites using the default MonoBook skin will
18521 display correctly in the Internet Explorer 7 beta. (1.3 and 1.5 are not
18522 affected by this bug.)
18523
18524 == MediaWiki 1.4.7 ==
18525 (released 2005-07-16)
18526 MediaWiki 1.4.7 is a bug fix release. Those affected by the following problems
18527 in 1.4.6 should upgrade:
18528 * Watchlist breakage on MySQL 3.23.x and with table prefix enabled
18529 * Possible breakage in watchlist, some image resizing modes on PHP 4.1.2 1.4.6
18530 included a fix for a cross-site scripting vulnerability, so anyone running
18531 older 1.4 releases is very strongly encouraged to upgrade as well. Note to
18532 upgraders: this version of MediaWiki is known to produce a large number of
18533 notice-level warnings under the newly released PHP 4.4.0. These appear however
18534 to be harmless; if you encounter them add this to your LocalSettings.php to
18535 suppress the notices: error_reporting( E_ALL & ~E_NOTICE ); PHP 5.1.0beta3 is
18536 known to be incompatible at this time.
18537
18538 == MediaWiki 1.4.6 ==
18539 (released 2005-07-07) MediaWiki 1.4.6 is a bug fix and security update release.
18540 Incorrect escaping of a parameter in the page move template could
18541 be used to inject JavaScript code by getting a victim to visit a maliciously
18542 constructed URL. Users of vulnerable releases are recommended to upgrade to
18543 this release. Vulnerable versions:
18544 * 1.5 preview series: n <= 1.5beta2 vulnerable, fixed in 1.5beta3
18545 * 1.4 stable series: 1.4beta6 <= n <= 1.4.5 vulnerable, fixed in 1.4.6
18546 * 1.3 legacy series: not vulnerable This release also includes fixes for some
18547 rare bug annoying HTTP errors, a PHP 4.1.2 breakage bug, and works around some
18548 template limitations introduced in 1.4.5. See the changelog at the end of this
18549 file for a detailed list of bugs fixed.
18550
18551 == MediaWiki 1.4.5 ==
18552 (released 2005-06-03) MediaWiki 1.4.5 is a security update and bugfix release.
18553 Incorrect handling of page template inclusions made it possible to inject
18554 JavaScript code into HTML attributes, which could lead to cross-site scripting
18555 attacks on a publicly editable wiki. Vulnerable releases and fix:
18556 * 1.5 prerelease: fixed in 1.5alpha2
18557 * 1.4 stable series: fixed in 1.4.5
18558 * 1.3 legacy series: fixed in 1.3.13
18559 * 1.2 series no longer supported; upgrade to 1.4.5 strongly recommended This
18560 release also includes a number of bug fixes (see changelog below) and merges
18561 some large-server load balancing patches from Wikipedia. An experimental rate
18562 limiter for page edits and moves can be enabled with global, per-IP,
18563 per-subnet, or per-user bases. See configuration options in
18564 includes/DefaultSettings.php
18565
18566 == MediaWiki 1.4.4 ==
18567 (released 2005-05-04) MediaWiki 1.4.4 is a bugfix release for the 1.4 stable
18568 release series. Some bugs in the installer/updater and refreshLinks maintenance
18569 script were introduced in the last release and have been corrected.
18570
18571 == MediaWiki 1.4.3 ==
18572
18573 (released 2005-04-28)
18574
18575 MediaWiki 1.4.3 is a bugfix release for the 1.4 stable release series.
18576
18577 Chiefly, this fixes a compatibility problem with PHP 5 and a minor link
18578 table corruption bug on initial page save.
18579
18580
18581 == MediaWiki 1.4.2 ==
18582
18583 (released 2005-04-20)
18584
18585 MediaWiki 1.4.2 is a security and bug fix release for the 1.4 stable release
18586 series.
18587
18588 A cross-site scripting injection vulnerability was discovered, which
18589 affects only MSIE clients and is only open if MediaWiki has been
18590 manually configured to run output through HTML Tidy ($wgUseTidy).
18591
18592 Several other bugs are fixed in this release, see the changelog below.
18593
18594 All new installations are highly recommended to use 1.4.2 instead of
18595 1.3.x; 1.3.x users should consider upgrading for bug fixes and new
18596 features. Ealier 1.4.x release and beta users should upgrade to this
18597 release for relevant bug fixes; see the changelog later in this file.
18598
18599
18600 If you have trouble, remember to read this whole file and the online FAQ page
18601 before asking for help:
18602
18603 https://www.mediawiki.org/wiki/Manual:FAQ
18604
18605
18606 === READ THIS FIRST: Upgrading ===
18607
18608 If upgrading from an older release, see the notes in the file UPGRADE.
18609 There are a couple of minor database changes from the beta releases,
18610 and somewhat larger changes from 1.3.x.
18611
18612 Upgrading from a previous 1.4.x stable release installation should
18613 generally only require copying the new files over the old ones.
18614
18615
18616 ==== READ THIS FIRST, TOO: MySQL 4.1 AND 5.0 ====
18617
18618 MySQL 5.0 is a beta release, not yet ready for production use. If you
18619 are using it, the notes below about 4.1 apply to you too.
18620
18621 If you have the choice of MySQL 4.0 or MySQL 4.1 and don't need 4.1 for
18622 some other application, you should consider sticking with 4.0 for the
18623 moment. 4.1 may require you to do extra fiddling to get things to work
18624 due to changes that aren't fully backwards-compatible.
18625
18626 MySQL 4.1 has changed the authentication protocol in an incompatible
18627 way; many PHP installations still use the older client libraries and
18628 CANNOT CONNECT TO THE SERVER WITH A PASSWORD without some changes.
18629
18630 See: http://dev.mysql.com/doc/mysql/en/Old_client.html
18631
18632 If MySQL is set with utf-8 as the default character set, installation
18633 may fail with "key too long" errors. Set the default charset to 'latin1'
18634 for installation and it should work.
18635
18636 The mysqldump backup generator now applies an automatic conversion to
18637 UTF-8, which may irretrivably corrupt your data. Pass the -charset option
18638 with the original default charset (eg 'latin1') to skip the conversion.
18639
18640
18641 ==== READ THIS FIRST IF RUNNING ON A WINDOWS SERVER ====
18642
18643 MediaWiki is tested and deployed primarily under the Apache web server
18644 on Linux Unix systems. There are known to be problems running on
18645 Microsoft's IIS which are not fully resolved. If you have a choice,
18646 try running under Apache on Windows, or on a Unix/Linux box instead.
18647
18648 If you're having trouble with blank pages on IIS and can't switch,
18649 try the workaround suggested in this bug report:
18650 http://bugzilla.wikimedia.org/show_bug.cgi?id=1763
18651
18652
18653 === New features ===
18654
18655 * 'Recentchanges Patrol' to mark new edits that haven't yet been viewed.
18656 * New, searchable deletion/upload/protection logs
18657 * Image gallery generation (Special:Newimages and <gallery> tag)
18658 * SVG rasterization support (requires external support tools)
18659 * Users can select from the available localizations to override the
18660 default user interface language.
18661 * Traditional/Simplified Chinese conversion support
18662 * rel="nofollow" support to combat linkspam
18663
18664 The current implementation adds this attribute to _all_ external URL
18665 links in wiki text (but not internal [[wiki links]] or interwiki links).
18666 To disable the attribute for _all_ external links, add this line to your
18667 LocalSettings.php:
18668
18669 $wgNoFollowLinks = false
18670
18671 For background information on nofollow see:
18672
18673 http://www.google.com/googleblog/2005/01/preventing-comment-spam.html
18674
18675
18676 === Installation and compatibility ===
18677
18678 * The default MonoBook theme now works with PHP 5.0
18679 * Installation on systems with PHP's safe mode or other oddities
18680 should work more reliably, as MonoBook no longer needs to
18681 create a compiled template file for the wiki to run.
18682 * A table prefix may be specified, to avoid conflicts with other
18683 web applications forced to share a database.
18684 * More thorough UTF-8 input validation; fixes non-ASCII uploaded
18685 filenames from Safari.
18686 * Command-line database upgrade script.
18687
18688
18689 === Customizability ===
18690
18691 * Default user options can now be overridden in LocalSettings.
18692 * Skins system more modular: templates and CSS are now in /skins/
18693 New skins can be dropped into this directory and used immediately.
18694 * More extension hooks have been added.
18695 * Authentication plugin hook.
18696 * More internal code documentation, generated with phpdoc:
18697 https://doc.wikimedia.org/mediawiki-core/master/php/html/
18698
18699
18700 === Optimization ===
18701
18702 * For many operations, MediaWiki 1.4 should run faster and use
18703 less memory than MediaWiki 1.3. Page rendering is up to twice
18704 as fast. (Use a PHP accelerator such as Turck MMCache for best
18705 results with any PHP application, though!)
18706 * The parser cache no longer requires memcached, and is enabled
18707 by default. This avoids a lot of re-rendering of pages that
18708 have been shown recently, greatly speeding longer page views.
18709 * Support for compiled PHP modules to speed up page diff and
18710 Unicode validation/normalization. (Requires ability to compile
18711 and load PHP extensions).
18712
18713
18714 === What isn't ready yet ===
18715
18716 * A new user/groups permissions scheme has been held back to 1.5.
18717 * An experimental SOAP interface will be made available as an extension
18718 * PostgreSQL support is largely working, minus search and the installer.
18719 You can perform a manual installation.
18720 * E-mail notification of watched page changes and verification of
18721 user-submitted e-mail addresses is not yet included.
18722 * Log pages are not automatically imported into the new log table
18723 at upgrade time. A script to import old text log entries is
18724 incomplete, but may be available in later point releases.
18725 * Some localizations are still incomplete.
18726
18727
18728
18729 == Changelog ==
18730
18731 === Important security updates ===
18732
18733 A security audit found and fixed a number of problems. Users of MediaWiki
18734 1.3.10 and earlier should upgrade to 1.3.11; users of 1.4 beta releases
18735 prior to 1.4rc1 should upgrade immediately.
18736
18737 ==== Cross-site scripting vulnerability ====
18738
18739 XSS injection points can be used to hijack session and authentication
18740 cookies as well as more serious attacks.
18741
18742 * Media: links output raw text into an attribute value, potentially
18743 abusable for JavaScript injection. This has been corrected.
18744 * Additional checks added to file upload to protect against MSIE and
18745 Safari MIME-type autodetection bugs.
18746
18747 As of 1.3.10/1.4beta6, per-user customized CSS and JavaScript is disabled
18748 by default as a general precaution. Sites which want this ability may set
18749 $wgAllowUserCss and $wgAllowUserJs in LocalSettings.php.
18750
18751
18752 ==== Cross-site request forgery ====
18753
18754 An attacker could use JavaScript-submitted forms to perform various
18755 restricted actions by tricking an authenticated user into visiting
18756 a malicious web page. A fix for page editing in 1.3.10/1.4beta6 has
18757 been expanded in this release to other forms and functions.
18758
18759 Authors of bot tools may need to update their code to include the
18760 additional fields.
18761
18762
18763 ==== Directory traversal ====
18764
18765 An unchecked parameter in image deletion could allow an authenticated
18766 administrator to delete arbitary files in directories writable by the
18767 web server, and confirm existence of files not deletable.
18768
18769
18770 ==== Older issues ====
18771
18772 Note that 1.4 beta releases prior to beta 5 include an input validation
18773 error which could lead to execution of arbitrary PHP code on the server.
18774 Users of older betas should upgrade immediately to the current version.
18775
18776
18777 Beta 6 also introduces the use of rel="nofollow" attributes on external
18778 links in wiki pages to reduce the effectiveness of wiki spam. This will
18779 cause participating search engines to ignore external URL links from wiki
18780 pages for purposes of page relevancy ranking.
18781
18782
18783 === Misc bugs fixed in beta 1 ===
18784
18785 * (bug 95) Templates no longer limited to 5 inclusions per page
18786 * New user preference for limiting the image size for images on image description
18787 pages
18788 * (bug 530) Allow user to preview article on first edit
18789 * (bug 479) [[RFC 1234]] will now make an internal link
18790 * (bug 511) PhpTal skins shown bogus 'What links here' etc on special pages
18791 * (bug 770) Adding filter and username exact search match for Special:Listusers
18792 * (bug 733) Installer die if it can not write LocalSettings.php
18793 * (bug 705) Various special pages no more show the rss/atom feed links
18794 * (bug 114) use category backlinks in Special:Recentchangeslinked
18795
18796 === Beta 2 fixes ===
18797
18798 * (bug 987) Reverted bogus fix for bug 502
18799 * (bug 992) Fix enhanced recent changes in PHP5
18800 * (bug 1009) Fix Special:Makesysop when using table prefixes
18801 * (bug 1010) fix broken Commons image link on Classic & Cologne Blue
18802 * (bug 985) Fix auto-summary for section edits
18803 * (bug 995) Close <a> tag
18804 * (bug 1004) renamed norsk language links (twice)
18805 * Login works again when using an old-style default skin
18806 * Fix for load balancing mode, notify if using old settings format
18807 * (bug 1014) Missing image size option on old accounts handled gracefully
18808 * (bug 1027) Fix page moves with table prefix
18809 * (bug 1018) Some pages fail with stub threshold enabled
18810 * (bug 1024) Fix link to high-res image version on Image: pages
18811 * (bug 1016) Fix handling of lines omitting Image: in a <gallery> tag
18812 * security fix for image galleries
18813 * (bug 1039) Avoid error message in certain message cache failure modes
18814 * Fix string escaping with PostgreSQL
18815 * (bug 1015) [partial] -- use comment formatter on image gallery text
18816 * Allow customization of all UI languages
18817 * use $wgForceUIMsgAsContentMsg to make regular UI messages act as content
18818 * new user option for zh users to disable language conversion
18819 * Defer message cache initialization, shaving a few ms off file cache hits
18820 * Fixed Special:Allmessages when using table prefixes
18821 * (bug 996) Fix $wgWhitelistRead to work again
18822 * (bug 1028) fix page move over redirect to not fail on the unique index
18823
18824 === Beta 3 fixes ===
18825
18826 * Hide RC patrol markers when patrol is disabled or not allowed to patrol.
18827 * Fix language selection for upgraded accounts
18828 * (bug 1076) navigation links in QueryPage should be translated by wgContLang.
18829 * (bug 922) bogus DOS line endings in LanguageEl.php
18830 * Fix index usage in contribs
18831 * Caching and load limiting options for Recentchanges RSS/Atom feed
18832 * (bug 1074) Add stock icons for non-image files in gallery/Newimages
18833 * Add width and height attributes on thumbs in gallery/Newimages
18834 * Enhance upload extension blacklist to protect against vulnerable
18835 Apache configurations
18836
18837 === Beta 4 fixes ===
18838
18839 * (bug 1090) Fix sitesupport links in CB/classic skins
18840 * Gracefully ignore non-legal titles in a <gallery>
18841 * Fix message page caching behavior when $wgCapitalLinks is turned off
18842 after installation and the wiki is subsequently upgraded
18843 * Database error messages include the database server name/address
18844 * Paging support for large categories
18845 * Fix image page scaling when thumbnail generation is disabled
18846 * Select the content language in prefs when bogus interface language is set
18847 * Fix interwiki links in edit comments
18848 * Fix crash on banned user visit
18849 * Avoid PHP warning messages when thumbnail not generated
18850 * (bug 1157) List unblocks correctly in Special:Log
18851 * Fix fatal errors in LanguageLi.php
18852 * Undo overly bright, difficult to read colors in Cologne Blue
18853 * (bug 1162) fix five-tilde date inserter
18854 * Add raw signatures option for those who simply must have cute sigs
18855 * (bug 1164) Let wikitext be used in Loginprompt and Loginend messages
18856 * Add the dreaded <span> to the HTML whitelist
18857 * (bug 1170) Fix Russian linktrail
18858 * (bug 1168) Missing text on the bureaucrat log
18859 * (bug 1180) Fix Makesysop on shared-user-table sites
18860 * (bug 1178) Fix previous diff link when using 'oldid=0'
18861 * (bug 1173) Stop blocked accounts from reverting/deleting images
18862 * Keep generated stylesheets cache-separated for each user
18863 * (bug 1175) Fix "preview on first edit" mode
18864 * Fix revert bug caused by bug 1175 fix
18865 * Fix CSS classes on minor, new, unpatrolled markers in enhanced RC
18866 * Set MySQL 4 boolean search back to 'and' mode by default
18867 * (bug 1193) Fix move-only page protection mode
18868 * Fix zhtable Makefile to include the traditional manual table
18869 * Add memcache timeout for the zh conversion tables
18870 * Allow user customization of the zh conversion tables through
18871 Mediawiki:zhconversiontable
18872 * Add zh-min-man (back) to language names list
18873 * Ported $wgCopyrightIcon setting from REL1_3A
18874 * (bug 1218) Show the original image on image pages if the thumbnail would be
18875 bigger than the original image
18876 * (bug 1213) i18n of Special:Log labels
18877 * (bug 1013) Fix jbo, minnan in language names list
18878 * Added magic word MAG_NOTITLECONVERT to indicate that the title of the page
18879 do not need to be converted. Useful in zh:
18880 * (bug 1224) Use proper date messages for date reformatter
18881 * (bug 1241) Don't show 'cont.' for first entry of the category list
18882 * (bug 1240) Special:Preferences was broken in Slovenian locale when
18883 $wgUseDynamicDates is enabled
18884 * Added magic word MAG_NOCONTENTCONVERT to suppress the conversion of the
18885 content of an article. Useful in zh:
18886 * write-lock for updating the zh conversion tables in memcache
18887 * recursively parse subpages of MediaWiki:Zhconversiontable
18888 * (bug 1144) Fix export for fy language
18889 * make removal of an entry from zhconversiontable work
18890 * (bug 752) Don't insert newline in link title for url with %0a
18891 * Fix missing search box contents in MonoBook skin
18892 * Add option to forward search directly to an external URL (eg google)
18893 * Correctly highlight the fallback language variant when the selected
18894 variant is disabled. Used in zh: only for now.
18895
18896 === Beta 5 fixes ===
18897
18898 * (bug 1124) Fix ImageGallery XHTML compliance
18899 * (bug 1186) news: in the middle of a word
18900 * (bug 1283) Use underlining and borders to highlight additions/deletions
18901 in diff-view
18902 * Use user's local timezone in Special:Log display
18903 * Show filename for images in gallery by default (restore beta 3 behavior)
18904 * (bug 1201) Double-escaping in brokenlinks, imagelinks, categorylinks, searchindex
18905 * When using squid reverse proxy, cache the redirect to the Main_Page
18906 * (bug 1302) Fix Norwegian language file
18907 * (bug 1205) Fix broken article saving in PHP 5.1
18908 * (bug 1206) Implement CURRENTWEEK and CURRENTDOW magic keyword (will give
18909 number of the week and number of the day).
18910 * (bug 1204) Blocks do not expire automatically
18911 * (bug 1184) expiry time of indefinite blocks shown as the current time
18912 * (bug 1317) Fix external links in image captions
18913 * (bug 1084) Fix logo not rendering centrally in IE
18914 * (bug 288) Fix tabs wrapping in IE6
18915 * (bug 119) Fix full-width tabs with RTL text in IE
18916 * (bug 1323) Fix logo rendering off-screen in IE with RTL language
18917 * Show "block" link in Special:Recentchanges for logged in users, too, if
18918 wgUserSysopBans is true.
18919 * (bug 1326) Use content language for '1movedto2' in edit history
18920 * zh: Fix warning when HTTP_ACCEPT_LANGUAGE is not set
18921 * zh: Fix double conversion for zh-sg and zh-hk
18922 * (bug 1132) Fix concatenation of link lists in refreshLinks
18923 * (bug 1101) Fix memory leak in refreshLinks
18924 * (bug 1339) Fix order of @imports in Cologne Blue CSS
18925 * Don't try to create links without namespaces ([[Category:]] link bug)
18926 * Memcached data compression fixes
18927 * Several valid XHTML fixes
18928 * (bug 624) Fix IE freezing rendering whilst waiting for CSS with MonoBook
18929 * (bug 211) Fix tabbed preferences with XHTML MIME type
18930 * Fix for script execution vulnerability.
18931
18932 === Beta 6 fixes ===
18933
18934 * (bug 1335) implement 'tooltip-watch' in Language.php
18935 * Fix linktrail for nn: language
18936 * (bug 1214) Fix prev/next links in Special:Log
18937 * (bug 1354) Fix linktrail for fo: language
18938 * (bug 512) Reload generated CSS on preference change
18939 * (bug 63) Fix displaying as if logged in after logout
18940 * Set default MediaWiki:Sitenotice to '-', avoiding extra database hits
18941 * Skip message cache initialization on raw page view (quick hack)
18942 * Fix notice errors in wfDebugDieBacktrace() in XML callbacks
18943 * Suppress notice error on bogus timestamp input (returns epoch as before)
18944 * Remove unnecessary initialization and double-caching of parser variables
18945 * Call-tree output mode for profiling
18946 * (bug 730) configurable $wgRCMaxAge; don't try to update purged RC entries
18947 * Add $wgNoFollowLinks option to add rel="nofollow" on external links
18948 (on by default)
18949 * (bug 1130) Show actual title when moving page instead of encoded one.
18950 * (bug 925) Fix headings containing <math>
18951 * (bug 1131) Fix headings containing interwiki links
18952 * (bug 1380) Update Nynorsk language file
18953 * (bug 1232) Fix sorting of cached Special:Wantedpages in miser mode
18954 * (bug 1217) Image within an image caption broke rendering
18955 * (bug 1384) Make patrol signs have the same width for page moves as for edits
18956 * (bug 1364) fix "clean up whitespace" in Title:SecureAndSplit
18957 * (bug 1389) i18n for proxyblocker message
18958 * Add fur/Furlan/Friulian to language names list
18959 * Add TitleMoveComplete hook on page renames
18960 * Allow simple comments for each translation rules in MW:Zhconversiontable
18961 * (bug 1402) Make link color of tab subject page link on talk page indicate whether article exists
18962 * (bug 1368) Fix SQL error on stopword/short word search w/ MySQL 3.x
18963 * Translated Hebrew namespace names
18964 * (bug 1429) Stop double-escaping of block comments; fix formatting
18965 * (bug 829) Fix URL-escaping on block success
18966 * (bug 1228) Fix double-escaping on &amp; sequences in [enclosed] URLs
18967 * (bug 1435) Fixed many CSS errors
18968 * (bug 1457) Fix XHTML validation on category column list
18969 * (bug 1458) Don't save if edit form submission is incomplete
18970 * Logged-in edits and preview of user CSS/JS are now locked to a session token.
18971 * Per-user CSS and JavaScript subpage customizations now disabled by default.
18972 They can be re-enabled via $wgAllowUserJs and $wgAllowUserCss.
18973 * Removed .ogg from the default uploads whitelist as an extra precaution.
18974 If your web server is configured to serve Ogg files with the correct
18975 Content-Type header, you can re-add it in LocalSettings.php:
18976 $wgFileExtensions[] = 'ogg';
18977
18978 === RC1 fixes ===
18979
18980 * Fix notice error on nonexistent template in wikitext system message
18981 * (bug 1469) add missing <ul> tags on Special:Log
18982 * (bug 1470) remove extra <ul> tags from Danish log messages
18983 * Fix notice on purge w/ squid mode off
18984 * (bug 1477) hide details of SQL error messages by default
18985 Set $wgShowSQLErrors = true for debugging.
18986 * (bug 1430) Don't check for template data when editing page that doesn't exist
18987 * Recentchanges table purging fixed when using table prefix
18988 * (bug 1431) Avoid redundant objectcache garbage collection
18989 * (bug 1474) Switch to better-cached index for statistics page count
18990 * Run Unicode normalization on all input fields
18991 * Fix translation for allpagesformtext2 in LanguageZh_cn and LanguageZh_tw
18992 * Block image revert without valid login
18993 * (bug 1446) stub Bambara (bm) language file using French messages
18994 * (bug 1432) Update Estonian localization
18995 * (bug 1471) unclosed <p> tag in Danish messages
18996 * convertLinks script fixes
18997 * Corrections to template loop detection
18998 * XHTML encoding fix for usernames containing & in Special:Emailuser
18999 * (for zh) Search for variant links even when conversion is turned off,
19000 to help prevent duplicate articles.
19001 * Disallow ISO 8859-1 C1 characters and "no-break space" in user names
19002 on Latin-1 wikis.
19003 * Correct the name of the main page it LanguageIt
19004 * Allow Special:Makesysop to work for usernames containing SQL special
19005 characters.
19006 * Fix annoying blue line in Safari on scaled-down images on description page
19007 * Increase upload sanity checks
19008 * Fix XSS bug in Media: links
19009 * Add cross-site form submission protection to various actions
19010 * Fix fatal error on some dubious page titles
19011 * Stub threshold displays correctly again
19012
19013
19014 === 1.4.0 final fixes ===
19015
19016 * (bug 65) Fix broken interwiki link encoding on Latin-1 wikis; force to UTF-8
19017 * (bug 563) Fix UTF-8 interwiki URL redirects via Latin-1 wikis
19018 * (bug 1536) Fix page info
19019 * Support os (Ossetic) as language code, using Russian localization base
19020 * (bug 1610) Support non (Old Norse) as language code, using Icelandic localization base
19021 * (bug 1618) Properly list custom namespaces in Special:Allpages
19022 * (bug 1622) Remove trailing' >' when using category browser
19023 * (bug 1570) Fix php 4.2.x error on conflict merging
19024 * (bug 1585) Fix page title on post-login redirection page
19025 * Run UTF-8 validation on old text in Recentchanges RSS diffs
19026 * (bug 1642) fix a mime type typo in img_auth.php
19027 * Automated interwiki redirects only for local interwikis
19028 * Respect read-only mode on block removals
19029 * Trim old illegal characters from syndication feeds
19030 * Reduce message cache outage recovery delay from 1 day to 5 minutes
19031 * (bug 1403) Update Finnish localization
19032 * (bug 1478) Punjabi localization
19033 * (bug 1667) Update script 5 second countdown.
19034 * (bug 1057) Fix logging table encoding (error on MySQL 4.1)
19035 * (bug 1680) Fix linktrail for fo
19036 * (bug 1653) Removing hardcoded messages in Special:Allmessages
19037 * (bug 1594) Render a hyphen in a formula as &minus; in HTML
19038 * (bug 1495) Fall back to default language MediaWiki: for custom messages
19039 * (bug 1617) Show different error messages for "user does not
19040 exist" and "wrong password" when using AuthPlugin
19041 * (bug 1532), (bug 1544) Changed language names for
19042 'bn', 'bo', 'dv', 'dz', 'ht', 'ii', 'li', 'lo', 'ng', 'or', 'pa', 'si',
19043 'ti', 've'
19044 * Fix editing on non-Esperanto wiki with user language pref set to Esperanto
19045 * Make conversion table for zh-sg default to zh-cn, and zh-hk default to zh-tw
19046 * Fix PHP notice in MonoBook when counters disabled
19047 * (bug 1696) Update namespaces, dates in uk localization
19048 * (bug 551) Installer warns about magic_quotes_runtime and magic_quotes_sybase
19049 instead of trying to install with corrupt table files
19050 * Installer no longer tries to move non-default MediaWiki: pages into Template:
19051 * User-to-user email disabled by default ($wgEnableUserEmail)
19052
19053
19054 === 1.4.1 fixes ===
19055
19056 * (bug 1720) fix genitive month names for uk
19057 * (bug 1704) fixed untranslateable string in Special:Log
19058 * (bug 1638) Added Belrusian language file
19059 * (bug 1736) typo in SpecialValidate.php
19060 * (bug 73) Upload doesn't run edit updates on description page (links,
19061 search index and categories)
19062 * (bug 646) <math> fails to recognize \ll and \gg
19063 * (bug 926) \div element from TeX not supported in <math> element
19064 * (bug 1147) add \checkmark to whitelist in texutil.ml
19065 * (bug 937) \limits function from LaTeX not supported in <math> element
19066 * Support for manually converting article title to different Chinese
19067 variants (for zh)
19068 * (bug 1488, bug 1744) Fix encoding for preferences, dates in Latin-1 mode
19069 * (bug 1042) Fix UTF-8 case conversion for PHP <4.3 with mbstring extension
19070 * Fix code typo that broke article credits display
19071 * Installation fixes for running under IIS
19072 * (bug 1556) login page tab order. "remember" checkbox now come after password.
19073 * SQL debug log fixlets
19074 * (bug 1815) Fix namespace in old revision display with mismatched title
19075 * (bug 1788) Fix link duplication when edit/upload comment includes newlines
19076 * Change default on $wgSysopUserBans and $wgSysopRangeBans to true
19077 * Fix link conversion for URL request
19078 * (bug 1851) Updated download URL for the SCIM packages used by zhtable
19079 * (bug 1853) Try stripping quotes from term for 'go' title match
19080 * Fix missing function in Latin1 mode
19081 * (bug 1860) Anchors of interwiki links did not get normalized
19082 * (bug 1847) accept lowercase x in ISBN, do not accept invalid A-W,Y,Z
19083 * Fix link conversion for URL request, hopefully without breaking the wiki
19084 * (bug 1849) New option allows to consider categorized images as used on
19085 Special:Unusedimages
19086 * Localized category namespace for ka (Georgian)
19087 * (bug 1107) Work around includes problem in installer when parent dir is not
19088 readable by the web server
19089 * (bug 1927) Incorrect escaping on wikitext message in Blockip
19090
19091
19092 === 1.4.2 fixes ===
19093
19094 * Fix math options in Finnish localization
19095 * Use in-process Tidy extension if available when $wgUseTidy is on
19096 * (bug 1933) Fix PATH_INFO usage under IIS with PHP ISAPI module
19097 * (bug 1188) <nowiki> in {{subst:}} includes fixed
19098 * (bug 1936) <!-- comments --> in {{subst:}} includes fixed
19099 * Fix a potential MSIE JavaScript injection vector in Tidy mode
19100
19101
19102 === 1.4.3 fixes ===
19103
19104 * (bug 1636) Refs like &#0355; were misinterpreted as octal in some places
19105 * (bug 1163) Special:Undelete showed oldest revision instead of newest
19106 * (bug 1938) Fix escaping of illegal character references in link text
19107 * (bug 1997) Fix for error on display of renamed items in Recentchanges on PHP5
19108 * (bug 1949) Profiling typo in rare error case
19109 * (bug 1963) Fix deletion log link when $wgCapitalLinks is off
19110 * (bug 1970) Don't show move tab for immobile pages
19111 * (bug 1770) Page creation recorded links from the 'newarticletext' message
19112 * Optional change to the site_stats table. When applied, this removes the need
19113 for expensive queries in Special:Statistics.
19114
19115
19116 === 1.4.4 fixes ===
19117
19118 * (bug 725) Let dir="ltr" attribute work again in MonoBook on RTL languages
19119 * (bug 2024) Skip JavaScript error for custom skins where .js message not set
19120 * (bug 2025) Updated Indonesian localization
19121 * (bug 2039) Updated Lithuanian localization
19122
19123
19124 === Caveats ===
19125
19126 Some output, particularly involving user-supplied inline HTML, may not
19127 produce 100% valid or well-formed XHTML output. Testers are welcome to
19128 set $wgMimeType = "application/xhtml+xml"; to test for remaining problem
19129 cases, but this is not recommended on live sites. (This must be set for
19130 MathML to display properly in Mozilla.)
19131
19132
19133 For notes on 1.3.x and older releases, see HISTORY.
19134
19135
19136 === Online documentation ===
19137
19138 Documentation for both end-users and site administrators is currently being
19139 built up on MediaWiki.org, and is covered under the GNU Free Documentation
19140 License:
19141
19142 https://www.mediawiki.org/
19143
19144
19145 === Mailing list ===
19146
19147 A MediaWiki-l mailing list has been set up distinct from the Wikipedia
19148 wikitech-l list:
19149
19150 http://lists.wikimedia.org/mailman/listinfo/mediawiki-l
19151
19152 A low-traffic announcements-only list is also available:
19153 http://lists.wikimedia.org/mailman/listinfo/mediawiki-announce
19154
19155 It's highly recommended that you sign up for one of these lists if you're
19156 going to run a public MediaWiki, so you can be notified of security fixes.
19157
19158
19159 === IRC help ===
19160
19161 There's usually someone online in #mediawiki on irc.freenode.net
19162
19163 =MediaWiki 1.3=
19164
19165 == MediaWiki 1.3.18 ==
19166 (released 2005-11-02)
19167 MediaWiki 1.3.18 is a bugfix and security maintenance release. A change in PHP
19168 4.4.1 broke handling of extension and <nowiki><pre></nowiki> sections, causing
19169 garbage data to be inserted in output and saved edits. This version works
19170 around the change. This release includes further corrections to the inline CSS
19171 style sanitation which works around a JavaScript "feature" on Microsoft
19172 Internet Explorer. Users of Microsoft Internet Explorer for Windows may be
19173 vulnerable to XSS injections on prior 1.3 releases; users of
19174 standards-compliant browsers are not vulnerable.
19175
19176 == MediaWiki 1.3.17 ==
19177 (released 2005-10-05)
19178 MediaWiki 1.3.17 is a security maintenance release. Unsafe handling of CSS by
19179 Microsoft Internet Explorer could be exploited to produce cross-site scripting
19180 attacks by JavaScript injection to clients running that browser. This release
19181 blacklists several additional variants from use in HTML inline style
19182 attributes. All publicly accessible wikis are recommended to upgrade to reduce
19183 the risk to visitors using Microsoft web browsers.Note: the MediaWiki 1.3.x
19184 series is not compatible with PHP 5.0.5 or higher. Upgrade to the 1.5.0 release
19185 if you require this version of PHP 5.
19186
19187 == MediaWiki 1.3.16 ==
19188 (released 2005-09-21)
19189 MediaWiki 1.3.16 is a security maintenance release. A bug in edit submission
19190 handling could cause corruption of the previous revision in the database if an
19191 abnormal URL was used, such as those used by some spambots. Affected releases:
19192 * 1.4.x <= 1.4.9; fixed in 1.4.10
19193 * 1.3.x <= 1.3.15; fixed in 1.3.16
19194 1.5 release candidates are not affected by this problem. All publicly editable
19195 wikis are strongly recommended to upgrade immediately.
19196 1.3 releases can be manually patched by changing this bit in
19197 {{manual|EditPage.php}}:
19198 <syntaxhighlight lang="php">
19199 if( $this->tokenOk( $request ) ) {
19200 $this->save = $request->wasPosted() && !$this->preview;
19201 } else {
19202 </syntaxhighlight>
19203 to:
19204 <syntaxhighlight lang="php">
19205 if( $this->tokenOk( $request ) ) {
19206 $this->save = $request->getVal( 'action' ) == 'submit' &&
19207 $request->wasPosted() && !$this->preview;
19208 } else {
19209 </syntaxhighlight>
19210
19211 == MediaWiki 1.3.15, 2005-08-29 ==
19212 MediaWiki 1.3.15 is a security maintenance release. It corrects across-site
19213 scripting security bug:
19214 * <nowiki><math></nowiki> tags were handled incorrectly when TeX rendering
19215 support is off, as in the default configuration. Wikis where the optional math
19216 support has been *enabled* are not vulnerable. The 1.3.x series is no longer
19217 maintained except for security fixes; new users and those seeking bug fixes
19218 should upgrade to 1.4.9 or 1.5.0.
19219
19220 == MediaWiki 1.3.14, 2005-08-23 ==
19221 MediaWiki 1.3.14 is a security maintenance release. A flaw in the interaction
19222 between extensions and HTML attribute sanitization was discovered which could
19223 allow unauthorized use of offsite resources in style sheets, and possible
19224 exploitation of a JavaScript injection feature on Microsoft Internet Explorer.
19225 The 1.3.x series is no longer maintained except for security fixes; new users
19226 and those seeking bug fixes should upgrade to 1.4.8 or 1.5.0. Existing 1.3.x
19227 installations not willing to upgrade to the current stable release should apply
19228 the change manually:
19229 In includes/Parser.php, function {{code|inline=y|lang=php|fixTagAttributes()}}
19230 add:
19231 <syntaxhighlight lang="php">
19232 # Any placeholder items should have been unstripped already before
19233 # we got to this point. Raw text inserted later could be dangerous.
19234 if( strpos( $t, UNIQ_PREFIX ) !== false ) {
19235 wfDebug( "Parser::fixTagAttributes found stripped data placeholder;
19236 dropping attributes\n" );
19237 $t = '';
19238 }
19239 </syntaxhighlight>
19240 If you are actively using extensions to generate HTML attribute values, upgrade
19241 to 1.4 or 1.5 for a more thorough fix.
19242
19243 == MediaWiki 1.3.13, 2005-06-03 ==
19244 MediaWiki 1.3.13 is a security maintenance release. Incorrect handling of page
19245 template inclusions made it possible to inject JavaScript code into HTML
19246 attributes, which could lead to cross-site scripting attacks on a publicly
19247 editable wiki. Vulnerable releases and fix:
19248 * 1.5 prerelease: fixed in 1.5alpha2
19249 * 1.4 stable series: fixed in 1.4.5
19250 * 1.3 legacy series: fixed in 1.3.13
19251 * 1.2 series no longer supported; upgrade to 1.4.5 strongly recommended The
19252 1.3.x series is no longer maintained except for security fixes; new users and
19253 those seeking general bug fixes should install 1.4.5. Existing 1.3.x
19254 installations not willing or able to upgrade to the current stable relase
19255 should update the installation to 1.3.13; only includes/Parser.php has changed
19256 from 1.3.12.
19257
19258 == MediaWiki 1.3.12, 2005-02-20 ==
19259 MediaWiki 1.3.12 is a security maintenance release. A cross-site scripting
19260 injection vulnerability was discovered, which affects only MSIE clients and is
19261 only open if MediaWiki has been manually configured to run output through HTML
19262 Tidy ($wgUseTidy). The 1.3.x series is no longer maintained except for security
19263 fixes; new users and those seeking bug fixes should upgrade to 1.4.2. Existing
19264 1.3.x installations using Tidy not willing to upgrade to the current stable
19265 relase should either turn off Tidy or update the installation to 1.3.12.
19266
19267 == MediaWiki 1.3.11, 2005-02-20 ==
19268 MediaWiki 1.3.11 is a security release.
19269 A security audit found and fixed a number of problems. Users of MediaWiki
19270 1.3.10 and earlier should upgrade to 1.3.11; users of 1.4 beta releases should
19271 upgrade to 1.4rc1.
19272
19273 === Cross-site scripting vulnerability ===
19274 XSS injection points can be used to hijack session and authentication cookies
19275 as well as more serious attacks.
19276 * Media: links output raw text into an attribute value, potentially abusable
19277 for JavaScript injection. This has been corrected.
19278 * Additional checks added to file upload to protect against MSIE and Safari
19279 MIME-type autodetection bugs.
19280 As of <code>1.3.10/1.4beta6</code>, per-user customized CSS and JavaScript is
19281 disabled by default as a general precaution. Sites which want this ability may
19282 set {{wg|AllowUserCss}} and {{wg|AllowUserJs}} in LocalSettings.php.
19283
19284 === Cross-site request forgery ===
19285 An attacker could use JavaScript-submitted forms to perform various restricted
19286 actions by tricking an authenticated user into visiting a malicious web page. A
19287 fix for page editing in 1.3.10/1.4beta6 has been expanded in this release to
19288 other forms and functions. Authors of bot tools may need to update their code
19289 to include the additional fields.
19290
19291 === Directory traversal ===
19292 An unchecked parameter in image deletion could allow an authenticated
19293 administrator to delete arbitary files in directories writable by the web
19294 server, and confirm existence of files not deletable.
19295
19296 == MediaWiki 1.3.10, 2005-02-03 ==
19297 MediaWiki 1.3.10 is a security release.
19298 An attacker could craft a URL which, when visited by a particular logged-in
19299 user, would execute arbitrary JavaScript code on the user's browser in the
19300 wiki's site context. This attack has been blocked, and as an extra precaution
19301 the user CSS and JavaScript subpage support is now disabled by default. Sites
19302 which want this ability may set {{wg|AllowUserCss}} and {{wg|AllowUserJs}} in
19303 {{manual|LocalSettings.php}}. Additional protections have been added against
19304 off-site form submissions
19305 hijacking user credentials. Authors of bot tools may need to update their code
19306 to include additional fields. All wikis running 1.3.x are strongly urged to
19307 upgrade to 1.3.10.
19308 Changes from 1.3.9:
19309 * Logged-in edits and preview of user CSS/JS are now locked to a session token.
19310 * Per-user CSS and JavaScript subpage customizations now disabled by default.
19311 They can be re-enabled via {{wg|AllowUserJs}} and {{wg|AllowUserCss}}.
19312 * Removed .ogg from the default uploads whitelist as an extra precaution. If
19313 your web server is configured to serve Ogg files with the correct Content-Type
19314 header, you can re-add it in LocalSettings.php: {{wg|FileExtensions}}<code>[] =
19315 'ogg'</code>
19316
19317 == MediaWiki 1.3.9, 2004-12-12 ==
19318 MediaWiki 1.3.9 is a security and bug fix release.
19319 A flaw in upload handling has been found which may allow upload and execution
19320 of arbitrary scripts with the permissions of the web server. Only wikis that
19321 have enabled uploads and have a vulnerable Apache configuration will be
19322 affected, but to be safe all wikis should upgrade. Wikis with uploads available
19323 should either disable uploads or upgrade to 1.3.9 immediately; if other files
19324 are customized and require merging changes,
19325 includes/{{manual|SpecialUpload.php}} may be replaced individually to add the
19326 fix. (It is also recommended to configure your web server to disable script
19327 execution in the 'images' subdirectory where uploads are placed, which prevents
19328 most attacks even if the wiki fails.)
19329 Changes from 1.3.8:
19330 * Backported "Templates used in this page"-feature of EditPage
19331 * Allow "MySkin" as a default skin.
19332 * ({{bugzilla|938}}) Parse namespaces correctly on self-interwiki links
19333 * ({{bugzilla|1010}}) fix broken Commons image link on [[Skin:Classic|Classic]]
19334 & [[Skin:Cologne Blue|Cologne Blue]]
19335 * ({{bugzilla|1004}}) Norsk language names for interwiki links changed, Nauruan
19336 language name changed
19337 * Enhance upload extension blacklist to protect against vulnerable Apache
19338 configurations
19339
19340 == MediaWiki 1.3.8, 2004-11-15 ==
19341 MediaWiki 1.3.8 is a bugfix release. Those running wikis with uploads enabled
19342 are strongly recommended to upgrade as this fixes several problems with
19343 overwriting previously-uploaded files.
19344 Changes from 1.3.7:
19345 * ({{bugzilla|506}}) fix {{code|inline=y|lang=html|array_key_exists()}} warning
19346 for IIS servers using ISAPI mode
19347 * ({{bugzilla|718}}) fix bad charset in (file) cached pages
19348 * use local numerals in category page (for Hindi et al)
19349 * alias month abbreviations to month names in Hindi
19350 * add localized numerals for Gujarati and Kannada
19351 * fix Category and project namespaces for Hindi
19352 * Don't output bogus timestamp on [[Special:RecentChanges]] if no entries
19353 * Correct template include path which broke some but not all Windows installs
19354 * Fix edit form submission problem with some PHP versions
19355 * Disallow unreachable titles with %XX hex codes
19356 * Allow page [[0]] to be renamed
19357 * ({{bugzilla|774}}) when saving with <code>section=new</code>, return to the
19358 anchor as with existing numbered section edits
19359 * Experimental shared upload overlay area (disabled by default)
19360 * ({{bugzilla|806}}) Removed some "Wikipedia" hardcoding in German localization
19361 * User option localization fix for some extensions
19362 * ({{bugzilla|809}}) now try to load the mysql php extension if it isn't loaded
19363 * ({{bugzilla|848}}) fix error message in [[Special:Newpages]] RSS and Atom
19364 feeds
19365 * ({{bugzilla|26}}) fix cache headers on anon talk page notification
19366 * ({{bugzilla|874}}) added 'cgi' to {{wg|FileBlacklist}}
19367 * ({{bugzilla|862}}) localize date and time format for Finnish
19368 * ({{bugzilla|548}}) Don't overwrite images until the user confirms it
19369
19370 == MediaWiki 1.3.7, 2004-10-18 ==
19371 Changes from 1.3.6:
19372 * Fix protected-page related security issue.
19373
19374 == MediaWiki 1.3.6, 2004-10-14 ==
19375 Changes from 1.3.5:
19376 * ({{bugzilla|296}}) Variables in user interface messages are no longer
19377 substituted at install time, so changes to the site name etc should be easier
19378 to make
19379 * ({{bugzilla|149}}) [[Special:RecentChanges]] "changes from" link preserves
19380 limit
19381 * ({{bugzilla|433}}) tooltip for "Undelete" tab now labeled correctly
19382 * ({{bugzilla|439}}) unclickable "Move" tab no longer displays on protected
19383 pages
19384 * ({{bugzilla|484}}) graceful deletion of images where the actual file is
19385 missing
19386 * ({{bugzilla|686}}) fixed [[plural]]s in Catalan localization
19387 * Fixed potential HTML/JavaScript injection attack in the
19388 [[Extension:UnicodeConverter|UnicodeConverter]] extension. (This extension is
19389 not enabled by default.)
19390 * Fixed potential HTML/JavaScript injection attack via raw page views to a
19391 maliciously crafted wiki page.
19392 * ({{bugzilla|187}}, {{bugzilla|669}}) Fixed centered thumbnails, using
19393 {{code|inline=y|lang=html|<div>}} instead of {{code|inline=y|lang=html|<span>}}.
19394 * catch MySQL error 2000 during installation.
19395 * ({{bugzilla|704}}) Removed misleading LocalSettings.sample
19396 * Fix cross site scripting bugs in [[Special:Ipblocklist]],
19397 [[Special:EmailUser]]
19398 * Fix SQL injection and cross site scripting bugs in Special:Maintenance
19399 * Fix cross site scripting bugs and possible filename validation vulnerability
19400 in ImagePage.
19401 * and more of that sort
19402
19403 == MediaWiki 1.3.5, 2004-09-30 ==
19404 Changes from 1.3.4:
19405 * Clean up input validation in 'raw' page output mode which was a potential
19406 cross-site scripting opportunity.
19407
19408 == MediaWiki 1.3.4, 2004-09-28 ==
19409 === SECURITY NOTE ===
19410 As of 1.3.4, MediaWiki performs some screening of newly uploaded files for
19411 validity. (Some) corrupt image files, and HTML files mistakenly or maliciously
19412 masquerading as images, should now be rejected. These checks protect against
19413 Internet Explorer security holes relating to type autodetection which are a
19414 potential cross-site scripting attack vector, and also rejects at least one
19415 known version of the "JPEG virus" which might attack unpatched clients. If you
19416 already have invalid files uploaded this will not protect against them. If you
19417 have expanded the <code>filetype</code> whitelist or disabled the strict type
19418 checking, other dangerous file types may still get through. You should always
19419 be careful when allowing uploads!
19420 Changes from 1.3.3:
19421 * Fixed lots of template-related bugs, esp. for cases where template variables
19422 are used for links, images, etc.
19423 * Fixed transformation of page messages when viewing [[Special:Allmessages]]
19424 * Handle "ISBN ISBN 1234" correctly
19425 * Fixed warning on Category pages
19426 * Fixed some bad error messages on login page
19427 * Fixed history entry for initial main page on install
19428 * Removed problematic <code>{</code> and <code>}</code> from legal title
19429 characters
19430 * Strip leading blank from output in preformatted text.
19431 * Fixed problem when moving pages to titles with '#' in
19432 * Optional {{wg|RawHtml}} for raw {{code|inline=y|lang=html|<html>}} sections.
19433 Use only on limited- participation 'trusted' wikis, as it does not protect
19434 against cross-site scripting attacks. For security, this option can only be
19435 enabled if in {{wg|WhitelistEdit}} mode.
19436 * Fixed problem where pages which were created as a redirect following a move
19437 never showed on [[Special:Randompage]].
19438 * Fixed line spacing on printed table of contents
19439 * Allow links to pages with names of the form [[RFC 1234]]
19440 * Fixed broken edit links being shown for sections from included templates
19441 * Verify that uploaded image files are of the claimed type.
19442
19443 == MediaWiki 1.3.3, 2004-09-09 ==
19444 Changes from 1.3.2:
19445 * Fix for long numeric page titles
19446 * Fix Go search for "0", numeric almost-self-links
19447 * Avoid caching of pages with "You have new messages" headers
19448 * Fix for upgrades as non-root users from 1.2 command-line installs.
19449 * Fix for {{wg|DebugDumpSql}} debug mode.
19450 * {{wg|ExtraNamespaces}} setting for configuring additional namespaces (see
19451 note in {{manual|DefaultSettings.php}})
19452 * 'recache' on query pages now disabled when miser mode is on; special case the
19453 global settings in your {{manual|LocalSettings.php}} to do automatic updates.
19454 * Don't block UTF-8 titles containing byte 0xA0 (bug added in 1.3.2)
19455 * Watch/unwatch tabs now shown on edit pages in MonoBook.
19456 * Fix default skin in Irish localization (ga)
19457 * Add Traditional Chinese localization (zh-tw)
19458 * Changed default sortkey of subcategories. Don't include "Category:"-prefix
19459 any longer
19460 * More helpful info on spam catcher.
19461 * Allow larger offsets for queries such as [[Special:Listusers]]
19462 * Semicolon (;) added to French non-break space rules
19463 * Possible fix for some install errors with path names permission problems.
19464 * Removed [[Project:All system messages]], which has been superseded by the
19465 much faster [[Special:Allmessages]]. This speeds up installation considerably.
19466
19467 == MediaWiki 1.3.2, 2004-08-30 ==
19468 Changes from 1.3.1:
19469 * Fix namespaced page creation links when no go match
19470 * When cookies are disabled, don't show login screen twice
19471 * Install should no longer die when PHP is pre-configured to compress output
19472 * Fixed bug that caused long Japanese pages to time out with Tidy active
19473 * When session.handler is set incorrectly, try automatic override to 'files'
19474 * Watch/Unwatch links back to the affected page instead of Main Page
19475 * Upload link no longer displayed on Monobook if uploading is disabled
19476 * Special:Allmessages faster, shows correct original text, works in safe mode
19477
19478 == MediaWiki 1.3.1, 2004-08-14 ==
19479 Changes from 1.3.0:
19480 * Watchlist parameters now work with register_globals off
19481 * Fixed parsing of ''italics'' and '''bold''' mark-up (again)
19482 * Special:Allpages display is more sensible on smaller wikis
19483 * Fixed XHTML parsing error in classic skins
19484 * Moved pages update watchlist correctly
19485 * Fixed rebuildall.php on case-sensitive Unix filesystems
19486 * Disabled file cache compression by default due to incompatibility with output
19487 buffer compression (ob_gzhandler)
19488 * New magic word {{code|inline=y|PAGENAMEE}} (URL-escaped version of
19489 {{code|inline=y|PAGENAME}})
19490 * Installation avoids blank username; better message on missing XML module
19491 * {{wg|WhitelistAccount}} no longer breaks all logins.
19492
19493 == MediaWiki 1.3.0, 2004-08-11 ==
19494 Look & layout:
19495 * New default layout '[[Skin:MonoBook|MonoBook]]' (available on PHP4 only
19496 currently)
19497 * Print stylesheet now built-in to every page
19498 * More or less correct XHTML 1.0 (served as text/html by default)
19499 Wiki features:
19500 * Image captions can now include links and other basic formatting
19501 * Image bounding box can be specified instead of width, e.g. as 100x100px,
19502 making the image not wider than 100px and not higher than 100px, keeping aspect
19503 ratio.
19504 * Templates have been expanded with parameters, and separated from the
19505 MediaWiki: localization scheme.
19506 * Categories more or less work
19507 * added a special page for listing users with sysop rights.
19508 Editing:
19509 * Automatic merging of edit conflicts that don't directly interfere
19510 * Edit summaries can now include basic formatting and links
19511 Metadata and output:
19512 * Linked Creative Commons copyright metadata (optional)
19513 * RSS 2.0 & Atom 0.3 feeds for Recent Changes, New Pages
19514 Optional modules:
19515 * WikiHiero hieroglyphic module can be added (separate download)
19516 * Timeline module can be added (separate download). Requires ploticus.
19517 * TeX now has an experimental MathML output mode (incomplete!)
19518 Installation and upgrading:
19519 * The old install.php and update.php have been removed. In-place installation
19520 introduced in 1.2 is now the standard installation and upgrade method, see
19521 INSTALL and UPGRADE for directions.
19522 Database:
19523 * The links table has been changed to use a cur_id for l_from. The link tables
19524 must be converted on upgrade, which may entail some downtime.
19525 Code and compatibility:
19526 * Should now run clean with error reporting set to E_ALL.
19527 * register_globals hack from 1.2 has been replaced with safer code
19528 * Bundled PHPTAL 0.7.0 from http://phptal.sourceforge.net/ (with some patches)
19529 * Most image-related code moved to Image.php
19530 * More fixes for PHP 4.1.2 (thanks to Asheesh Laroia)
19531 * URL encoding fix for anchors
19532 * All languages now available in UTF-8 mode
19533 * Various other fixes
19534
19535 === Caveats ===
19536 Some output, particularly involving user-supplied inline HTML, may not produce
19537 100% valid or well-formed XHTML output. Testers are welcome to set $wgMimeType
19538 = "application/xhtml+xml"; to test for remaining problem cases, but this is not
19539 recommended on live sites. (This must be set for MathML to display properly in
19540 Mozilla.) The new 'MonoBook' skin is not compatible with PHP 5 due to bugs in
19541 the underlying PHPTAL library. It will be automatically disabled when running
19542 on PHP5; the older look and feel will be used instead.
19543
19544 = MediaWiki 1.2 =
19545
19546 == MediaWiki 1.2.6, 2004-05-24 ==
19547 * Spam blocker ({{wg|SpamRegex}} - refuses to save edits that match)
19548 * Updated documentation about {{wg|WhitelistRead}}
19549 * Ensure that searchindex table is created as MyISAM
19550 * Interwiki cache timeout (memcached)
19551 * Fix uploads on Windows with magic_quotes_gpc
19552 * Some config fixes for Windows (slashes etc)
19553 * Local interwiki URL redirects
19554 * Fixed obscure deletion problem in squid mode on corrupt entries
19555 * Language files updated to remove more hard-coded "Wikipedia" strings
19556
19557 == MediaWiki 1.2.5, 2004-05-03 ==
19558 * Fixed install problem with blank root password
19559 * Fixed Special:Emailuser/Username links
19560 * Fixed main-page edit links on fuzzy search results
19561 * Fixed wikipedia-interwiki.sql
19562 * Fixed install with apache2filter (ugly URLs)
19563 * IP in 'go' search brings up contributions
19564 * Switch from broken & to ? on top-level wiki URL hack
19565 * Fix for moved pages in enhanced Recentchanges
19566 * Initial main page on new installs links to the online documentation
19567
19568 == MediaWiki 1.2.4, 2004-04-13 ==
19569 * Fixed edit toolbar in Mozilla
19570 * Diff links in Contributions for 'top' edits
19571 * Fixed Nostalgia skin drop-down for register_globals off
19572 * Backported optional open proxy blocker
19573 * Backported {{wg|WhitelistRead}}
19574 * {{wg|CapitalLinks}} option to force full case sensitivity in titles
19575 * Cleaned up error handling when can't talk to database
19576 * Disabled unsafe command-line installer (remove the <code>die()</code> call to
19577 use)
19578
19579 == MediaWiki 1.2.3, 2004-04-02 ==
19580 * Fixed an in-place install bug with non-root MySQL user
19581 * Fixed history diff checkboxes bug on titles with ampersands
19582 * Fixed printable link bug on special pages with parameters
19583 * Fixed bug that broke IP blocking w/o memcached
19584 * Turns off E_NOTICE warnings if PHP settings have them on (you can grope in
19585 and turn this off if you like to debug)
19586
19587 == MediaWiki 1.2.2, 2004-03-28 ==
19588 * Fixed an upgrade bug introduced in 1.2.1.
19589 * Disabled {{wg|UseCategoryMagic}}, which feature is incomplete broken
19590
19591 == MediaWiki 1.2.1, 2004-03-27 ==
19592 Installation, compatibility, security fixlets:
19593 * Detect use of PHP as CGI and disable <code>index.php/Title</code> URLs
19594 * Try to auto-create math tmp & output directories if not present
19595 * Disable Asksql in default install ({{wg|AllowSysopQueries}})
19596 * Better handling of <code>get_magic_quotes_gpc</code> (apostrophe problems)
19597 * French localisation no longer hard-codes "Wikipedia" name
19598
19599 == MediaWiki 1.2.0, 2004-03-24 ==
19600 This is the new production release; it is more or less in sync with what is
19601 running on Wikipedia right now. However this software is provided with NO
19602 WARRANTY of fitness for any purpose; there may be some interesting bugs, it may
19603 eat all your data, and documentation may not be up to date. New features in 1.2:
19604 * In-place web-based installation [experimental!] Note that maintenance
19605 functions are not yet available through the web install script.
19606 * Image resizing/thumbnail generation
19607 * Stricter upload file extension blacklist and whitelist options
19608 * More flexible blocking system; time period may be set
19609 * Handier sysop account management. An account marked "bureaucrat" may assign
19610 sysop access to other accounts via Special:Makesysop. (The exact details of
19611 this may change in the future)
19612 * Support for a squid cache with explicit purging of cached anon pages
19613 * Optional compression of old revision text (requires zlib support)
19614 * Fuzzy title search (experimental, requires memcached)
19615 * Page rendering cache (experimental)
19616 * Editing toolbar to demonstrate wiki syntax to newbies (off by default in user
19617 preferences)
19618 * Support for authenticated SMTP outgoing e-mail (experimental)
19619 * It's now possible to assign sysop accounts from within the wiki. An account
19620 with this ability must be labeled with the "bureaucrat" privilege, such as the
19621 'Developer' account created by the install. Fixes and tweaks:
19622 * Now works with register_globals off!
19623 * Should work out of the box on MySQL 3.2.x again. On 4.x set
19624 {{wg|EnablePersistentLC}}<code> = true;</code> to turn on the link cache table
19625 for a slight rendering speed boost.
19626 * Should work on PHP 5.0 beta (not thoroughly tested)
19627 * Works with short tags disabled.
19628 * rebuildMessages.php can now selectively update new messages, or overwrite
19629 everything.
19630 * Some layout fixes for RTL languages.
19631 * Now includes arrow icons for enhanced recent changes.
19632 * Various bug fixes.
19633
19634 === Behavior changes ===
19635 * wiki.phtml and redirect.phtml are now renamed to index.php and redirect.php
19636 The old names are provided too for compatibility, but make sure they don't
19637 conflict if you've been putting other files in your wiki.
19638 * Uploaded filenames are more strictly checked than before. See bits in
19639 DefaultSettings.php to tweak this behavior to your needs.
19640 * Database messages are now enabled by default, so the interface messages can
19641 be tweaked through the wiki with a sysop account. Disable this if you don't
19642 want the performance hit.
19643
19644 === Database changes ===
19645 An index was added to recentchanges table to speed up Newpages
19646 (patch-rc-newindex.sql for manual updaters). Expiration date field has been
19647 added to ipblocks table ({{manual|patch-ipb_expiry.sql}} for manual updaters).
19648 The links tables have slightly stricter indexes. ('links' and 'brokenlinks' are
19649 not changed on existing installations.)
19650
19651 === Known problems ===
19652 The version 1.1.0 LocalSettings.sample file included the setting
19653 {{wg|CategoryMagic}}<code> = true;</code> this setting is for an experimental
19654 feature that _does not work correctly_. If you have it left over, turn it off
19655 or you'll see mysterious problems with vanishing links. There may be problems
19656 with session handling on some systems. Checking the "remember my password" box
19657 may help as a temporary workaround. If you receive "Cannot load input file"
19658 errors when trying to get at the wiki after installation, make the following
19659 changes:
19660 in LocalSettings.php change the line something like this:
19661 {{wg|ArticlePath}} = "/wiki/index.php/$1";
19662 to:
19663 {{wg|ArticlePath}} = "/wiki/index.php?title=$1";
19664 in index.php, remove these lines:
19665 if( isset( $_SERVER['PATH_INFO'] ) ) {
19666 $title = substr( $_SERVER['PATH_INFO'], 1 );
19667 } else {
19668 $title = $_REQUEST['title'];
19669 }
19670
19671 = MediaWiki 1.1 =
19672
19673 == MediaWiki 1.1.0, 2003-12-08 ==
19674
19675 This is the new production release. Any following 1.1.x releases are expected
19676 to contain only bug fixes; developments of new features will go towards a 1.2.0
19677 release.
19678 New features in 1.1:
19679 * New wiki table syntax:
19680 http://meta.wikipedia.org/wiki/MediaWiki_User%27s_Guide:_Using_tables
19681 * User-editable interface messages:
19682 http://meta.wikipedia.org/wiki/MediaWiki_namespace
19683 * XML-wrapped page source export with optional history:
19684 http://meta.wikipedia.org/wiki/XML_import_and_export (There is not yet an
19685 import function!)
19686 * "Magic words" Fixes and tweaks:
19687 * linkscc table caches link data for rendering; faster
19688 {{manual|rebuildlinks.php}}
19689 * Numerous bugs in [[skin:Cologne Blue|Cologne Blue]] skin fixed
19690 * Login gives warning about missing cookies
19691 * Block log, protection log added; deletion log now includes undeletions
19692 * Deletion & upload logs now escape comment text properly
19693 * Problems with <nowiki><nowiki></nowiki> segments in section titles etc
19694 mitigated
19695 * Contributions offset and minor edit bugs fixed
19696 * Whatlinkshere now sorted alphabetically
19697 * Various exciting new profiling options.
19698 * Debug log is off by default.
19699 * Various small bugs fixed. Internal changes:
19700 * wfQuery has had a second parameter inserted, DB_READ or DB_WRITE. This value
19701 is not actually used so far.
19702 * Partial code for categories and Smarty template-based skins is in the tree
19703 but disabled.
19704 * Parts of Article.php have been moved to {{manual|EditPage.php}} and
19705 {{manual|ImagePage.php}}. New translations:
19706 * fi - Finnish
19707 * ia - Interlingua
19708 * no - Norwegian
19709 * sk - Slovak
19710 * ta - Tamil
19711
19712 === Database changes ===
19713 "linkscc" table added. If upgrading manually (rather than with
19714 {{manual|update.php}}), run maintenance/archives/patch-linkscc.sql to create
19715 the table. Older releases were dated snapshots from the old 'stable' branch:
19716
19717 = pre-MediaWiki 1.1.0 =
19718
19719 == Mediawiki-20031118 ==
19720 * Image deletion fixed.
19721 * Deletion of image old revisions now restricted to sysops (this is an
19722 irreversible action and not well logged)
19723 * Fixed maintenance scripts broken by last release's security fix
19724 * Many errors in {{manual|rebuildlinks.php|rebuildlinks}} script fixed.
19725
19726 == Mediawiki-20031117 ==
19727 * SECURITY FIX: stricter checking of include path
19728 * Fixed user contributions next/prev bug
19729 * Login cookies now have the database name prefixed to allow wikis to coexist
19730 in the same domain. This will invalidate any old saved password cookies.
19731 * Update cache timestamp when talk pages are created
19732 * Saving the login form in Mozilla no longer blanks password in prefs.
19733 * Check existence of source page before performing a move.
19734 * Detect invalid titles in Special:Allpages
19735 * Q-encode headers on outgoing inter-user e-mail
19736 * Updates to some translations.
19737 * Added table of contents border/bg to Cologne Blue, Nostalgia skins
19738 * Protected pages no longer appear unprotected when visited via redirect
19739 * Swapped old Wikipedia logo for the MediaWiki sunflower logo
19740 * install.php, update.php print warning on old PHP versions, added
19741 compatibility functions that might or might not help No database changes since
19742 20031107; upgrading should be clean.
19743
19744 == Mediawiki-20031107 ==
19745 * Fixed various bugs!
19746 * Some speed improvements from tweaks to the table indexes
19747 * Limited support for memcached (see below)
19748 * New translations (see below)
19749 * Interwiki link data now kept in database for flexibility
19750 * Friendlier read-only source view if asked to edit a page when the db is
19751 locked or the page is protected.
19752 * Normal IP blocks auto-expire after 24 hours
19753 * Optional support for blocking usernames
19754 * Uploads disabled by default (see below)
19755
19756 == Mediawiki-20030829 ==
19757 First release under MediaWiki name.
19758
19759 === Security note ===
19760 Uploads are now disabled by default. If you've set up a secure configuration
19761 you can reenable uploads by putting: $wgDisableUploads = false;
19762 into LocalSettings.php. Earlier versions of MediaWiki included a bug that
19763 potentially allows logged- in users to delete arbitrary files in directories
19764 writable by the web server user by manually feeding false form data; this is
19765 now fixed. As a reminder, disable PHP script execution in the upload directory!
19766 You may also wish to serve HTML pages as plaintext to prevent cookie- stealing
19767 JavaScript attacks. Example Apache config fragment:
19768 <pre>
19769 <Directory "/Library/MediaWiki/web/upload">
19770 # Ignore .htaccess files
19771 AllowOverride None
19772
19773 # Serve HTML as plaintext
19774 AddType text/plain .html .htm .shtml
19775
19776 # Don't run arbitrary PHP code.
19777 php_admin_flag engine off
19778
19779 # If you've other scripting languages, disable them too.
19780 </Directory>
19781 </pre>
19782
19783 === Database updates ===
19784 If you're using {{manual|update.php}}, the necessary database changes should be
19785 made automatically. To manually upgrade your database from the 2003-08-29
19786 release, run the following SQL scripts from the maintenance subdirectory:
19787 archives/patch-ipblocks.sql archives/patch-interwiki.sql
19788 archives/patch-indexes.sql interwiki.sql To copy in the Wikipedia
19789 language-prefix interwikis as well, add: wikipedia-interwiki.sql
19790
19791 === Translations ===
19792 New interface localization files are included for:
19793 *fy - Frisian
19794 *ro - Romanian
19795 *sl - Slovene
19796 *sq - Albanian
19797 *sr - Serbian
19798
19799 === Memcached ===
19800 Memcached is a distributed cache system. See http://www.danga.com/memcached/
19801 MediaWiki can optionally use memcached to store some data between calls to
19802 reduce load on the database. Currently this is limited to user and talk page
19803 notification data, interwiki prefix/URL matches, and the UTF-8 conversion
19804 tables. MediaWiki includes version 1.0.10 of the (GPL'd) PHP memcached client
19805 by Ryan Gilfether; if memcached is disabled it acts as a dummy object with
19806 minimal overhead. To use memcached you'll need PHP installed with sockets
19807 support (this is not in the default configure options). See docs/memcached for
19808 some more details. Additionally, you can store login session data in memcached
19809 instead of the local filesystem, which can help to enable load-balancing by
19810 letting login sessions transparently work on multiple front-end web servers.
19811 (The primary other issue is with uploads, which requires some care in
19812 handling.) To enable this, set $wgSessionsInMemcached = true; and set
19813 $wgCookieDomain appropriately if exposing multiple hostnames. This system is
19814 new and may be volatile; login sessions will fail dramatically if memcached is
19815 unavailable when this option is turned on.
19816
19817 === Online documentation ===
19818 Documentation for both end-users and site administrators is currently being
19819 built up on Meta-Wikipedia, and is covered under the GNU Free Documentation
19820 License: http://meta.wikipedia.org/wiki/MediaWiki_User%27s_Guide
19821
19822 === Mailing list ===
19823 A MediaWiki-l mailing list has been set up distinct from the Wikipedia
19824 wikitech-l list: http://mail.wikipedia.org/mailman/listinfo/mediawiki-l
19825
19826 === UseModWiki import script ===
19827 A stripped-down UseModWiki import script is available in the maintenance
19828 subdirectory. It is incomplete and requires a lot of manual clean-up, but does
19829 function for the brave and pure of heart.
19830
19831 === Test suite removed ===
19832 The unmaintained Java-based test suite has been removed from the tarball
19833 release. If you really want it you can check it out from CVS.