package cn.stylefeng.guns.gen.modular.service;
import cn.stylefeng.guns.base.db.entity.DatabaseInfo;
import cn.stylefeng.guns.base.db.model.TableFieldInfo;
import cn.stylefeng.guns.base.db.service.DatabaseInfoService;
import cn.stylefeng.guns.base.db.util.DbUtil;
import cn.stylefeng.guns.gen.core.enums.GenSessionKeyFlags;
import cn.stylefeng.guns.gen.modular.model.FieldConfig;
import cn.stylefeng.guns.gen.modular.model.GenSessionFieldConfigs;
import cn.stylefeng.guns.gen.modular.model.params.SaveFieldConfigParam;
import cn.stylefeng.roses.core.util.HttpContext;
import cn.stylefeng.roses.core.util.SpringContextHolder;
import cn.stylefeng.roses.core.util.ToolUtil;
import cn.stylefeng.roses.kernel.model.exception.ServiceException;
import cn.stylefeng.roses.kernel.validator.stereotype.ParamValidator;
import org.springframework.stereotype.Service;
import javax.servlet.http.HttpSession;
import java.util.List;
import java.util.stream.Collectors;
/**
* 代码生成相关逻辑
*
* @author fengshuonan
* @date 2019-05-06-19:04
*/
@Service
public class GenerateService {
/**
* 获取某个db容器下,某个表的字段配置
*
* 如果之前设置过,则从缓存中拿出
*
* @author fengshuonan
* @Date 2020/1/23 10:54 下午
*/
public List getTableFieldsConfig(Long dbId, String tableName) {
//查询session中有无已配置的字段数据,有配置过的直接返回
HttpSession session = HttpContext.getRequest().getSession();
GenSessionFieldConfigs sessionFieldConfigs = (GenSessionFieldConfigs) session.getAttribute(GenSessionKeyFlags.TABLE_FIELD_STYLES.name());
if (sessionFieldConfigs != null && sessionFieldConfigs.containConfigFlag(tableName)) {
return sessionFieldConfigs.getFieldConfigs(tableName);
}
//查找数据库元数据信息
DatabaseInfoService databaseInfoService = null;
try {
databaseInfoService = SpringContextHolder.getBean(DatabaseInfoService.class);
} catch (Exception e) {
throw new ServiceException(500, "请先开启数据源容器模块!");
}
DatabaseInfo databaseInfo = databaseInfoService.getById(dbId);
//获取对应表的所有字段
List tableFields = DbUtil.getTableFields(databaseInfo, tableName);
//将表的所有字段信息转化为配置信息
return tableFields.stream().map(i -> {
FieldConfig fieldConfig = new FieldConfig();
ToolUtil.copyProperties(i, fieldConfig);
return fieldConfig;
}).collect(Collectors.toList());
}
/**
* 设置表的字段配置
*
* @author fengshuonan
* @Date 2020/1/23 11:04 下午
*/
@ParamValidator
public void setTableFieldsConfig(SaveFieldConfigParam saveFieldConfigParam) {
//从session获取配置
HttpSession session = HttpContext.getRequest().getSession();
GenSessionFieldConfigs sessionFieldConfigs = (GenSessionFieldConfigs) session.getAttribute(GenSessionKeyFlags.TABLE_FIELD_STYLES.name());
if (sessionFieldConfigs == null) {
sessionFieldConfigs = new GenSessionFieldConfigs();
}
//放入session配置树形
sessionFieldConfigs.getFieldConfigs().put(
saveFieldConfigParam.getTableName(),
saveFieldConfigParam.getFieldConfigList());
session.setAttribute(GenSessionKeyFlags.TABLE_FIELD_STYLES.name(), sessionFieldConfigs);
}
}