/*******************************************************************************
* ***** BEGIN LICENSE BLOCK Version: MPL 1.1
*
* The contents of this file are subject to the Mozilla Public License Version
* 1.1 (the "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for
* the specific language governing rights and limitations under the License.
*
* The Original Code is the OpenCustomer CRM.
*
* The Initial Developer of the Original Code is Thomas Bader (Bader & Jene
* Software-Ingenieurb�ro). Portions created by the Initial Developer are
* Copyright (C) 2006 the Initial Developer. All Rights Reserved.
*
* Contributor(s): Thomas Bader <thomas.bader@bader-jene.de>
*
* ***** END LICENSE BLOCK *****
*/
package org.opencustomer.util.configuration;
import java.util.List;
import org.apache.log4j.Logger;
import org.opencustomer.db.dao.system.ConfigurationDAO;
import org.opencustomer.db.vo.system.ConfigurationVO;
import org.opencustomer.framework.util.EnumUtility;
public final class SystemConfiguration extends Configuration<SystemConfiguration.Key> {
private final static Logger log = Logger.getLogger(SystemConfiguration.class);
private static SystemConfiguration instance;
public static enum Key implements ConfigurationKey {
MAX_FAILED_LOGINS (Integer.class, new Integer(3)),
// DEFAULT_MAX_SESSION_INACTIVE (Integer.class, new Integer(300)),
DEFAULT_TIMELOCK (Integer.class, new Integer(30)),
DEFAULT_IPPATTERN (String.class, "*"),
MAIL_SMTP_SERVER (String.class),
SHOW_OVERVIEW (Boolean.class, Boolean.TRUE),
MULTIPLE_LOGINS (Boolean.class, Boolean.TRUE),
LDAP_AUTHENTICATION_ENABLED (Boolean.class, Boolean.FALSE),
LDAP_ADDRESS_EXPORT_ENABLED (Boolean.class, Boolean.FALSE),
LDAP_ADDRESS_INITIAL_EXPORT (Boolean.class, Boolean.FALSE),
LDAP_SERVER (String.class),
LDAP_PORT (Integer.class),
LDAP_ADMIN_USER (String.class),
LDAP_ADMIN_PASSWORD (String.class),
LDAP_BASE_DN (String.class),
LDAP_ADDRESS_PREFIX (String.class),
LDAP_ADDRESS_COMPANY_PREFIX (String.class),
LDAP_ADDRESS_PERSON_PREFIX (String.class),
LDAP_USER_PREFIX (String.class),
LDAP_GROUP_PREFIX (String.class),
LDAP_SYSTEM_USER (String.class);
private Class clazz;
private Object defaultValue;
private Key(Class clazz) {
this(clazz, null);
}
private Key(Class clazz, Object defaultValue) {
this.clazz = clazz;
this.defaultValue = defaultValue;
}
public Class getType() {
return clazz;
}
public Object getDefaultValue() {
return defaultValue;
}
}
private SystemConfiguration() {
refresh();
}
public static SystemConfiguration getInstance() {
if(instance == null)
instance = new SystemConfiguration();
return instance;
}
@Override
protected final SystemConfiguration.Key getKey(ConfigurationVO vo) {
return EnumUtility.valueOf(SystemConfiguration.Key.class,vo.getKey());
}
@Override
public void refresh() {
getConfigurations().clear();
List<ConfigurationVO> systemConfigurations = new ConfigurationDAO().getForSystem();
for(ConfigurationVO vo : systemConfigurations) {
addConfiguration(vo);
}
}
}