blob: 9e4bb772f50b2a8e0b0f89886062c58f36e03cf1 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
|
/*
@VaadinApache2LicenseForJavaFiles@
*/
package com.vaadin.data.util.sqlcontainer.connection;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.naming.InitialContext;
import javax.naming.NamingException;
import javax.sql.DataSource;
public class J2EEConnectionPool implements JDBCConnectionPool {
private static final Logger logger = Logger
.getLogger(J2EEConnectionPool.class.getName());
private String dataSourceJndiName;
private DataSource dataSource = null;
public J2EEConnectionPool(DataSource dataSource) {
this.dataSource = dataSource;
}
public J2EEConnectionPool(String dataSourceJndiName) {
this.dataSourceJndiName = dataSourceJndiName;
}
public Connection reserveConnection() throws SQLException {
Connection conn = getDataSource().getConnection();
conn.setAutoCommit(false);
return conn;
}
private DataSource getDataSource() throws SQLException {
if (dataSource == null) {
dataSource = lookupDataSource();
}
return dataSource;
}
private DataSource lookupDataSource() throws SQLException {
try {
InitialContext ic = new InitialContext();
return (DataSource) ic.lookup(dataSourceJndiName);
} catch (NamingException e) {
throw new SQLException(
"NamingException - Cannot connect to the database. Cause: "
+ e.getMessage());
}
}
public void releaseConnection(Connection conn) {
if (conn != null) {
try {
conn.close();
} catch (SQLException e) {
logger.log(Level.FINE, "Could not release SQL connection", e);
}
}
}
public void destroy() {
dataSource = null;
}
}
|