Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
   * JBoss, Home of Professional Open Source.
   * Copyright 2011, Red Hat, Inc., and individual contributors
   * as indicated by the @author tags. See the copyright.txt file in the
   * distribution for a full listing of individual contributors.
   *
   * This is free software; you can redistribute it and/or modify it
   * under the terms of the GNU Lesser General Public License as
   * published by the Free Software Foundation; either version 2.1 of
  * the License, or (at your option) any later version.
  *
  * This software is distributed in the hope that it will be useful,
  * but WITHOUT ANY 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 along with this software; if not, write to the Free
  * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
  * 02110-1301 USA, or see the FSF site: http://www.fsf.org.
  */
 
 package org.jboss.as.ejb3.remote.protocol.versionone;
 
 

Author(s):
Jaikiran Pai
 
 
     private static final Logger logger = Logger.getLogger(XidTransactionPrepareTask.class);
 
     XidTransactionPrepareTask(final TransactionRequestHandler txRequestHandlerfinal EJBRemoteTransactionsRepository transactionsRepository,
                               final MarshallerFactory marshallerFactoryfinal XidTransactionID xidTransactionID,
                               final ChannelAssociation channelAssociationfinal short invocationId) {
 
         super(txRequestHandlertransactionsRepositorymarshallerFactoryxidTransactionIDchannelAssociationinvocationId);
     }
 
     @Override
     public void run() {
         try {
             this.manageTransaction();
         } catch (Throwable t) {
             try {
                 // write out a failure message to the channel to let the client know that
                 // the transaction operation failed
                 .writeException(this.this.this.tnull);
             } catch (IOException e) {
                 .error("Could not write out message to channel due to"e);
                 // close the channel
                 IoUtils.safeClose(this..getChannel());
             }
             return;
         }
 
     }
 
     @Override
     protected void manageTransaction() throws Throwable {
         final int prepareResult = this.prepareTransaction();
         // write out the "prepare" result
         try {
             .writeTxPrepareResponseMessage(this.this.prepareResult);
         } catch (IOException e) {
             .error("Could not write out invocation success message to channel due to"e);
             // close the channel
             IoUtils.safeClose(this..getChannel());
         }
     }
 
 
     private int prepareTransaction() throws Throwable {
         // first associate the tx on this thread, by resuming the tx
         final Transaction transaction = this..getTransaction(this.);
         if(transaction == null) {
             if(..isDebugEnabled()) {
                 //this happens if no ejb invocations where made within the TX
                 ..debug("Not preparing transaction " + this. + " as is was not found on the server");
             }
            return .;
        }
        this.resumeTransaction(transaction);
        try {
            // now "prepare"
            final Xid xid = this..getXid();
            // Courtesy: com.arjuna.ats.internal.jta.transaction.arjunacore.jca.XATerminatorImple
            final SubordinateTransaction subordinateTransaction = SubordinationManager.getTransactionImporter().getImportedTransaction(xid);
            int result = subordinateTransaction.doPrepare();
            switch (result) {
                case .:
                    // TODO: Would it be fine to not remove the xid? (Need to understand how the subsequent
                    // flow works)
                    SubordinationManager.getTransactionImporter().removeImportedTransaction(xid);
                    return .;
                case .:
                    return .;
                case .:
                    // the JCA API spec limits what we can do in terms of reporting
                    // problems.
                    // try to use the exception code and cause to provide info
                    // whilst
                    // remaining API compliant. JBTM-427.
                    Exception initCause = null;
                    int xaExceptionCode = .;
                    try {
                        subordinateTransaction.doRollback();
                    } catch (HeuristicCommitException e) {
                        initCause = e;
                        xaExceptionCode = .;
                    } catch (HeuristicMixedException e) {
                        initCause = e;
                        xaExceptionCode = .;
                    } catch (SystemException e) {
                        initCause = e;
                        xaExceptionCode = .;
                    } catch (final HeuristicRollbackException e) {
                        initCause = e;
                        xaExceptionCode = .;
                    }
                    // remove the transaction
                    SubordinationManager.getTransactionImporter().removeImportedTransaction(xid);
                    final XAException xaException = new XAException(xaExceptionCode);
                    if (initCause != null) {
                        xaException.initCause(initCause);
                    }
                    throw xaException;
                case .:
                    throw new XAException(.);
                default:
                    throw new XAException(.);
            }
        } finally {
            // disassociate the tx that was associated (resumed) on this thread.
            // This needs to be done explicitly because the SubOrdinationManager isn't responsible
            // for clearing the tx context from the thread
            this..getTransactionManager().suspend();
        }
    }
New to GrepCode? Check out our FAQ X