Merge "Add support for DB2 database"
This commit is contained in:
@@ -0,0 +1,46 @@
|
||||
// Copyright (C) 2015 The Android Open Source Project
|
||||
//
|
||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||
// you may not use this file except in compliance with the License.
|
||||
// You may obtain a copy of the License at
|
||||
//
|
||||
// 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.
|
||||
|
||||
package com.google.gerrit.server.schema;
|
||||
|
||||
import static com.google.gerrit.server.schema.JdbcUtil.hostname;
|
||||
import static com.google.gerrit.server.schema.JdbcUtil.port;
|
||||
|
||||
import com.google.gerrit.server.config.ConfigSection;
|
||||
import com.google.gerrit.server.config.GerritServerConfig;
|
||||
import com.google.inject.Inject;
|
||||
|
||||
import org.eclipse.jgit.lib.Config;
|
||||
|
||||
public class DB2 extends BaseDataSourceType {
|
||||
private Config cfg;
|
||||
|
||||
@Inject
|
||||
public DB2(@GerritServerConfig final Config cfg) {
|
||||
super("com.ibm.db2.jcc.DB2Driver");
|
||||
this.cfg = cfg;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getUrl() {
|
||||
final StringBuilder b = new StringBuilder();
|
||||
final ConfigSection dbc = new ConfigSection(cfg, "database");
|
||||
b.append("jdbc:db2://");
|
||||
b.append(hostname(dbc.optional("hostname")));
|
||||
b.append(port(dbc.optional("port")));
|
||||
b.append("/");
|
||||
b.append(dbc.required("database"));
|
||||
return b.toString();
|
||||
}
|
||||
}
|
@@ -21,6 +21,7 @@ public class DataSourceModule extends AbstractModule {
|
||||
|
||||
@Override
|
||||
protected void configure() {
|
||||
bind(DataSourceType.class).annotatedWith(Names.named("db2")).to(DB2.class);
|
||||
bind(DataSourceType.class).annotatedWith(Names.named("h2")).to(H2.class);
|
||||
bind(DataSourceType.class).annotatedWith(Names.named("jdbc")).to(JDBC.class);
|
||||
bind(DataSourceType.class).annotatedWith(Names.named("mysql")).to(MySql.class);
|
||||
|
Reference in New Issue
Block a user