Auto Upgrade

This commit is contained in:
jipengfei-jpf
2023-07-23 17:47:20 +08:00
parent 2f42d74c60
commit 64142f9e9f
8 changed files with 80 additions and 4 deletions

View File

@ -1,6 +1,7 @@
package ai.chat2db.server.domain.api.model; package ai.chat2db.server.domain.api.model;
import java.time.LocalDateTime; import java.time.LocalDateTime;
import java.util.LinkedHashMap;
import java.util.List; import java.util.List;
import ai.chat2db.spi.config.DriverConfig; import ai.chat2db.spi.config.DriverConfig;
@ -8,6 +9,7 @@ import ai.chat2db.spi.model.KeyValue;
import ai.chat2db.spi.model.SSHInfo; import ai.chat2db.spi.model.SSHInfo;
import ai.chat2db.spi.model.SSLInfo; import ai.chat2db.spi.model.SSLInfo;
import lombok.Data; import lombok.Data;
import org.springframework.util.ObjectUtils;
/** /**
* @author moji * @author moji
@ -107,4 +109,16 @@ public class DataSource {
* 驱动配置 * 驱动配置
*/ */
private DriverConfig driverConfig; private DriverConfig driverConfig;
public LinkedHashMap<String,Object> getExtendMap() {
if (ObjectUtils.isEmpty(extendInfo)) {
return new LinkedHashMap<>();
}
LinkedHashMap<String,Object> map = new LinkedHashMap<>();
for (KeyValue keyValue : extendInfo) {
map.put(keyValue.getKey(),keyValue.getValue());
}
return map;
}
} }

View File

@ -1,7 +1,8 @@
package ai.chat2db.server.domain.api.param; package ai.chat2db.server.domain.api.param;
import jakarta.validation.constraints.NotNull; import java.sql.Connection;
import jakarta.validation.constraints.NotNull;
import lombok.AllArgsConstructor; import lombok.AllArgsConstructor;
import lombok.Data; import lombok.Data;
import lombok.NoArgsConstructor; import lombok.NoArgsConstructor;
@ -27,4 +28,14 @@ public class DatabaseQueryAllParam {
* if true, refresh the cache * if true, refresh the cache
*/ */
private boolean refresh; private boolean refresh;
/**
* Can be null, if null, use the default connection
*/
private Connection connection;
/**
* Can be null, if null, use the default dbType
*/
private String dbType;
} }

View File

@ -1,6 +1,8 @@
package ai.chat2db.server.domain.api.param; package ai.chat2db.server.domain.api.param;
import java.sql.Connection;
import jakarta.validation.constraints.NotNull; import jakarta.validation.constraints.NotNull;
import lombok.AllArgsConstructor; import lombok.AllArgsConstructor;
@ -29,4 +31,9 @@ public class SchemaQueryParam {
* if true, refresh the cache * if true, refresh the cache
*/ */
private boolean refresh; private boolean refresh;
/**
* Can be null, if null, use the default connection
*/
private Connection connection;
} }

View File

@ -1,5 +1,7 @@
package ai.chat2db.server.domain.core.impl; package ai.chat2db.server.domain.core.impl;
import java.sql.Connection;
import java.sql.SQLException;
import java.time.LocalDateTime; import java.time.LocalDateTime;
import java.util.List; import java.util.List;
@ -13,6 +15,7 @@ import ai.chat2db.server.domain.api.param.DataSourceTestParam;
import ai.chat2db.server.domain.api.param.DataSourceUpdateParam; import ai.chat2db.server.domain.api.param.DataSourceUpdateParam;
import ai.chat2db.server.domain.api.param.DatabaseQueryAllParam; import ai.chat2db.server.domain.api.param.DatabaseQueryAllParam;
import ai.chat2db.server.domain.api.service.DataSourceService; import ai.chat2db.server.domain.api.service.DataSourceService;
import ai.chat2db.server.domain.api.service.DatabaseService;
import ai.chat2db.server.domain.core.converter.DataSourceConverter; import ai.chat2db.server.domain.core.converter.DataSourceConverter;
import ai.chat2db.server.domain.repository.entity.DataSourceDO; import ai.chat2db.server.domain.repository.entity.DataSourceDO;
import ai.chat2db.server.domain.repository.mapper.DataSourceMapper; import ai.chat2db.server.domain.repository.mapper.DataSourceMapper;
@ -25,11 +28,13 @@ import ai.chat2db.spi.model.DataSourceConnect;
import ai.chat2db.spi.model.Database; import ai.chat2db.spi.model.Database;
import ai.chat2db.spi.model.KeyValue; import ai.chat2db.spi.model.KeyValue;
import ai.chat2db.spi.sql.Chat2DBContext; import ai.chat2db.spi.sql.Chat2DBContext;
import ai.chat2db.spi.sql.IDriverManager;
import ai.chat2db.spi.sql.SQLExecutor; import ai.chat2db.spi.sql.SQLExecutor;
import ai.chat2db.spi.util.JdbcUtils; import ai.chat2db.spi.util.JdbcUtils;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.lang3.BooleanUtils; import org.apache.commons.lang3.BooleanUtils;
import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
@ -40,6 +45,7 @@ import org.springframework.stereotype.Service;
* @version DataSourceCoreServiceImpl.java, v 0.1 2022年09月23日 15:51 moji Exp $ * @version DataSourceCoreServiceImpl.java, v 0.1 2022年09月23日 15:51 moji Exp $
* @date 2022/09/23 * @date 2022/09/23
*/ */
@Slf4j
@Service @Service
public class DataSourceServiceImpl implements DataSourceService { public class DataSourceServiceImpl implements DataSourceService {
@ -49,15 +55,37 @@ public class DataSourceServiceImpl implements DataSourceService {
@Autowired @Autowired
private DataSourceConverter dataSourceConverter; private DataSourceConverter dataSourceConverter;
@Autowired
private DatabaseService databaseService;
@Override @Override
public DataResult<Long> create(DataSourceCreateParam param) { public DataResult<Long> create(DataSourceCreateParam param) {
DataSourceDO dataSourceDO = dataSourceConverter.param2do(param); DataSourceDO dataSourceDO = dataSourceConverter.param2do(param);
dataSourceDO.setGmtCreate(LocalDateTime.now()); dataSourceDO.setGmtCreate(LocalDateTime.now());
dataSourceDO.setGmtModified(LocalDateTime.now()); dataSourceDO.setGmtModified(LocalDateTime.now());
dataSourceMapper.insert(dataSourceDO); dataSourceMapper.insert(dataSourceDO);
preWarmingData(dataSourceDO.getId());
return DataResult.of(dataSourceDO.getId()); return DataResult.of(dataSourceDO.getId());
} }
private void preWarmingData(Long dataSourceId) {
DataResult<DataSource> dataResult = queryById(dataSourceId);
if (dataResult.success() && dataResult.getData() != null) {
DataSource dataSource = dataResult.getData();
try (Connection connection = IDriverManager.getConnection(dataSource.getUrl(), dataSource.getUserName(),
dataSource.getPassword(), dataSource.getDriverConfig(), dataSource.getExtendMap())) {
DatabaseQueryAllParam databaseQueryAllParam = new DatabaseQueryAllParam();
databaseQueryAllParam.setDataSourceId(dataSourceId);
databaseQueryAllParam.setConnection(connection);
databaseQueryAllParam.setDbType(dataSource.getType());
databaseQueryAllParam.setRefresh(true);
databaseService.queryAll(databaseQueryAllParam);
} catch (SQLException e) {
log.error("preWarmingData error", e);
}
}
}
@Override @Override
public ActionResult update(DataSourceUpdateParam param) { public ActionResult update(DataSourceUpdateParam param) {
DataSourceDO dataSourceDO = dataSourceConverter.param2do(param); DataSourceDO dataSourceDO = dataSourceConverter.param2do(param);

View File

@ -41,8 +41,9 @@ public class DatabaseServiceImpl implements DatabaseService {
public ListResult<Database> queryAll(DatabaseQueryAllParam param) { public ListResult<Database> queryAll(DatabaseQueryAllParam param) {
List<Database> databases = CacheManage.getList(getDataBasesKey(param.getDataSourceId()), Database.class, List<Database> databases = CacheManage.getList(getDataBasesKey(param.getDataSourceId()), Database.class,
(key) -> param.isRefresh(), (key) -> { (key) -> param.isRefresh(), (key) -> {
Connection connection = Chat2DBContext.getConnection(); Connection connection = param.getConnection() == null ? Chat2DBContext.getConnection()
MetaData metaData = Chat2DBContext.getMetaData(); : param.getConnection();
MetaData metaData = Chat2DBContext.getMetaData(param.getDbType());
return metaData.databases(connection); return metaData.databases(connection);
}); });
return ListResult.of(databases); return ListResult.of(databases);
@ -53,7 +54,8 @@ public class DatabaseServiceImpl implements DatabaseService {
List<Schema> schemas = CacheManage.getList(getSchemasKey(param.getDataSourceId(), param.getDataBaseName()), List<Schema> schemas = CacheManage.getList(getSchemasKey(param.getDataSourceId(), param.getDataBaseName()),
Schema.class, Schema.class,
(key) -> param.isRefresh(), (key) -> { (key) -> param.isRefresh(), (key) -> {
Connection connection = Chat2DBContext.getConnection(); Connection connection = param.getConnection() == null ? Chat2DBContext.getConnection()
: param.getConnection();
MetaData metaData = Chat2DBContext.getMetaData(); MetaData metaData = Chat2DBContext.getMetaData();
return metaData.schemas(connection, param.getDataBaseName()); return metaData.schemas(connection, param.getDataBaseName());
}); });

View File

@ -23,6 +23,9 @@ import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController; import org.springframework.web.bind.annotation.RestController;
/**
* database controller
*/
@ConnectionInfoAspect @ConnectionInfoAspect
@RequestMapping("/api/rdb/database") @RequestMapping("/api/rdb/database")
@RestController @RestController

View File

@ -23,6 +23,9 @@ import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController; import org.springframework.web.bind.annotation.RestController;
/**
* shema controller
*/
@ConnectionInfoAspect @ConnectionInfoAspect
@RequestMapping("/api/rdb/schema") @RequestMapping("/api/rdb/schema")
@RestController @RestController

View File

@ -16,6 +16,7 @@ import ai.chat2db.spi.config.DriverConfig;
import com.jcraft.jsch.JSchException; import com.jcraft.jsch.JSchException;
import com.jcraft.jsch.Session; import com.jcraft.jsch.Session;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.apache.commons.lang3.StringUtils;
/** /**
* @author jipengfei * @author jipengfei
@ -54,6 +55,13 @@ public class Chat2DBContext {
return PLUGIN_MAP.get(getConnectInfo().getDbType()).getMetaData(); return PLUGIN_MAP.get(getConnectInfo().getDbType()).getMetaData();
} }
public static MetaData getMetaData(String dbType) {
if(StringUtils.isBlank(dbType)){
return getMetaData();
}
return PLUGIN_MAP.get(dbType).getMetaData();
}
public static DBConfig getDBConfig() { public static DBConfig getDBConfig() {
return PLUGIN_MAP.get(getConnectInfo().getDbType()).getDBConfig(); return PLUGIN_MAP.get(getConnectInfo().getDbType()).getDBConfig();
} }