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

org.firebirdsql.gds.ng.wire.FbWireDatabase Maven / Gradle / Ivy

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

import org.firebirdsql.gds.ng.FbDatabase;
import org.firebirdsql.gds.ng.WarningMessageCallback;
import org.firebirdsql.gds.ng.fields.BlrCalculator;

import java.io.IOException;
import java.sql.SQLException;

/**
 * @author Mark Rotteveel
 * @since 3.0
 */
public interface FbWireDatabase extends FbDatabase, FbWireAttachment {

    /**
     * Reads the response from the server.
     *
     * @param callback
     *         Callback object for warnings, null for default callback
     * @return {@link Response} read.
     * @throws SQLException
     *         For errors returned from the server, or when attempting to read
     * @throws IOException
     *         For errors reading the response from the connection.
     */
    Response readResponse(WarningMessageCallback callback) throws SQLException, IOException;

    /**
     * Release object.
     *
     * @param operation
     *         Operation
     * @param objectId
     *         ID of the object to release
     */
    void releaseObject(int operation, int objectId) throws SQLException;

    /**
     * Convenience method to read a Response to a SqlResponse
     *
     * @param callback
     *         Callback object for warnings, null for default callback
     * @return SqlResponse
     * @throws SQLException
     *         For errors returned from the server, or when attempting to
     *         read.
     * @throws IOException
     *         For errors reading the response from the connection.
     */
    SqlResponse readSqlResponse(WarningMessageCallback callback) throws SQLException, IOException;

    /**
     * @return The {@link BlrCalculator} instance for this database.
     */
    BlrCalculator getBlrCalculator();

    /**
     * Enqueue a deferred action.
     * 

* FbDatabase implementations that do not support deferred actions are allowed to throw an * {@link java.lang.UnsupportedOperationException} *

* * @param deferredAction * Deferred action * @throws SQLException * for errors forcing handling of oversized queue using {@code op_ping} (or {@code op_batch_sync}) */ void enqueueDeferredAction(DeferredAction deferredAction) throws SQLException; /** * Completes pending deferred actions. *

* FbDatabase implementations that do not support deferred actions should simply do nothing. *

* * @throws SQLException * for errors forcing ping/batch sync * @since 6 */ void completeDeferredActions() throws SQLException; /** * Consumes packets notifying for warnings, but ignoring exceptions thrown from the packet. *

* This method should only be used inside the implementation if either packets need to be ignored, * or to ensure that there is no backlog of packets (eg when an exception occurs during processing of multiple * package responses). *

* * @param numberOfResponses Number of responses to consume. * @param warningCallback Callback for warnings */ void consumePackets(int numberOfResponses, WarningMessageCallback warningCallback); /** * Generic info request. *

* The implementation does not perform handle validation nor notification of error dispatchers. Doing that is the * responsibility of the caller. *

* * @param operation * Operation code * @param handle * Handle (db, transaction, statement, blob, etc) * @param requestItems * Information items to request * @param maxBufferLength * Maximum response buffer length to use * @param warningMessageCallback * Callback for warnings when reading the response (can be {@code null} to use database default) * @return The response buffer (note: length is the actual length of the response, not {@code maxBufferLength}) * @throws SQLException * For errors retrieving the information */ byte[] getInfo(int operation, int handle, byte[] requestItems, int maxBufferLength, WarningMessageCallback warningMessageCallback) throws SQLException; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy