Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
   * 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) 1998, 1999, 2000, 2001,
  *
  * Arjuna Solutions Limited,
  * Newcastle upon Tyne,
  * Tyne and Wear,
  * UK.
  *
  * $Id: IndirectRecoverableConnection.java 2342 2006-03-30 13:06:17Z  $
  */
 
 package com.arjuna.ats.internal.jdbc;
 
 
 import  javax.transaction.Transaction;
 
This class is responsible for maintaining connection information in such a manner that we can recover the connection to the XA database in the event of a failure.

Author(s):
Mark Little (mark@arjuna.com)
Version:
$Id: IndirectRecoverableConnection.java 2342 2006-03-30 13:06:17Z $
Since:
JTS 2.0.
 
 
 {
 
     public IndirectRecoverableConnection () throws SQLException
     {
 	if (..isTraceEnabled()) {
         ..trace("IndirectRecoverableConnection.IndirectRecoverableConnection ()");
     }
 
 	 = null;
 	 = null;
 	 = null;
 	 = null;
 	 = null;
 	 = null;
 	 = null;
 	 = null;
     }
 
     public IndirectRecoverableConnection (String dbNameString user,
 				     String passwd,
 				     ConnectionImple connthrows SQLException
     {
 	if (..isTraceEnabled()) {
         ..trace("IndirectRecoverableConnection.IndirectRecoverableConnection ( " + dbName + ", " + user + ", " + passwd + " )");
     }
 
 	 = dbName;
 	 = user;
 	 = passwd;
 	 = null;
 	 = null;
 	 = null;
 	 = null;
 
 	/*
 	 * Create a jndi specific modifier first, so that we can then
	 * use this to find out what the end-point datasource really
	 * is.
	 */
	 = jndiModifier.initialise();
	 = null;
    }
    public void finalize ()
    {
	try
	{
	    if ( != null)
	    {
	    }
	}
	catch (SQLException e)
	{
	}
    }
    public boolean packInto (OutputObjectState os)
    {
	if (..isTraceEnabled()) {
        ..trace("IndirectRecoverableConnection.packInto ()");
    }
	try
	{
	    os.packString();
	    os.packString();
	    os.packString();
	    return true;
	}
	catch (Exception e)
	{
	    return false;
	}
    }
    public boolean unpackFrom (InputObjectState os)
    {
	if (..isTraceEnabled()) {
        ..trace("IndirectRecoverableConnection.unpackFrom ()");
    }
	try
	{
	     = os.unpackString();
	     = os.unpackString();
	     = os.unpackString();
	    return true;
	}
	catch (Exception e)
	{
	    return false;
	}
    }
    public String getDatabaseName ()
    {
	return ;
    }
    public XAResource getResource () throws SQLException
    {
	if (..isTraceEnabled()) {
        ..trace("IndirectRecoverableConnection.getResource ()");
    }
	try
	{
	    if ( == null)
	    return ;
	}
	catch (Exception e)
	{
        SQLException sqlException = new SQLException(e.toString());
        sqlException.initCause(e);
	    throw sqlException;
	}
    }
    public final void close ()
    {
    }
    public final void reset ()
    {
    }
    public boolean setTransaction (javax.transaction.Transaction tx)
    {
	synchronized (this)
	{
	    if ( == null)
	    {
		return true;
	    }
	}
	/*
	 * In case we have already set it for this transaction.
	 */
	return validTransaction(tx);
    }
    public boolean validTransaction (javax.transaction.Transaction tx)
    {
	boolean valid = true;
	if ( != null)
	    valid = .equals(tx);
	return valid;
    }
    /*
     * If there is a connection then return it. Do not create a
     * new connection otherwise.
     */
    public XAConnection getCurrentConnection () throws SQLException
    {
    }
    public void closeCloseCurrentConnection() throws SQLException
    {
        synchronized (this)
        {
            if ( != null)
            {
                .close();
                 = null;
            }
        }
    }
    public XAConnection getConnection () throws SQLException
    {
	if (..isTraceEnabled()) {
        ..trace("IndirectRecoverableConnection.getConnection ()");
    }
	try
	{
	    synchronized (this)
	    {
		if ( == null)
		{
		}
	    }
	    return ;
	}
	catch (Exception e)
	{
	    e.printStackTrace();
        SQLException sqlException = new SQLException(e.toString());
        sqlException.initCause(e);
	    throw sqlException;	}
    }
    public XADataSource getDataSource () throws SQLException
    {
	if (..isTraceEnabled()) {
        ..trace("IndirectRecoverableConnection.getDataSource ()");
    }
    }
    public boolean inuse ()
    {
	return (boolean) ( != null);
    }
    public String user ()
    {
	return ;
    }
    public String password ()
    {
	return ;
    }
    public String url ()
    {
	return ;
    }
    public String dynamicClass ()
    {
	return "";
    }
    public String dataSourceName ()
    {
	if ( != null)
	    return .toString();
	else
	    return "";
    }
    public Transaction transaction ()
    {
    }
    public void setModifier (ConnectionModifier cm)
    {
	if ( != null)
    }
    
    private final void createDataSource () throws SQLException
    {
	try
	{
	    if ( == null)
	    {
    		Hashtable env = jdbcPropertyManager.getJDBCEnvironmentBean().getJndiProperties();
            Context ctx = new InitialContext(env);
             = (XADataSourcectx.lookup();
		}
		if ( == null) {
	    }
	}
	catch (SQLException ex)
	{
	    throw ex;
	}
	catch (Exception e)
	{
        ..error(e);
        SQLException sqlException = new SQLException(e.toString());
        sqlException.initCause(e);
	    throw sqlException;	}
    }
    private final void createConnection () throws SQLException
    {
	try
	{
	    if ( == null)
	    if (( == null) && ( == null))
	    else
	}
	catch (SQLException ex)
	{
	    throw ex;
	}
	catch (Exception e)
	{
	    e.printStackTrace();
        SQLException sqlException = new SQLException(e.toString());
        sqlException.initCause(e);
	    throw sqlException;	}
    }
    /*
     * Warning; roadworks ahead!!
     *
     * For some reasons JNDI uses different property names internally for
     * specifying things like the initial context to those it expects
     * users to manipulate. Why?! There are some really stupid people
     * at Sun!!
     */
    private final String translate (String name)
    {
	try
	{
	    if (name.equals("Context.APPLET"))
		return .;
	    if (name.equals("Context.AUTHORITATIVE"))
	    if (name.equals("Context.BATCHSIZE"))
	    if (name.equals("Context.DNS_URL"))
	    if (name.equals("Context.INITIAL_CONTEXT_FACTORY"))
	    if (name.equals("Context.LANGUAGE"))
	    if (name.equals("Context.OBJECT_FACTORIES"))
	    if (name.equals("Context.PROVIDER_URL"))
	    if (name.equals("Context.REFERRAL"))
	    if (name.equals("Context.SECURITY_AUTHENTICATION"))
	    if (name.equals("Context.SECURITY_CREDENTIALS"))
	    if (name.equals("Context.SECURITY_PRINCIPAL"))
	    if (name.equals("Context.SECURITY_PROTOCOL"))
	    if (name.equals("Context.STATE_FACTORIES"))
	    if (name.equals("Context.URL_PKG_PREFIXES"))
	}
	{
	    // name is null
	}
	return name;
    }
    private String                        _dbName;
    private String                        _user;
    private String                        _passwd;
    private XAConnection                  _theConnection;
    private XADataSource                  _theDataSource;
    private XAResource                    _theXAResource;
    private javax.transaction.Transaction _theTransaction;
    private ConnectionImple               _theArjunaConnection;
    private ConnectionModifier            _theModifier;
New to GrepCode? Check out our FAQ X