All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.atomikos.icatch.config.UserTransactionService Maven / Gradle / Ivy

There is a newer version: 6.0.0
Show newest version
/**
 * Copyright (C) 2000-2010 Atomikos 
 *
 * 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.config;
import java.util.Enumeration;
import java.util.Properties;

import javax.transaction.TransactionManager;
import javax.transaction.UserTransaction;

import com.atomikos.datasource.RecoverableResource;
import com.atomikos.icatch.CompositeTransactionManager;
import com.atomikos.icatch.ExportingTransactionManager;
import com.atomikos.icatch.ImportingTransactionManager;
import com.atomikos.icatch.SysException;
import com.atomikos.icatch.TSListener;
import com.atomikos.icatch.admin.LogAdministrator;

 /**
  *
  *
  *The user's (client program) view of the transaction manager's configuration, 
  *with all the information the client program needs.
  *
  */

public interface UserTransactionService
{
    
 
     
      /**
       *Get the JTA transaction manager handle for the  config.
       *
       *@deprecated Use the UserTransactionManager and
       *J2eeTransactionManager classes instead.
       *
       *@return TransactionManager The JTA transaction manager.
       */
       
     public TransactionManager getTransactionManager();
     
      /**
       *Get the JTA user transaction, for client-demarcated 
       *transactions.
       *
       *@deprecated Use the classes in 
       *package com.atomikos.icatch.jta instead.
       *
       *@return UserTransaction The JTA user transaction.
       *IMPORTANT: the returned instance can be
       *bound in JNDI. In addition, remote clients 
       *can use this instance only if the configuration
       *parameters allow remote client transaction demarcation!
       *
       */
       
     public UserTransaction getUserTransaction();
      
      /**
       *Get the ImportingTransactionManager instance.
       *
       *@return ImportingTransactionManager The instance.
       */
       
     public ImportingTransactionManager getImportingTransactionManager();
     
      /**
       *Get the ExportingTransactionManager instance
       *
       *@return ExportingTransactionManager The instance.
       */
       
     public ExportingTransactionManager getExportingTransactionManager();
     
      
       /**
        *Get the meta data for the transaction service.
        *@return TSMetaData The meta data.
        *@deprecated 
        */
        
     public TSMetaData getTSMetaData();

     /**
      * Create a TSInitInfo for this transaction service.
      * @return  TSInitInfo The init info instance.
      * @deprecated Use the properties-based init method instead.
      */

     public TSInitInfo createTSInitInfo();

	/**
	     *Shuts down the TM.
	     *It is highly recommended that this method be called 
	     *before the VM exits, in order to ensure proper log closing.
	     *After this method completes, all resources will have been removed 
	     *from the configuration, as well as all logadministrators.
	     *To re-initialize, everything should be registered again.
	     *
	     *@param force If true, then shutdown will succeed even if
	     *some transactions are still active. If false, then the calling thread
	     *will block until any active transactions are terminated. A heuristic
	     *transaction is also considered to be active.
	     */
	     
	   public void shutdown ( boolean force ) 
	   throws IllegalStateException;

	/**
	 * Register a new resource for recovery.
	 * 
	 * @param res The resource to be added.
	 * 
	 */
	
	public void registerResource ( RecoverableResource res );
	
	/**
	 * Removes the given resource. This method should be 
	 * used with extreme care, because removing resources
	 * can endanger recovery!
	 * @param The resource to remove.
	 * If the resource is not found then this method does 
	 * nothing.
	 */
	
	public void removeResource ( RecoverableResource res );

	/**
		 *Register a LogAdministrator instance for administration.
		 *This allows inspection of active transactions and manual
		 *intervention.
		 *Care should be taken if multiple instances are registered:
		 *the responsibility of taking conflicting manual decisions is
		 *entirely with the user!
		 *@param admin The instance.
		 */
	      
	  public void registerLogAdministrator ( LogAdministrator admin );
	  
	  /**
	   * Removes the given log administrator. Does nothing if 
	   * the instance is not found.
	   * @param admin
	   */
	  public void removeLogAdministrator ( LogAdministrator admin );
	  
	  /**
	   * Registers a listener with the transaction service.
	   * @param listener
	   */
	  public void registerTSListener ( TSListener listener );
	  
	  /**
	   * Removes a listener from the transaction service.
	   * After this method is called, the listener in question
	   * will no longer receive callback notifications from the
	   * transaction service.
	   * This method does nothing if the listener is not found.
	   * @param listener 
	   */
	  public void removeTSListener ( TSListener listener );

	/**
	     *Initializes the intra-VM transaction manager.
	     *
	     *@param info The TSInitInfo with details for initialization.
	     *@deprecated Use the property-based init method instead.
	     */
	       
	   public void init ( TSInitInfo info )
	   throws SysException;
	   
	   public void init ( Properties properties ) throws SysException;

	/**
	  *Get the resources registered.
	  *@return Enumeration The resources, or empty if none.
	  *
	  */
	
	public Enumeration getResources();

	/**
	  *Get the log administrators.
	  *@return Enumeration The registered administrators.
	  *
	  */
	
	public Enumeration getLogAdministrators();

	/**
	     *Get the composite transaction manager for the config.
	     *
	     *@return CompositeTransactionManager The composite
	     *transaction manager.
	     */
	     
	   public CompositeTransactionManager 
	   getCompositeTransactionManager();
     

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy