XWiki Enterprise 2.2

Version 27.1 by Sergiu Dumitriu on 2010/02/16

This release contains many important UI improvements of existing features (xar import, user registration, comments, 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.

New and Noteworthy (since XWiki Enterprise 2.1.2)

New XAR Import UI

The XAR import interface has been completely revamped. The new interface (see screenshots below) now provides:

  • More explicit options regarding revision history handling
  • The new option to add a new version to existing documents instead of overriding them
  • A rich UI that allows to select/unselect whole spaces at once
  • Support for importing when no javascript is available. The UI degrades nicely to a less rich interface

import.png

UI for Deleted documents & attachments

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.

trash1.png

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.

trash2.png

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.

trash3.png

New Profile & WatchList UI

  • Complete overhaul of the Profile UI: better display of the user information, recent changes by the user are shown, different tabs for user details, user settings, and watchlist information

    profile.png

  • Improved inline-based editing for modifying profile details

    profileedit.png

  • Inclusion of the WatchList manager page into the Profile as a tab

    watchlist.png

    • Added a tab in the Profile for managing user preferences, which is currently rather small, but will be improved later to include more settings

      preferences.png

      preferencesedit.png

    • User profiles have been converted to XWiki Syntax 2.0

    New Registration page, new CAPTCHA implementation

    registration.png

    • Ability to display a Captcha for spam prevention.
    • All fields are checked by client-side script as the user types, then checked by the server for security.
    • One-click login after registration.

      autologin.png

    • Easy for administrators to add new fields, configuration with code.
    • The registration page can be imported/edited without programming rights, allowing easier customization of the registration in a wiki farm
    • Works on older wikis if LiveValidation is imported (Captcha won't appear)

    New Menu in Edit mode

    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).

    editmenu.png

    Comments UI improvements

    Preview comment

    The users have the possibility to preview their comment before submitting it. A current known limitation is that the preview does not work for unauthenticated users.

    commentpreview.png

    commentpreviewing.png

    Edit comment

    The users have the possibility to edit their comments. This only works for authenticated users, since there is no way of knowing which unauthenticated user created a guest comment.

    commentedit.png

    commentediting.png

    WYSIWYG and Rendering improvements

    • Add API to find the syntax of the executing document from scripts
    • Macros descriptors can now be translatated

    wysiwygl10n.png

    wysiwygl10n2.png

    General UI improvements

    • In the wiki source code viewer, allow to toggle line numbers faster from Javascript
    • Enable full screen view when displaying the wiki source code (viewer=code)
    • ActionMenu: Add Profile submenu item to the "current user" menu

      usermenu.png

    • Reorder the document actions in the "More actions" menu: copy, rename, delete

      moreactionsmenu.png

    • More UI components make use of the (recently introduced) color theme
    • All panels have nice readable names
    • Allow to copy a document's default language + all translations in the copy menu action

      copyl10n.png

    Contextual wikimacros

    Previously, wiki macros 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.

    New Model module with Reference implementation

    The goal is to provide APIs 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.

    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).

    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.

    Development improvements

    • Added support for "xcontext" binding in 1.0 groovy macro
    • Allow set to null in velocity
    • Add an API method for creating a LinkedHashMap
    • New APIs for accessing deleted attachments from the trash
    • The class wizard should propose to add a SheetClass object to the class sheet
    • Add support for 'on page' style extensions

    Office import improvements

    • Added support for Office2007 document formats

    Blog improvement

    • Added the Create a new post to category pages - when used by default select that category

    Dependencies upgrade

    • Upgraded to Groovy 1.7
    • Upgrade to GWT 2.0.0

    Miscellaneous

    • Always use UTF-8 for URL encoding
    • Attachments should produce document modification events
    • New user profile pages are created in XWiki Syntax 2.0
    • New zh_TW translation
    • Lots of accessibility fixes
    • Lots of bugs fixes

    Known issues

    Backward Compatibility and Migration Notes

    Important non-compatible changes

    Warning

    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.

    Warning

    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.

    This means that the following script will generate a different result:

    #set($s = 'abc')
    $s
    #set($s = $util.null)
    $s

    While previously the result would have been abc abc, now it is abc $s.

    Special care must be taken care with constructs like the following:

    #set($var = '')
    #set($var = $xwiki.methodThatMightReturnNull())
    #if($var != '')
      The method succeeded
    #else
      The method failed
    #end

    Since null != '' in Velocity, now a different branch will be executed. The following rewrites work.

    Works in both modes, with or without null allowed:
    #set($var = '')
    #set($var = $xwiki.methodThatMightReturnNull())
    #if("$!var" != '')
      The method succeeded
    #else
      The method failed
    #end

    Works only in the new mode, with null allowed, but is shorter, slightly faster, and more familiar for java developers:
    #set($var = $xwiki.methodThatMightReturnNull())
    #if($!var != $util.null)
      The method succeeded
    #else
      The method failed
    #end

    Captcha

    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).

    Removed pages

    • Main.RecentMembers as been removed from default XWiki Enterprise xar

    General Notes

    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,....

    You may also want to import the default wiki XAR in order to benefit from the improvements listed above.

    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.

    Migration Notes

    • The new parser/serializer for document names comes with new features and changes some behaviors:
      • introducing escaping means:
        • \ which is now the escaping character needs to be doubled in full document name, as in Space.Docu
          ment
          , which means space Space and document Docu\ment
        • 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
      • 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
    • 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.
    • CoreConguration#getSyntax now returns a Syntax object instead of a String

    Dependencies

    This release includes the following modules in the specified versions since XWiki Enterprise 2.1.2 was released.

    Core/Web

    Group IdArtifact IdNew VersionOld VersionJIRA URL
    com.xpn.xwiki.platformxwiki-*2.22.1.2jira
    org.xwiki.platformxwiki-*2.22.1.2jira

    Applications

    Group IdArtifact IdNew VersionOld VersionJIRA URL
    com.xpn.xwiki.platform.applicationsxwiki-application-administration1.261.21jira
    com.xpn.xwiki.platform.applicationsxwiki-application-blog1.201.18jira
    com.xpn.xwiki.platform.applicationsxwiki-application-officeimporter1.131.12jira
    com.xpn.xwiki.platform.applicationsxwiki-application-panels1.341.30jira
    com.xpn.xwiki.platform.applicationsxwiki-application-scheduler1.161.15jira
    com.xpn.xwiki.platform.applicationsxwiki-application-statistics1.61.5jira
    com.xpn.xwiki.platform.applicationsxwiki-application-tag1.101.8jira
    com.xpn.xwiki.platform.applicationsxwiki-application-watchlist1.261.23jira
    com.xpn.xwiki.platform.applicationsxwiki-application-webdav1.31.2jira
    com.xpn.xwiki.platform.applicationsxwiki-application-wiki-macro-bridge1.31.2jira

    Plugins

    Group IdArtifact IdNew VersionOld VersionJIRA URL
    com.xpn.xwiki.platform.pluginsxwiki-plugin-activitystream1.61.5jira
    com.xpn.xwiki.platform.pluginsxwiki-plugin-jodatime1.31.3jira
    com.xpn.xwiki.platform.pluginsxwiki-plugin-lucene1.161.12jira
    com.xpn.xwiki.platform.pluginsxwiki-plugin-mailsender1.131.13jira
    com.xpn.xwiki.platform.pluginsxwiki-plugin-scheduler1.161.15jira
    com.xpn.xwiki.platform.pluginsxwiki-plugin-skinx1.131.12jira
    com.xpn.xwiki.platform.pluginsxwiki-plugin-tag1.101.8jira
    com.xpn.xwiki.platform.pluginsxwiki-plugin-watchlist1.261.23jira

    Skins

    Group IdArtifact IdNew VersionOld VersionJIRA URL
    com.xpn.xwiki.platform.skinsxwiki-skin-albatross1.271.26jira
    com.xpn.xwiki.platform.skinsxwiki-skin-colibri1.12.11.8jira
    com.xpn.xwiki.platform.skinsxwiki-skin-toucan1.321.31jira

    Top Level POM

    Group IdArtifact IdNew VersionOld Version
    com.xpn.xwiki.platformxwiki2929

    Tools

    Group IdArtifact IdNew VersionOld VersionJIRA URL
    org.xwiki.platform.toolsxwiki-configuration-resources1.361.36jira
    org.xwiki.platform.toolsxwiki-jetty-resources1.171.17jira
    org.xwiki.platform.toolsxwiki-license-resources1.11.1jira
    org.xwiki.platform.toolsxwiki-packager-plugin1.151.15jira
    org.xwiki.platform.toolsxwiki-rootwebapp1.31.3jira
    org.xwiki.platform.toolsstandards-validator1.11.1jira
    org.xwiki.platform.toolsxwiki-xar-handlers1.91.9jira
    org.xwiki.platform.toolsxwiki-xar-plugin1.131.13jira
    org.xwiki.platform.toolsxwiki-verification-resources1.151.14jira

Get Connected