Summary Table
Categories |
Total Count |
PII |
0 |
URL |
0 |
DNS |
1 |
EKL |
0 |
IP |
0 |
PORT |
0 |
VsID |
0 |
CF |
0 |
AI |
0 |
VPD |
0 |
PL |
0 |
Other |
0 |
File Content
/**
*
*/
package gov.va.med.ars.configuration.hibernate;
import java.util.HashMap;
import javax.persistence.EntityManagerFactory;
import javax.sql.DataSource;
import org.apache.commons.lang.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.env.Environment;
import org.springframework.data.jpa.repository.config.EnableJpaRepositories;
import org.springframework.jdbc.datasource.DriverManagerDataSource;
import org.springframework.orm.hibernate5.HibernateExceptionTranslator;
import org.springframework.orm.jpa.JpaTransactionManager;
import org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean;
import org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter;
import org.springframework.transaction.PlatformTransactionManager;
import org.springframework.transaction.annotation.EnableTransactionManagement;
/**
* @author
DNS
*
*/
@Configuration
@EnableTransactionManagement
@EnableJpaRepositories(basePackages = "gov.va.med.ars.dao.erepos", entityManagerFactoryRef = "eReposEntityManager", transactionManagerRef = "eReposTransactionManager")
public class EreposPersistenceConfig {
@Autowired
DataSource arsDataSource;
@Autowired
private Environment env;
@Value("$(init-db:false)")
private String initDatabase;
@Bean(name = "eReposEntityManager")
public LocalContainerEntityManagerFactoryBean eReposEntityManager() {
final LocalContainerEntityManagerFactoryBean em = new LocalContainerEntityManagerFactoryBean();
em.setDataSource(eReposDataSource());
em.setPackagesToScan( "gov.va.med.domain.ereposModel" );
final HibernateJpaVendorAdapter vendorAdapter = new HibernateJpaVendorAdapter();
em.setJpaVendorAdapter(vendorAdapter);
final HashMap<String, Object> properties = new HashMap<String, Object>();
properties.put("hibernate.hbm2ddl.auto", env.getProperty("hibernate.hbm2ddl.auto"));
properties.put("hibernate.dialect", env.getProperty("hibernate.dialect"));
em.setJpaPropertyMap(properties);
return em;
}
@Bean(name = "ereposDataSource")
public DataSource eReposDataSource() {
String ereposUrl = env.getProperty("jdbc.erepos.url");
String arsUrl = env.getProperty("jdbc.ars.url");
String ereposUsername = env.getProperty("jdbc.erepos.username");
String arsUsername = env.getProperty("jdbc.ars.username");
if (StringUtils.isBlank(ereposUrl)) {
ereposUrl = arsUrl;
}
if (StringUtils.isBlank(ereposUsername)) {
ereposUsername = arsUsername;
}
/*
* arsUrl = | arsUsername = | Result
* ereposUrl | ereposUsername |
* -----------------------------------
* True | True | arsDatasource
* True | False | ereposDatasource
* False | True | ereposDatasource
* False | False | ereposDatasource
*
*/
if (arsUrl.equalsIgnoreCase(ereposUrl) && arsUsername.equalsIgnoreCase(ereposUsername)) {
return arsDataSource;
} else {
final DriverManagerDataSource dataSource = new DriverManagerDataSource();
dataSource.setDriverClassName(env.getProperty("jdbc.ars.driverClassName"));
dataSource.setUrl(ereposUrl);
dataSource.setUsername(ereposUsername);
if (StringUtils.isNotBlank(env.getProperty("jdbc.erepos.password"))) {
dataSource.setPassword(env.getProperty("jdbc.erepos.password"));
} else {
dataSource.setPassword(env.getProperty("jdbc.ars.password"));
}
return dataSource;
}
}
@Bean
public HibernateExceptionTranslator hibernateExceptionTranslator() {
return new HibernateExceptionTranslator();
}
@Bean(name = "eReposTransactionManager")
public PlatformTransactionManager eReposTransactionManager() {
EntityManagerFactory factory = eReposEntityManager().getObject();
return new JpaTransactionManager(factory);
}
}