I'm trying to like the specification, but I just can't.
Here's one more reason why:
I have SSB (Stateless Session Beans). The persistence is via JPA (implementation is Hibernate).
All my business method look something like:
...
public Object1 doSomething( Object2 ) throws ApplicationException1;
...
I use CMT (Container Managed Transactions) which means that the container calls begin() before the method call and commit() after the method call is over.
The problem: what happens if the transaction is rolled back?
A RollbackException is thrown. It looks common sense to try to rewrite it as ApplicationException1. Well.... YOU CAN'T.
No F way (at least not an easy one).
Solution1:
Make the Beans stateful and use SessionSynchronization. UGLY - I don't want to be stateful.
Solution2:
Implement TransactionSynchronizationRegistry - just look at it.
Solution3:
Make a facade EJB that calls my own EJBs which should use requiresNew. One more level of abstraction? I have to change the contract? I don't have just one Bean, so a wrapper for every single one of them?
Solution4:
Switch back to BMT (Bean Managed Transactions) and call begin() and commit() myself. Well then the container becomes useless. But my business methods are rarely longer than a few lines, so I'm choosing this one.
CMT without any simple way to plug after commit() and this is an enterprise level spec? Really?
I'd be really happy if someone corrects me and shows me a simple way to do what I need.