Package com.atomikos.icatch.jta

Source Code of com.atomikos.icatch.jta.UserTransactionManager

             
/*
* Copyright 2000-2008, Atomikos (http://www.atomikos.com)
*
* This code ("Atomikos TransactionsEssentials"), by itself,
* is being distributed under the
* Apache License, Version 2.0 ("License"), a copy of which may be found at
* http://www.atomikos.com/licenses/apache-license-2.0.txt .
* You may not use this file except in compliance with the License.
*            
* While the License grants certain patent license rights,
* those patent license rights only extend to the use of
* Atomikos TransactionsEssentials by itself.
*            
* This code (Atomikos TransactionsEssentials) contains certain interfaces
* in package (namespace) com.atomikos.icatch
* (including com.atomikos.icatch.Participant) which, if implemented, may
* infringe one or more patents held by Atomikos. 
* It should be appreciated that you may NOT implement such interfaces;
* licensing to implement these interfaces must be obtained separately from Atomikos.
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
*/
package com.atomikos.icatch.jta;

import java.io.Serializable;

import javax.naming.NamingException;
import javax.naming.Reference;
import javax.naming.Referenceable;
import javax.transaction.HeuristicMixedException;
import javax.transaction.HeuristicRollbackException;
import javax.transaction.InvalidTransactionException;
import javax.transaction.NotSupportedException;
import javax.transaction.RollbackException;
import javax.transaction.SystemException;
import javax.transaction.Transaction;
import javax.transaction.TransactionManager;

import com.atomikos.icatch.config.TSInitInfo;
import com.atomikos.icatch.config.UserTransactionService;
import com.atomikos.icatch.config.UserTransactionServiceImp;
import com.atomikos.util.SerializableObjectFactory;

/**
*
*
*
*
*
* A straightforward, zero-setup implementation of a transaction manager. J2SE
* applications can use an instance of this class to get a handle to the
* transaction manager, and automatically startup or recover the transaction
* service on first use. <b>J2EE applications should NOT use this class in order
* to avoid the concurrent use of different transaction services. For J2EE
* applications, we have the class J2eeTransactionManager instead.</b>
*/
public class UserTransactionManager implements TransactionManager,
        Serializable, Referenceable
{

    private transient TransactionManagerImp tm;
   
    private UserTransactionService uts;

  private boolean forceShutdown;
 
  private boolean startupTransactionService;
 
  private boolean closed;

    private void checkSetup () throws SystemException
    {
      if ( closed ) throw new SystemException ( "This UserTransactionManager instance was closed already. Call init() to reuse if desired." );
       
        synchronized ( TransactionManagerImp.class ) {

            tm = (TransactionManagerImp) TransactionManagerImp
                    .getTransactionManager ();
            if ( tm == null ) {
                // not initialized -> startup TM
                // System.out.println ( "STARTING UP TM!!!!!!");
                 if ( getStartupTransactionService() ) {
                  uts = new UserTransactionServiceImp ();
                  TSInitInfo info = uts.createTSInitInfo ();
                  uts.init ( info );
                  tm = (TransactionManagerImp) TransactionManagerImp
                          .getTransactionManager ();
                 }
                 else {
                   throw new SystemException ( "Transaction service not running" );
                 }
            }
        }
    }
   
    public UserTransactionManager()
    {
        //startup by default, to have backward compatibility
        this.startupTransactionService = true;
        this.closed = false;
    }
   
    /**
     * Sets whether the transaction service should be
     * started if not already running.
     * @param startup
     */
    public void setStartupTransactionService ( boolean startup )
    {
        this.startupTransactionService = startup;
    }
   
    /**
     * Returns true if the transaction service will
     * be started if not already running.
     * @return
     */
    public boolean getStartupTransactionService()
    {
        return this.startupTransactionService;
    }
   
    /**
     * Performs initialization if necessary.
     * This will startup the TM (if not running)
     * and perform recovery, unless <b>getStartupTransactionService</b>
     * returns false.
     *
     * @throws SystemException
     */
   
    public void init() throws SystemException
    {
          closed = false;
        checkSetup();
    }

    /**
     * @see javax.transaction.TransactionManager#begin()
     */
    public void begin () throws NotSupportedException, SystemException
    {
        checkSetup ();
        tm.begin ();

    }
   
    public boolean getForceShutdown()
    {
        return forceShutdown;
    }
   
    /**
     * Sets the force shutdown mode to use during close.
     * @param value
     */
    public void setForceShutdown ( boolean value )
    {
        this.forceShutdown = value;
    }

    /**
     * @see javax.transaction.TransactionManager#commit()
     */
    public void commit () throws RollbackException, HeuristicMixedException,
            HeuristicRollbackException, SecurityException,
            IllegalStateException, SystemException
    {
        checkSetup ();
        tm.commit ();

    }

    /**
     * @see javax.transaction.TransactionManager#getStatus()
     */
    public int getStatus () throws SystemException
    {
        checkSetup ();
        return tm.getStatus ();
    }

    /**
     * @see javax.transaction.TransactionManager#getTransaction()
     */
    public Transaction getTransaction () throws SystemException
    {
        checkSetup ();
        return tm.getTransaction ();
    }

    /**
     * @see javax.transaction.TransactionManager#resume(javax.transaction.Transaction)
     */
    public void resume ( Transaction tx ) throws InvalidTransactionException,
            IllegalStateException, SystemException
    {
        checkSetup ();
        tm.resume ( tx );

    }

    /**
     * @see javax.transaction.TransactionManager#rollback()
     */
    public void rollback () throws IllegalStateException, SecurityException,
            SystemException
    {
        checkSetup ();
        tm.rollback ();

    }

    /**
     * @see javax.transaction.TransactionManager#setRollbackOnly()
     */
    public void setRollbackOnly () throws IllegalStateException,
            SystemException
    {
        checkSetup ();
        tm.setRollbackOnly ();

    }

    /**
     * @see javax.transaction.TransactionManager#setTransactionTimeout(int)
     */
    public void setTransactionTimeout ( int secs ) throws SystemException
    {
        checkSetup ();
        tm.setTransactionTimeout ( secs );

    }

    /**
     * @see javax.transaction.TransactionManager#suspend()
     */
    public Transaction suspend () throws SystemException
    {
        checkSetup ();
        return tm.suspend ();
    }

    /**
     * @see javax.naming.Referenceable#getReference()
     */
    public Reference getReference () throws NamingException
    {
        return SerializableObjectFactory.createReference ( this );
    }
   
    /**
     * Closes the transaction service, but only if it was
     * implicitly started via this instance.
     * In other words, if the transaction service was started
     * in another way then this method will not do anything.
     *
     */
    public void close()
    {
        if ( uts != null ) {
          uts.shutdown ( forceShutdown );
          uts = null;
        }
        closed = true;
    }

}
TOP

Related Classes of com.atomikos.icatch.jta.UserTransactionManager

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.