org.springframework.orm.jpa.JpaVendorAdapter.java Source code

Java tutorial

Introduction

Here is the source code for org.springframework.orm.jpa.JpaVendorAdapter.java

Source

/*
 * Copyright 2002-2017 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.orm.jpa;

import java.util.Collections;
import java.util.Map;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.spi.PersistenceProvider;
import javax.persistence.spi.PersistenceUnitInfo;

import org.springframework.lang.Nullable;

/**
 * SPI interface that allows to plug in vendor-specific behavior
 * into Spring's EntityManagerFactory creators. Serves as single
 * configuration point for all vendor-specific properties.
 *
 * @author Juergen Hoeller
 * @author Rod Johnson
 * @since 2.0
 * @see AbstractEntityManagerFactoryBean#setJpaVendorAdapter
 */
public interface JpaVendorAdapter {

    /**
     * Return the vendor-specific persistence provider.
     */
    PersistenceProvider getPersistenceProvider();

    /**
     * Return the name of the persistence provider's root package
     * (e.g. "oracle.toplink.essentials"). Will be used for
     * excluding provider classes from temporary class overriding.
     * @since 2.5.2
     */
    @Nullable
    default String getPersistenceProviderRootPackage() {
        return null;
    }

    /**
     * Return a Map of vendor-specific JPA properties for the given persistence
     * unit, typically based on settings in this JpaVendorAdapter instance.
     * <p>Note that there might be further JPA properties defined on the
     * EntityManagerFactory bean, which might potentially override individual
     * JPA property values specified here.
     * <p>This implementation delegates to {@link #getJpaPropertyMap()} for
     * non-unit-dependent properties. Effectively, this PersistenceUnitInfo-based
     * variant only needs to be implemented if there is an actual need to react
     * to unit-specific characteristics such as the transaction type.
     * <p><b>NOTE:</b> This variant will only be invoked in case of Java EE style
     * container bootstrapping where a {@link PersistenceUnitInfo} is present
     * (i.e. {@link LocalContainerEntityManagerFactoryBean}. In case of simple
     * Java SE style bootstrapping via {@link javax.persistence.Persistence}
     * (i.e. {@link LocalEntityManagerFactoryBean}), the parameter-less
     * {@link #getJpaPropertyMap()} variant will be called directly.
     * @param pui the PersistenceUnitInfo for the current persistence unit
     * @return a Map of JPA properties, as accepted by the standard JPA bootstrap
     * facilities, or an empty Map if there are no properties to expose
     * @since 4.3.13
     * @see PersistenceUnitInfo#getTransactionType()
     * @see javax.persistence.spi.PersistenceProvider#createContainerEntityManagerFactory(PersistenceUnitInfo, Map)
     */
    default Map<String, ?> getJpaPropertyMap(PersistenceUnitInfo pui) {
        return getJpaPropertyMap();
    }

    /**
     * Return a Map of vendor-specific JPA properties,
     * typically based on settings in this JpaVendorAdapter instance.
     * <p>Note that there might be further JPA properties defined on the
     * EntityManagerFactory bean, which might potentially override individual
     * JPA property values specified here.
     * @return a Map of JPA properties, as accepted by the standard JPA bootstrap
     * facilities, or an empty Map if there are no properties to expose
     * @see javax.persistence.Persistence#createEntityManagerFactory(String, Map)
     */
    default Map<String, ?> getJpaPropertyMap() {
        return Collections.emptyMap();
    }

    /**
     * Return the vendor-specific JpaDialect implementation for this
     * provider, or {@code null} if there is none.
     */
    @Nullable
    default JpaDialect getJpaDialect() {
        return null;
    }

    /**
     * Return the vendor-specific EntityManagerFactory interface
     * that the EntityManagerFactory proxy is supposed to implement.
     * <p>If the provider does not offer any EntityManagerFactory extensions,
     * the adapter should simply return the standard
     * {@link javax.persistence.EntityManagerFactory} class here.
     * @since 2.5.2
     */
    default Class<? extends EntityManagerFactory> getEntityManagerFactoryInterface() {
        return EntityManagerFactory.class;
    }

    /**
     * Return the vendor-specific EntityManager interface
     * that this provider's EntityManagers will implement.
     * <p>If the provider does not offer any EntityManager extensions,
     * the adapter should simply return the standard
     * {@link javax.persistence.EntityManager} class here.
     */
    default Class<? extends EntityManager> getEntityManagerInterface() {
        return EntityManager.class;
    }

    /**
     * Optional callback for post-processing the native EntityManagerFactory
     * before active use.
     * <p>This can be used for triggering vendor-specific initialization processes.
     * While this is not expected to be used for most providers, it is included
     * here as a general extension hook.
     */
    default void postProcessEntityManagerFactory(EntityManagerFactory emf) {
    }

}