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

org.firebirdsql.jdbc.FirebirdConnectionProperties Maven / Gradle / Ivy

There is a newer version: 6.0.0-beta-1
Show newest version
/*
 * 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.jdbc;

import org.firebirdsql.gds.DatabaseParameterBuffer;
import org.firebirdsql.gds.TransactionParameterBuffer;
import org.firebirdsql.gds.ng.WireCrypt;

import java.sql.SQLException;

/**
 * Connection properties for the Firebird connection. Main part of this
 * interface corresponds to the Database Parameter Buffer, but also contains
 * properties to specify default transaction parameters.
 */
public interface FirebirdConnectionProperties {

    /**
     * @return path to the database including the server name and the port,
     * if needed.
     */
    String getDatabase();

    /**
     * @param database
     *         path to the database including the server name and the
     *         port, if needed.
     */
    void setDatabase(String database);

    /**
     * @return type of the connection, for example, "PURE_JAVA", "LOCAL",
     * "EMBEDDED", depends on the GDS implementations installed in the system.
     */
    String getType();

    /**
     * @param type
     *         type of the connection, for example, "PURE_JAVA", "LOCAL",
     *         "EMBEDDED", depends on the GDS implementations installed in the system.
     */
    void setType(String type);

    /**
     * @return BLOB buffer size in bytes.
     */
    int getBlobBufferSize();

    /**
     * @param bufferSize
     *         size of the BLOB buffer in bytes.
     */
    void setBlobBufferSize(int bufferSize);

    /**
     * @return Character set for the connection.
     * @see #setCharSet(String)
     */
    String getCharSet();

    /**
     * @param charSet
     *         Character set for the connection. Similar to
     *         encoding property, but accepts Java names
     *         instead of Firebird ones.
     */
    void setCharSet(String charSet);

    /**
     * @return Character encoding for the connection.
     * @see #setEncoding(String)
     */
    String getEncoding();

    /**
     * @param encoding
     *         Character encoding for the connection. See Firebird
     *         documentation for more information.
     */
    void setEncoding(String encoding);

    /**
     * @return SQL role to use.
     */
    String getRoleName();

    /**
     * @param roleName
     *         SQL role to use.
     */
    void setRoleName(String roleName);

    /**
     * @return SQL dialect of the client.
     */
    String getSqlDialect();

    /**
     * @param sqlDialect
     *         SQL dialect of the client.
     */
    void setSqlDialect(String sqlDialect);

    /**
     * @return true if stream blobs should be created, otherwise
     * false.
     */
    boolean isUseStreamBlobs();

    /**
     * @param useStreamBlobs
     *         true if stream blobs should be created,
     *         otherwise false.
     */
    void setUseStreamBlobs(boolean useStreamBlobs);

    /**
     * @return true if driver should assume that standard UDF are
     * installed.
     */
    boolean isUseStandardUdf();

    /**
     * @param useStandardUdf
     *         true if driver should assume that standard UDF
     *         are installed.
     */
    void setUseStandardUdf(boolean useStandardUdf);

    /**
     * @return socket buffer size in bytes, or -1 is not specified.
     */
    int getSocketBufferSize();

    /**
     * @param socketBufferSize
     *         socket buffer size in bytes.
     */
    void setSocketBufferSize(int socketBufferSize);

    /**
     * @return true if the Jaybird 1.0 handling of the calendar
     * in corresponding setters. This is also compatible with MySQL
     * calendar treatment.
     */
    boolean isTimestampUsesLocalTimezone();

    /**
     * @param timestampUsesLocalTimezone
     *         true if the Jaybird 1.0 handling of the
     *         calendar in corresponding setters. This is also compatible
     *         with MySQL calendar treatment.
     */
    void setTimestampUsesLocalTimezone(boolean timestampUsesLocalTimezone);

    /**
     * @return name of the user that will be used when connecting to the database.
     */
    String getUserName();

    /**
     * @param userName
     *         name of the user that will be used when connecting to the database.
     */
    void setUserName(String userName);

    /**
     * @return password corresponding to the specified user name.
     */
    String getPassword();

    /**
     * @param password
     *         password corresponding to the specified user name.
     */
    void setPassword(String password);

    /**
     * @return number of cache buffers that should be allocated for this
     * connection, should be specified for ClassicServer instances,
     * SuperServer has a server-wide configuration parameter.
     */
    int getBuffersNumber();

    /**
     * @param buffersNumber
     *         number of cache buffers that should be allocated for this
     *         connection, should be specified for ClassicServer instances,
     *         SuperServer has a server-wide configuration parameter.
     */
    void setBuffersNumber(int buffersNumber);

    /**
     * Get the property that does not have corresponding getter method by its
     * name.
     *
     * @param key
     *         name of the property to get.
     * @return value of the property.
     */
    String getNonStandardProperty(String key);

    /**
     * Set the property that does not have corresponding setter method.
     *
     * @param key
     *         name of the property to set.
     * @param value
     *         value of the property.
     */
    void setNonStandardProperty(String key, String value);

    /**
     * Set the property that does not have corresponding setter method.
     *
     * @param propertyMapping
     *         parameter value in the ?propertyName[=propertyValue]? form,
     *         this allows setting non-standard parameters using
     *         configuration files.
     */
    void setNonStandardProperty(String propertyMapping);

    /**
     * Get the database parameter buffer corresponding to the current connection
     * request information.
     *
     * @return instance of {@link DatabaseParameterBuffer}.
     * @throws SQLException
     *         if database parameter buffer cannot be created.
     */
    DatabaseParameterBuffer getDatabaseParameterBuffer() throws SQLException;

    /**
     * Get the used TPB mapping.
     *
     * @return path to the TPB mapping.
     * @see #setTpbMapping(String)
     */
    String getTpbMapping();

    /**
     * Set path to the properties file with the TPB mapping. The path begins
     * with the protocol specification followed by the path to the resource. A
     * special protocol "res:" should be used to specify resource
     * in the classpath.
     * 

* For the compatibility reasons, if no protocol is specified, classpath is * used by default. *

* Properties file contains a mapping between the transaction isolation * level (name of the constant in the {@link java.sql.Connection} interface * and a comma-separated list of TPB parameters. * * @param tpbMapping * path to the properties file. */ void setTpbMapping(String tpbMapping); /** * Get the default transaction isolation level. This is the transaction * isolation level for the newly created connections. * * @return default transaction isolation level. */ int getDefaultTransactionIsolation(); /** * Set the default transaction isolation level. * * @param defaultIsolationLevel * default transaction isolation level. */ void setDefaultTransactionIsolation(int defaultIsolationLevel); /** * Get the default transaction isolation level as string. This method is * complementary to the {@link #getDefaultTransactionIsolation()}, however * it takes a string as parameter instead of a numeric constant. * * @return default transaction isolation as string. * @see #setDefaultIsolation(String) */ String getDefaultIsolation(); /** * Set the default transaction isolation level as string. This method is * complementary to the {@link #setDefaultTransactionIsolation(int)}, * however it takes a string as parameter instead of a numeric constant. *

* Following strings are allowed: *

    *
  • "TRANSACTION_READ_COMMITTED" for a READ COMMITTED * isolation level. *
  • "TRANSACTION_REPEATABLE_READ" for a REPEATABLE READ * isolation level. *
  • "TRANSACTION_SERIALIZABLE" for a SERIALIZABLE * isolation level. *
* * @param isolation * string constant representing a default isolation level. */ void setDefaultIsolation(String isolation); /** * Get the transaction parameter buffer corresponding to the current * connection request information. * * @param isolation * transaction isolation level for which TPB should be returned. * @return instance of {@link TransactionParameterBuffer}. */ TransactionParameterBuffer getTransactionParameters(int isolation); /** * Set transaction parameters for the specified transaction isolation level. * The specified TPB is used as a default mapping for the specified * isolation level. * * @param isolation * transaction isolation level. * @param tpb * instance of {@link TransactionParameterBuffer} containing * transaction parameters. */ void setTransactionParameters(int isolation, TransactionParameterBuffer tpb); /** * Get the default ResultSet holdability. * * @return true when ResultSets are holdable by default, false not holdable. */ boolean isDefaultResultSetHoldable(); /** * Sets the default ResultSet holdability. * * @param isHoldable * true when ResultSets are holdable by default, false not holdable. */ void setDefaultResultSetHoldable(boolean isHoldable); /** * Get the current Socket blocking timeout (SoTimeout). * * @return The socket blocking timeout in milliseconds (0 is 'infinite') */ int getSoTimeout(); /** * Set the Socket blocking timeout (SoTimeout). * * @param soTimeout * Timeout in milliseconds (0 is 'infinite') */ void setSoTimeout(int soTimeout); /** * Get the current connect timeout. * * @return Connect timeout in seconds (0 is 'infinite', or better: OS specific timeout) */ int getConnectTimeout(); /** * Set the connect timeout. * * @param connectTimeout * Connect timeout in seconds (0 is 'infinite', or better: OS specific timeout) */ void setConnectTimeout(int connectTimeout); /** * Get whether to use Firebird autocommit (experimental). * * @return {@code true} use Firebird autocommit */ boolean isUseFirebirdAutocommit(); /** * Set whether to use Firebird autocommit (experimental). * * @param useFirebirdAutocommit * {@code true} Use Firebird autocommit */ void setUseFirebirdAutocommit(boolean useFirebirdAutocommit); /** * Get the wire encryption level value. * * @return Wire encryption level ({@code null} implies {@code DEFAULT}) * @since 4.0 */ String getWireCrypt(); /** * Sets the wire encryption level. *

* Values are defined by {@link WireCrypt}, values are handled case insensitive. * Invalid values are accepted, but will cause an error when a connection is established. *

* * @param wireCrypt * Wire encryption level * @since 4.0 */ void setWireCrypt(String 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 the {@code generatedKeysEnabled} configuration. * * @return configuration value for {@code generatedKeysEnabled}, or {@code null} for driver default * @since 4.0 */ String getGeneratedKeysEnabled(); /** * Sets the {@code generatedKeysEnabled} configuration. * * @param generatedKeysEnabled * Generated keys support configuration: {@code default} (or null/empty), {@code disabled}, {@code ignored}, * or a list of statement types to enable (possible values: {@code insert}, {@code update}, {@code delete}, * {@code update_or_insert}, {@code merge}) */ void setGeneratedKeysEnabled(String generatedKeysEnabled); /** * Get the {@code dataTypeBind} configuration. * * @return configuration value for {@code dataTypeBind}, or {@code null} for driver default * @since 4.0 */ String getDataTypeBind(); /** * Sets the {@code dataTypeBind} configuration. *

* If the value is explicitly set to a non-null value and the connected server is Firebird 4 or higher, this will * configure the data type binding with the specified values using {@code isc_dpb_set_bind}, which is equivalent to * executing {@code SET BIND} statements with the values. *

*

* See also Firebird documentation for {@code SET BIND}. *

* * @param dataTypeBind * Firebird 4+ data type bind configuration, a semicolon-separated list of {@code TO } * @since 4.0 */ void setDataTypeBind(String dataTypeBind); /** * Get the {@code sessionTimeZone}. * * @return value for {@code sessionTimeZone}, or {@code null} for driver default (JVM default time zone) * @since 4.0 */ String getSessionTimeZone(); /** * Sets the {@code sessionTimeZone}. * * @param sessionTimeZone * Firebird 4+ session time zone name (we strongly suggest to use Java compatible names only), * use {@code "server"} to use server default time zone (note: conversion will use JVM default time zone) * @since 4.0 */ void setSessionTimeZone(String sessionTimeZone); /** * Get the value for {@code ignoreProcedureType}. * * @return value for {@code ignoreProcedureType} * @since 3.0.6 */ boolean isIgnoreProcedureType(); /** * Sets the value {@code ignoreProcedureType}. *

* When set to true, the {@link java.sql.CallableStatement} implementation in Jaybird will ignore metadata * information about the stored procedure type and default to using {@code EXECUTE PROCEDURE}, unless the type is * explicitly set using {@link FirebirdCallableStatement#setSelectableProcedure(boolean)}. This can be useful in * situations where a stored procedure is selectable, but tooling or code expects an executable stored procedure. *

* * @param ignoreProcedureType * {@code true} Ignore procedure type * @since 3.0.6 */ void setIgnoreProcedureType(boolean ignoreProcedureType); /** * 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); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy