refactor: 代码生成重构
This commit is contained in:
@@ -55,7 +55,7 @@ public class GeneratorProperties {
|
|||||||
|
|
||||||
private String templatePath;
|
private String templatePath;
|
||||||
|
|
||||||
private String packageName;
|
private String subpackageName;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 文件扩展名,如 .java
|
* 文件扩展名,如 .java
|
||||||
|
|||||||
@@ -3,10 +3,12 @@ package com.youlai.system.controller;
|
|||||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||||
import com.youlai.system.common.result.PageResult;
|
import com.youlai.system.common.result.PageResult;
|
||||||
import com.youlai.system.common.result.Result;
|
import com.youlai.system.common.result.Result;
|
||||||
|
import com.youlai.system.enums.LogModuleEnum;
|
||||||
import com.youlai.system.model.form.GenConfigForm;
|
import com.youlai.system.model.form.GenConfigForm;
|
||||||
import com.youlai.system.model.query.TablePageQuery;
|
import com.youlai.system.model.query.TablePageQuery;
|
||||||
import com.youlai.system.model.vo.GeneratorPreviewVO;
|
import com.youlai.system.model.vo.GeneratorPreviewVO;
|
||||||
import com.youlai.system.model.vo.TablePageVO;
|
import com.youlai.system.model.vo.TablePageVO;
|
||||||
|
import com.youlai.system.plugin.syslog.annotation.LogAnnotation;
|
||||||
import com.youlai.system.service.GeneratorService;
|
import com.youlai.system.service.GeneratorService;
|
||||||
import io.swagger.v3.oas.annotations.Operation;
|
import io.swagger.v3.oas.annotations.Operation;
|
||||||
import io.swagger.v3.oas.annotations.Parameter;
|
import io.swagger.v3.oas.annotations.Parameter;
|
||||||
@@ -35,6 +37,7 @@ public class GeneratorController {
|
|||||||
|
|
||||||
@Operation(summary = "获取数据表分页列表")
|
@Operation(summary = "获取数据表分页列表")
|
||||||
@GetMapping("/table/page")
|
@GetMapping("/table/page")
|
||||||
|
@LogAnnotation(value = "代码生成分页列表", module = LogModuleEnum.OTHER)
|
||||||
public PageResult<TablePageVO> getTablePage(
|
public PageResult<TablePageVO> getTablePage(
|
||||||
TablePageQuery queryParams
|
TablePageQuery queryParams
|
||||||
) {
|
) {
|
||||||
@@ -53,6 +56,7 @@ public class GeneratorController {
|
|||||||
|
|
||||||
@Operation(summary = "保存代码生成配置")
|
@Operation(summary = "保存代码生成配置")
|
||||||
@PostMapping("/{tableName}/config")
|
@PostMapping("/{tableName}/config")
|
||||||
|
@LogAnnotation(value = "生成代码", module = LogModuleEnum.OTHER)
|
||||||
public Result saveGenConfig(@RequestBody GenConfigForm formData) {
|
public Result saveGenConfig(@RequestBody GenConfigForm formData) {
|
||||||
generatorService.saveGenConfig(formData);
|
generatorService.saveGenConfig(formData);
|
||||||
return Result.success();
|
return Result.success();
|
||||||
@@ -69,15 +73,15 @@ public class GeneratorController {
|
|||||||
|
|
||||||
@Operation(summary = "获取预览生成代码")
|
@Operation(summary = "获取预览生成代码")
|
||||||
@GetMapping("/{tableName}/preview")
|
@GetMapping("/{tableName}/preview")
|
||||||
|
@LogAnnotation(value = "预览生成代码", module = LogModuleEnum.OTHER)
|
||||||
public Result<List<GeneratorPreviewVO>> getTablePreviewData(@PathVariable String tableName) {
|
public Result<List<GeneratorPreviewVO>> getTablePreviewData(@PathVariable String tableName) {
|
||||||
List<GeneratorPreviewVO> list = generatorService.getTablePreviewData(tableName);
|
List<GeneratorPreviewVO> list = generatorService.getTablePreviewData(tableName);
|
||||||
return Result.success(list);
|
return Result.success(list);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Operation(summary = "下载代码")
|
||||||
|
@GetMapping("/{tableName}/download")
|
||||||
@Operation(summary = "下载代码zip")
|
@LogAnnotation(value = "下载代码", module = LogModuleEnum.OTHER)
|
||||||
@GetMapping("/{tableName}/downloadZip")
|
|
||||||
public void downloadZip(HttpServletResponse response, @PathVariable String tableName) throws IOException {
|
public void downloadZip(HttpServletResponse response, @PathVariable String tableName) throws IOException {
|
||||||
String[] tableNames = tableName.split(",");
|
String[] tableNames = tableName.split(",");
|
||||||
byte[] data = generatorService.downloadCode(tableNames);
|
byte[] data = generatorService.downloadCode(tableNames);
|
||||||
|
|||||||
@@ -270,12 +270,14 @@ public class GeneratorServiceImpl implements GeneratorService {
|
|||||||
|
|
||||||
|
|
||||||
/* 2. 生成文件路径 */
|
/* 2. 生成文件路径 */
|
||||||
// com.youlai.system
|
// com.youlai
|
||||||
String packageName = genConfig.getPackageName();
|
String packageName = genConfig.getPackageName();
|
||||||
|
// system
|
||||||
|
String moduleName = genConfig.getModuleName();
|
||||||
// controller
|
// controller
|
||||||
String subPackageName = templateConfig.getPackageName();
|
String subpackageName = templateConfig.getSubpackageName();
|
||||||
// 文件路径 com.youlai.system.controller
|
// 文件路径 src/main/java/com/youlai/system/controller
|
||||||
String filePath = getFilePath(templateName, packageName, subPackageName, entityName);
|
String filePath = getFilePath(templateName,moduleName, packageName, subpackageName, entityName);
|
||||||
previewVO.setPath(filePath);
|
previewVO.setPath(filePath);
|
||||||
|
|
||||||
/* 3. 生成文件内容 */
|
/* 3. 生成文件内容 */
|
||||||
@@ -309,7 +311,7 @@ public class GeneratorServiceImpl implements GeneratorService {
|
|||||||
return entityName + templateName + extension;
|
return entityName + templateName + extension;
|
||||||
}
|
}
|
||||||
|
|
||||||
private String getFilePath(String templateName, String packageName, String subPackageName, String entityName) {
|
private String getFilePath(String templateName,String moduleName, String packageName, String subPackageName, String entityName) {
|
||||||
String path;
|
String path;
|
||||||
if ("MapperXml".equals(templateName)) {
|
if ("MapperXml".equals(templateName)) {
|
||||||
path = (generatorProperties.getBackendAppName()
|
path = (generatorProperties.getBackendAppName()
|
||||||
@@ -324,16 +326,18 @@ public class GeneratorServiceImpl implements GeneratorService {
|
|||||||
);
|
);
|
||||||
} else if ("VIEW".equals(templateName)) {
|
} else if ("VIEW".equals(templateName)) {
|
||||||
path = (generatorProperties.getFrontendAppName()
|
path = (generatorProperties.getFrontendAppName()
|
||||||
+ File.separator
|
+ File.separator + "src"
|
||||||
+ "src" + File.separator + subPackageName
|
+ File.separator + moduleName
|
||||||
+ File.separator
|
+ File.separator + subPackageName
|
||||||
+ StrUtil.toSymbolCase(entityName, '-')
|
+ File.separator + StrUtil.toSymbolCase(entityName, '-')
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
path = (generatorProperties.getBackendAppName()
|
path = (generatorProperties.getBackendAppName()
|
||||||
+ File.separator
|
+ File.separator
|
||||||
+ "src" + File.separator + "main" + File.separator + "java"
|
+ "src" + File.separator + "main" + File.separator + "java"
|
||||||
+ File.separator + packageName + File.separator + subPackageName
|
+ File.separator + packageName
|
||||||
|
+ File.separator + moduleName
|
||||||
|
+ File.separator + subPackageName
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -357,8 +361,8 @@ public class GeneratorServiceImpl implements GeneratorService {
|
|||||||
|
|
||||||
String entityName = genConfig.getEntityName();
|
String entityName = genConfig.getEntityName();
|
||||||
|
|
||||||
bindMap.put("package", genConfig.getPackageName());
|
bindMap.put("packageName", genConfig.getPackageName());
|
||||||
bindMap.put("subPackage", templateConfig.getPackageName());
|
bindMap.put("moduleName", genConfig.getModuleName());
|
||||||
bindMap.put("date", DateUtil.format(new Date(), "yyyy-MM-dd HH:mm"));
|
bindMap.put("date", DateUtil.format(new Date(), "yyyy-MM-dd HH:mm"));
|
||||||
bindMap.put("entityName", entityName);
|
bindMap.put("entityName", entityName);
|
||||||
bindMap.put("tableName", genConfig.getTableName());
|
bindMap.put("tableName", genConfig.getTableName());
|
||||||
|
|||||||
@@ -15,42 +15,42 @@ generator:
|
|||||||
templateConfigs:
|
templateConfigs:
|
||||||
Controller:
|
Controller:
|
||||||
templatePath: generator/controller.java.vm
|
templatePath: generator/controller.java.vm
|
||||||
packageName: controller
|
subpackageName: controller
|
||||||
Service:
|
Service:
|
||||||
templatePath: generator/service.java.vm
|
templatePath: generator/service.java.vm
|
||||||
packageName: service
|
subpackageName: service
|
||||||
ServiceImpl:
|
ServiceImpl:
|
||||||
templatePath: generator/serviceImpl.java.vm
|
templatePath: generator/serviceImpl.java.vm
|
||||||
packageName: service.impl
|
subpackageName: service.impl
|
||||||
Mapper:
|
Mapper:
|
||||||
templatePath: generator/mapper.java.vm
|
templatePath: generator/mapper.java.vm
|
||||||
packageName: mapper
|
subpackageName: mapper
|
||||||
MapperXml:
|
MapperXml:
|
||||||
templatePath: generator/mapper.xml.vm
|
templatePath: generator/mapper.xml.vm
|
||||||
packageName: mapper
|
subpackageName: mapper
|
||||||
extension: .xml
|
extension: .xml
|
||||||
Converter:
|
Converter:
|
||||||
templatePath: generator/converter.java.vm
|
templatePath: generator/converter.java.vm
|
||||||
packageName: converter
|
subpackageName: converter
|
||||||
Query:
|
Query:
|
||||||
templatePath: generator/query.java.vm
|
templatePath: generator/query.java.vm
|
||||||
packageName: model.query
|
subpackageName: model.query
|
||||||
Form:
|
Form:
|
||||||
templatePath: generator/form.java.vm
|
templatePath: generator/form.java.vm
|
||||||
packageName: model.form
|
subpackageName: model.form
|
||||||
VO:
|
VO:
|
||||||
templatePath: generator/vo.java.vm
|
templatePath: generator/vo.java.vm
|
||||||
packageName: model.vo
|
subpackageName: model.vo
|
||||||
Entity:
|
Entity:
|
||||||
templatePath: generator/entity.java.vm
|
templatePath: generator/entity.java.vm
|
||||||
packageName: model.entity
|
subpackageName: model.entity
|
||||||
API:
|
API:
|
||||||
templatePath: generator/api.ts.vm
|
templatePath: generator/api.ts.vm
|
||||||
packageName: api
|
subpackageName: api
|
||||||
extension: .ts
|
extension: .ts
|
||||||
VIEW:
|
VIEW:
|
||||||
templatePath: generator/index.vue.vm
|
templatePath: generator/index.vue.vm
|
||||||
packageName: views
|
subpackageName: views
|
||||||
extension: .vue
|
extension: .vue
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,11 +1,11 @@
|
|||||||
package ${package}.controller;
|
package ${packageName}.${moduleName}.${subpackageName};
|
||||||
|
|
||||||
import lombok.RequiredArgsConstructor;
|
import lombok.RequiredArgsConstructor;
|
||||||
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;
|
||||||
import ${package}.model.form.${entityName}Form;
|
import ${packageName}.${moduleName}.model.form.${entityName}Form;
|
||||||
import ${package}.model.query.${entityName}PageQuery;
|
import ${packageName}.${moduleName}.model.query.${entityName}PageQuery;
|
||||||
import ${package}.model.vo.${entityName}PageVO;
|
import ${packageName}.${moduleName}.model.vo.${entityName}PageVO;
|
||||||
import com.baomidou.mybatisplus.core.metadata.IPage;
|
import com.baomidou.mybatisplus.core.metadata.IPage;
|
||||||
import com.youlai.common.result.PageResult;
|
import com.youlai.common.result.PageResult;
|
||||||
import com.youlai.common.result.Result;
|
import com.youlai.common.result.Result;
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
package ${package}.converter;
|
package ${packageName}.${moduleName}.${subpackageName};
|
||||||
|
|
||||||
import org.mapstruct.Mapper;
|
import org.mapstruct.Mapper;
|
||||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||||
import ${package}.model.entity.${entityName};
|
import ${packageName}.${moduleName}.model.entity.${entityName};
|
||||||
import ${package}.model.form.${entityName}Form;
|
import ${packageName}.${moduleName}.model.form.${entityName}Form;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* $!{businessName}对象转换器
|
* $!{businessName}对象转换器
|
||||||
@@ -16,5 +16,5 @@ public interface ${entityName}Converter{
|
|||||||
|
|
||||||
${entityName}Form toForm(${entityName} entity);
|
${entityName}Form toForm(${entityName} entity);
|
||||||
|
|
||||||
${entityName} toEntity(${entityName}Form entity);
|
${entityName} toEntity(${entityName}Form formData);
|
||||||
}
|
}
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
package ${package}.model.entity;
|
package ${packageName}.${moduleName}.${subpackageName};
|
||||||
|
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
import lombok.Setter;
|
import lombok.Setter;
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
package ${package}.${subPackage};
|
package ${packageName}.${moduleName}.${subpackageName};
|
||||||
|
|
||||||
import java.io.Serial;
|
import java.io.Serial;
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
package ${package}.mapper;
|
package ${packageName}.${moduleName}.${subpackageName};
|
||||||
|
|
||||||
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
|
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
|
||||||
import ${package}.model.entity.${entityName};
|
import ${packageName}.${moduleName}.model.entity.${entityName};
|
||||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||||
import ${package}.model.query.${entityName}Query;
|
import ${packageName}.${moduleName}.model.query.${entityName}Query;
|
||||||
import org.apache.ibatis.annotations.Mapper;
|
import org.apache.ibatis.annotations.Mapper;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||||
<mapper namespace="${package}.mapper.${entityName}Mapper">
|
<mapper namespace="${packageName}.${moduleName}.mapper.${entityName}Mapper">
|
||||||
|
|
||||||
<!-- 获取${businessName}分页列表 -->
|
<!-- 获取${businessName}分页列表 -->
|
||||||
<select id="get${entityName}Page" resultType="${package}.model.vo.${entityName}VO">
|
<select id="get${entityName}Page" resultType="${packageName}.${moduleName}.model.vo.${entityName}VO">
|
||||||
SELECT
|
SELECT
|
||||||
#if($fieldConfigs)
|
#if($fieldConfigs)
|
||||||
#set ($fields = [])
|
#set ($fields = [])
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
package ${package}.model.query;
|
package ${packageName}.${moduleName}.${subpackageName};
|
||||||
|
|
||||||
import com.youlai.common.base.BasePageQuery;
|
import com.youlai.common.base.BasePageQuery;
|
||||||
import io.swagger.v3.oas.annotations.media.Schema;
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
package ${package}.Service;
|
package ${packageName}.${moduleName}.${subpackageName};
|
||||||
|
|
||||||
import ${package}.model.entity.${entityName};
|
import ${packageName}.${moduleName}.model.entity.${entityName};
|
||||||
import ${package}.model.form.${entityName}Form;
|
import ${packageName}.${moduleName}.model.form.${entityName}Form;
|
||||||
import ${package}.model.query.${entityName}PageQuery;
|
import ${packageName}.${moduleName}.model.query.${entityName}PageQuery;
|
||||||
import ${package}.model.vo.${entityName}PageVO;
|
import ${packageName}.${moduleName}.model.vo.${entityName}PageVO;
|
||||||
import com.baomidou.mybatisplus.core.metadata.IPage;
|
import com.baomidou.mybatisplus.core.metadata.IPage;
|
||||||
import com.baomidou.mybatisplus.extension.service.IService;
|
import com.baomidou.mybatisplus.extension.service.IService;
|
||||||
|
|
||||||
|
|||||||
@@ -1,17 +1,17 @@
|
|||||||
package ${package}.service.impl;
|
package ${packageName}.${moduleName}.${subpackageName};
|
||||||
|
|
||||||
import ${package}.model.entity.${entityName};
|
|
||||||
import ${package}.mapper.${entityName}Mapper;
|
|
||||||
import ${package}.service.${entityName}Service;
|
|
||||||
import lombok.RequiredArgsConstructor;
|
import lombok.RequiredArgsConstructor;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
import ${package}.model.form.${entityName}Form;
|
|
||||||
import ${package}.model.query.${entityName}Query;
|
|
||||||
import ${package}.model.vo.${entityName}PageVO;
|
|
||||||
import ${package}.converter.${entityName}Converter;
|
|
||||||
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 com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||||
|
import ${packageName}.${moduleName}.mapper.${entityName}Mapper;
|
||||||
|
import ${packageName}.${moduleName}.service.${entityName}Service;
|
||||||
|
import ${packageName}.${moduleName}.model.entity.${entityName};
|
||||||
|
import ${packageName}.${moduleName}.model.form.${entityName}Form;
|
||||||
|
import ${packageName}.${moduleName}.model.query.${entityName}Query;
|
||||||
|
import ${packageName}.${moduleName}.model.vo.${entityName}PageVO;
|
||||||
|
import ${packageName}.${moduleName}.converter.${entityName}Converter;
|
||||||
|
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
package ${package}.model.vo;
|
package ${packageName}.${moduleName}.model.vo;
|
||||||
|
|
||||||
import java.io.Serial;
|
import java.io.Serial;
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
|
|||||||
Reference in New Issue
Block a user