Split off some of these validation methods into their own class called Validate so...
[mediawiki.git] / RELEASE-NOTES
blobd78a19299b286a21a4ab1d0eccd3f8d8f1ab83d6
1 = MediaWiki release notes =
3 Security reminder: MediaWiki does not require PHP's register_globals
4 setting since version 1.2.0. If you have it on, turn it *off* if you can.
6 == MediaWiki 1.14 ==
8 THIS IS NOT A RELEASE YET
10 MediaWiki is now using a "continuous integration" development model with
11 quarterly snapshot releases. The latest development code is always kept
12 "ready to run", and in fact runs our own sites on Wikipedia.
14 Release branches will continue to receive security updates for about a year
15 from first release, but nonessential bugfixes and feature developments
16 will be made on the development trunk and appear in the next quarterly release.
18 Those wishing to use the latest code instead of a branch release can obtain
19 it from source control: http://www.mediawiki.org/wiki/Download_from_SVN
21 === Configuration changes in 1.14 ===
23 * $wgExemptFromUserRobotsControl is an array of namespaces to be exempt from
24   the effect of the new __INDEX__/__NOINDEX__ magic words.  (Default: null, ex-
25   empt all content namespaces.)
26 * $wgForwardSearchUrl has been removed entirely. Documented setting since 1.4
27   has been $wgSearchForwardUrl.
28 * (bug 15080) $wgOverrideSiteFeed has been added. Setting either
29   $wgSiteFeed['rss'] or 'atom' to a URL will override the default Recent Changes
30   feed that appears on all pages.
31 * $wgSQLiteDataDirMode has been introduced as the default directory mode for
32   SQLite data directories on creation. Note this setting is separate from
33   $wgDirectoryMode, which applies to all normal directories created by MediaWiki.
34 * $wgGroupsAddToSelf and $wgGroupsRemoveFromSelf now work more like
35   $wgAddGroups and $wgRemoveGroups, where the user must belong to a specified
36   group in order to add or remove those groups from themselves.
37   Backwards compatibility is maintained.
38 * $wgRestrictDisplayTitle controls if the use of the {{DISPLAYTITLE}} magic
39   word is restricted to titles equivalent to the actual page title. This
40   is true per default, but can be set to false to allow any title.
41 * $wgSpamRegex may now be an array of multiple regular expressions.
42 * $wgAjaxSearch has been removed; use $wgEnableMWSuggest instead.
43 * Editing the MediaWiki namespace is now unconditionally restricted to people 
44   with the editinterface right, configuring this in $wgNamespaceProtection 
45   is not required.
46 * $wgAllowExternalImagesFrom may now be an array of multiple strings.
47 * Introduced $wgEnableImageWhitelist to toggle the on-wiki external image
48   whitelist on or off.
49 * Added $wgRenderHashAppend to append some string to the parser cache and the
50   sitenotice cache keys.
52 === Migrated extensions ===
53 The following extensions are migrated into MediaWiki 1.14:
55 * Special:DeletedContributions to show deleted user contributions (was extension
56   DeletedContributions)
57 * Special:Log/newusers recording new users (was extension Newuserlog)
58 * Special:LinkSearch to search for external links (was extension LinkSearch)
59 * RenderHash
60 * NoMoveUserPages
62 === New features in 1.14 ===
64 * New URL syntaxes for Special:ListUsers - 'Special:ListUsers/USER' and
65   'Special:ListUsers/GROUP/USER', in addition to the older syntax
66   'Special:ListUsers/GROUP' where GROUP is a valid group name.
67 * Configurable per-namespace and per-page notices for the edit form,
68   respectively MediaWiki:Editnotice-# where # is the namespace number, and
69   MediaWiki:Editnotice-#-PAGENAME where # is the page's namespace number and
70   PAGENAME is the page name minus the namespace prefix.
71 * (bug 8068) New __INDEX__ and __NOINDEX__ magic words allow user control of
72   search engine indexing on a per-article basis.
73 * Handheld stylesheet options
74 * Added 'DoEditSectionLink' hook as a cleaner unified version of the old
75   'EditSectionLink' and 'EditSectionLinkForOther' hooks.  Note that the
76   'EditSectionLinkForOther' hook has been removed, but 'EditSectionLink' is
77   run in all cases instead, so extensions using the old hooks should still work
78   if they ran roughly the same code for both hooks (as is almost certain).
79 * Signature (~~~~) "cleaning", i.e. template removal, can be disabled with
80   $wgCleanSignatures=false
81 * Extensions can use the SkinBuildSidebar hook to modify the content of the
82   sidebar and add custom portlets to it
83 * Added 'MakeGlobalVariablesScript' hook for extensions to be able to add vari-
84   ables into into the output of Skin::makeVariablesScript
85 * (bug 13846) Added $wgAddGroups and $wgRemoveGroups display on
86   Special:ListGroupRights
87 * (bug 14377) Add a date selector to history pages
88 * (bug 15007) New 'pagetitle-view-mainpage' message allows the HTML <title> of
89   the main page to be customized
90 * Added $wgDisableTitleConversion to disabling the conversion for all pages on
91   the wiki
92 * Added 'noconvertlink' toggle that can be set per user preferences, also
93   added 'convertlink=no|yes' on GET requests whether have the link titles
94   being converted or not
95 * (bug 14921) Special:Contributions/: add user name to <title>
96   Patch by Emufarmers
97 * Unescape more "safe" characters when producing URLs, for added prettiness
98 * Introduced a new hook 'SkinAfterContent' that allows extensions to add text
99   after the page content and article metadata. Updated all skins and skin
100   templates to work with that hook.
101 * (bug 14929) removeUnusedAccounts.php now supports 'ignore-touched' and
102   'ignore-groups'. Patch by Louperivois
103 * (bug 15127) Work around minor display glitch in Opera.
104 * By default, reject file uploads that look like ZIP files, to avoid the
105   so-called GIFAR vulnerability.
106 * (bug 15141) Give ability to only list protected pages with the cascading
107   option enabled on Special:ProtectedPages
108 * (bug 15157) Special:Watchlist has the same options as Special:Watchlist:
109   Show/Hide logged in users, Show/Hide anonymous, Invert namespace selection
110 * Added hook 'UserrightsChangeableGroups' to allow modification of what
111   groups may be added or removed via the Special:UserRights interface.
112 * HTML entities like &nbsp; now work (are not escaped) in edit summaries.
113 * (bug 13815) In the comment for page moves, use the colon-separator message
114   instead of a hardcoded colon.
115 * Allow <gallery> to accept image names without an Image: prefix
116 * Add tooltips to rollback and undo links
117 * BMP images are now displayed as PNG
118 * (bug 13471) Added NUMBERINGROUP magic word
119 * (bug 11884) Now support Flash EXIF attribute
120 * Show thumbnails in the file history list, patch by User:Agbad
121 * Added support of piped wikilinks using double-width brackets
122 * Added an on-wiki external image whitelist. Items in this whitelist are
123   treated as regular expression fragments to match for when possibly
124   displaying an external image inline.
125 * (bugs 15405, 15436) Sort more currency types correctly in sortable tables
126 * (bug 15422) Sort more different types of numbers in sortable tables
127 * (bug 2889) MediaWiki:Print.css applies to the printable version
128 * Category counts (e.g. from {{PAGESINCATEGORY:}}) should be more accurate for
129   small categories
130 * After logging in, automatically redirect to wherever you logged in from
131 * (bug 5619) Break messages used in Special:Statistics down further
132 * (bug 11029) Add link to Special:Listusers?group=sysop etc at
133   Special:Statistics
134 * (bug 15514) Setting $wgRightsText without $wgRightsUrl now produces a 
135   plaintext copyright notice. Patch by Juliano F. Ravasi.
136 * (bug 15551) Deletion log excerpt is now shown whenever a user vists a 
137   deleted page, even if they are unable to edit it.
138 * Added Wantedfiles special pages, allowing users to find image links with no
139   image.
140 * (bug 12650) It is now possible to set different expiration times for different
141   restriction types on the protection form.
142 * (bug 8440) Allow preventing blocked users from editing their talk pages
143 * Improved upload file type detection for OpenDocument formats
144 * Added the ability to set the target attribute on external links with 
145   $wgExternalLinkTarget
146 * api.php now sends "Retry-After" and "X-Database-Lag" HTTP headers if the maxlag
147   check fails, just like index.php does
150 === Bug fixes in 1.14 ===
152 * (bug 14907) DatabasePostgres::fieldType now defined.
153 * (bug 14659) Passing the default limit param to Special:Recentchanges no more
154   falls back to the user option
155 * (bug 14954) Fix regression in Modern and Simple skins
156 * Recursion loop check added to Categoryfinder class
157 * Fixed few performance troubles of large job queue processing
158 * Not setting various parameters in Foreign Repos now fails more gracefully
159 * (bug 2333) Redirects are properly rendered when previewing an edit.
160 * (bug 14972) Use localized alias of Special:Search on all search forms
161 * (bug 11035) Special:Search should have descriptive <title>
162 * Special pages are now not subject to special handling for "self-links"
163 * (bug 15053) Syntactically incorrect redirects with another link in them
164   no longer redirect to the second link
165 * (bug 15049) Fix for CheckUser extension's log search: usernames containing
166   a "-" were incorrectly turned into bogus IP range searches.
167   Patch by Max Semenik.
168 * (bug 15055) Talk page notifications no longer attempt to send mail when
169   user's e-mail address is invalid or unconfirmed
170 * (bug 12370) Add throttle on password attempts. Defaults to max 5 attempts in 5
171   minutes.
172 * (bug 15016) 'Templates used on this page' list in view source should be
173   wrapped in a div with class "templatesUsed"
174 * (bug 14868) Setting $wgFeedDiffCutoff to 0 now disables generation of the diff
175   entirely, not just the display of it.
176 * (bug 6387) Introduced new setting $wgCategoryPrefixedDefaultSortkey which
177   allows having the unprefixed page title as the default category sortkey
178 * (bug 15079) Add class="ns-talk" / "ns-subject" to <body>. Also added
179   ns-special to special pages.
180 * (bug 15052) Skins should add their name as a class in <body>
181 * (bug 14165, bug 14294) Wikimedia specific configuration in convertGrammar()
182   for several languages was removed. The settings have been put in extension
183   WikimediaMessages. Patch for Czech by Danny B.
184 * (bug 15101) Displaying only bots edits in Special:Recentchanges now works
185   again
186 * (bug 13770) Fixed incorrect detection of PHP's DOM module
187 * (bug 14790) Export of category pages when using Category: prefix now actually
188   gives results
189 * Avoid recursive crazy expansions in section edit comments for pages which
190   contain '/*' in the title
191 * Fix excessive memory usage when parsing pages with lots of links
192 * $wgSpamRegex now matches the edit summary and page move descriptions in
193   addition to body text.
194 * Navigation links to images available from a shared repository (like Commons)
195   from their local talk pages no longer appear as redlinks
196 * Action=purge on ForeignApiFiles now works (purges their thumbnails and 
197   description pages).
198 * (bug 15303) Title conversion for templates wasn't working in some cases.
199 * (bug 15264) Underscores in Special:Search/Foo_bar parameters were taken
200   literally; now converting them to spaces per expectation.
201 * (bug 15342) "Invert" checkbox now works correctly when selecting main
202   namespace in Special:Watchlist
203 * (bug 15172) 'Go' button of Special:Recentchanges now on the same line as the
204   last input element (like Special:Watchlist too)
205 * (bug 15351) Fix fatal error for invalid section fragments in autocomments
206 * Fixed intermittent deadlock errors involving objectcache table queries. 
207   Use a separate database connection for the objectcache table to avoid 
208   long-lasting locks on that table.
209 * Respect file restrictions in the file history list
210 * (bug 15399) Odd/even classes on sortable tables' rows could be slow for large
211   tables, and have been disabled by default.
212 * (bug 15482) Special:Recentchangeslinked has no longer two submit buttons
213 * (bug 15292) New message notification for unregistred users now works again
214 * (bug 14398) mwsuggest.js: Let width of container be configurable
215 * (bug 15543) Only include user touched timestamp to generated CSS
216 * (bug 15497) Removed encoding attribute from <?xml ?> tag
217 * (bug 12284) Special:Preferences now sets a returnto parameter on the link to
218   Special:Userlogin. Patch by Marooned.
219 * Fixed the HTTP accept language string detection length in 
220   LanguageConverter.php, instead of the fixed length language codes.
221 * Special:Recentchangeslinked no longer shows outgoing links for nonexistent pages
222   even if there are broken link records with source article id 0 in the database
223 * (bug 15598) Special:Newpages default limit uses user preference for recentchanges
224   limit instead of hardcoded 50.
225 * (bug 15617) $wgFeedClassesOutputPage::getHeadLinks() respects $wgFeedClasses,
226   instead of hardcoding rss and atom. Patch by Juliano F. Ravasi. 
227 * (bug 14638) Special:Blockip now provides a link to the block log if the user
228   has been blocked more than 10 times. Patch by Matt Johnston.
229 * (bug 12678) Skins don't show Upload link if the user isn't allowed to upload.
230 * Fixed incorrect usage of DB_LAST in Special:Export. Deprecated DB_LAST.
231 * (bug 15642) Blocked sysops can no longer block other users
232 * Http::request() now respects $wgHTTPtimeout when not using cURL
233 * (bug 15158) Userinvalidcssjstitle not shown on preview
234 * (bug 15196) Free external links should be numbered in a localised manner
235 * (bug 15388) Title of Special:PrefixIndex
236 * Links with no title but a curid parameter now use the curid to pick a page
238 === API changes in 1.14 ===
240 * Registration time of users registered before the DB field was created is now
241   shown as empty instead of the current time.
242 * API search now falls back to fulltext search by default when using Lucene
243   or other engine which doesn't support a separate title search function.
244   This means you can use API search on Wikipedia without explicitly adding
245   &srwhat=text to the query.
246 * Added iiprop=bitdepth to imageinfo and aiprop=bitdepth to allimages
247 * (bug 14713) API-specific permissions (such as 'writeapi' and 'apihighlimits'
248   are now listed on action=help
249 * (bug 15044) Added requestid parameter to api.php to facilitate distinguishing
250   between requests
251 * (bug 15048) Added limit field for multivalue parameters to action=paraminfo
252   output.
253 * When the limit on multivalue parameters is exceeded, a warning is issued
254 * list=search doesn't list missing pages any more
255 * (bug 15178) Added clshow to prop=categories to allow filtering for hidden/
256   non-hidden categories
257 * (bug 15228) Combining revids= and redirects now throws a warning instead of an
258   error, and still resolves redirects generated by the generator.
259 * list={backlinks,embeddedin,imageusage} now return arrays with keys 0, 1, 2,
260   etc. (AKA lists) instead of arrays with pageIDs as keys (AKA hash tables)
261   for consistency with other list modules.
262 * Added action=watch
263 * (bug 15275) apprefix and related parameters ignore spaces at the end
264 * action=edit no longer throws unknown error 228  when trying to create an empty
265   section with section=new
266 * Database replication lag doesn't cause all action=edit requests to return the
267   nochange flag any more
268 * (bug 15392) ApiFormatBase::formatHTML now uses $wgUrlProtocols.
269 * (bug 15444) action=edit returns "Unknown error: ``AS_END''" where it should
270   return just "Unknown error"
271 * (bug 15448) YAML output returns empty values instead of 0
272 * (bug 15445) Added action=patrol
273 * (bug 15466) Added action=purge
274 * (bug 15486) action=block ignores autoblock parameter
275 * (bug 15492) added rcprop=loginfo to list=recentchanges
276 * (bug 15527) action=rollback can now revert anonymous editors
277 * (bug 15535) prop=info&inprop=protection doesn't list pre-1.10 protections
278   if the page is also protected otherwise (1.10+ style or cascading)
279 * list=random now has rnredirect parameter, to get random redirects.
280 * Added APIAfterExecute, APIQueryAfterExecute and APIQueryGeneratorAfterExecute
281   hooks which allow for extending core modules in a cleaner way
282 * action=protect checks for invalid protection types and levels
283 * (bug 15673) Added indentation to format=wddxfm output and improved built-in 
284   WDDX formatter to resemble PHP's more
285 * (bug 15706) Empty values for apprtype and apprlevel are now silently ignored
286   rather than causing an exception
287 * Added uiprop=preferencestoken to meta=userinfo
288 * (bug 15609) Add inprop=url and inprop=readable to prop=info
289 * Add ApiDisabled and ApiQueryDisabled classes so individual modules can
290   be disabled in LocalSettings.php
291 * (bug 15653) Add prop=duplicatefiles
293 === Languages updated in 1.14 ===
295 MediaWiki supports over 300 languages. Many localisations are updated
296 regularly. Below only new and removed languages are listed.
298 * Bakhtiari (bqi) (new)
299 * Fiji Hindi (Devanagari script) (hif-deva) (new)
300 * Krio (kri) (new)
301 * Lezghian (lez) (new)
302 * Laz (lzz) (new)
303 * Niuean (niu) (new)
304 * Oromo (om) (new)
305 * Plautdietsch (pdt) (new)
306 * Tarantino (roa-tara) (new)
307 * Serbo-Croatian (sh) (new)
308 * Tulu (tcy) (new)
310 == Compatibility ==
312 MediaWiki 1.14 requires PHP 5 (5.2 recommended). PHP 4 is no longer supported.
314 PHP 5.0.x fails on 64-bit systems due to serious bugs with array processing:
315 http://bugs.php.net/bug.php?id=34879
316 Upgrade affected systems to PHP 5.1 or higher.
318 MySQL 3.23.x is no longer supported; some older hosts may need to upgrade.
319 At this time we still recommend 4.0, but 4.1/5.0 will work fine in most cases.
322 == Upgrading ==
324 1.14 has several database changes since 1.13, and will not work without schema
325 updates.
327 If upgrading from before 1.11, and you are using a wiki as a commons repository,
328 make sure that it is updated as well. Otherwise, errors may arise due to
329 database schema changes.
331 If upgrading from before 1.7, you may want to run refreshLinks.php to ensure
332 new database fields are filled with data.
334 If you are upgrading from MediaWiki 1.4.x or earlier, some major database
335 changes are made, and there is a slightly higher chance that things could
336 break. Don't forget to always back up your database before upgrading!
338 See the file UPGRADE for more detailed upgrade instructions.
341 === Caveats ===
343 Some output, particularly involving user-supplied inline HTML, may not
344 produce 100% valid or well-formed XHTML output. Testers are welcome to
345 set $wgMimeType = "application/xhtml+xml"; to test for remaining problem
346 cases, but this is not recommended on live sites. (This must be set for
347 MathML to display properly in Mozilla.)
349 For notes on 1.13.x and older releases, see HISTORY.
352 === Online documentation ===
354 Documentation for both end-users and site administrators is currently being
355 built up on MediaWiki.org, and is covered under the GNU Free Documentation
356 License (except for pages that explicitly state that their contents are in
357 the public domain) :
359   http://www.mediawiki.org/wiki/Documentation
362 === Mailing list ===
364 A MediaWiki-l mailing list has been set up distinct from the Wikipedia
365 wikitech-l list:
367   http://lists.wikimedia.org/mailman/listinfo/mediawiki-l
369 A low-traffic announcements-only list is also available:
371   http://lists.wikimedia.org/mailman/listinfo/mediawiki-announce
373 It's highly recommended that you sign up for one of these lists if you're
374 going to run a public MediaWiki, so you can be notified of security fixes.
377 === IRC help ===
379 There's usually someone online in #mediawiki on irc.freenode.net