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

src.com.ibm.as400.access.ConnectionPoolProperties Maven / Gradle / Ivy

The newest version!
///////////////////////////////////////////////////////////////////////////////
//                                                                             
// JTOpen (IBM Toolbox for Java - OSS version)                              
//                                                                             
// Filename: ConnectionPoolProperties.java
//                                                                             
// The source code contained herein is licensed under the IBM Public License   
// Version 1.0, which has been approved by the Open Source Initiative.         
// Copyright (C) 1997-2003 International Business Machines Corporation and     
// others. All rights reserved.                                                
//                                                                             
///////////////////////////////////////////////////////////////////////////////

package com.ibm.as400.access;

import java.beans.PropertyChangeListener;
import java.beans.PropertyChangeSupport;
import java.beans.PropertyVetoException;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.Serializable;

/**
*  Contains properties for maintaining a ConnectionPool.  
*  It is used to control the behavior of the connection pool.
*
*  A maintenance daemon is used to validate the connection status and determine if the connection should
*  be closed based on the timeout limits.  The daemon can be set to run at any defined time interval.
**/
class ConnectionPoolProperties implements Serializable
{
  static final long serialVersionUID = 4L;

  /**
   Indicates that the CCSID used for new connections is the same as the system default CCSID.
   **/
  static final int CCSID_DEFAULT = -1;

  // Default setting for pretestConnections property.
  private static boolean defaultPretestConnections_ = false;
  static
  {
    String propVal = SystemProperties.getProperty(SystemProperties.CONNECTIONPOOL_PRETEST);
    if (propVal != null)
    {
      try {
        defaultPretestConnections_ = Boolean.valueOf(propVal).booleanValue();
      }
      catch (Exception e) {
        Trace.log(Trace.WARNING, "Error retrieving default pretestConnections property value:", e);
      }
    }
  }

  private long cleanupInterval_ = 300000;           // 5 minutes maintenance intervals
  private int maxConnections_ = -1;                 // maximum number of active connections for the datasource.
  private long maxInactivity_ = 3600000;                // 60 minutes
  private long maxLifetime_ = 86400000;                 // 24 hours
  private int maxUseCount_ = -1;                        // maximum number of times connection can be used.
  private long maxUseTime_ = -1;                  // maximum usage time, release after this period, -1 for never
  private boolean pretestConnections_ = defaultPretestConnections_;
  private boolean useThreads_ = true;
  private int ccsid_ = -1;                        // CCSID to use when creating connections

  transient private PropertyChangeSupport changes_;

	/**
	*  Constructs a default ConnectionPoolProperties object.  
   **/
	public ConnectionPoolProperties()
	{
//      initializeTransient();
  } 

  /**
  *  Adds a PropertyChangeListener.
  *  @param listener The PropertyChangeListener.
  *  @see #removePropertyChangeListener
  **/
  public void addPropertyChangeListener(PropertyChangeListener listener)
  {
    if (listener == null)
      throw new NullPointerException("listener");

    synchronized(this)
    {
      if (changes_ == null) changes_ = new PropertyChangeSupport(this);
      changes_.addPropertyChangeListener(listener);
    }
  }

  /**
  *  Indicates whether connections are pretested before being allocated to a requester.
  *  The default value is false.
  *  @return true if connections are pretested; false otherwise.
  **/
  public boolean isPretestConnections()
  {
   	return pretestConnections_;
  }

  /**
  *  Indicates whether threads are used in communication with the host servers.
  *  The default value is true.
  *  @return true if threads are used; false otherwise.
  **/
  public boolean isThreadUsed()
  {
   	return useThreads_;
  }


	/**
	*  Returns the CCSID used for connections in the pool.
	*  Special value {@link #CCSID_DEFAULT CCSID_DEFAULT} is the default.
	*  @return     The CCSID.
	**/
	public int getCCSID()
	{
		return ccsid_;
	}


	/**
	*  Returns the time interval for how often the maintenance daemon is run.
	*  The default value is 300000 milliseconds.
	*  @return     Number of milliseconds.
	**/
	public long getCleanupInterval()
	{
		return cleanupInterval_;
	}

  /**
 *  Returns the maximum number of connections.
  *  The default value is -1 indicating no limit to the number of connections.
 *  @return Maximum number of connections.
 **/
	public int getMaxConnections()
	{
		return maxConnections_;
	}

	/**
	*  Returns the maximum amount of inactive time before the connection is closed.
   *  The maintenance daemon closes the connection if the threshold is reached.
   *  The default value is 60 minutes.  A value of -1 indicates that there is no limit.
	*  @return     Number of milliseconds.
	**/
	public long getMaxInactivity()
	{
		return maxInactivity_;
	}

	/**
	*  Returns the maximum life for an available connection.
   *  The maintenance daemon closes the available connection if the threshold is reached.
   *  The default value is a 24 hour limit.  A value of -1 indicates that there is no limit.
   *  @return Number of milliseconds.
	**/
	public long getMaxLifetime()
	{
		return maxLifetime_;
	}

  /**
 *  Returns the maximum number of times a connection can be used before it is replaced in the pool.
 *  The default value is -1.  A value of -1 indicates that there is no limit.
 *  @return Maximum usage count.
 **/
	public int getMaxUseCount()
	{
		return maxUseCount_;
	}

  /**
 *  Returns the maximum amount of time a connection can be in use before it is closed and returned to the pool.
 *  The default value is -1 indicating that there is no limit.
 *  @return Number of milliseconds.
 **/
	public long getMaxUseTime()
	{
		return maxUseTime_;
	}

  /**
  *  Initializes the transient data.
  **/
//   private void initializeTransient()
//   {
//      changes_ = new PropertyChangeSupport(this);
//   }

  /**
  *  Deserializes and initializes transient data.
  *  @exception IOException If a file I/O error occurs.
  *  @exception ClassNotFoundException If a file error occurs.
  **/
  private void readObject(ObjectInputStream in) throws IOException, ClassNotFoundException
  {
    in.defaultReadObject();

//      initializeTransient();
  }

  /**
  *  Removes a PropertyChangeListener.
  *  @param listener The PropertyChangeListener.
  *  @see #addPropertyChangeListener
	**/
  public void removePropertyChangeListener(PropertyChangeListener listener)
  {
    if (listener == null)
      throw new NullPointerException("listener");

    if (changes_ != null) changes_.removePropertyChangeListener(listener);
  }

  /**
   *  Sets the CCSID used for connections in the pool.
   *  The default value is the system default CCSID as determined by the AS400 class.
   *  @param ccsid  The CCSID.
   * Special value {@link #CCSID_DEFAULT CCSID_DEFAULT} is the default.
   **/
  public void setCCSID(int ccsid)
  {
    if (Trace.traceOn_) Trace.log(Trace.DIAGNOSTIC, "ConnectionPoolProperties.setCCSID("+ccsid+")");

    String property = "ccsid";

    if (ccsid < CCSID_DEFAULT || ccsid > 65535)
      throw new ExtendedIllegalArgumentException(property, ExtendedIllegalArgumentException.RANGE_NOT_VALID);

    int oldValue = ccsid_;

    ccsid_ = ccsid;
    if (changes_ != null) changes_.firePropertyChange(property, new Integer(oldValue), new Integer(ccsid));
  }

  /**
 *  Sets the time interval for how often the maintenance daemon is run.
 *  The default value is 300000 milliseconds or 5 minutes.
 *  @param cleanupInterval The number of milliseconds.
 **/
  public void setCleanupInterval(long cleanupInterval)
  {
    if (Trace.traceOn_) Trace.log(Trace.DIAGNOSTIC, "ConnectionPoolProperties.setCleanupInterval("+cleanupInterval+")");

    String property = "cleanupInterval";

    if (cleanupInterval < 0)
      throw new ExtendedIllegalArgumentException(property, ExtendedIllegalArgumentException.RANGE_NOT_VALID);

//      Long oldValue = new Long(getCleanupInterval());
//      Long newValue = new Long(cleanupInterval);
    long oldValue = cleanupInterval_;

		cleanupInterval_ = cleanupInterval;
    if (changes_ != null) changes_.firePropertyChange(property, new Long(oldValue), new Long(cleanupInterval));
  }

  /**
 *  Sets the maximum number of connections.
 *  The default value is -1 indicating no limit to the number of connections.
 *  @param maxConnections Maximum number of connections.
 **/
	public void setMaxConnections(int maxConnections)
	{
    if (Trace.traceOn_) Trace.log(Trace.DIAGNOSTIC, "ConnectionPoolProperties.setMaxConnections("+maxConnections+")");

    String property = "maxConnections";
    if (maxConnections < -1)
      throw new ExtendedIllegalArgumentException(property, ExtendedIllegalArgumentException.RANGE_NOT_VALID);

//    Integer oldValue = new Integer(getMaxConnections());
//    Integer newValue = new Integer(maxConnections);
    int oldValue = maxConnections_;

		maxConnections_ = maxConnections;
    if (changes_ != null) changes_.firePropertyChange(property, new Integer(oldValue), new Integer(maxConnections));
  }

 	/**
	*  Sets the maximum amount of inactive time before the connection is closed.
   *  The maintenance daemon closes the connection if the threshold is reached.
   *  The default value is 60 minutes.  A value of -1 indicates that there is no limit.
	*  @param   maxInactivity  Number of milliseconds.
	**/
	public void setMaxInactivity(long maxInactivity)
	{
    if (Trace.traceOn_) Trace.log(Trace.DIAGNOSTIC, "ConnectionPoolProperties.setMaxInactivity("+maxInactivity+")");

    String property = "maxInactivity";
    if (maxInactivity < -1)
      throw new ExtendedIllegalArgumentException(property, ExtendedIllegalArgumentException.RANGE_NOT_VALID);

//    Long oldValue = new Long(getMaxInactivity());
//    Long newValue = new Long(maxInactivity);
    long oldValue = maxInactivity_;

		maxInactivity_ = maxInactivity;
    if (changes_ != null) changes_.firePropertyChange(property, new Long(oldValue), new Long(maxInactivity));
  }

	/**
	*  Sets the maximum life for an available connection.
   *  The maintenance daemon closes the available connection if the threshold is reached.
   *  The default value is a 24 hour limit.  A value of -1 indicates that there is no limit.
	*  @param maxLifetime Number of milliseconds.
	**/
	public void setMaxLifetime(long maxLifetime)
	{
    if (Trace.traceOn_) Trace.log(Trace.DIAGNOSTIC, "ConnectionPoolProperties.setMaxLifetime("+maxLifetime+")");

    String property = "maxLifetime";
    if (maxLifetime < -1)
      throw new ExtendedIllegalArgumentException(property, ExtendedIllegalArgumentException.RANGE_NOT_VALID);

//    Long oldValue = new Long(getMaxLifetime());
//    Long newValue = new Long(maxLifetime);
    long oldValue = maxLifetime_;

		maxLifetime_ = maxLifetime;
    if (changes_ != null) changes_.firePropertyChange(property, new Long(oldValue), new Long(maxLifetime));
  }


  /**
   *  Sets whether connections are pretested before being allocated to requesters. 
   *  The default value is false.   
   *  @param pretest true to pretest connections; false otherwise.
   **/
  public void setPretestConnections(boolean pretest)
  {
    if (Trace.traceOn_) Trace.log(Trace.DIAGNOSTIC, "ConnectionPoolProperties.setPretestConnections("+pretest+")");

    String property = "pretestConnections";
    boolean oldValue = pretestConnections_;

    pretestConnections_ = pretest;
    if (changes_ != null) changes_.firePropertyChange(property, new Boolean(oldValue), new Boolean(pretest));

  }


  /**
   *  Sets whether the IBM Toolbox for Java uses threads in communication with the host servers
   *  and whether the pool uses threads for running maintenance.   
   *  The default value is true.   
   *  @param useThreads true to use threads; false otherwise.
   * @param isInUse 
   **/
  public void setThreadUsed(boolean useThreads, boolean isInUse)
  {
    if (Trace.traceOn_) Trace.log(Trace.DIAGNOSTIC, "ConnectionPoolProperties.setThreadUsed("+useThreads+","+isInUse+")");

    String property = "threadUsed";
    //
    // If the value does not change, just return
    // 
    if (useThreads_ == useThreads) { 
      return; 
    }
    
    if (isInUse)
      throw new ExtendedIllegalStateException(property, ExtendedIllegalStateException.PROPERTY_NOT_CHANGED);

//    Boolean oldValue = new Boolean(isThreadUsed());
//    Boolean newValue = new Boolean(useThreads);
    boolean oldValue = useThreads_;

    useThreads_ = useThreads;
    if (changes_ != null) changes_.firePropertyChange(property, new Boolean(oldValue), new Boolean(useThreads));

  }

	/**
	*  Sets the maximum number of times a connection can be used before it is replaced in the pool.
	*  The default value is -1.  A value of -1 indicates that there is no limit.
	*  @param   maxUseCount  Maximum usage count.
	**/
	public void setMaxUseCount(int maxUseCount)
	{
    if (Trace.traceOn_) Trace.log(Trace.DIAGNOSTIC, "ConnectionPoolProperties.setMaxUseCount("+maxUseCount+")");

    String property = "maxUseCount";
    if (maxUseCount < -1)
      throw new ExtendedIllegalArgumentException(property, ExtendedIllegalArgumentException.RANGE_NOT_VALID);

//    Integer oldValue = new Integer(getMaxUseCount());
//    Integer newValue = new Integer(maxUseCount);
    int oldValue = maxUseCount_;

		maxUseCount_ = maxUseCount;
    if (changes_ != null) changes_.firePropertyChange(property, new Integer(oldValue), new Integer(maxUseCount));
  }

	/**
	*  Sets the maximum amount of time a connection can be in use before it is closed and returned to the pool.
	*  The default value is -1 indicating that there is no limit.
	*  @param maxUseTime Number of milliseconds.
	**/
	public void setMaxUseTime(long maxUseTime)
	{
    if (Trace.traceOn_) Trace.log(Trace.DIAGNOSTIC, "ConnectionPoolProperties.setMaxUseTime("+maxUseTime+")");

    String property = "maxUseTime";
    if (maxUseTime < -1)
      throw new ExtendedIllegalArgumentException(property, ExtendedIllegalArgumentException.RANGE_NOT_VALID);

//    Long oldValue = new Long(getMaxUseTime());
//    Long newValue = new Long(maxUseTime);
    long oldValue = maxUseTime_;

		maxUseTime_ = maxUseTime;
    if (changes_ != null) changes_.firePropertyChange(property, new Long(oldValue), new Long(maxUseTime));
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy