edu.vt.middleware.ldap.pool.LdapPoolConfig Maven / Gradle / Ivy
/*
$Id: LdapPoolConfig.java 1330 2010-05-23 22:10:53Z dfisher $
Copyright (C) 2003-2010 Virginia Tech.
All rights reserved.
SEE LICENSE FOR MORE INFORMATION
Author: Middleware Services
Email: [email protected]
Version: $Revision: 1330 $
Updated: $Date: 2010-05-23 18:10:53 -0400 (Sun, 23 May 2010) $
*/
package edu.vt.middleware.ldap.pool;
import java.io.InputStream;
import edu.vt.middleware.ldap.props.AbstractPropertyConfig;
import edu.vt.middleware.ldap.props.LdapConfigPropertyInvoker;
import edu.vt.middleware.ldap.props.LdapProperties;
/**
* LdapPoolConfig
contains all the configuration data that the
* pooling implementations need to control the pool.
*
* @author Middleware Services
* @version $Revision: 1330 $ $Date: 2010-05-23 18:10:53 -0400 (Sun, 23 May 2010) $
*/
public class LdapPoolConfig extends AbstractPropertyConfig
{
/** Domain to look for ldap properties in, value is {@value}. */
public static final String PROPERTIES_DOMAIN = "edu.vt.middleware.ldap.pool.";
/** Default min pool size, value is {@value}. */
public static final int DEFAULT_MIN_POOL_SIZE = 3;
/** Default max pool size, value is {@value}. */
public static final int DEFAULT_MAX_POOL_SIZE = 10;
/** Default validate on check in, value is {@value}. */
public static final boolean DEFAULT_VALIDATE_ON_CHECKIN = false;
/** Default validate on check out, value is {@value}. */
public static final boolean DEFAULT_VALIDATE_ON_CHECKOUT = false;
/** Default validate periodically, value is {@value}. */
public static final boolean DEFAULT_VALIDATE_PERIODICALLY = false;
/** Default validate timer period, value is {@value}. */
public static final long DEFAULT_VALIDATE_TIMER_PERIOD = 1800000;
/** Default prune timer period, value is {@value}. */
public static final long DEFAULT_PRUNE_TIMER_PERIOD = 300000;
/** Default expiration time, value is {@value}. */
public static final long DEFAULT_EXPIRATION_TIME = 600000;
/** Invoker for ldap properties. */
private static final LdapConfigPropertyInvoker PROPERTIES =
new LdapConfigPropertyInvoker(LdapPoolConfig.class, PROPERTIES_DOMAIN);
/** Min pool size. */
private int minPoolSize = DEFAULT_MIN_POOL_SIZE;
/** Max pool size. */
private int maxPoolSize = DEFAULT_MAX_POOL_SIZE;
/** Whether the ldap object should be validated when returned to the pool. */
private boolean validateOnCheckIn = DEFAULT_VALIDATE_ON_CHECKIN;
/** Whether the ldap object should be validated when given from the pool. */
private boolean validateOnCheckOut = DEFAULT_VALIDATE_ON_CHECKOUT;
/** Whether the pool should be validated periodically. */
private boolean validatePeriodically = DEFAULT_VALIDATE_PERIODICALLY;
/** Time in milliseconds that the validate pool timer should repeat. */
private long validateTimerPeriod = DEFAULT_VALIDATE_TIMER_PERIOD;
/** Time in milliseconds that the prune pool timer should repeat. */
private long pruneTimerPeriod = DEFAULT_PRUNE_TIMER_PERIOD;
/** Time in milliseconds that ldap objects should be considered expired. */
private long expirationTime = DEFAULT_EXPIRATION_TIME;
/** Default constructor. */
public LdapPoolConfig() {}
/**
* This returns the min pool size for the LdapPoolConfig
. Default
* value is {@link #DEFAULT_MIN_POOL_SIZE}. This value represents the size of
* the pool after the prune timer has run.
*
* @return int
- min pool size
*/
public int getMinPoolSize()
{
return this.minPoolSize;
}
/**
* This returns the max pool size for the LdapPoolConfig
. Default
* value is {@link #DEFAULT_MAX_POOL_SIZE}. This value may or may not be
* strictly enforced depending on the pooling implementation.
*
* @return int
- max pool size
*/
public int getMaxPoolSize()
{
return this.maxPoolSize;
}
/**
* This returns the validate on check in flag for the
* LdapPoolConfig
. Default value is {@link
* #DEFAULT_VALIDATE_ON_CHECKIN}.
*
* @return boolean
- validate on check in
*/
public boolean isValidateOnCheckIn()
{
return this.validateOnCheckIn;
}
/**
* This returns the validate on check out flag for the
* LdapPoolConfig
. Default value is {@link
* #DEFAULT_VALIDATE_ON_CHECKOUT}.
*
* @return boolean
- validate on check in
*/
public boolean isValidateOnCheckOut()
{
return this.validateOnCheckOut;
}
/**
* This returns the validate periodically flag for the
* LdapPoolConfig
. Default value is {@link
* #DEFAULT_VALIDATE_PERIODICALLY}.
*
* @return boolean
- validate periodically
*/
public boolean isValidatePeriodically()
{
return this.validatePeriodically;
}
/**
* This returns the prune timer period for the LdapPoolConfig
.
* Default value is {@link #DEFAULT_PRUNE_TIMER_PERIOD}. The prune timer
* attempts to execute {@link LdapPool#prune()}.
*
* @return long
- prune timer period in milliseconds
*/
public long getPruneTimerPeriod()
{
return this.pruneTimerPeriod;
}
/**
* This returns the validate timer period for the LdapPoolConfig
.
* Default value is {@link #DEFAULT_VALIDATE_TIMER_PERIOD}. The validate timer
* attempts to execute {@link LdapPool#validate()}.
*
* @return long
- validate timer period in milliseconds
*/
public long getValidateTimerPeriod()
{
return this.validateTimerPeriod;
}
/**
* This returns the expiration time for the LdapPoolConfig
.
* Default value is {@link #DEFAULT_EXPIRATION_TIME}. The expiration time
* represents the max time an ldap object should be available before it is
* considered stale. This value does not apply to objects in the pool if the
* pool has only a minimum number of objects available.
*
* @return long
- expiration time in milliseconds
*/
public long getExpirationTime()
{
return this.expirationTime;
}
/**
* This sets the min pool size for the LdapPoolConfig
.
*
* @param size int
*/
public void setMinPoolSize(final int size)
{
checkImmutable();
if (size >= 0) {
if (this.logger.isTraceEnabled()) {
this.logger.trace("setting minPoolSize: " + size);
}
this.minPoolSize = size;
}
}
/**
* This sets the max pool size for the LdapPoolConfig
.
*
* @param size int
*/
public void setMaxPoolSize(final int size)
{
checkImmutable();
if (size >= 0) {
if (this.logger.isTraceEnabled()) {
this.logger.trace("setting maxPoolSize: " + size);
}
this.maxPoolSize = size;
}
}
/**
* This sets the validate on check in flag for the
* LdapPoolConfig
.
*
* @param b boolean
*/
public void setValidateOnCheckIn(final boolean b)
{
checkImmutable();
if (this.logger.isTraceEnabled()) {
this.logger.trace("setting validateOnCheckIn: " + b);
}
this.validateOnCheckIn = b;
}
/**
* This sets the validate on check out flag for the
* LdapPoolConfig
.
*
* @param b boolean
*/
public void setValidateOnCheckOut(final boolean b)
{
checkImmutable();
if (this.logger.isTraceEnabled()) {
this.logger.trace("setting validateOnCheckOut: " + b);
}
this.validateOnCheckOut = b;
}
/**
* This sets the validate periodically flag for the
* LdapPoolConfig
.
*
* @param b boolean
*/
public void setValidatePeriodically(final boolean b)
{
checkImmutable();
if (this.logger.isTraceEnabled()) {
this.logger.trace("setting validatePeriodically: " + b);
}
this.validatePeriodically = b;
}
/**
* Sets the period for which the prune pool timer will run.
*
* @param time in milliseconds
*/
public void setPruneTimerPeriod(final long time)
{
checkImmutable();
if (time >= 0) {
if (this.logger.isTraceEnabled()) {
this.logger.trace("setting pruneTimerPeriod: " + time);
}
this.pruneTimerPeriod = time;
}
}
/**
* Sets the period for which the validate pool timer will run.
*
* @param time in milliseconds
*/
public void setValidateTimerPeriod(final long time)
{
checkImmutable();
if (time >= 0) {
if (this.logger.isTraceEnabled()) {
this.logger.trace("setting validateTimerPeriod: " + time);
}
this.validateTimerPeriod = time;
}
}
/**
* Sets the time that an ldap object should be considered stale and ready for
* removal from the pool.
*
* @param time in milliseconds
*/
public void setExpirationTime(final long time)
{
checkImmutable();
if (time >= 0) {
if (this.logger.isTraceEnabled()) {
this.logger.trace("setting expirationTime: " + time);
}
this.expirationTime = time;
}
}
/** {@inheritDoc} */
public String getPropertiesDomain()
{
return PROPERTIES_DOMAIN;
}
/** {@inheritDoc} */
public void setEnvironmentProperties(final String name, final String value)
{
checkImmutable();
if (name != null && value != null) {
if (PROPERTIES.hasProperty(name)) {
PROPERTIES.setProperty(this, name, value);
}
}
}
/** {@inheritDoc} */
public boolean hasEnvironmentProperty(final String name)
{
return PROPERTIES.hasProperty(name);
}
/**
* Create an instance of this class initialized with properties from the input
* stream. If the input stream is null, load properties from the default
* properties file.
*
* @param is to load properties from
*
* @return LdapPoolConfig
initialized ldap pool config
*/
public static LdapPoolConfig createFromProperties(final InputStream is)
{
final LdapPoolConfig poolConfig = new LdapPoolConfig();
LdapProperties properties = null;
if (is != null) {
properties = new LdapProperties(poolConfig, is);
} else {
properties = new LdapProperties(poolConfig);
properties.useDefaultPropertiesFile();
}
properties.configure();
return poolConfig;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy