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

org.apache.struts.config.DataSourceConfig Maven / Gradle / Ivy

Go to download

Base project: http://central.maven.org/maven2/struts/struts/1.2.9/ This version of Struts doesn't throw java.io.NotSerializableException when the application server wants to persist sessions and makes renderFocusJavascript return valid xml

The newest version!
/*
 * $Id: DataSourceConfig.java 54929 2004-10-16 16:38:42Z germuska $ 
 *
 * Copyright 1999-2004 The Apache Software Foundation.
 * 
 * Licensed under the Apache License, Version 2.0 (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.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */


package org.apache.struts.config;


import java.io.Serializable;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import org.apache.struts.Globals;


/**
 * 

A JavaBean representing the configuration information of a * <data-source> element from a Struts * configuration file.

* *

WARNING - The properties of this configuration bean * are recognized by the default data source implementation, but some or all * of them may be ignored by custom data source implementations.

* * @version $Rev: 54929 $ $Date: 2004-10-16 17:38:42 +0100 (Sat, 16 Oct 2004) $ * @since Struts 1.1 */ public class DataSourceConfig implements Serializable { // ----------------------------------------------------- Instance Variables /** * Has this component been completely configured? */ protected boolean configured = false; // ------------------------------------------------------------- Properties /** * The servlet context attribute key under which this data source * is stored and made available. */ protected String key = Globals.DATA_SOURCE_KEY; public String getKey() { return (this.key); } public void setKey(String key) { if (configured) { throw new IllegalStateException("Configuration is frozen"); } this.key = key; } /** * The custom configuration properties for this data source implementation. */ protected HashMap properties = new HashMap(); public Map getProperties() { return (this.properties); } /** * The fully qualified class name of the javax.sql.DataSource * implementation class. */ protected String type; public String getType() { return (this.type); } public void setType(String type) { if (configured) { throw new IllegalStateException("Configuration is frozen"); } this.type = type; } // --------------------------------------------------------- Public Methods /** * Add a new custom configuration property. * * @param name Custom property name * @param value Custom property value */ public void addProperty(String name, String value) { if (configured) { throw new IllegalStateException("Configuration is frozen"); } properties.put(name, value); } /** * Freeze the configuration of this data source. */ public void freeze() { configured = true; } /** * Return a String representation of this object. */ public String toString() { StringBuffer sb = new StringBuffer("DataSourceConfig["); sb.append("key="); sb.append(key); sb.append(",type="); sb.append(type); Iterator names = properties.keySet().iterator(); while (names.hasNext()) { String name = (String) names.next(); String value = (String) properties.get(name); sb.append(','); sb.append(name); sb.append('='); sb.append(value); } sb.append("]"); return (sb.toString()); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy