Wiki source code of XWiki Enterprise 2.2

Version 18.1 by Sergiu Dumitriu on 2010/02/16

Show last authors
1 {{box cssClass="floatinginfobox" title="**Contents**"}}{{toc/}}{{/box}}
2
3 This release contains many important UI improvements of existing features (xar import, user registration, edit, comemnt, etc.) and introduces the new Model API starting with a new EntityReference and related tools to remove all String manipulations around documents and attachment names.
4
5 = New and Noteworthy (since XWiki Enterprise 2.1.2) =
6
7 == New XAR Import UI ==
8
9 The XAR import interface has been completely revamped. The new interface (see screenshots below) now provides:
10
11 * More explicit options regarding revision history handling
12 * The new option to **add a new version to existing documents** instead of overriding them
13 * A rich UI that allows to select/unselect whole spaces at once
14 * Support for importing when no javascript is available. The UI degrades nicely to a less rich interface
15
16 [[image:ReleaseNotesXWikiEnterprise22M1@importer.png||width="700"]]
17
18 == UI for Deleted documents & attachments ==
19
20 While deleted documents and attachments have been stored in a trash instead of being completely deleted since XWiki 1.2, there was no general interface for viewing the contents of the trash. This has been remedied by the introduction of two new tabs in the wiki's Document Index, //Deleted Documents// and //Deleted Attachments//.
21
22 image:ReleaseNotesXWikiEnterprise22M1@trash1.png
23
24 Both use the livetable, thus allowing filtering and ordering for easier browsing. A document from the trash can be viewed, permanently deleted, or restored if the location is still available.
25
26 image:ReleaseNotesXWikiEnterprise22M1@trash2.png
27
28 The attachment trash contains only attachments deleted from a document, and not attachments that were deleted together with their owner document; in the latter case, the attachments are kept together with the document in the document trash. For attachments, there is no restore option yet, it will be implemented in a future release.
29
30 image:ReleaseNotesXWikiEnterprise22M1@trash3.png
31
32 == New Profile & WatchList UI ==
33
34 * Complete overhaul of the Profile UI(((
35 [[[[image:ReleaseNotesXWikiEnterprise22M2@profile-home.png||style="border:1px solid black; padding:1px; display:block; width: 800px"]]>>attach:ReleaseNotesXWikiEnterprise22M2@profile-home.png]]
36 )))
37 * Inclusion of the WatchList manager page into the Profile as a tab(((
38 [[[[image:ReleaseNotesXWikiEnterprise22M2@profile-watchlist.png||style="border:1px solid black; padding:1px; display:block; width: 800px"]]>>attach:ReleaseNotesXWikiEnterprise22M2@profile-watchlist.png]]
39 )))
40 * Inline-based editing for modifying profile details(((
41 [[[[image:ReleaseNotesXWikiEnterprise22M2@profile-edit.png||style="border:1px solid black; padding:1px; display:block;"]]>>attach:ReleaseNotesXWikiEnterprise22M2@profile-edit.png]]
42 )))
43 * Added Profile tab for managing Profile preferences
44 * Converted to XWiki Syntax 2.0
45
46 == New Registration page ==
47
48 [[[[image:ReleaseNotesXWikiEnterprise22M2@registration.png||style="border:1px solid black; padding:1px; display:block; width: 800px"]]>>attach:ReleaseNotesXWikiEnterprise22M2@registration.png]]
49
50 * Ability to display a Captcha for spam prevention.
51 * All fields are checked by client-side script as the user types, then checked by the server for security.
52 * One-click login after registration.(((
53 [[image:ReleaseNotesXWikiEnterprise22M2@OneClickLogin.png||width="500"]]
54 )))
55 * Easy for administrators to add fields, configuration with code.
56 * Can be imported/edited without programming rights.
57 * Works on older wikis if LiveValidation is imported (Captcha won't appear)
58
59 == New Menu in Edit mode ==
60
61 The different edition modes that used to be in a separate Panel are now in a new edit menu (similarly to the menu you get in view mode).
62
63 image:ReleaseNotesXWikiEnterprise22M2@editmodeui.png
64
65 == Comments UI improvements ==
66
67 === Edit comment ===
68
69 The users have the possibility to edit their comments.
70
71 [[[[image:ReleaseNotesXWikiEnterprise22M2@editcomment.png||style="border:1px solid black; padding:1px; display:block;"]]>>attach:ReleaseNotesXWikiEnterprise22M2@editcomment.png]]
72
73 === Preview comment ===
74
75 The users have the possibility to preview their comment before submitting it.
76
77 [[[[image:ReleaseNotesXWikiEnterprise22M2@previewcomment1.png||style="border:1px solid black; padding:1px; display:block;"]]>>attach:ReleaseNotesXWikiEnterprise22M2@previewcomment1.png]]
78
79 [[[[image:ReleaseNotesXWikiEnterprise22M2@previewcomment2.png||style="border:1px solid black; padding:1px; display:block;"]]>>attach:ReleaseNotesXWikiEnterprise22M2@previewcomment2.png]]
80
81 == WYSIWYG and Rendering improvements ==
82
83 * Add API to find the syntax of the executing document from scripts
84 * Macros descriptors now have translations
85 image:translatedwysiwyg.png
86
87 == General UI improvements ==
88
89 * In the wiki source code viewer, allow to toggle line numbers faster from Javascript
90 * Enable full screen view when displaying the wiki source code (viewer=code)
91 * ActionMenu: Add Profile submenu item to the "current user" menu
92 image:ReleaseNotesXWikiEnterprise22M1@XSCOLIBRI-170.png
93 * Reorder the document actions in the "More actions" menu: copy, rename, delete
94 * More UI components make use of the (recently introduced) color theme
95 * Have all panels have nice readable names
96 * Allow to copy a document's default language + all translations in the copy menu action
97
98 == Contextual wikimacros ==
99
100 Previously, [[wiki macros>>platform:DevGuide.WikiMacroTutorial]] could only be defined by users with administrator rights, and only in the main wiki (when in a virtual wiki farm). It's now possible for any user to register wiki macros, and in any wiki. However, this follows some user rights restrictions, preventing a limited user to write dangerous scripts available to all other users. For example, if the user does not have the proper rights, only he will see and use the macro he registered. To make the macro available globally, an administrator must re-save it.
101
102 == New Model module with Reference implementation ==
103
104 The goal is to provide [[APIs>>http://svn.xwiki.org/svnroot/xwiki/platform/core/trunk/xwiki-model/]] to remove all String manipulations around documents and attachment names. It also introduces the concept of Reference for any entity of the model and the parser/serializer associated. For now Wiki, Space, Document and attachment are supported; classes objects and properties should come in 2.3 branch.
105
106 From a user point of view this will result in supporting any character in document names for example. In addition, this is also a step in the direction of supporting nested spaces (the storage would also need to be changed to support that).
107
108 In practice the existing code has not yet been fully refactored to benefit from the new implementation. The work has been started in XWiki Enterprise 2.2 Milestone 1 and will continue in XWiki Enterprise 2.3 and beyond.
109
110 == Development improvements ==
111
112 * Added support for "xcontext" binding in 1.0 groovy macro
113 * Allow set to null in velocity
114 * Add an API method for creating a LinkedHashMap
115 * New APIs for accessing deleted attachments from the trash
116 * The class wizard should propose to add a SheetClass object to the class sheet
117 * Add support for 'on page' style extensions
118
119 == Office import improvements ==
120
121 * Added support for Office2007 document formats
122
123 == Blog improvement ==
124
125 * Added the Create a new post to category pages - when used by default select that category
126
127 == Dependencies upgrade ==
128
129 * Upgraded to Groovy 1.7
130 * Upgrade to GWT 2.0.0
131
132 == Miscellaneous ==
133
134 * Always use UTF-8 for URL encoding
135 * Attachments should produce document modification events
136 * New user profile pages are created in XWiki Syntax 2.0
137 * New zh_TW translation
138
139 * Lots of accessibility fixes
140 * Lots of bugs fixes
141
142 = Known issues =
143
144 * [[Bugs we know about>>http://jira.xwiki.org/jira/secure/IssueNavigator.jspa?reset=true&&type=1&pid=10010&resolution=-1&sorter/field=updated&sorter/order=DESC]]
145
146 = Backward Compatibility and Migration Notes =
147
148 == Important non-compatible changes ==
149
150 {{warning}}
151 The way URLs are generated and parsed has changed. While previously the wiki encoding was used to convert non-ASCII bytes to their ##%XY## escapes, as allowed by the older HTTP/URL specifications, now all URLs escape the UTF-8 bytes of the path, to better adhere to the modern URI specification. This should only affect non-UTF-8 wikis, and only by breaking some bookmarks.
152 {{/warning}}
153
154 {{warning}}
155 The velocity configuration has been changed so that setting ##null## values to variables is now allowed. This could break some scripts and macros, please check before upgrading.
156 {{/warning}}
157
158 This means that the following script will generate a different result:
159
160 {{code language="none"}}
161 #set($s = 'abc')
162 $s
163 #set($s = $util.null)
164 $s
165 {{/code}}
166
167 While previously the result would have been ##abc abc##, now it is ##abc $s##.
168
169 Special care must be taken care with constructs like the following:
170
171 {{code language="none"}}
172 #set($var = '')
173 #set($var = $xwiki.methodThatMightReturnNull())
174 #if($var != '')
175 The method succeeded
176 #else
177 The method failed
178 #end
179 {{/code}}
180
181 Since ##null != ''## in Velocity, now a different branch will be executed. The following rewrites work.
182
183 Works in both modes, with or without null allowed:
184 {{code language="none"}}
185 #set($var = '')
186 #set($var = $xwiki.methodThatMightReturnNull())
187 #if("$!var" != '')
188 The method succeeded
189 #else
190 The method failed
191 #end
192 {{/code}}
193
194 Works only in the new mode, with null allowed, but is shorter, slightly faster, and more familiar for java developers:
195 {{code language="none"}}
196 #set($var = $xwiki.methodThatMightReturnNull())
197 #if($!var != $util.null)
198 The method succeeded
199 #else
200 The method failed
201 #end
202 {{/code}}
203
204 == Captcha ==
205
206 Captcha related configuration changed in Struts configuration file. If you keep the old file it will fail silently so make sure to use the proper configuration you can find in the new file (or overwrite it if you don't have any local modification obviously).
207
208 == Removed pages ==
209
210 * Main.RecentMembers as been removed from default XWiki Enterprise xar
211
212 == General Notes ==
213
214 {{warning}}If you're running in a multiwiki setup you'll also need to define the property //xwiki.store.migration.databases=all// to your //xwiki.cfg// file or explicitly name all databases to be migrated as in <tt>xwiki.store.migration.databases=db1,db2,...//.{{/warning}}
215
216 You may also want to [[import the default wiki XAR>>Main.Download]] in order to benefit from the improvements listed above.
217
218 {{warning}}Always make sure you compare your //xwiki.cfg// file with the newest version since some configuration parameters were added. Note you should add //xwiki.store.migration=1// so that XWiki will attempt to automatically migrate your current database to the new schema. Make sure you backup your Database before doing anything.{{/warning}}
219
220 == Migration Notes ==
221
222 * The new parser/serializer for document names comes with new features and changes some behaviors:
223 ** introducing escaping means:
224 *** ##\## which is now the escaping character needs to be doubled in full document name, as in ##Space.Docu
225 ment##, which means space ##Space## and document ##Docu\ment##
226 *** some generated documents names will now contains ##\## to escape thing like dot in a document name. For example ##Space.Docu\.ment## means space ##Space## and document ##Docu.ment##
227 ** support for the syntax ##wikiname:Document## has been dropped, so in this example "wikiname:Document" will be seen as the document name because no ##.## has been found
228 * If you had Wiki Macros defined in your wiki before, you might want to edit them to check their visibility field since the notion of visibility was introduced in XE 2.2 and the default value is user-visibility.
229 * CoreConguration#getSyntax now returns a Syntax object instead of a String
230
231 = Dependencies =
232
233 This release includes the following modules in the specified versions since XWiki Enterprise 2.1.2 was released.
234
235 == Core/Web ==
236
237 |=Group Id|=Artifact Id|=New Version|=Old Version|=JIRA URL
238 |##com.xpn.xwiki.platform##|##xwiki-*##|2.2|2.1.2|[[jira>>http://jira.xwiki.org/jira/browse/XWIKI]]
239 |##org.xwiki.platform##|##xwiki-*##|2.2|2.1.2|[[jira>>http://jira.xwiki.org/jira/browse/XWIKI]]
240
241 == Applications ==
242
243 |=Group Id|=Artifact Id|=New Version|=Old Version|=JIRA URL
244 |##com.xpn.xwiki.platform.applications##|##xwiki-application-administration##|1.26|1.21|[[jira>>http://jira.xwiki.org/jira/browse/XAADMINISTRATION]]
245 |##com.xpn.xwiki.platform.applications##|##xwiki-application-blog##|1.20|1.18|[[jira>>http://jira.xwiki.org/jira/browse/XABLOG]]
246 |##com.xpn.xwiki.platform.applications##|##xwiki-application-officeimporter##|1.13|1.12|[[jira>>http://jira.xwiki.org/jira/browse/XAOFFICE]]
247 |##com.xpn.xwiki.platform.applications##|##xwiki-application-panels##|1.34|1.30|[[jira>>http://jira.xwiki.org/jira/browse/XAPANELS]]
248 |##com.xpn.xwiki.platform.applications##|##xwiki-application-scheduler##|1.16|1.15|[[jira>>http://jira.xwiki.org/jira/browse/XASCH]]
249 |##com.xpn.xwiki.platform.applications##|##xwiki-application-statistics##|1.6|1.5|[[jira>>http://jira.xwiki.org/jira/browse/XASTATS]]
250 |##com.xpn.xwiki.platform.applications##|##xwiki-application-tag##|1.10|1.8|[[jira>>http://jira.xwiki.org/jira/browse/XATAG]]
251 |##com.xpn.xwiki.platform.applications##|##xwiki-application-watchlist##|1.26|1.23|[[jira>>http://jira.xwiki.org/jira/browse/XPWATCHLIST]]
252 |##com.xpn.xwiki.platform.applications##|##xwiki-application-webdav##|1.3|1.2|[[jira>>http://jira.xwiki.org/jira/browse/XAWEBDAV]]
253 |##com.xpn.xwiki.platform.applications##|##xwiki-application-wiki-macro-bridge##|1.3|1.2|[[jira>>http://jira.xwiki.org/jira/browse/XAWMB]]
254
255 == Plugins ==
256
257 |=Group Id|=Artifact Id|=New Version|=Old Version|=JIRA URL
258 |##com.xpn.xwiki.platform.plugins##|##xwiki-plugin-activitystream##|1.6|1.5|[[jira>>http://jira.xwiki.org/jira/browse/XPAS]]
259 |##com.xpn.xwiki.platform.plugins##|##xwiki-plugin-jodatime##|1.3|1.3|[[jira>>http://jira.xwiki.org/jira/browse/XPJODA]]
260 |##com.xpn.xwiki.platform.plugins##|##xwiki-plugin-lucene##|1.16|1.12|[[jira>>http://jira.xwiki.org/jira/browse/XPLUCENE]]
261 |##com.xpn.xwiki.platform.plugins##|##xwiki-plugin-mailsender##|1.13|1.13|[[jira>>http://jira.xwiki.org/jira/browse/XPMAIL]]
262 |##com.xpn.xwiki.platform.plugins##|##xwiki-plugin-scheduler##|1.16|1.15|[[jira>>http://jira.xwiki.org/jira/browse/XASCH]]
263 |##com.xpn.xwiki.platform.plugins##|##xwiki-plugin-skinx##|1.13|1.12|[[jira>>http://jira.xwiki.org/jira/browse/XSKINX]]
264 |##com.xpn.xwiki.platform.plugins##|##xwiki-plugin-tag##|1.10|1.8|[[jira>>http://jira.xwiki.org/jira/browse/XATAG]]
265 |##com.xpn.xwiki.platform.plugins##|##xwiki-plugin-watchlist##|1.26|1.23|[[jira>>http://jira.xwiki.org/jira/browse/XPWATCHLIST]]
266
267 == Skins ==
268
269 |=Group Id|=Artifact Id|=New Version|=Old Version|=JIRA URL
270 |##com.xpn.xwiki.platform.skins##|##xwiki-skin-albatross##|1.27|1.26|[[jira>>http://jira.xwiki.org/jira/browse/XSALBATROSS]]
271 |##com.xpn.xwiki.platform.skins##|##xwiki-skin-colibri##|1.12.1|1.8|[[jira>>http://jira.xwiki.org/jira/browse/XSCOLIBRI]]
272 |##com.xpn.xwiki.platform.skins##|##xwiki-skin-toucan##|1.32|1.31|[[jira>>http://jira.xwiki.org/jira/browse/XSTOUCAN]]
273
274 == Top Level POM ==
275
276 |=Group Id|=Artifact Id|=New Version|=Old Version
277 |##com.xpn.xwiki.platform##|##xwiki##|29|29
278
279 == Tools ==
280
281 |=Group Id|=Artifact Id|=New Version|=Old Version|=JIRA URL
282 |##org.xwiki.platform.tools##|##xwiki-configuration-resources##|1.36|1.36|[[jira>>http://jira.xwiki.org/jira/browse/XTCONFRES]]
283 |##org.xwiki.platform.tools##|##xwiki-jetty-resources##|1.17|1.17|[[jira>>http://jira.xwiki.org/jira/browse/XTJETTY]]
284 |##org.xwiki.platform.tools##|##xwiki-license-resources##|1.1|1.1|[[jira>>http://jira.xwiki.org/jira/browse/XTLICENSE]]
285 |##org.xwiki.platform.tools##|##xwiki-packager-plugin##|1.15|1.15|[[jira>>http://jira.xwiki.org/jira/browse/XTPACKAGER]]
286 |##org.xwiki.platform.tools##|##xwiki-rootwebapp##|1.3|1.3|[[jira>>http://jira.xwiki.org/jira/browse/XTROOT]]
287 |##org.xwiki.platform.tools##|##standards-validator##|1.1|1.1|[[jira>>http://jira.xwiki.org/jira/browse/XTVALIDATOR]]
288 |##org.xwiki.platform.tools##|##xwiki-xar-handlers##|1.9|1.9|[[jira>>http://jira.xwiki.org/jira/browse/XTXARHANDLER]]
289 |##org.xwiki.platform.tools##|##xwiki-xar-plugin##|1.13|1.13|[[jira>>http://jira.xwiki.org/jira/browse/XPXARPLUGIN]]
290 |##org.xwiki.platform.tools##|##xwiki-verification-resources##|1.15|1.14|[[jira>>http://jira.xwiki.org/jira/browse/XTVERIFICATIONS]]

Get Connected