[xwiki-devs] XWiki CRUD

Ludovic Dubost ludovic at xwiki.com
Mon Apr 7 16:44:27 CEST 2008


I've done some experiments to improve applications creating in XWiki.

Here is a proposal to allow CRUD (Create, Read, Update, Delete) in XWiki 
in a more easy manner.

The proposal is also available here: 
http://dev.xwiki.org/xwiki/bin/view/Design/XWikiCRUD

The idea is to be able to control all this from an XWiki Class. Some 
configuration fields would be available for the edit class user interface.

Let's take the following use case of creating a client database:

- the developer would define an XWiki class with the field describing 
the clients:  name, address, client type, city, country
- the developer would choose in the XWiki class the default space to 
hold the client documents:  Clients
- the developer would choose an alias for the URL to access the CRUD 
features:  clients
- the developer would choose optionnaly to override sheets for the view, 
edit, create, search, list actions
- the developer would choose optionnaly validation controls for the 
fields or for the whole class (would be used by the create and edit 
forms automatically)
- the developer would choose optionnaly which fields should be visible 
on the view/edit form and the list/search results
- the developer would choose the field to be used to generate the wiki 
page name for the created documents. If none is set a counter would be used.

By doing this. automatically would be made available the following URLs:

- /xwiki/bin/clients/create

This URL would show the creation form. It would either be the standard 
one showing the visible fields or the custom form defined in the Create 
sheet. This is currently equivalent to the 2 step process to create a 
document with a form. It would be in one step, thanks to the automatic 
generating of page name using the field in the settings. The document 
would automatically be created in the space specified in the class settings.

/xwiki/bin/clients/view/PageName or /xwiki/bin/clients/PageName

This URL would show the view form. It would either be the standard one 
showing the visible fields or the custom form defined in the Create 
sheet. This is equivalent to the current document view of a document 
with a form. Now it would not be necessary to add #includeForm in the 
content of the document. The content field would still be usable.

The wiki document would still be available through it's standard 
document URL in the space where it is. We would need to decide if we 
automatically redirect one URL to the other.
/xwiki/bin/clients/edit/PageName

This URL would show the edit form. It would either be the standard one 
showing the visible fields or the custom form defined in the Create 
sheet. This is equivalend to the inline view of a document with a form. 
Now it would not be necessary to add #includeForm in the content of the 
document. The content field would still be usable.

/xwiki/bin/clients/list or /xwiki/bin/clients/

This URL would allow to show a list of documents with pagination. It 
would show the columns specified in the class settings. This is 
equivalent to velocity script we usually create to show the list of 
documents matching a class.

/xwiki/bin/clients/search

This URL would allow to show a search interface allowing to choose 
multiple criterias and search for documents of the class. The results 
would be similar to the list action.

Automatically similar actions would return the same results in XML, RSS 
or JSON giving a REST interface to the data of the class. The results 
from these forms would also be available through easy to use velocity 
macros to be used in other places of the XWiki site.
 

Some questions are still open:

- In this scheme, the pages are still available through 2 URLs. We could 
decide the alias is the space name (automatically) and then the "create, 
search, list" would be implicit page names in the space. The normal page 
name URL could be used instead of the new view and edit URLs. The skins 
can handle this and look for the class params as long as there is some 
information telling us with class information to use.
- The URLs are inverted versus our current URL scheme. An approach could 
be to stay with the current way to handle URLs and add the create, 
search, list actions on a space with our without using the alias but the 
space name.

Without alias (only one class by space)
     /xwiki/bin/create/Clients/
     /xwiki/bin/list/Clients/
     /xwiki/bin/search/Clients/
With alias (with multiple classes per space, but conflict between alias 
and space name in view and edit mode):
     /xwiki/bin/create/clients/
     /xwiki/bin/list/clients/
     /xwiki/bin/search/clients/

Any ideas, suggestions, remarks ?

-- 
Ludovic Dubost
Blog: http://blog.ludovic.org/
XWiki: http://www.xwiki.com
Skype: ldubost GTalk: ldubost



More information about the devs mailing list