9909c1d2130d375a261aaceecd5ec89d6c48ef76
[appc.git] /
1 /*-
2  * ============LICENSE_START=======================================================
3  * APPC
4  * ================================================================================
5  * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
6  * Copyright (C) 2017 Amdocs
7  * ================================================================================
8  * Licensed under the Apache License, Version 2.0 (the "License");
9  * you may not use this file except in compliance with the License.
10  * You may obtain a copy of the License at
11  * 
12  *      http://www.apache.org/licenses/LICENSE-2.0
13  * 
14  * Unless required by applicable law or agreed to in writing, software
15  * distributed under the License is distributed on an "AS IS" BASIS,
16  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17  * See the License for the specific language governing permissions and
18  * limitations under the License.
19  * ============LICENSE_END=========================================================
20  * ECOMP is a trademark and service mark of AT&T Intellectual Property.
21  */
22
23 package org.openecomp.appc.dao.util;
24
25 import java.sql.Connection;
26 import java.sql.DriverManager;
27 import java.sql.SQLException;
28
29 public abstract class DefaultJdbcConnectionFactory implements JdbcConnectionFactory {
30
31     private static boolean driverRegistered = false;
32
33     private String jdbcURL;
34     private String jdbcUserName;
35     private String jdbcPassword;
36
37     public void setJdbcURL(String jdbcURL) {
38         this.jdbcURL = jdbcURL;
39     }
40
41     public void setJdbcUserName(String jdbcUserName) {
42         this.jdbcUserName = jdbcUserName;
43     }
44
45     public void setJdbcPassword(String jdbcPassword) {
46         this.jdbcPassword = jdbcPassword;
47     }
48
49
50     protected abstract void registedDriver() throws SQLException;
51
52     @Override
53     public Connection openDbConnection() {
54         try {
55             if(!driverRegistered) {
56                 registedDriver();
57                 driverRegistered = true;
58             }
59             return DriverManager.getConnection(jdbcURL, jdbcUserName, jdbcPassword);
60         } catch(SQLException e) {
61             throw new JdbcRuntimeException(Messages.EXP_JDBC_CONNECT.format(jdbcURL), e);
62         }
63     }
64
65     @Override
66     public void closeDbConnection(Connection connection) {
67         try {
68             connection.close();
69         } catch(SQLException e) {
70             throw new JdbcRuntimeException(Messages.EXP_JDBC_DISCONNECT.format(jdbcURL), e);
71         }
72     }
73 }