Dan,

Let me address both your comments, and then your questions.

- Both IBM and HP EACH have an implementation of a REST runtime.  We are 
bringing both.  Speaking for the IBM portion, yes - we have something 
which is already compliant.  Apache CXF is both a JAX-WS and JAX-RS 
implementation.  In IBM, our JAX-WS implementation is based on Apache 
Axis2.  Therefore, it was prohibitive to pull in CXF as part of our 
runtime.   IBM wanted/needed something smaller - it's as simple as that. 
Perhaps the answers to your questions may help me position some of this in 
a better light...

1) 
a) IBMs implementation is JAX-RS 1.0 compliant.  With the fact that there 
is now a 1.1 spec - so that's something that needs to be looked at. 
b) one of the things that I see that are missing are more in depth 
examples for how to use JAX-RS in a RESTful fashion.   Getting these 
written up can benefit BOTH projects
c) Some of the message body readers/writers (to handle other mime types 
and programming models) can be shared among both projects.  They should be 
portable
d) There is no client programming model in JAX-RS.  This is something 
which I think is needed as REST services get pushed deeper into the 
enterprise (and away from the presentation tier).  These will help feed 
back changes for a later update to JAX-RS.  Look at Jersey, RESTlet, 
RESTeasy, CXF (they all offer a client API).

This may be a naive assumption, but I do think there are opportunities to 
share capabilities amongst the 2 projects - even letting them pull code 
back and forth.

HP was also working on JAX-RS compliance for their implementation (so - 
again), it would be a melding of the various runtimes (in a lighter 
fashion).

2) 1b, c, d) are examples which we should be able to agree - or get very 
very close on.  Whether we can get to a single implementation (I don't 
know).  If we can figure out how to tease them apart into pieces - 
perhaps.  I haven't, myself, seen the HP code (but our IBM participants 
are willing to do whatever it takes to try and quickly come to a joint 
resolution between the 2 runtimes).

Getting the various teams together at an ApacheCon is a great idea (but 
given the current economic times), I don't know how much it's immediately 
practical.  I'm think the first step is to at least get things on the 
table (i.e. code contributed, discussions formulated, to see how 
close/apart we really are) - and go from there.

My question back to you is, do you think we can pull out the JAX-WS 
capabilities from CXF? 

Regards... Greg

Greg Truty
WebSphere Web Services and REST Architect,  IBM Austin
EMail:     gtr...@us.ibm.com 
Phone:   (ext)  (512) 286-8985
                (Tie) 363-8985



From:
Daniel Kulp <dk...@apache.org>
To:
general@incubator.apache.org
Cc:
Greg Truty/Austin/i...@ibmus, Nicholas L Gallardo/Austin/i...@ibmus, Dustin 
Amrhein/Austin/i...@ibmus, Bryant Luk/Austin/i...@ibmus, Jesse A 
Ramos/Austin/i...@ibmus, Christopher J Blythe/Raleigh/i...@ibmus, "Baram, 
Eliezer" <eba...@hp.com>, el...@hp.com, nadav.fisc...@hp.com, "Snitkovsky, 
Martin" <martin.snitkov...@hp.com>, tali.alsaigh-co...@hp.com, 
tomer.sh...@hp.com, Michael Rheinheimer/Austin/i...@ibmus
Date:
04/22/2009 02:15 PM
Subject:
Re: Apache Wink Proposal



On Wed April 22 2009 1:07:39 pm Greg Truty wrote:
> Hello all, I would like to formally present the incubator proposal for
> Apache Wink, stand-alone REST toolkit supporting JAX-RS (JSR 311), a
> client runtime and test cases (as well as other items). The full 
proposal
> can be found on the wiki at: 
http://wiki.apache.org/incubator/WinkProposal
> .  We are looking forward to all questions and feedback, positive or
> negative.  In addition, we welcome all participants and mentors to help
> support the effort.

I know you are expecting a response from me (I've talked to Dims about 
this 
already) so I might as well get it out of the way....  :-)

So, basically, you wanted a JAX-RS implementation.  You looked at Apache 
CXF 
but it didn't completely meet your needs.   Instead of engaging with CXF 
(there wasn't any discussion about any of this on the CXF dev/users list) 
to 
enhance CXF, you fork it in house and update it and enhance it outside of 
any 
community.   Now you want to push it back into Apache, but not with any of 
the 
CXF community.    I just wanted to get that out in the open.    Two 
implementations isn't a bad thing (think Axis2 and CXF) but the way this 
was 
approached is a concern.

Next come the hard questions:
1) The proposal mentions it's already JAX-RS TCK compliant.   From a 
JAX-RS 
standpoint, were do you see the community "growing"?   I've seen several 
projects that come in with their stated goals already "complete" and have 
a 
tough time getting new committers. 

2) What "advantages" would it have over CXF's implementation and/or 
Jersey? 
(apart from the TCK compliance which CXF is working on now that we got the 

TCK)  Since Wink would be Apache licensed, I'd expect anything "cool" 
would be 
pulled into CXF anyway if possible.    One advantage of multiple Apache 
licensed implementations is that great ideas can also be pulled back and 
forth.   :-)        Obviously, I haven't seen the Wink code so I don't 
know 
how easy/hard that would be.

One "question" I have when I see projects with duplicate goals is to see 
if 
the differences could be resolved to a point where only one project is 
needed. 
I remember with CXF and Axis 2 sitting down in a room at some conference 
several years ago (ApacheCon Austin maybe?  Don't really remember.) with 
Dan 
Diephouse, myself, Glen Daniels, Sanjiva and several others involved with 
both 
projects to try and resolve any issues and possibly merge things.    In 
that 
meeting, we really did conclude we had strong differences in opinions on 
designs, priorities, and ideas and it really wasn't possible.   That is 
quite 
OK.   At least the discussion occurred.     I haven't seen discussions 
like 
that with CXF/Wink. 


I guess from my standpoint, while I'm not "against" the proposal, I'd 
definitely like to see it have the option of "graduating" via a merger 
with 
the CXF implementation and engagements with that community.


-- 
Daniel Kulp
dk...@apache.org
http://www.dankulp.com/blog


Reply via email to