org.firebirdsql.gds.ng.AbstractFbAttachment Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jaybird Show documentation
Show all versions of jaybird Show documentation
JDBC Driver for the Firebird RDBMS
/*
* 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