Hi Vincent, hi all,
I tried to explain below which advantages I see in reusing JCR concepts
as much as possible.
Vincent Massol wrote:
ok I'll try to summarize my current thinking after
all the exchanged
emails:
* I don't think we should model our Model classes using a similar API
as the JCR one. I much prefer we have an expressive Model with a
strongly typed API, with objects like Document, Space, MetaData,
Farm, Wiki, etc. Stephane, I keep turning this in my head and I can't
figure a good reason to have a JRC like API for our model. Maybe
you're seeing something that I don't see? Ludovic also said "[...]
quite a few benefits to have our objects comply with the JCR model".
I don't see them so maybe someone could enlighten me.
I agree we need in any case an expressive model that will capture the
specific features of XWiki. However, since a significant part of XWiki
features are already quite well expressed by the JCR API, we could take
into account the well thought and well accepted JCR content manipulation
concepts and APIs such as Node, NodeDefinition, NodeType, Property,
PropertyDefinition, PropertyType, Workspace, Session, for adopting the
following methodology: we could consider the current version of the JCR
as a set of services to be supplemented with services that we're missing
for building XWiki features, introducing specific concepts only when
necessary. In that sense, I agree with Luis for saying that the JCR is a
possible "metamodel" for our specific XWiki model. As Ludovic also
pointed out earlier in this thread, we should not reduce the JCR to a
storage API, since it is is a general API for representing operations on
content, and is, as such, an API that models well part of our
application behaviour.
Note about Session: Session is not part of the data model indeed, but I
think it's a handy class to be present at the model level, avoiding to
pass the context to each method of the data model classes, as opposed to
the current XWiki API.
However, the JCR has drawbacks as well, and it is obviously missing
important features needed for XWiki:
- the JCR is too monolithic: all the services live in the same API, and
new services cannot easily be added. Moreover, the API provides several
identical functionalities from different places (redundant API
example: a node can be moved from different classes: Session and Workspace).
- the JCR is lacking a service for advanced management of properties:
for instance, it's not possible with the JCR API to get all the
back-references to a Node.
- the JCR is obviously missing other services that we need for XWiki.
Following a discussion with Mikhail, my proposal would be the following:
Step 1: we split the JCR into the following services(to be possibly
submitted as a JCR evolution proposal later on):
- StorageService for atomic types including binaries
- ContentMonitoringService
- LockService
- IndexingService
- RepositoryAccessControlService
- QueryService
- XMLExportService
- VersioningService
- TransactionService
- TypedPropertyService
- DirectReferenceService
- [...] probably others
Step 2: implement those services using an existing JCR implementation,
and also possibly using our own implementation, reusing the
XWikiHibernateStore and the surrounding classes.
Step 3: supplement these content services with the property management
services we're missing for dealing with our XClass functionalities,
but not introducing any specific XWiki concept at this stage. The
advantage of having those services as extensions to the JCR instead of
having them at the XWiki level is that the services would remain as
generic as possible while providing easy interoperability with the JCR.
Complementing the JCR with services providing advanced management of
node properties is a topic that is currently of high interest to several
communities. Participating in that effort may lead to a sound
and standard API, implemented by several vendors, XWiki among others,
and may make our community a strategic one among the emerging semantic
web content repository initiatives. The needs for these supplementary
services are well captured by the idea of a "Semantic Web Content
Repository" in the slides below by Max Völkel [1],[2] and are mentioned
in a recent email to the jackrabbit-dev list [3].
[1]
http://swecr.googlecode.com/files/2007-03-12-SWECR-2.pdf
[2] SWECR project:
http://code.google.com/p/swecr/
[3]
http://www.mail-archive.com/dev@jackrabbit.apache.org/msg05524.html
The services we're speaking about are typically the following:
- ReferenceService (for manipulating object properties)
- SparqlService (if we go for RDF for representing our classes and
instances)
- IdentityService (ID/URI mapping)
- InferenceService
They should in particular cover the use cases described by
Sergiu in a previous post, which are of great relevance indeed [4].
Cognium Systems has expressed interest for co-developing such services
with us, in an Apache License-like.
[4]
http://www.nabble.com/Re%3A--ArchitectureV2--Model-proposal-p10865097.html).
Step 4: specify the specific XWiki services for dealing with structured
and unstructured data as complementary services to the SWECR, and design
an expressive model describing XWiki specific artifacts on top of the SWECR.
Step 5: implement these services on top of an SWCR implementation
Step 6: design and implement the other XWiki services (i.e. all those
that do not directly relate to content manipulation).
As a summary, here are two schematic stacks of models and services for
comparing the two approaches we're discussing, as I understand them.
Approach 1 stack
================
XWiki services
---------------------------
XWiki type model:
XClass, XProperty
---------------------------
XWiki document model:
Document, Space, Attachment,
Wiki, Farm
---------------------------
XWiki persistence service:
Data Access Objects
---------------------------
JCR impl.|Relational impl.|...
Advantages:
- we can quite easily implement several storages (JCR, relational
storage) using Data Access Objects
- the model is quite close to the existing one
- we don't modify the JCR
Cons:
- the management of types and properties is not generic
- people used to the JCR concepts have a complete new model to learn,
without clear correspondance between XWiki concepts and JCR concepts
- we have no obvious reason to participate in content management
standardization efforts
Approach 2 stack
================
XWiki services
--------------------------
XWiki document model
---------------------------
SWCR services:
- Type/Property services
- JCR services splitted into
serveral ones
----------------------------
JCR document model, JCR type model
---------------------------
JCR impl.|Relational storage impl|...
Pros:
- genericity of the property/types services
- we embrace the JCR movement, and take part in its evolution
- we take part in the emerging area of semantic web content repositories
and the design of standard Semantic Web APIs complementing the JCR
Cons:
- larger effort
- probably harder to implement a compatibility layer with XWiki 1.0 API
- bigger performance risks
Stéphane
* Our model classes should call the storage interface for any methods
requiring storage access (for example: Space.getDocuments()). If
other services are required they should be called out too. We still
need to define a rule for when a new method can be added to the model
classes and when a new component should rather be created. I have
some ideas but I'm not 100% sure here so I'd like to hear what you
think.
* I think it would be a good idea to have our model defined
independently of the language (for example in XML - Here's for
example the Maven model defined in xml:
http://svn.apache.org/repos/asf/maven/components/trunk/maven-model/src/main…
The reason is that this will allow us to generate lots of things from
this model: - Java bindings - XSD - Documentation - Any other
language bindings - etc
We could use Modello for doing this. It's well integrated into Maven2
and is easy to use.
* I don't think we should use JPOX. Jason, whom I trust, says it's
been a bad decision for Continuum (they use jpox) and that there are
only 2 active developers for jpox which makes bugs take time to fix,
etc. In addition, I'm not sure what this would buy us as I think we
should have storage interface and a JCR implementation of it that
would map to whatever underlying store is configured. Not sure where
we would fit JPOX in there.
WDYT?
Thanks -Vincent
On May 28, 2007, at 9:38 AM, Vincent Massol wrote:
Hi,
Starting from today I'm going to spend some time every week on the
V2 Architecture/Redesign. Today I'd like to start at the heart of
the topic with the domain model. Here's my proposal:
* Model classes are classes representing the XWiki model. The main
classes are: - Farm - Wiki - Space - Document - XObject - XClass -
(probably lots of others) * As you can see I'd like to introduce
the Space and Farm objects * We create a model/ build module in
trunks-devs/xwiki/model for storing model classes * Model classes
cannot access other classes outside of the model/ module. They are
meant to be used by components to provide services but they
shouldn't provide services themselves. They can methods to
manipulate their fields and they can call each other but they
cannot call outside of their model. * We use the org.xwiki.model
package for storing Model classes * These model classes are all
user public (API)
WDYT?
Barring any negative feedback I'll start implementing this today
and in the coming days. One question that remains unanswered in my
mind is how do we integrate back these model classes into the V1
architecture. I think we should be able to retrofit the existing
classes to use these classes by composition. For example the
Document object could have 2 fields: one org.xwiki.model.Document
and one org.xwiki.model.Space. The XWiki object could have 2
fields: Wiki and Farm, etc. I'm not sure how this would work out
though. Any idea is welcome.
Thanks -Vincent
-- You receive this message as a subscriber of the
xwiki-dev(a)objectweb.org mailing list. To unsubscribe:
mailto:xwiki-dev-unsubscribe@objectweb.org For general help:
mailto:sympa@objectweb.org?subject=help ObjectWeb mailing lists
service home page:
http://www.objectweb.org/wws
--
Stéphane Laurière
slauriere(a)xwiki.com
XWiki Research
http://www.xwiki.com
http://concerto.xwiki.com
http://nepomuk.semanticdesktop.org