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

org.springframework.orm.jpa.JpaVendorAdapter Maven / Gradle / Ivy

There is a newer version: 6.1.6
Show newest version
/*
 * 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
 *
 *      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.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.
	 * 

Note that there might be further JPA properties defined on the * EntityManagerFactory bean, which might potentially override individual * JPA property values specified here. *

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. *

NOTE: 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 getJpaPropertyMap(PersistenceUnitInfo pui) { return getJpaPropertyMap(); } /** * Return a Map of vendor-specific JPA properties, * typically based on settings in this JpaVendorAdapter instance. *

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 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. *

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 getEntityManagerFactoryInterface() { return EntityManagerFactory.class; } /** * Return the vendor-specific EntityManager interface * that this provider's EntityManagers will implement. *

If the provider does not offer any EntityManager extensions, * the adapter should simply return the standard * {@link javax.persistence.EntityManager} class here. */ default Class getEntityManagerInterface() { return EntityManager.class; } /** * Optional callback for post-processing the native EntityManagerFactory * before active use. *

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) { } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy