All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy