org.firebirdsql.gds.impl.jni.NativeGDSFactoryPlugin Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jaybird Show documentation
Show all versions of jaybird Show documentation
JDBC Driver for the Firebird RDBMS
/*
* Firebird Open Source JavaEE Connector - JDBC Driver
*
* Distributable under LGPL license.
* You may obtain a copy of the License at http://www.gnu.org/copyleft/lgpl.html
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* LGPL License for more details.
*
* This file was created by members of the firebird development team.
* All individual contributions remain the Copyright (C) of those
* individuals. Contributors to this file are either listed here or
* can be obtained from a source control history command.
*
* All rights reserved.
*/
package org.firebirdsql.gds.impl.jni;
import org.firebirdsql.gds.GDSException;
import org.firebirdsql.gds.impl.BaseGDSFactoryPlugin;
import org.firebirdsql.gds.ng.jna.FbClientDatabaseFactory;
import java.util.Arrays;
public class NativeGDSFactoryPlugin extends BaseGDSFactoryPlugin {
public static final String NATIVE_TYPE_NAME = "NATIVE";
private static final String[] TYPE_ALIASES = new String[] { "TYPE2" };
private static final String[] JDBC_PROTOCOLS = new String[] {
"jdbc:firebirdsql:native:", "jdbc:firebird:native:"
};
public String getPluginName() {
return "JNA-based GDS implementation.";
}
public String getTypeName() {
return NATIVE_TYPE_NAME;
}
public String[] getTypeAliases() {
return Arrays.copyOf(TYPE_ALIASES, TYPE_ALIASES.length);
}
public String[] getSupportedProtocols() {
return Arrays.copyOf(JDBC_PROTOCOLS, JDBC_PROTOCOLS.length);
}
public String getDatabasePath(String server, Integer port, String path) throws GDSException{
if (server == null) {
throw new GDSException("Server name/address is required for native implementation.");
}
if (path == null) {
throw new GDSException("Database name/path is required.");
}
StringBuilder sb = new StringBuilder();
sb.append(server);
if (port != null) {
sb.append('/').append(port.intValue());
}
sb.append(':').append(path);
return sb.toString();
}
@Override
public FbClientDatabaseFactory getDatabaseFactory() {
return FbClientDatabaseFactory.getInstance();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy