mirror of
https://github.com/dalbodeule/snap-admin.git
synced 2025-06-08 21:38:21 +00:00
WIP
This commit is contained in:
parent
c407404900
commit
88f411af4e
@ -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;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Bean
|
|
||||||
// @Primary
|
|
||||||
public PlatformTransactionManager primeTransactionManager() {
|
|
||||||
JpaTransactionManager transactionManager = new JpaTransactionManager();
|
|
||||||
transactionManager.setEntityManagerFactory(primeEntityManager().getObject());
|
|
||||||
return transactionManager;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
return factoryBean;
|
||||||
|
}
|
||||||
}
|
}
|
@ -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;
|
||||||
@ -52,6 +72,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
|
||||||
@ -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 -> {
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -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
|
||||||
|
Loading…
x
Reference in New Issue
Block a user