76 lines
3.0 KiB
Java
76 lines
3.0 KiB
Java
package eu.eudat.configurations;
|
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
import org.springframework.context.annotation.Bean;
|
|
import org.springframework.context.annotation.ComponentScan;
|
|
import org.springframework.context.annotation.Configuration;
|
|
import org.springframework.context.annotation.Profile;
|
|
import org.springframework.core.env.Environment;
|
|
import org.springframework.dao.annotation.PersistenceExceptionTranslationPostProcessor;
|
|
import org.springframework.jdbc.datasource.DriverManagerDataSource;
|
|
import org.springframework.orm.jpa.JpaTransactionManager;
|
|
import org.springframework.orm.jpa.JpaVendorAdapter;
|
|
import org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean;
|
|
import org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter;
|
|
import org.springframework.transaction.PlatformTransactionManager;
|
|
import org.springframework.transaction.annotation.EnableTransactionManagement;
|
|
|
|
import javax.persistence.EntityManagerFactory;
|
|
import javax.sql.DataSource;
|
|
import java.util.Properties;
|
|
|
|
/**
|
|
* Created by ikalyvas on 2/9/2018.
|
|
*/
|
|
@Configuration
|
|
@EnableTransactionManagement
|
|
@Profile({ "production", "staging" })
|
|
@ComponentScan(basePackages = {"eu.eudat.data.entities"})
|
|
public class ProductionDatabaseConfiguration {
|
|
|
|
@Autowired
|
|
private Environment env;
|
|
|
|
@Bean
|
|
public LocalContainerEntityManagerFactoryBean entityManagerFactory() {
|
|
LocalContainerEntityManagerFactoryBean em = new LocalContainerEntityManagerFactoryBean();
|
|
em.setDataSource(dataSource());
|
|
em.setPackagesToScan(new String[]{"eu.eudat.data.entities"});
|
|
JpaVendorAdapter vendorAdapter = new HibernateJpaVendorAdapter();
|
|
em.setJpaVendorAdapter(vendorAdapter);
|
|
em.setJpaProperties(additionalProperties());
|
|
|
|
return em;
|
|
}
|
|
|
|
@Bean
|
|
public DataSource dataSource() {
|
|
DriverManagerDataSource dataSource = new DriverManagerDataSource();
|
|
dataSource.setDriverClassName(env.getProperty("database.driver-class-name"));
|
|
dataSource.setUrl(env.getProperty("database.url"));
|
|
dataSource.setUsername(env.getProperty("database.username"));
|
|
dataSource.setPassword(env.getProperty("database.password"));
|
|
return dataSource;
|
|
}
|
|
|
|
@Bean
|
|
public PlatformTransactionManager transactionManager(EntityManagerFactory emf) {
|
|
JpaTransactionManager transactionManager = new JpaTransactionManager();
|
|
transactionManager.setEntityManagerFactory(emf);
|
|
|
|
return transactionManager;
|
|
}
|
|
|
|
@Bean
|
|
public PersistenceExceptionTranslationPostProcessor exceptionTranslation() {
|
|
return new PersistenceExceptionTranslationPostProcessor();
|
|
}
|
|
|
|
private Properties additionalProperties() {
|
|
Properties properties = new Properties();
|
|
properties.setProperty("hibernate.dialect", "org.hibernate.dialect.PostgreSQL92Dialect");
|
|
properties.setProperty("hibernate.show_sql", "true");
|
|
properties.setProperty("hibernate.temp.use_jdbc_metadata_defaults", "false");
|
|
return properties;
|
|
}
|
|
} |