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

org.springframework.r2dbc.connection.ConnectionHolder Maven / Gradle / Ivy

/*
 * Copyright 2002-2023 the original author or authors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      https://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.springframework.r2dbc.connection;

import io.r2dbc.spi.Connection;
import io.r2dbc.spi.ConnectionFactory;

import org.springframework.lang.Nullable;
import org.springframework.transaction.support.ResourceHolderSupport;
import org.springframework.util.Assert;

/**
 * Resource holder wrapping a R2DBC {@link Connection}.
 * {@link R2dbcTransactionManager} binds instances of this class to the subscription,
 * for a specific {@link ConnectionFactory}.
 *
 * 

Inherits rollback-only support for nested R2DBC transactions and reference * count functionality from the base class. * *

Note: This is an SPI class, not intended to be used by applications. * * @author Mark Paluch * @author Christoph Strobl * @since 5.3 * @see R2dbcTransactionManager * @see ConnectionFactoryUtils */ public class ConnectionHolder extends ResourceHolderSupport { /** * Prefix for savepoint names. * @since 6.0.10 */ static final String SAVEPOINT_NAME_PREFIX = "SAVEPOINT_"; @Nullable private Connection currentConnection; private boolean transactionActive; private int savepointCounter = 0; /** * Create a new ConnectionHolder for the given R2DBC {@link Connection}, * assuming that there is no ongoing transaction. * @param connection the R2DBC {@link Connection} to hold * @see #ConnectionHolder(Connection, boolean) */ public ConnectionHolder(Connection connection) { this(connection, false); } /** * Create a new ConnectionHolder for the given R2DBC {@link Connection}. * @param connection the R2DBC {@link Connection} to hold * @param transactionActive whether the given {@link Connection} is involved * in an ongoing transaction */ public ConnectionHolder(Connection connection, boolean transactionActive) { this.currentConnection = connection; this.transactionActive = transactionActive; } /** * Return whether this holder currently has a {@link Connection}. */ protected boolean hasConnection() { return (this.currentConnection != null); } /** * Set whether this holder represents an active, R2DBC-managed transaction. * @see R2dbcTransactionManager */ protected void setTransactionActive(boolean transactionActive) { this.transactionActive = transactionActive; } /** * Return whether this holder represents an active, R2DBC-managed transaction. */ protected boolean isTransactionActive() { return this.transactionActive; } /** * Override the existing Connection with the given {@link Connection}. *

Used for releasing the {@link Connection} on suspend * (with a {@code null} argument) and setting a fresh {@link Connection} on resume. */ protected void setConnection(@Nullable Connection connection) { this.currentConnection = connection; } /** * Return the current {@link Connection} held by this {@link ConnectionHolder}. *

This will be the same {@link Connection} until {@code released} gets called * on the {@link ConnectionHolder}, which will reset the held {@link Connection}, * fetching a new {@link Connection} on demand. * @see #released() */ public Connection getConnection() { Assert.state(this.currentConnection != null, "Active Connection is required"); return this.currentConnection; } /** * Create a new savepoint for the current {@link Connection}, * using generated savepoint names that are unique for the Connection. * @return the name of the new savepoint * @since 6.0.10 */ String nextSavepoint() { this.savepointCounter++; return SAVEPOINT_NAME_PREFIX + this.savepointCounter; } /** * Releases the current {@link Connection}. */ @Override public void released() { super.released(); if (!isOpen() && this.currentConnection != null) { this.currentConnection = null; } } @Override public void clear() { super.clear(); this.transactionActive = false; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy