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

org.firebirdsql.gds.ng.AbstractFbAttachment Maven / Gradle / Ivy

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

import org.firebirdsql.encodings.Encoding;
import org.firebirdsql.encodings.IEncodingFactory;
import org.firebirdsql.gds.JaybirdErrorCodes;
import org.firebirdsql.gds.impl.GDSServerVersion;
import org.firebirdsql.gds.impl.GDSServerVersionException;
import org.firebirdsql.gds.ng.listeners.ExceptionListener;
import org.firebirdsql.gds.ng.listeners.ExceptionListenerDispatcher;

import java.sql.SQLException;
import java.util.Arrays;

import static java.util.Objects.requireNonNull;

/**
 * Common behavior for {@link AbstractFbService} and {@link AbstractFbDatabase}.
 *
 * @author Mark Rotteveel
 * @since 3.0
 */
public abstract class AbstractFbAttachment, ? extends FbAttachment>>
        implements FbAttachment {

    private static final System.Logger log = System.getLogger(AbstractFbAttachment.class.getName());

    private volatile boolean attached;
    protected final ExceptionListenerDispatcher exceptionListenerDispatcher = new ExceptionListenerDispatcher(this);
    protected final T connection;
    private final DatatypeCoder datatypeCoder;
    private GDSServerVersion serverVersion;
    private ServerVersionInformation serverVersionInformation;

    protected AbstractFbAttachment(T connection, DatatypeCoder datatypeCoder) {
        this.connection = requireNonNull(connection, "parameter connection should be non-null");
        this.datatypeCoder = requireNonNull(datatypeCoder, "parameter datatypeCoder should be non-null");
    }

    @Override
    public final LockCloseable withLock() {
        return connection.withLock();
    }

    @Override
    public final boolean isLockedByCurrentThread() {
        return connection.isLockedByCurrentThread();
    }

    /**
     * {@inheritDoc}
     * 

* Default implementation, calls {@link #close()} *

*/ @Override public void forceClose() throws SQLException { close(); } @Override public GDSServerVersion getServerVersion() { return serverVersion; } /** * Sets the Firebird version from one or more version string elements. *

* This method should only be called by this instance. *

* * @param versionStrings * Raw version strings */ protected final void setServerVersion(String... versionStrings) { try { serverVersion = GDSServerVersion.parseRawVersion(versionStrings); } catch (GDSServerVersionException e) { log.log(System.Logger.Level.ERROR, () -> "Received unsupported server version \"%s\", replacing with dummy invalid version" .formatted(Arrays.toString(versionStrings)), e); serverVersion = GDSServerVersion.INVALID_VERSION; } serverVersionInformation = ServerVersionInformation.getForVersion(serverVersion); } final ServerVersionInformation getServerVersionInformation() { return serverVersionInformation; } /** * Called when this attachment is attached. *

* Only this {@link org.firebirdsql.gds.ng.AbstractFbDatabase} instance should call this method. *

*/ protected final void setAttached() { attached = true; } @Override public boolean isAttached() { return attached; } /** * Called when this attachment is detached. *

* Only this {@link AbstractFbAttachment} instance should call this method. *

*/ protected final void setDetached() { attached = false; } @Override public final IEncodingFactory getEncodingFactory() { return connection.getEncodingFactory(); } @Override public final Encoding getEncoding() { return connection.getEncoding(); } @Override public final DatatypeCoder getDatatypeCoder() { return datatypeCoder; } @Override public int getNetworkTimeout() throws SQLException { checkConnected(); int soTimeout = connection.getAttachProperties().getSoTimeout(); return soTimeout != -1 ? soTimeout : 0; } @Override public final void addExceptionListener(ExceptionListener listener) { exceptionListenerDispatcher.addListener(listener); } @Override public final void removeExceptionListener(ExceptionListener listener) { exceptionListenerDispatcher.removeListener(listener); } /** * Checks if the attachment is connected, and throws a {@link SQLException} if it isn't connected. */ protected abstract void checkConnected() throws SQLException; /** * Performs {@link #close()} suppressing any exception. */ protected final void safelyDetach() { try { close(); } catch (Exception ex) { // ignore, but log log.log(System.Logger.Level.DEBUG, "Exception on safely detach", ex); } } /** * Checks if not currently attached. * * @throws SQLException * if this attachment is currently attached * @since 6 */ protected final void requireNotAttached() throws SQLException { if (isAttached()) { throw FbExceptionBuilder.forNonTransientConnectionException(JaybirdErrorCodes.jb_alreadyAttached) .messageParameter(this instanceof FbDatabase ? "database" : "service") .toSQLException(); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy