This commit is contained in:
Francesco 2023-09-22 12:16:30 +02:00
parent c407404900
commit 88f411af4e
6 changed files with 98 additions and 49 deletions

View File

@ -1,22 +1,19 @@
package tech.ailef.dbadmin; package tech.ailef.dbadmin;
import java.util.HashMap; import java.util.Properties;
import javax.sql.DataSource; import javax.sql.DataSource;
import org.hibernate.jpa.HibernatePersistenceProvider;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.autoconfigure.AutoConfiguration; import org.springframework.boot.autoconfigure.AutoConfiguration;
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty; import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
import org.springframework.boot.context.properties.EnableConfigurationProperties; import org.springframework.boot.context.properties.EnableConfigurationProperties;
import org.springframework.boot.jdbc.DataSourceBuilder; import org.springframework.boot.jdbc.DataSourceBuilder;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan; import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Primary;
import org.springframework.core.env.Environment; import org.springframework.core.env.Environment;
import org.springframework.orm.jpa.JpaTransactionManager;
import org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean; import org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean;
import org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter; import org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter;
import org.springframework.transaction.PlatformTransactionManager;
@ConditionalOnProperty(name = "dbadmin.enabled", matchIfMissing = true) @ConditionalOnProperty(name = "dbadmin.enabled", matchIfMissing = true)
@ComponentScan @ComponentScan
@ -26,17 +23,8 @@ public class DbAdminAutoConfiguration {
@Autowired @Autowired
Environment env; Environment env;
// @Bean private static DataSource internalDataSource() {
// @Primary DataSourceBuilder<?> dataSourceBuilder = DataSourceBuilder.create();
//// @ConfigurationProperties("spring.datasource.dbadmin")
// public DataSourceProperties internalDataSourceProperties() {
// return new DataSourceProperties();
// }
@Bean
// @Primary
public DataSource internalDataSource() {
DataSourceBuilder dataSourceBuilder = DataSourceBuilder.create();
dataSourceBuilder.driverClassName("org.h2.Driver"); dataSourceBuilder.driverClassName("org.h2.Driver");
dataSourceBuilder.url("jdbc:h2:file:./dbadmin_internal"); dataSourceBuilder.url("jdbc:h2:file:./dbadmin_internal");
dataSourceBuilder.username("sa"); dataSourceBuilder.username("sa");
@ -44,28 +32,19 @@ public class DbAdminAutoConfiguration {
return dataSourceBuilder.build(); return dataSourceBuilder.build();
} }
@Bean public static LocalContainerEntityManagerFactoryBean internalEntityManager() {
// @Primary LocalContainerEntityManagerFactoryBean factoryBean = new LocalContainerEntityManagerFactoryBean();
public LocalContainerEntityManagerFactoryBean primeEntityManager() { factoryBean.setDataSource(internalDataSource());
LocalContainerEntityManagerFactoryBean em = new LocalContainerEntityManagerFactoryBean(); factoryBean.setPersistenceUnitName("internal");
em.setDataSource(internalDataSource()); factoryBean.setPersistenceProvider(new HibernatePersistenceProvider());
em.setPackagesToScan("tech.ailef.dbadmin.model"); factoryBean.setPackagesToScan("tech.ailef.dbadmin.model");
HibernateJpaVendorAdapter vendorAdapter = new HibernateJpaVendorAdapter(); factoryBean.setJpaVendorAdapter(new HibernateJpaVendorAdapter());
em.setJpaVendorAdapter(vendorAdapter); Properties properties = new Properties();
HashMap<String, Object> properties = new HashMap<>(); properties.setProperty("hibernate.dialect", "org.hibernate.dialect.H2Dialect");
properties.put("spring.jpa.hibernate.ddl-auto", env.getProperty("spring.jpa.hibernate.ddl-auto")); properties.setProperty("hibernate.hbm2ddl.auto", "update");
// properties.put("hibernate.dialect", env.getProperty("hibernate.dialect")); factoryBean.setJpaProperties(properties);
em.setJpaPropertyMap(properties); factoryBean.afterPropertiesSet();
return em;
return factoryBean;
} }
@Bean
// @Primary
public PlatformTransactionManager primeTransactionManager() {
JpaTransactionManager transactionManager = new JpaTransactionManager();
transactionManager.setEntityManagerFactory(primeEntityManager().getObject());
return transactionManager;
}
} }

View File

@ -1,17 +1,28 @@
package tech.ailef.dbadmin.controller; package tech.ailef.dbadmin.controller;
import java.io.IOException;
import java.io.UncheckedIOException;
import java.net.URL;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Optional; import java.util.Optional;
import java.util.Properties;
import java.util.Set; import java.util.Set;
import java.util.stream.Collectors; import java.util.stream.Collectors;
import javax.sql.DataSource;
import org.hibernate.dialect.H2Dialect;
import org.hibernate.dialect.Oracle12cDialect;
import org.hibernate.jpa.HibernatePersistenceProvider;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.dao.DataIntegrityViolationException; import org.springframework.dao.DataIntegrityViolationException;
import org.springframework.http.HttpStatus; import org.springframework.http.HttpStatus;
import org.springframework.jdbc.UncategorizedSQLException; import org.springframework.jdbc.UncategorizedSQLException;
import org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean;
import org.springframework.stereotype.Controller; import org.springframework.stereotype.Controller;
import org.springframework.ui.Model; import org.springframework.ui.Model;
import org.springframework.util.LinkedMultiValueMap; import org.springframework.util.LinkedMultiValueMap;
@ -24,10 +35,19 @@ import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.multipart.MultipartFile; import org.springframework.web.multipart.MultipartFile;
import org.springframework.web.server.ResponseStatusException; import org.springframework.web.server.ResponseStatusException;
import org.springframework.web.servlet.mvc.support.RedirectAttributes; import org.springframework.web.servlet.mvc.support.RedirectAttributes;
import static org.hibernate.cfg.AvailableSettings.*;
import jakarta.annotation.PostConstruct;
import jakarta.persistence.EntityManager;
import jakarta.persistence.EntityManagerFactory;
import jakarta.persistence.SharedCacheMode;
import jakarta.persistence.ValidationMode;
import jakarta.persistence.spi.ClassTransformer;
import jakarta.persistence.spi.PersistenceUnitInfo;
import jakarta.persistence.spi.PersistenceUnitTransactionType;
import jakarta.servlet.http.HttpServletRequest; import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse; import jakarta.servlet.http.HttpServletResponse;
import tech.ailef.dbadmin.DbAdmin; import tech.ailef.dbadmin.DbAdmin;
import tech.ailef.dbadmin.DbAdminAutoConfiguration;
import tech.ailef.dbadmin.DbAdminProperties; import tech.ailef.dbadmin.DbAdminProperties;
import tech.ailef.dbadmin.dbmapping.DbAdminRepository; import tech.ailef.dbadmin.dbmapping.DbAdminRepository;
import tech.ailef.dbadmin.dbmapping.DbObject; import tech.ailef.dbadmin.dbmapping.DbObject;
@ -53,6 +73,32 @@ public class DefaultDbAdminController {
@Autowired @Autowired
private DbAdmin dbAdmin; private DbAdmin dbAdmin;
private EntityManager entityManager;
@PostConstruct
public void initialize() {
// params.put("hibernate.dialect", "org.hibernate.dialect.H2Dialect");
// params.put("spring.jpa.database-platform", "org.hibernate.dialect.H2Dialect");
LocalContainerEntityManagerFactoryBean emf = DbAdminAutoConfiguration.internalEntityManager();
EntityManagerFactory factory = emf.getNativeEntityManagerFactory();
entityManager = factory.createEntityManager();
// EntityManagerFactory emf = new HibernatePersistenceProvider().createEntityManagerFactory("internal", params);
// entityManager = entityManagerFactory.createEntityManager();
// entityManager = emf.createEntityManager();
}
// @Autowired
// private ApplicationContext applicationContext;
// public void displayAllBeans() {
// String[] allBeanNames = applicationContext.getBeanDefinitionNames();
// for(String beanName : allBeanNames) {
// System.out.println(beanName);
// }
// }
/** /**
* Home page with list of schemas * Home page with list of schemas
* @param model * @param model
@ -60,7 +106,15 @@ public class DefaultDbAdminController {
* @return * @return
*/ */
@GetMapping @GetMapping
// @Transactional("internalTransactionManager")
public String index(Model model, @RequestParam(required = false) String query) { public String index(Model model, @RequestParam(required = false) String query) {
// Action a = new Action();
// a.setDescription("ciao");
// a.setId(1);
// new ActionRepository(entityManger).save(a);
// repo.save(a);
// displayAllBeans();
List<DbObjectSchema> schemas = dbAdmin.getSchemas(); List<DbObjectSchema> schemas = dbAdmin.getSchemas();
if (query != null && !query.isBlank()) { if (query != null && !query.isBlank()) {
schemas = schemas.stream().filter(s -> { schemas = schemas.stream().filter(s -> {

View File

@ -18,9 +18,9 @@ import org.springframework.data.jpa.repository.support.SimpleJpaRepository;
import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.simple.SimpleJdbcInsert; import org.springframework.jdbc.core.simple.SimpleJdbcInsert;
import org.springframework.stereotype.Component; import org.springframework.stereotype.Component;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.web.multipart.MultipartFile; import org.springframework.web.multipart.MultipartFile;
import jakarta.transaction.Transactional;
import tech.ailef.dbadmin.dto.PaginatedResult; import tech.ailef.dbadmin.dto.PaginatedResult;
import tech.ailef.dbadmin.dto.PaginationInfo; import tech.ailef.dbadmin.dto.PaginationInfo;
import tech.ailef.dbadmin.dto.QueryFilter; import tech.ailef.dbadmin.dto.QueryFilter;
@ -128,18 +128,18 @@ public class DbAdminRepository {
* @param schema * @param schema
* @param params * @param params
*/ */
@Transactional @Transactional("transactionManager")
public void update(DbObjectSchema schema, Map<String, String> params, Map<String, MultipartFile> files) { public void update(DbObjectSchema schema, Map<String, String> params, Map<String, MultipartFile> files) {
schema.getJpaRepository().update(schema, params, files); schema.getJpaRepository().update(schema, params, files);
} }
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
@Transactional @Transactional("transactionManager")
private void save(DbObjectSchema schema, DbObject o) { private void save(DbObjectSchema schema, DbObject o) {
schema.getJpaRepository().save(o.getUnderlyingInstance()); schema.getJpaRepository().save(o.getUnderlyingInstance());
} }
@Transactional @Transactional("transactionManager")
public void attachManyToMany(DbObjectSchema schema, Object id, Map<String, List<String>> params) { public void attachManyToMany(DbObjectSchema schema, Object id, Map<String, List<String>> params) {
Optional<DbObject> optional = findById(schema, id); Optional<DbObject> optional = findById(schema, id);
@ -256,7 +256,7 @@ public class DbAdminRepository {
* @return * @return
*/ */
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
@Transactional @Transactional("transactionManager")
public void delete(DbObjectSchema schema, String id) { public void delete(DbObjectSchema schema, String id) {
schema.getJpaRepository().deleteById(id); schema.getJpaRepository().deleteById(id);
} }

View File

@ -9,15 +9,15 @@ import jakarta.persistence.Id;
public class Action { public class Action {
@Id @Id
@GeneratedValue(strategy = GenerationType.IDENTITY) @GeneratedValue(strategy = GenerationType.IDENTITY)
private int id; private Integer id;
private String description; private String description;
public int getId() { public Integer getId() {
return id; return id;
} }
public void setId(int id) { public void setId(Integer id) {
this.id = id; this.id = id;
} }

View File

@ -0,0 +1,16 @@
package tech.ailef.dbadmin.repository;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.support.SimpleJpaRepository;
import org.springframework.stereotype.Repository;
import jakarta.persistence.EntityManager;
import tech.ailef.dbadmin.model.Action;
public class ActionRepository extends SimpleJpaRepository<Action, Integer> {
public ActionRepository(EntityManager em) {
super(Action.class, em);
}
}

View File

@ -1,4 +1,4 @@
spring.jpa.hibernate.ddl-auto=create #spring.jpa.hibernate.ddl-auto=create
#spring.datasource.dbadmin.url=jdbc:h2:file:./database #spring.datasource.dbadmin.url=jdbc:h2:file:./database
#spring.datasource.dbadmin.username=sa #spring.datasource.dbadmin.username=sa