[jboss-user] [JBoss Seam] - Re: Spring-injected ManagedHibernateSession
do-not-reply at jboss.com
Fri Nov 17 11:24:49 EST 2006
You need three things, AFAICT:
(1) an way to get the sessionfactory into JNDI, so Seam can use it
(2) a way to inject Seam objects into non-Seam objects
(3) a JTA environment
(1) is easy
(2) is be doable with some spring factories, AFAIK
(3) is the harder bit (problem when outside-of-Java-EE)
Unfortunately for everyone, Spring went ahead and created their whole own nonstandard transaction management API that is a subset of JTA (there was no good reason to do this, of course, but people like to reinvent wheels).
Seam expects a JTA environment (I *don't* like reinventing), and thats what we use JBoss MC for: the JTA and JCA datasource support. With some effort I probably *could* support other transaction APIs than JTA, but why? There is just no good reason to do that, since all transaction APIs that I know of offer less functionality than JTA.
(People have misinterpreted JBoss MC as being a spring-like project but actually its purpose is quite different. The purpose of MC is to let you run infrastructure components like deployers, jta, jca, jndi, etc in an embeddable way. It not really intended for running business logic components. It is really the core microkernel of JBoss 5.)
Now, in a Java EE environment, you already have JTA from the container (and, indeed Spring transactions just map down to JTA transactions, duh). So Seam does not need MC in an EE environment. So in the EE environment, (3) is not a problem.
Outside the EE environment you got a problem, and you need JBoss MC.
View the original post : http://www.jboss.com/index.html?module=bb&op=viewtopic&p=3986876#3986876
Reply to the post : http://www.jboss.com/index.html?module=bb&op=posting&mode=reply&p=3986876
More information about the jboss-user