Support DataDirect and Tibco Jdbc URLs (#6420)

This commit is contained in:
Trask Stalnaker 2022-08-08 17:13:27 -07:00 committed by GitHub
parent 9fe3761731
commit 0804fef429
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 44 additions and 0 deletions

View File

@ -789,6 +789,35 @@ public enum JdbcConnectionUrlParser {
}
return builder.name(instance);
}
},
DATADIRECT("datadirect", "tibcosoftware") {
@Override
DbInfo.Builder doParse(String jdbcUrl, DbInfo.Builder builder) {
int typeEndIndex = jdbcUrl.indexOf(':');
int subtypeEndIndex = jdbcUrl.indexOf(':', typeEndIndex + 1);
if (subtypeEndIndex == -1) {
return builder;
}
String subtype = jdbcUrl.substring(typeEndIndex + 1, subtypeEndIndex);
builder.subtype(subtype);
if (subtype.equals("sqlserver")) {
builder.system(DbSystemValues.MSSQL);
} else if (subtype.equals("oracle")) {
builder.system(DbSystemValues.ORACLE);
} else if (subtype.equals("mysql")) {
builder.system(DbSystemValues.MYSQL);
} else if (subtype.equals("postgresql")) {
builder.system(DbSystemValues.POSTGRESQL);
} else if (subtype.equals("db2")) {
builder.system(DbSystemValues.DB2);
}
return MODIFIED_URL_LIKE.doParse(jdbcUrl, builder);
}
};
private static final Logger logger = Logger.getLogger(JdbcConnectionUrlParser.class.getName());

View File

@ -203,6 +203,21 @@ class JdbcConnectionUrlParserTest extends Specification {
"jdbc:derby:jar:/derbydb;user=derbyuser;password=pw" | null | "derby:jar:" | "derby" | "jar" | "derbyuser" | null | null | "/derbydb" | null
"jdbc:derby:jar:(~/path/to/db.jar)/other/derbydb;user=derbyuser;password=pw" | null | "derby:jar:" | "derby" | "jar" | "derbyuser" | null | null | "(~/path/to/db.jar)/other/derbydb" | null
// https://docs.progress.com/bundle/datadirect-connect-jdbc-51/page/URL-Formats-DataDirect-Connect-for-JDBC-Drivers.html
"jdbc:datadirect:sqlserver://server_name:1433;DatabaseName=dbname" | null | "datadirect:sqlserver://server_name:1433" | "mssql" | "sqlserver" | null | "server_name" | 1433 | null | "dbname"
"jdbc:datadirect:oracle://server_name:1521;ServiceName=your_servicename" | null | "datadirect:oracle://server_name:1521" | "oracle" | "oracle" | null | "server_name" | 1521 | null | null
"jdbc:datadirect:mysql://server_name:3306" | null | "datadirect:mysql://server_name:3306" | "mysql" | "mysql" | null | "server_name" | 3306 | null | null
"jdbc:datadirect:postgresql://server_name:5432;DatabaseName=dbname" | null | "datadirect:postgresql://server_name:5432" | "postgresql" | "postgresql" | null | "server_name" | 5432 | null | "dbname"
"jdbc:datadirect:db2://server_name:50000;DatabaseName=dbname" | null | "datadirect:db2://server_name:50000" | "db2" | "db2" | null | "server_name" | 50000 | null | "dbname"
// "the TIBCO JDBC drivers are based on the Progress DataDirect Connect drivers"
// https://community.jaspersoft.com/documentation/tibco-jasperreports-server-administrator-guide/v601/working-data-sources
"jdbc:tibcosoftware:sqlserver://server_name:1433;DatabaseName=dbname" | null | "tibcosoftware:sqlserver://server_name:1433" | "mssql" | "sqlserver" | null | "server_name" | 1433 | null | "dbname"
"jdbc:tibcosoftware:oracle://server_name:1521;ServiceName=your_servicename" | null | "tibcosoftware:oracle://server_name:1521" | "oracle" | "oracle" | null | "server_name" | 1521 | null | null
"jdbc:tibcosoftware:mysql://server_name:3306" | null | "tibcosoftware:mysql://server_name:3306" | "mysql" | "mysql" | null | "server_name" | 3306 | null | null
"jdbc:tibcosoftware:postgresql://server_name:5432;DatabaseName=dbname" | null | "tibcosoftware:postgresql://server_name:5432" | "postgresql" | "postgresql" | null | "server_name" | 5432 | null | "dbname"
"jdbc:tibcosoftware:db2://server_name:50000;DatabaseName=dbname" | null | "tibcosoftware:db2://server_name:50000" | "db2" | "db2" | null | "server_name" | 50000 | null | "dbname"
expected = DbInfo.builder().system(system).subtype(subtype).user(user).name(name).db(db).host(host).port(port).shortUrl(shortUrl).build()
}
}