com.sun.enterprise.deployment.DataSourceDefinitionDescriptor Maven / Gradle / Ivy
/*
* Copyright (c) 2022, 2023 Contributors to the Eclipse Foundation
* Copyright (c) 1997, 2018 Oracle and/or its affiliates. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0, which is available at
* http://www.eclipse.org/legal/epl-2.0.
*
* This Source Code may also be made available under the following Secondary
* Licenses when the conditions for such availability set forth in the
* Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
* version 2 with the GNU Classpath Exception, which is available at
* https://www.gnu.org/software/classpath/license.html.
*
* SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
*/
package com.sun.enterprise.deployment;
import com.sun.enterprise.deployment.util.DOLUtils;
import java.sql.Connection;
import java.util.Objects;
import java.util.Properties;
import java.util.logging.Level;
import org.glassfish.deployment.common.JavaEEResourceType;
/**
* @author Jagadish Ramu
*/
public class DataSourceDefinitionDescriptor extends ResourceDescriptor {
private static final long serialVersionUID = 1L;
private String name ;
private String description;
private String className ;
private int portNumber = -1;
private String databaseName ;
private String serverName = "localhost";
private String url;
private String user;
private String password;
private long loginTimeout;
private boolean transactional = true;
private int isolationLevel = -1;
private int initialPoolSize =-1;
private int maxPoolSize = -1;
private int minPoolSize =-1;
private long maxIdleTime = -1;
private int maxStatements =-1;
private final Properties properties = new Properties();
private boolean transactionSet;
private boolean loginTimeoutSet;
private boolean serverNameSet;
private boolean deployed;
// represents the valid values for isolation-level in Deployment Descriptors
private static final String TRANSACTION_NONE = "TRANSACTION_NONE";
private static final String TRANSACTION_READ_UNCOMMITTED = "TRANSACTION_READ_UNCOMMITTED";
private static final String TRANSACTION_READ_COMMITTED = "TRANSACTION_READ_COMMITTED";
private static final String TRANSACTION_REPEATABLE_READ = "TRANSACTION_REPEATABLE_READ";
private static final String TRANSACTION_SERIALIZABLE = "TRANSACTION_SERIALIZABLE";
public DataSourceDefinitionDescriptor(){
super.setResourceType(JavaEEResourceType.DSD);
}
public void setDeployed(boolean deployed){
this.deployed = deployed;
}
public boolean isDeployed(){
return deployed;
}
@Override
public String getName() {
return name;
}
@Override
public void setName(String name) {
this.name = name;
}
public void setUrl(String Url){
this.url = Url;
}
public String getUrl(){
return url;
}
@Override
public String getDescription() {
return description;
}
public void setTransactionSet(boolean value){
this.transactionSet = value;
}
public boolean isTransactionSet(){
return transactionSet;
}
@Override
public void setDescription(String description) {
this.description = description;
}
public String getClassName() {
return className;
}
public void setClassName(String className) {
this.className = className;
}
public int getPortNumber() {
return portNumber;
}
public void setPortNumber(int portNumber) {
this.portNumber = portNumber;
}
public String getDatabaseName() {
return databaseName;
}
public void setDatabaseName(String databaseName) {
this.databaseName = databaseName;
}
public String getServerName() {
return serverName;
}
public void setServerName(String serverName) {
this.serverName = serverName;
setServerNameSet(true);
}
public String getUser() {
return user;
}
public void setUser(String user) {
this.user = user;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public long getLoginTimeout() {
return loginTimeout;
}
public void setLoginTimeout(String loginTimeout) {
try {
this.loginTimeout = Long.parseLong(loginTimeout);
setLoginTimeoutSet(true);
} catch (NumberFormatException nfe) {
DOLUtils.getDefaultLogger().log(Level.WARNING,
"invalid loginTimeout value [ " + loginTimeout + " ]," + " required long");
}
}
private void setLoginTimeoutSet(boolean b) {
loginTimeoutSet = b;
}
public boolean isLoginTimeoutSet(){
return loginTimeoutSet;
}
public boolean isServerNameSet(){
return serverNameSet;
}
private void setServerNameSet(boolean b){
this.serverNameSet = b;
}
public boolean isTransactional() {
return transactional;
}
public void setTransactional(boolean transactional) {
this.transactional = transactional;
setTransactionSet(true);
}
//DD specified Enumeration values are String
//Annotation uses integer values and hence this mapping is needed
public String getIsolationLevelString() {
String isolationLevelString = null;
if (isolationLevel == Connection.TRANSACTION_READ_COMMITTED) {
isolationLevelString = TRANSACTION_READ_COMMITTED;
} else if (isolationLevel == Connection.TRANSACTION_READ_UNCOMMITTED) {
isolationLevelString = TRANSACTION_READ_UNCOMMITTED;
} else if (isolationLevel == Connection.TRANSACTION_REPEATABLE_READ) {
isolationLevelString = TRANSACTION_REPEATABLE_READ;
} else if (isolationLevel == Connection.TRANSACTION_SERIALIZABLE) {
isolationLevelString = TRANSACTION_SERIALIZABLE;
}
return isolationLevelString;
}
public int getIsolationLevel() {
return isolationLevel;
}
//DD specified Enumeration values are String
//Annotation uses integer values and hence this mapping is needed
public void setIsolationLevel(String isolationLevelString) {
if (!isIntegerIsolationLevelSet(isolationLevelString)) {
if (isolationLevelString.equals(TRANSACTION_READ_COMMITTED)) {
this.isolationLevel = Connection.TRANSACTION_READ_COMMITTED;
} else if (isolationLevelString.equals(TRANSACTION_READ_UNCOMMITTED)) {
this.isolationLevel = Connection.TRANSACTION_READ_UNCOMMITTED;
} else if (isolationLevelString.equals(TRANSACTION_REPEATABLE_READ)) {
this.isolationLevel = Connection.TRANSACTION_REPEATABLE_READ;
} else if (isolationLevelString.equals(TRANSACTION_SERIALIZABLE)) {
this.isolationLevel = Connection.TRANSACTION_SERIALIZABLE;
} else {
throw new IllegalStateException
("Isolation level [ " + isolationLevelString + " ] not of of standard isolation levels.");
}
}
}
public boolean isIntegerIsolationLevelSet(String isolationLevelString) {
int isolationLevel;
try {
isolationLevel = Integer.parseInt(isolationLevelString);
} catch (NumberFormatException nfe) {
return false;
}
if(isolationLevel == -1){
//do nothing as no value is specified.
return true;
}
switch (isolationLevel) {
case Connection.TRANSACTION_READ_COMMITTED:
case Connection.TRANSACTION_READ_UNCOMMITTED:
case Connection.TRANSACTION_REPEATABLE_READ:
case Connection.TRANSACTION_SERIALIZABLE:
this.isolationLevel = isolationLevel;
break;
default:
throw new IllegalStateException
("Isolation level [ " + isolationLevel + " ] not of of standard isolation levels.");
}
return true;
}
public int getInitialPoolSize() {
return initialPoolSize;
}
public void setInitialPoolSize(int initialPoolSize) {
this.initialPoolSize = initialPoolSize;
}
public int getMaxPoolSize() {
return maxPoolSize;
}
public void setMaxPoolSize(int maxPoolSize) {
this.maxPoolSize = maxPoolSize;
}
public int getMinPoolSize() {
return minPoolSize;
}
public void setMinPoolSize(int minPoolSize) {
this.minPoolSize = minPoolSize;
}
public long getMaxIdleTime() {
return maxIdleTime;
}
public void setMaxIdleTime(String maxIdleTime) {
try{
this.maxIdleTime = Long.parseLong(maxIdleTime);
}catch(NumberFormatException nfe){
DOLUtils.getDefaultLogger().log(Level.WARNING, "invalid maxIdleTime value [ " + maxIdleTime + " ]," +
" required long");
}
}
public int getMaxStatements() {
return maxStatements;
}
public void setMaxStatements(int maxStatements) {
this.maxStatements = maxStatements;
}
public void addProperty(String key, String value){
properties.put(key, value);
}
public String getProperty(String key){
return (String)properties.get(key);
}
public Properties getProperties(){
return properties;
}
@Override
public boolean equals(Object object) {
if (object instanceof DataSourceDefinitionDescriptor) {
DataSourceDefinitionDescriptor reference = (DataSourceDefinitionDescriptor) object;
return getJndiName().equals(reference.getJndiName());
}
return false;
}
@Override
public int hashCode() {
return Objects.hash(getName());
}
public void addDataSourcePropertyDescriptor(ResourcePropertyDescriptor propertyDescriptor){
properties.put(propertyDescriptor.getName(), propertyDescriptor.getValue());
}
public boolean isConflict(DataSourceDefinitionDescriptor other) {
return (getName().equals(other.getName())) &&
!(
DOLUtils.equals(getClassName(), other.getClassName()) &&
DOLUtils.equals(getServerName(), other.getServerName()) &&
getPortNumber() == other.getPortNumber() &&
DOLUtils.equals(getDatabaseName(), other.getDatabaseName()) &&
DOLUtils.equals(getUrl(), other.getUrl()) &&
DOLUtils.equals(getUser(), other.getUser()) &&
DOLUtils.equals(getPassword(), other.getPassword()) &&
properties.equals(other.properties) &&
getLoginTimeout() == other.getLoginTimeout() &&
isTransactional() == other.isTransactional() &&
getIsolationLevel() == other.getIsolationLevel() &&
getInitialPoolSize() == other.getInitialPoolSize() &&
getMinPoolSize() == other.getMinPoolSize() &&
getMaxPoolSize() == other.getMaxPoolSize() &&
getMaxIdleTime() == other.getMaxIdleTime() &&
getMaxStatements() == other.getMaxStatements()
);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy