1 package org.onap.vid.config;
4 import org.hibernate.SessionFactory;
5 import org.onap.portalsdk.core.service.DataAccessService;
6 import org.onap.portalsdk.core.service.DataAccessServiceImpl;
7 import org.springframework.beans.factory.annotation.Autowired;
8 import org.springframework.context.annotation.Bean;
9 import org.springframework.context.annotation.Configuration;
10 import org.springframework.jdbc.datasource.DriverManagerDataSource;
11 import org.springframework.orm.hibernate4.HibernateTransactionManager;
12 import org.springframework.orm.hibernate4.LocalSessionFactoryBean;
13 import org.springframework.transaction.PlatformTransactionManager;
14 import org.springframework.transaction.annotation.EnableTransactionManagement;
16 import javax.sql.DataSource;
17 import java.util.Properties;
20 @EnableTransactionManagement
21 public class DataSourceConfig {
25 public LocalSessionFactoryBean sessionFactory(DataSource dataSource) {
26 LocalSessionFactoryBean sessionFactory = new LocalSessionFactoryBean();
27 sessionFactory.setDataSource(dataSource);
28 //I used this class org.openecomp.portalsdk.core.conf.HibernateConfiguration to learn how to config the session factory
29 // and use the following url for actual h2 properties
30 //https://github.com/levi-putna/Hibernate-H2-Example/blob/master/hibernate-h2-example/src/hibernate.cfg.xml
31 Properties properties = getH2Properties();
33 properties.put("hibernate.default_schema", "PUBLIC");
34 properties.put("connection.pool_size", 10);
35 properties.put("cache.provider_class", "org.hibernate.cache.internal.NoCacheProvider");
36 properties.put("hibernate.show_sql", false);
37 properties.put("hbm2ddl.auto", "create");
38 properties.put("hibernate.hbm2ddl.auto", "create");
40 sessionFactory.setHibernateProperties(properties);
41 sessionFactory.setPackagesToScan("org.onap");
42 return sessionFactory;
46 public DataSource getDataSource() {
47 DriverManagerDataSource dataSource = new DriverManagerDataSource();
48 dataSource.setDriverClassName("org.h2.Driver");
49 dataSource.setUrl("jdbc:h2:mem:testdb;DB_CLOSE_DELAY=-1");
50 dataSource.setUsername("sa");
51 dataSource.setPassword("");
55 public Properties getH2Properties() {
56 Properties properties = new Properties();
57 properties.put("dialect", "org.hibernate.dialect.H2Dialect");
61 public Properties getSqliteProperties() {
62 Properties properties = new Properties();
63 properties.put("connection.driver_class", "org.sqlite.JDBC");
64 properties.put("connection.url", "jdbc:sqlite:memory:myDb");
65 properties.put("connection.username", "sa");
66 properties.put("connection.password", "sa");
67 properties.put("dialect", "com.enigmabridge.hibernate.dialect.SQLiteDialect");
72 public DataAccessService dataAccessService() {
73 return new DataAccessServiceImpl();
78 public PlatformTransactionManager transactionManager(SessionFactory sessionFactory) {
79 return new HibernateTransactionManager(sessionFactory);