org.firebirdsql.gds.ng.IAttachProperties Maven / Gradle / Ivy
/*
* Public Firebird Java API.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
* 1. Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
* EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package org.firebirdsql.gds.ng;
/**
* Common properties for database and service attach.
*
* @author Mark Rotteveel
* @since 3.0
*/
public interface IAttachProperties {
int DEFAULT_PORT = 3050;
String DEFAULT_SERVER_NAME = "localhost";
int DEFAULT_SOCKET_BUFFER_SIZE = -1;
int DEFAULT_SO_TIMEOUT = -1;
int DEFAULT_CONNECT_TIMEOUT = -1;
/**
* @return The name of the object to attach to (either a database or service name).
*/
String getAttachObjectName();
/**
* Get the hostname or IP address of the Firebird server.
*
* NOTE: Implementer should take care to return {@link #DEFAULT_SERVER_NAME}
* if value hasn't been set yet.
*
*
* @return Hostname or IP address of the server
*/
String getServerName();
/**
* Set the hostname or IP address of the Firebird server.
*
* NOTE: Implementer should take care to use {@link #DEFAULT_SERVER_NAME} if
* value hasn't been set yet.
*
*
* @param serverName
* Hostname or IP address of the server
*/
void setServerName(String serverName);
/**
* Get the portnumber of the server.
*
* NOTE: Implementer should take care to return {@link #DEFAULT_PORT} if
* value hasn't been set yet.
*
*
* @return Portnumber of the server
*/
int getPortNumber();
/**
* Set the port number of the server.
*
* NOTE: Implementer should take care to use the {@link #DEFAULT_PORT} if
* this method hasn't been called yet.
*
*
* @param portNumber
* Port number of the server
*/
void setPortNumber(int portNumber);
/**
* @return Name of the user to authenticate to the server.
*/
String getUser();
/**
* @param user
* Name of the user to authenticate to the server.
*/
void setUser(String user);
/**
* @return Password to authenticate to the server.
*/
String getPassword();
/**
* @param password
* Password to authenticate to the server.
*/
void setPassword(String password);
/**
* @return SQL role to use.
*/
String getRoleName();
/**
* @param roleName
* SQL role to use.
*/
void setRoleName(String roleName);
/**
* @return Java character set for the connection.
*/
String getCharSet();
/**
* Set the Java character set for the connection.
*
* Contrary to other parts of the codebase, the value of
* encoding
should not be changed when charSet
is
* set.
*
*
* @param charSet
* Character set for the connection. Similar to
* encoding
property, but accepts Java names instead
* of Firebird ones.
* @see #setEncoding(String)
*/
void setCharSet(String charSet);
/**
* @return Firebird character encoding for the connection.
*/
String getEncoding();
/**
* Set the Firebird character set for the connection.
*
* Contrary to other parts of the codebase, the value of
* charSet
should not be changed when encoding
is
* set.
*
*
* @param encoding
* Firebird character encoding for the connection. See Firebird
* documentation for more information.
*/
void setEncoding(String encoding);
/**
* Get the socket buffer size.
*
* NOTE: Implementer should take care to return {@link #DEFAULT_SOCKET_BUFFER_SIZE} if the
* value hasn't been set yet.
*
*
* @return socket buffer size in bytes, or -1 if not specified.
*/
int getSocketBufferSize();
/**
* Set the socket buffer size.
*
* NOTE: Implementer should take care to use {@link #DEFAULT_SOCKET_BUFFER_SIZE} if the
* value hasn't been set yet.
*
*
* @param socketBufferSize
* socket buffer size in bytes.
*/
void setSocketBufferSize(int socketBufferSize);
/**
* Get the initial Socket blocking timeout (SoTimeout).
*
* NOTE: Implementer should take care to return {@link #DEFAULT_SO_TIMEOUT} if the
* value hasn't been set yet.
*
*
* @return The initial socket blocking timeout in milliseconds (0 is
* 'infinite')
*/
int getSoTimeout();
/**
* Set the initial Socket blocking timeout (SoTimeout).
*
* NOTE: Implementer should take care to use {@link #DEFAULT_SO_TIMEOUT} if the
* value hasn't been set yet.
*
*
* @param soTimeout
* Timeout in milliseconds (0 is 'infinite')
*/
void setSoTimeout(int soTimeout);
/**
* Get the connect timeout in seconds.
*
* NOTE: Implementer should take care to return {@link #DEFAULT_CONNECT_TIMEOUT} if the
* value hasn't been set yet.
*
*
* @return Connect timeout in seconds (0 is 'infinite', or better: OS
* specific timeout)
*/
int getConnectTimeout();
/**
* Set the connect timeout in seconds.
*
* NOTE: Implementer should take care to use {@link #DEFAULT_CONNECT_TIMEOUT} if the
* value hasn't been set yet.
*
*
* @param connectTimeout
* Connect timeout in seconds (0 is 'infinite', or better: OS
* specific timeout)
*/
void setConnectTimeout(int connectTimeout);
/**
* Get the wire encryption level.
*
* NOTE: Implementer should take care to return {@link WireCrypt#DEFAULT} if
* the value hasn't been set yet.
*
*
* @return Wire encryption level
* @since 4.0
*/
WireCrypt getWireCrypt();
/**
* Set the wire encryption level.
*
* NOTE: Implementer should take care to use {@link WireCrypt#DEFAULT} if
* the value hasn't been set yet.
*
*
* @param wireCrypt
* Wire encryption level ({@code null} not allowed)
* @since 4.0
*/
void setWireCrypt(WireCrypt wireCrypt);
/**
* Get the database encryption plugin configuration.
*
* @return Database encryption plugin configuration, meaning plugin specific
* @since 3.0.4
*/
String getDbCryptConfig();
/**
* Sets the database encryption plugin configuration.
*
* @param dbCryptConfig
* Database encryption plugin configuration, meaning plugin specific
* @since 3.0.4
*/
void setDbCryptConfig(String dbCryptConfig);
/**
* Get the list of authentication plugins to try.
*
* @return comma-separated list of authentication plugins, or {@code null} for driver default
* @since 4.0
*/
String getAuthPlugins();
/**
* Sets the authentication plugins to try.
*
* Invalid names are skipped during authentication.
*
*
* @param authPlugins
* comma-separated list of authentication plugins, or {@code null} for driver default
* @since 4.0
*/
void setAuthPlugins(String authPlugins);
/**
* Get if wire compression should be enabled.
*
* Wire compression requires Firebird 3 or higher, and the server must have the zlib library. If compression cannot
* be negotiated, the connection will be made without wire compression.
*
*
* This property will be ignored for native connections. For native connections, the configuration in
* {@code firebird.conf} read by the client library will be used.
*
*
* @return {@code true} wire compression enabled
* @since 4.0
*/
boolean isWireCompression();
/**
* Sets if the connection should try to enable wire compression.
*
* @param wireCompression
* {@code true} enable wire compression, {@code false} disable wire compression (the default)
* @see #isWireCompression()
* @since 4.0
*/
void setWireCompression(boolean wireCompression);
/**
* @return An immutable version of this instance as an implementation of {@link IAttachProperties}
*/
T asImmutable();
/**
* @return A new, mutable, instance as an implementation of {@link IAttachProperties} with all properties copied.
*/
T asNewMutable();
}