Version 30.1 by Thomas Mortagne on 2015/03/02

Show last authors
1 {{box cssClass="floatinginfobox" title="**Contents**"}}
2 {{toc/}}
3 {{/box}}
4
5 This is the release notes for [[XWiki Commons>>http://commons.xwiki.org]], [[XWiki Rendering>>http://rendering.xwiki.org]], [[XWiki Platform>>http://platform.xwiki.org]] and [[XWiki Enterprise>>http://enterprise.xwiki.org]]. They share the same release notes as they are released together and have the same version.
6
7 <insert description of release here>
8
9 = New and Noteworthy (since XWiki 7.0 Milestone 1) =
10
11 [[Full list of issues fixed and Dashboard for 7.0>>http://jira.xwiki.org/secure/Dashboard.jspa?selectPageId=13092]].
12
13 == Wiki Creation ==
14
15 * During the wiki creation, Distribution Wizard is not triggered anymore. Instead, the whole wiki creation process has been moved into a job, and everything happens inside the Wiki Creation Wizard (with a progress bar and a logging area):(((
16 {{image reference="WikiCreationStep.png" width="45%"/}} {{image reference="WikiCreationStepEnd.png" width="45%"/}}
17 )))
18 * The Wiki Provisioning Step has been integrated into the job too.
19 * When a wiki is created from a template, we now have a message in the logs that displays which document is copied.
20
21 == Extension categories ==
22
23 It's now possible to indicate a predefined category for each extension in the repository.
24
25 {{image reference="category.png"/}}
26 {{image reference="categorylivetable.png"/}}
27
28 == Miscellaneous ==
29
30 * The user/group displayer is now showing the wiki for local users/groups in edit mode too (the wiki was shown only in view mode previously).(((
31 {{image reference="userDisplayer-editMode-wiki.png"/}}
32 )))
33 * When deleting a wiki the confirmation page now asks to type in the wiki identifier to prevent accidental deletion.(((
34 {{image reference="delete-wiki-confirm-screen.png"/}}
35 )))
36
37 See the [[full list of JIRA issues>>http://jira.xwiki.org/sr/jira.issueviews:searchrequest-printable/temp/SearchRequest.html?jqlQuery=project+in+%28XCOMMONS%2C+XRENDERING%2C+XWIKI%2C+XE%29+and+status+%3D+Closed+and+resolution+%3D+Fixed+and+fixVersion+%3D+%227.0-milestone-2%22&tempMax=1000]] fixed in this release.
38
39 = For Developers =
40
41 == Mail Sender API Improvements ==
42
43 The [[Mail Sender API>>extensions:Extension.Mail Sender API]] has been improved to allow sending mails to a list of users, a list of groups and a list of email addresses, all at once. It also supports excluding users, groups and email addresses. Last, it ensures that recipients don't get duplicate mails. Before 6.4.2/7.0M2, you could send a mail either to a list of users or to a group (and to an email address) but you had to use several API calls for that and you had to handle yourself potential mail duplication (if a user was inside your user list and inside the group you were sending to for example).
44
45 Using the new API, the following example will send a template email to all the users in the ##XWiki.MyGroup## group, to the ##XWiki.User1## and ##XWiki.User2## users + to the ##john@doe.com## email address.
46
47 Also note that contrary to the previous API to send email to a group, the new API handles nested groups (i.e. if the ##XWiki.MyGroup## group contains other groups, all users of those other groups will also receive the template email)!
48
49 {{code language="none"}}
50 {{velocity}}
51 ## Parameters for the 'template' MimeMessageFactory
52 #set ($templateParameters = {'language' : $xcontext.language, 'velocityVariables' : { 'var1' : 'value1' }})
53
54 #set ($templateReference = $services.model.createDocumentReference('', 'Space', 'MailTemplatePage'))
55 #set ($parameters = {'hint' : 'template', 'parameters' : $templateParameters, 'source' : $templateReference})
56
57 #set ($groupReference = $services.model.createDocumentReference('', 'XWiki', 'MyGroup'))
58 #set ($user1Reference = $services.model.createDocumentReference('', 'XWiki', 'User1'))
59 #set ($user2Reference = $services.model.createDocumentReference('', 'XWiki', 'User2'))
60
61 #set ($source = {'groups' : [$groupReference], 'users' : [$user1Reference, $user2Reference], 'emails' : ['john@doe.com']})
62
63 #set ($messages = $services.mailsender.createMessages('usersandgroups', $source, $parameters))
64 #set ($mailResult = $services.mailsender.send($messages, 'database'))
65 {{/velocity}}
66 {{/code}}
67
68 == Group Member Iterator ==
69
70 A new ##ReferenceUserIterator## iterator has been introduced to iterate over all the users found in a list of users/groups. It supports the following:
71
72 * Ability to iterate over a list of references (either group or user) or a single user/group
73 * Handles nested groups
74 * Ability to return user data (e.g. user's email) and to programatically skip some entries based on programmatic condition
75 * Ability to exclude users/groups
76
77 Notes:
78
79 * Right now duplication is not handled at the level of ##UserIterator## (thus for example if a user is a member of several groups it'll be returned several times).
80 * This code is not performant as it will load one document per group and per user found. There's [[currently no way of handling this in a performant way>>http://jira.xwiki.org/browse/XWIKI-10377]].
81
82 Example 1: List all users of a group by returning references
83
84 {{code language="groovy"}}
85 {{groovy}}
86 import com.xpn.xwiki.internal.plugin.rightsmanager.*
87 import org.xwiki.model.reference.*
88 import org.xwiki.context.*
89
90 def groupReference = new DocumentReference("xwiki", "XWiki", "XWikiAllGroup")
91 def resolver = services.component.getInstance(DocumentReferenceResolver.TYPE_STRING, "explicit")
92 def execution = services.component.getInstance(Execution.class)
93 def iterator = new ReferenceUserIterator(groupReference, resolver, execution)
94 iterator.each() {
95 println "* ${it}"
96 }
97 {{/groovy}}
98 {{/code}}
99
100 Example 2: Get all emails from all users inside the passed groups
101
102 {{code language="groovy"}}
103 {{groovy}}
104 import com.xpn.xwiki.doc.*
105 import com.xpn.xwiki.objects.*
106 import com.xpn.xwiki.internal.plugin.rightsmanager.*
107 import org.xwiki.model.reference.*
108 import org.xwiki.context.*
109
110 def group1Reference = new DocumentReference("xwiki", "XWiki", "XWikiAllGroup")
111 def group2Reference = new DocumentReference("xwiki", "XWiki", "XWikiAdminGroup")
112 def resolver = services.component.getInstance(DocumentReferenceResolver.TYPE_STRING, "explicit")
113 def execution = services.component.getInstance(Execution.class)
114
115 class EmailUserDataExtractor implements UserDataExtractor<String>
116 {
117 public String extractFromSuperadmin(DocumentReference reference)
118 {
119 return null
120 }
121
122 public String extractFromGuest(DocumentReference reference)
123 {
124 return null
125 }
126
127 public String extract(DocumentReference reference, XWikiDocument document, BaseObject userObject)
128 {
129 return userObject.getStringValue("email")
130 }
131 }
132
133 def iterator = new UserIterator([group1Reference, group2Reference], [], new EmailUserDataExtractor(), resolver, execution)
134 iterator.each() {
135 println "* ${it}"
136 }
137 {{/groovy}}
138 {{/code}}
139
140 == Extensions improvement and new features ==
141
142 === Extension category ===
143
144 Each extension can now expose a category (flavor, application, macro...).
145
146 === Advanced extensions search ===
147
148 A new ##org.xwiki.extension.repository.search.AdvancedSearchable## extending ##org.xwiki.extension.repository.search.Searchable## provide field based filtering and ordering to extensions search. It's implemented by default core, local, installed, xar extensions repositories.
149
150 === Advanced extensions search in REST protocol ===
151
152 Support for advanced filtering and ordering or extensions search result has been added XWiki Repository protocol and client. See [[extensions:Extension.Repository Module||anchor="H2Fsearch"]].
153
154 === Custom properties in REST protocol ===
155
156 Support for missing custom properties has been added to the XWiki Repository REST protocol. See [[extensions:Extension.Repository Module||anchor="HREST"]]. Only String properties are supported for now.
157
158 == Deprecated and Retired projects ==
159
160 <description of deprecated and retired projects>
161
162 == Upgrades ==
163
164 The following dependencies have been upgraded:
165
166 * [[Selenium 2.44.0>>http://jira.xwiki.org/browse/XCOMMONS-753]]
167 * [[Arquilian Phantom JS Driver 1.1.3.Final>>http://jira.xwiki.org/browse/XWIKI-11832]]
168 * [[Groovy 2.4.1>>http://jira.xwiki.org/browse/XCOMMONS-755]]
169 * [[JGroups 3.6.2>>http://jira.xwiki.org/browse/XWIKI-11848]]
170 * [[Jython 2.7-b4>>http://jira.xwiki.org/browse/XWIKI-11850]]
171 * [[DBCP 2.1>>http://jira.xwiki.org/browse/XCOMMONS-756]]
172 * [[Pygments 2.0.2>>http://jira.xwiki.org/browse/XWIKI-11864]]
173
174 == Miscellaneous ==
175
176 * $datetool has a new method to access the [[DateFormatSymbols>>http://docs.oracle.com/javase/7/docs/api/java/text/DateFormatSymbols.html]]:(((
177 {{code language="none"}}
178 {{velocity}}
179 #set ($currentLocale = $services.localization.currentLocale)
180 #set ($dateFormatSymbols = $datetool.getDateFormatSymbols($currentLocale))
181 $jsontool.serialize($dateFormatSymbols.shortMonths)
182
183 ## Output for French locale:
184 ## ["janv.","févr.","mars","avr.","mai","juin","juil.","août","sept.","oct.","nov.","déc.",""]
185 {{/velocity}}
186 {{/code}}
187 )))
188 * Message Stream script service now offers a ##getLastError()## method to get the last error.
189 * "input" displayed Static and Database Lists separators handling has been improved to properly allow using multiple separators at once for entering data (including escaped separators inside list values). More importantly, when displaying an existing list inside an input, the existing values will always be separated using the first separator specified in the object's class for the edited object property. For non-relationally stored properties, the value that is stored in the database as a LargeStringProperty will always be separated using the default pipe ("|") separator. See [[XWIKI-10098>>http://jira.xwiki.org/browse/XWIKI-10098]] for more details.
190 * The ##/deleteversions/## action now supports the "latest" and "previous" pseudoversions and the ##/rollback/## action now supports the "previous" pseudoversion. See [[XWIKI-11841>>http://jira.xwiki.org/browse/XWIKI-11841]] for more information.
191
192 = Translations =
193
194 The following translations have been updated:
195
196 {{language codes="none, none"/}}
197
198 = Tested Browsers & Databases =
199
200 {{include reference="TestReports.ManualTestReportSummaryXWiki70M2"/}}
201
202 = Performances tests compared to <last super stable version> =
203
204 <a summary of the comparison with latest super stable version>
205
206 More details on <link to the test report>.
207
208 = Known issues =
209
210 * [[Bugs we know about>>http://jira.xwiki.org/secure/IssueNavigator.jspa?reset=true&jqlQuery=category+%3D+%22Top+Level+Projects%22+AND+issuetype+%3D+Bug+AND+resolution+%3D+Unresolved+ORDER+BY+updated+DESC]]
211
212 = Backward Compatibility and Migration Notes =
213
214 == General Notes ==
215
216 When upgrading make sure you compare your ##xwiki.cfg##, ##xwiki.properties## and ##web.xml## files with the newest version since some configuration parameters may have been modified or added. Note that 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.
217
218 == Issues specific to XWiki 7.0M2 ==
219
220 * The Watchlist class and its objects have been migrated to use relationally stored DBList properties instead of TextArea properties in order to solve scalability issues that occurred when too many elements were being watched by a user. See [[XWIKI-7339>>http://jira.xwiki.org/browse/XWIKI-7339]].
221 * The upgrade to DBCP 2.1 has caused some Hibernate configuration properties to have been removed and new ones created. The following properties have been removed:(((
222 * ##dbcp.maxActive## replaced by ##dbcp.maxTotal##
223 * ##dbcp.maxWait## replaced by ##dbcp.maxWaitMillis##
224
225 Note that we've kept backward compatibility support for the old properties so that you don't need to immediately modify your ##hibernate.cfg## file (although we recommend you do that!).
226
227 Also note that even though the following properties were defined in ##hibernate.cfg## they were not handled by XWiki's code (nor by DBCP 1.3 - which was the version we were using prior to moving to 2.1). Since they had no effect they've now been removed:
228
229 * ##dbcp.whenExhaustedAction##. Note that the default action is BLOCK in Commons Pool (used by DBCP)
230 * ##dbcp.ps.whenExhaustedAction##
231 * ##dbcp.ps.maxWait##
232 * ##dbcp.ps.maxIdle##
233 )))
234
235 == API Breakages ==
236
237 The following APIs were modified since XWiki 6.4.1:
238
239 {{code language="none"}}
240 <clirr output here>
241 {{/code}}

Get Connected