|
|
@ -1,21 +1,21 @@
|
|
|
|
/*
|
|
|
|
/*
|
|
|
|
* Copyright (c) 2015, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
|
|
|
|
* Copyright (c) 2015, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* WSO2 Inc. licenses this file to you under the Apache License,
|
|
|
|
* WSO2 Inc. licenses this file to you under the Apache License,
|
|
|
|
* Version 2.0 (the "License"); you may not use this file except
|
|
|
|
* Version 2.0 (the "License"); you may not use this file except
|
|
|
|
* in compliance with the License.
|
|
|
|
* in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
* 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.
|
|
|
|
|
|
|
|
*
|
|
|
|
*
|
|
|
|
|
|
|
|
* 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.wso2.carbon.device.mgt.core.operation.mgt.dao;
|
|
|
|
package org.wso2.carbon.device.mgt.core.operation.mgt.dao;
|
|
|
|
|
|
|
|
|
|
|
|
import org.apache.commons.logging.Log;
|
|
|
|
import org.apache.commons.logging.Log;
|
|
|
@ -33,8 +33,8 @@ import java.util.List;
|
|
|
|
|
|
|
|
|
|
|
|
public class OperationManagementDAOFactory {
|
|
|
|
public class OperationManagementDAOFactory {
|
|
|
|
|
|
|
|
|
|
|
|
private static DataSource dataSource;
|
|
|
|
|
|
|
|
private static final Log log = LogFactory.getLog(OperationManagementDAOFactory.class);
|
|
|
|
private static final Log log = LogFactory.getLog(OperationManagementDAOFactory.class);
|
|
|
|
|
|
|
|
private static DataSource dataSource;
|
|
|
|
private static ThreadLocal<Connection> currentConnection = new ThreadLocal<Connection>();
|
|
|
|
private static ThreadLocal<Connection> currentConnection = new ThreadLocal<Connection>();
|
|
|
|
|
|
|
|
|
|
|
|
public static OperationDAO getCommandOperationDAO() {
|
|
|
|
public static OperationDAO getCommandOperationDAO() {
|
|
|
@ -70,29 +70,26 @@ public class OperationManagementDAOFactory {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public static void beginTransaction() throws OperationManagementDAOException {
|
|
|
|
public static void beginTransaction() throws OperationManagementDAOException {
|
|
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
currentConnection.set(dataSource.getConnection());
|
|
|
|
currentConnection.set(dataSource.getConnection());
|
|
|
|
} catch (SQLException e) {
|
|
|
|
} catch (SQLException e) {
|
|
|
|
throw new OperationManagementDAOException("Error occurred while retrieving config.datasource connection", e);
|
|
|
|
throw new OperationManagementDAOException(
|
|
|
|
|
|
|
|
"Error occurred while retrieving config.datasource connection", e);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public static Connection getConnection() throws OperationManagementDAOException {
|
|
|
|
public static Connection getConnection() throws OperationManagementDAOException {
|
|
|
|
|
|
|
|
|
|
|
|
if (currentConnection.get() == null) {
|
|
|
|
if (currentConnection.get() == null) {
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
currentConnection.set(dataSource.getConnection());
|
|
|
|
currentConnection.set(dataSource.getConnection());
|
|
|
|
} catch (SQLException e) {
|
|
|
|
} catch (SQLException e) {
|
|
|
|
throw new OperationManagementDAOException("Error occurred while retrieving data source connection",
|
|
|
|
throw new OperationManagementDAOException("Error occurred while retrieving data source connection", e);
|
|
|
|
e);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return currentConnection.get();
|
|
|
|
return currentConnection.get();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public static void closeConnection() throws OperationManagementDAOException {
|
|
|
|
public static void closeConnection() throws OperationManagementDAOException {
|
|
|
|
|
|
|
|
|
|
|
|
Connection con = currentConnection.get();
|
|
|
|
Connection con = currentConnection.get();
|
|
|
|
if (con != null) {
|
|
|
|
if (con != null) {
|
|
|
|
try {
|
|
|
|
try {
|
|
|
@ -130,11 +127,11 @@ public class OperationManagementDAOFactory {
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
if (log.isDebugEnabled()) {
|
|
|
|
if (log.isDebugEnabled()) {
|
|
|
|
log.debug("Datasource connection associated with the current thread is null, hence rollback " +
|
|
|
|
log.debug("Datasource connection associated with the current thread is null, hence rollback " +
|
|
|
|
"has not been attempted");
|
|
|
|
"has not been attempted");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} catch (SQLException e) {
|
|
|
|
} catch (SQLException e) {
|
|
|
|
throw new OperationManagementDAOException("Error occurred while rollbacking the transaction", e);
|
|
|
|
throw new OperationManagementDAOException("Error occurred while roll-backing the transaction", e);
|
|
|
|
} finally {
|
|
|
|
} finally {
|
|
|
|
closeConnection();
|
|
|
|
closeConnection();
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -149,28 +146,23 @@ public class OperationManagementDAOFactory {
|
|
|
|
private static DataSource resolveDataSource(DataSourceConfig config) {
|
|
|
|
private static DataSource resolveDataSource(DataSourceConfig config) {
|
|
|
|
DataSource dataSource = null;
|
|
|
|
DataSource dataSource = null;
|
|
|
|
if (config == null) {
|
|
|
|
if (config == null) {
|
|
|
|
throw new RuntimeException(
|
|
|
|
throw new RuntimeException("Device Management Repository data source configuration is null and " +
|
|
|
|
"Device Management Repository data source configuration " + "is null and " +
|
|
|
|
"thus, is not initialized");
|
|
|
|
"thus, is not initialized");
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
JNDILookupDefinition jndiConfig = config.getJndiLookupDefinition();
|
|
|
|
JNDILookupDefinition jndiConfig = config.getJndiLookupDefinition();
|
|
|
|
if (jndiConfig != null) {
|
|
|
|
if (jndiConfig != null) {
|
|
|
|
if (log.isDebugEnabled()) {
|
|
|
|
if (log.isDebugEnabled()) {
|
|
|
|
log.debug("Initializing Device Management Repository data source using the JNDI " +
|
|
|
|
log.debug("Initializing Device Management Repository data source using the JNDI Lookup Definition");
|
|
|
|
"Lookup Definition");
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
List<JNDILookupDefinition.JNDIProperty> jndiPropertyList =
|
|
|
|
List<JNDILookupDefinition.JNDIProperty> jndiPropertyList = jndiConfig.getJndiProperties();
|
|
|
|
jndiConfig.getJndiProperties();
|
|
|
|
|
|
|
|
if (jndiPropertyList != null) {
|
|
|
|
if (jndiPropertyList != null) {
|
|
|
|
Hashtable<Object, Object> jndiProperties = new Hashtable<Object, Object>();
|
|
|
|
Hashtable<Object, Object> jndiProperties = new Hashtable<Object, Object>();
|
|
|
|
for (JNDILookupDefinition.JNDIProperty prop : jndiPropertyList) {
|
|
|
|
for (JNDILookupDefinition.JNDIProperty prop : jndiPropertyList) {
|
|
|
|
jndiProperties.put(prop.getName(), prop.getValue());
|
|
|
|
jndiProperties.put(prop.getName(), prop.getValue());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
dataSource = DeviceManagementDAOUtil
|
|
|
|
dataSource = DeviceManagementDAOUtil.lookupDataSource(jndiConfig.getJndiName(), jndiProperties);
|
|
|
|
.lookupDataSource(jndiConfig.getJndiName(), jndiProperties);
|
|
|
|
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
dataSource =
|
|
|
|
dataSource = DeviceManagementDAOUtil.lookupDataSource(jndiConfig.getJndiName(), null);
|
|
|
|
DeviceManagementDAOUtil.lookupDataSource(jndiConfig.getJndiName(), null);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return dataSource;
|
|
|
|
return dataSource;
|
|
|
|