1 /*
2  * Licensed to the Apache Software Foundation (ASF) under one or more
3  * contributor license agreements.  See the NOTICE file distributed with
4  * this work for additional information regarding copyright ownership.
5  * The ASF licenses this file to You under the Apache License, Version 2.0
6  * (the "License"); you may not use this file except in compliance with
7  * the License.  You may obtain a copy of the License at
8  *
9  *      http://www.apache.org/licenses/LICENSE-2.0
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  */

17 package org.apache.tomcat.dbcp.dbcp2;
18
19 import java.sql.Connection;
20 import java.sql.Driver;
21 import java.sql.SQLException;
22 import java.util.Properties;
23
24 /**
25  * A {@link Driver}-based implementation of {@link ConnectionFactory}.
26  *
27  * @since 2.0
28  */

29 public class DriverConnectionFactory implements ConnectionFactory {
30
31     private final String connectionString;
32
33     private final Driver driver;
34
35     private final Properties properties;
36
37     /**
38      * Constructs a connection factory for a given Driver.
39      *
40      * @param driver
41      *            The Driver.
42      * @param connectString
43      *            The connection string.
44      * @param properties
45      *            The connection properties.
46      */

47     public DriverConnectionFactory(final Driver driver, final String connectString, final Properties properties) {
48         this.driver = driver;
49         this.connectionString = connectString;
50         this.properties = properties;
51     }
52
53     @Override
54     public Connection createConnection() throws SQLException {
55         return driver.connect(connectionString, properties);
56     }
57
58     /**
59      * @return The connection String.
60      * @since 2.6.0
61      */

62     public String getConnectionString() {
63         return connectionString;
64     }
65
66     /**
67      * @return The Driver.
68      * @since 2.6.0
69      */

70     public Driver getDriver() {
71         return driver;
72     }
73
74     /**
75      * @return The Properties.
76      * @since 2.6.0
77      */

78     public Properties getProperties() {
79         return properties;
80     }
81
82     @Override
83     public String toString() {
84         return this.getClass().getName() + " [" + String.valueOf(driver) + ";" + String.valueOf(connectionString) + ";"
85                 + String.valueOf(properties) + "]";
86     }
87 }
88