/*
 * Copyright 2002-2018 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
 *
 *      http://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.orm.hibernate5;

import javax.persistence.EntityManager;

import org.hibernate.FlushMode;
import org.hibernate.Session;
import org.hibernate.Transaction;

import org.springframework.lang.Nullable;
import org.springframework.orm.jpa.EntityManagerHolder;

Resource holder wrapping a Hibernate Session (plus an optional Transaction). HibernateTransactionManager binds instances of this class to the thread, for a given SessionFactory. Extends EntityManagerHolder as of 5.1, automatically exposing an EntityManager handle on Hibernate 5.2+.

Note: This is an SPI class, not intended to be used by applications.

Author:Juergen Hoeller
See Also:
Since:4.2
/** * Resource holder wrapping a Hibernate {@link Session} (plus an optional {@link Transaction}). * {@link HibernateTransactionManager} binds instances of this class to the thread, * for a given {@link org.hibernate.SessionFactory}. Extends {@link EntityManagerHolder} * as of 5.1, automatically exposing an {@code EntityManager} handle on Hibernate 5.2+. * * <p>Note: This is an SPI class, not intended to be used by applications. * * @author Juergen Hoeller * @since 4.2 * @see HibernateTransactionManager * @see SessionFactoryUtils */
public class SessionHolder extends EntityManagerHolder { private final Session session; @Nullable private Transaction transaction; @Nullable private FlushMode previousFlushMode; public SessionHolder(Session session) { // Check below is always true against Hibernate >= 5.2 but not against 5.0/5.1 at runtime super(EntityManager.class.isInstance(session) ? session : null); this.session = session; } public Session getSession() { return this.session; } public void setTransaction(@Nullable Transaction transaction) { this.transaction = transaction; setTransactionActive(transaction != null); } @Nullable public Transaction getTransaction() { return this.transaction; } public void setPreviousFlushMode(@Nullable FlushMode previousFlushMode) { this.previousFlushMode = previousFlushMode; } @Nullable public FlushMode getPreviousFlushMode() { return this.previousFlushMode; } @Override public void clear() { super.clear(); this.transaction = null; this.previousFlushMode = null; } }