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

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

/*
 * Copyright 2002-2012 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 javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.spi.PersistenceProvider;
import javax.persistence.spi.PersistenceUnitInfo;
import javax.sql.DataSource;

import org.springframework.lang.Nullable;

/**
 * Metadata interface for a Spring-managed JPA {@link EntityManagerFactory}.
 *
 * 

This facility can be obtained from Spring-managed EntityManagerFactory * proxies through casting the EntityManagerFactory handle to this interface. * * @author Rod Johnson * @author Juergen Hoeller * @since 2.0 */ public interface EntityManagerFactoryInfo { /** * Return the raw underlying EntityManagerFactory. * @return the unadorned EntityManagerFactory (never {@code null}) */ EntityManagerFactory getNativeEntityManagerFactory(); /** * Return the underlying PersistenceProvider that the underlying * EntityManagerFactory was created with. * @return the PersistenceProvider used to create this EntityManagerFactory, * or {@code null} if the standard JPA provider autodetection process * was used to configure the EntityManagerFactory */ @Nullable PersistenceProvider getPersistenceProvider(); /** * Return the PersistenceUnitInfo used to create this * EntityManagerFactory, if the in-container API was used. * @return the PersistenceUnitInfo used to create this EntityManagerFactory, * or {@code null} if the in-container contract was not used to * configure the EntityManagerFactory */ @Nullable PersistenceUnitInfo getPersistenceUnitInfo(); /** * Return the name of the persistence unit used to create this * EntityManagerFactory, or {@code null} if it is an unnamed default. *

If {@code getPersistenceUnitInfo()} returns non-null, the result of * {@code getPersistenceUnitName()} must be equal to the value returned by * {@code PersistenceUnitInfo.getPersistenceUnitName()}. * @see #getPersistenceUnitInfo() * @see javax.persistence.spi.PersistenceUnitInfo#getPersistenceUnitName() */ @Nullable String getPersistenceUnitName(); /** * Return the JDBC DataSource that this EntityManagerFactory * obtains its JDBC Connections from. * @return the JDBC DataSource, or {@code null} if not known */ @Nullable DataSource getDataSource(); /** * Return the (potentially vendor-specific) EntityManager interface * that this factory's EntityManagers will implement. *

A {@code null} return value suggests that autodetection is supposed * to happen: either based on a target {@code EntityManager} instance * or simply defaulting to {@code javax.persistence.EntityManager}. */ @Nullable Class getEntityManagerInterface(); /** * Return the vendor-specific JpaDialect implementation for this * EntityManagerFactory, or {@code null} if not known. */ @Nullable JpaDialect getJpaDialect(); /** * Return the ClassLoader that the application's beans are loaded with. *

Proxies will be generated in this ClassLoader. */ ClassLoader getBeanClassLoader(); }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy