edu.vt.middleware.ldap.props.AbstractPropertyConfig Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of vt-ldap Show documentation
Show all versions of vt-ldap Show documentation
Library for performing common LDAP operations
/*
$Id: AbstractPropertyConfig.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.props;
import java.util.Enumeration;
import java.util.HashMap;
import java.util.Hashtable;
import java.util.Map;
import java.util.Properties;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
/**
* AbstractPropertyConfig
provides a base implementation of
* PropertyConfig
.
*
* @author Middleware Services
* @version $Revision: 1330 $ $Date: 2010-05-23 18:10:53 -0400 (Sun, 23 May 2010) $
*/
public abstract class AbstractPropertyConfig implements PropertyConfig
{
/** Log for this class. */
protected final Log logger = LogFactory.getLog(this.getClass());
/** Whether this config has been marked immutable. */
private boolean immutable;
/** Make this property config immutable. */
public void makeImmutable()
{
this.immutable = true;
}
/**
* Verifies if this property config is immutable.
*
* @throws IllegalStateException if this property config is immutable
*/
public void checkImmutable()
{
if (this.immutable) {
throw new IllegalStateException("Cannot modify immutable object");
}
}
/** {@inheritDoc} */
public abstract String getPropertiesDomain();
/** {@inheritDoc} */
public abstract void setEnvironmentProperties(
final String name,
final String value);
/** {@inheritDoc} */
public void setEnvironmentProperties(final Properties properties)
{
if (properties != null) {
final Map props = new HashMap();
final Enumeration> en = properties.keys();
if (en != null) {
while (en.hasMoreElements()) {
final String name = (String) en.nextElement();
final String value = (String) properties.get(name);
if (this.hasEnvironmentProperty(name)) {
props.put(name, value);
} else {
this.setEnvironmentProperties(name, value);
}
}
for (Map.Entry e : props.entrySet()) {
this.setEnvironmentProperties(e.getKey(), e.getValue());
}
}
}
}
/**
* See {@link #setEnvironmentProperties(String,String)}.
*
* @param properties Hashtable
of environment properties
*/
public void setEnvironmentProperties(
final Hashtable properties)
{
if (properties != null) {
final Map props = new HashMap();
for (Map.Entry e : properties.entrySet()) {
if (this.hasEnvironmentProperty(e.getKey())) {
props.put(e.getKey(), e.getValue());
} else {
this.setEnvironmentProperties(e.getKey(), e.getValue());
}
}
for (Map.Entry e : props.entrySet()) {
this.setEnvironmentProperties(e.getKey(), e.getValue());
}
}
}
/** {@inheritDoc} */
public abstract boolean hasEnvironmentProperty(final String name);
/**
* Verifies that a string is not null or empty.
*
* @param s to verify
* @param allowNull whether null strings are valid
*
* @throws IllegalArgumentException if the string is null or empty
*/
protected void checkStringInput(final String s, final boolean allowNull)
{
if (allowNull) {
if (s != null && "".equals(s)) {
throw new IllegalArgumentException("Input cannot be empty");
}
} else {
if (s == null || "".equals(s)) {
throw new IllegalArgumentException("Input cannot be null or empty");
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy