/* * JBoss, Home of Professional Open Source * Copyright 2006, Red Hat Middleware LLC, and individual contributors * as indicated by the @author tags. * See the copyright.txt in the distribution for a * full listing of individual contributors. * This copyrighted material is made available to anyone wishing to use, * modify, copy, or redistribute it subject to the terms and conditions * of the GNU Lesser General Public License, v. 2.1. * This program is distributed in the hope that it will be useful, but WITHOUT A * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A * PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. * You should have received a copy of the GNU Lesser General Public License, * v.2.1 along with this distribution; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, * MA 02110-1301, USA. * * (C) 2005-2006, * @author JBoss Inc. */ /* * Copyright (C) 2004, * * Arjuna Technologies Ltd, Newcastle upon Tyne, Tyne and Wear, UK. * * $Id: XAResourceErrorHandler.java 2342 2006-03-30 13:06:17Z $ */ package com.arjuna.ats.internal.jta.resources.spi; import javax.transaction.xa.Xid; /** * Extensions to the basic XATerminator spi interface. It is important that * these extensions aren't relied on to drive the normal JCA protocol in case * we're ever embedded in a foreign implementation. * * It would be nice to have these non-XA specific extensions managed by a different * class than the one that deals with the standard XATerminator interface methods, * c.f. JTS/OTS for 2PC and Synchronizations. However, it's a lot easier to just bundle * these together in the same implementation because of the way JCA works. Of course that can * be changed later if necessary and the user(s) won't notice anyway. * * @author marklittle */ public interface XATerminatorExtensions { /* * Synchronizations aren't part of XA, so that's why it would be nice to have these * handled by a separate instance, as well as being architecturally symmetrical with * OTS. But it's not a big deal. Plus, this isn't really symmetrical either, since we * don't need afterCompletion. * * TODO check whether it makes sense to resurrect afterCompletion here for, say, * compensations. */ /** * Call beforeCompletion on the registered instance. Exceptions will cause the transaction * to be set rollback only. * * Note: this will run beforeCompletion even on setRollbackOnly transactions. * Users may wish to avoid calling this method in such cases, or prior to calling rollback. * * @param xid the transaction instance. * @return success (or not). */ public boolean beforeCompletion (Xid xid) throws javax.transaction.SystemException; }