GenTableServiceImpl.java 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691
  1. package com.boman.gen.service;
  2. import java.io.ByteArrayOutputStream;
  3. import java.io.File;
  4. import java.io.IOException;
  5. import java.io.StringWriter;
  6. import java.util.LinkedHashMap;
  7. import java.util.List;
  8. import java.util.Map;
  9. import java.util.stream.Collectors;
  10. import java.util.zip.ZipEntry;
  11. import java.util.zip.ZipOutputStream;
  12. import com.boman.common.core.constant.UserConstants;
  13. import com.boman.common.core.text.Convert;
  14. import com.boman.common.core.utils.DateUtils;
  15. import com.boman.common.core.web.domain.AjaxResult;
  16. import com.boman.common.log.enums.BusinessType;
  17. import com.boman.domain.RoleEnum;
  18. import com.boman.domain.TableSql;
  19. import com.boman.gen.api.RemoteGenTableService;
  20. import com.boman.gen.mapper.GenTableRelationMapper;
  21. import com.boman.system.api.RemoteSysMenuService;
  22. import com.boman.system.api.domain.SysMenu;
  23. import org.apache.commons.io.IOUtils;
  24. import org.apache.velocity.Template;
  25. import org.apache.velocity.VelocityContext;
  26. import org.apache.velocity.app.Velocity;
  27. import org.slf4j.Logger;
  28. import org.slf4j.LoggerFactory;
  29. import org.springframework.beans.factory.annotation.Autowired;
  30. import org.springframework.stereotype.Service;
  31. import org.springframework.transaction.annotation.Transactional;
  32. import com.alibaba.fastjson.JSON;
  33. import com.alibaba.fastjson.JSONObject;
  34. import com.boman.common.core.constant.Constants;
  35. import com.boman.common.core.constant.GenConstants;
  36. import com.boman.common.core.exception.CustomException;
  37. import com.boman.common.core.text.CharsetKit;
  38. import com.boman.common.core.utils.SecurityUtils;
  39. import com.boman.common.core.utils.StringUtils;
  40. import com.boman.common.core.utils.file.FileUtils;
  41. import com.boman.domain.GenTable;
  42. import com.boman.domain.GenTableColumn;
  43. import com.boman.gen.mapper.GenTableColumnMapper;
  44. import com.boman.gen.mapper.GenTableMapper;
  45. import com.boman.gen.util.GenUtils;
  46. import com.boman.gen.util.VelocityInitializer;
  47. import com.boman.gen.util.VelocityUtils;
  48. /**
  49. * 业务 服务层实现
  50. *
  51. * @author ruoyi
  52. */
  53. @Service
  54. public class GenTableServiceImpl implements IGenTableService {
  55. private static final Logger log = LoggerFactory.getLogger(GenTableServiceImpl.class);
  56. @Autowired
  57. private GenTableMapper genTableMapper;
  58. @Autowired
  59. private GenTableColumnMapper genTableColumnMapper;
  60. @Autowired
  61. private RemoteSysMenuService remoteSysMenuService;
  62. @Autowired
  63. private TableSqlServiceImpl tableSqlService;
  64. @Autowired
  65. private IGenTableColumnService tableColumnService;
  66. @Autowired
  67. private GenTableRelationMapper genTableRelationMapper;
  68. @Autowired
  69. private RemoteGenTableService remoteGenTableService;
  70. /**
  71. * 查询业务信息
  72. *
  73. * @param id 业务ID
  74. * @return 业务信息
  75. */
  76. @Override
  77. public GenTable selectGenTableById(Long id) {
  78. GenTable genTable = genTableMapper.selectGenTableById(id);
  79. Long tablePrimaryKey = genTable.getTablePrimaryKey();
  80. Long akColumn = genTable.getAkColumn();
  81. Long dkColumn = genTable.getDkColumn();
  82. List<GenTableColumn> columns = genTable.getColumns();
  83. int index = 0;
  84. for (GenTableColumn column : columns) {
  85. Long columnId = column.getColumnId();
  86. if (tablePrimaryKey != null && tablePrimaryKey.equals(columnId)) {
  87. genTable.setTablePrimaryKeyName(column.getColumnName());
  88. index++;
  89. } if (akColumn != null && akColumn.equals(columnId)) {
  90. genTable.setAkColumnName(column.getColumnName());
  91. index++;
  92. } if (dkColumn != null && dkColumn.equals(columnId)) {
  93. genTable.setDkColumnName(column.getColumnName());
  94. index++;
  95. }
  96. if (index == 3) {
  97. break;
  98. }
  99. }
  100. setTableFromOptions(genTable);
  101. return genTable;
  102. }
  103. @Override
  104. public GenTable getByTableId(Long id) {
  105. return genTableMapper.selectGenTableById(id);
  106. }
  107. /**
  108. * 查询业务列表
  109. *
  110. * @param genTable 业务信息
  111. * @return 业务集合
  112. */
  113. @Override
  114. public List<GenTable> selectGenTableList(GenTable genTable) {
  115. List<GenTable> genTables = genTableMapper.selectGenTableList(genTable);
  116. return genTables;
  117. }
  118. /**
  119. * 查询据库列表
  120. *
  121. * @param genTable 业务信息
  122. * @return 数据库表集合
  123. */
  124. @Override
  125. public List<GenTable> selectDbTableList(GenTable genTable) {
  126. return genTableMapper.selectDbTableList(genTable);
  127. }
  128. /**
  129. * 查询据库列表
  130. *
  131. * @param tableNames 表名称组
  132. * @return 数据库表集合
  133. */
  134. @Override
  135. public List<GenTable> selectDbTableListByNames(String[] tableNames) {
  136. return genTableMapper.selectDbTableListByNames(tableNames);
  137. }
  138. /**
  139. * 查询表名称业务信息
  140. *
  141. * @param tableName 表名称
  142. * @return 业务信息
  143. */
  144. @Override
  145. public GenTable selectGenTableByName(String tableName) {
  146. return genTableMapper.selectGenTableByName(tableName);
  147. }
  148. /**
  149. * 查询所有表信息
  150. *
  151. * @return 表信息集合
  152. */
  153. @Override
  154. public List<GenTable> selectGenTableAll() {
  155. return genTableMapper.selectGenTableAll();
  156. }
  157. /**
  158. * 修改业务
  159. *
  160. * @param genTable 业务信息
  161. * @return 结果
  162. */
  163. @Override
  164. @Transactional
  165. public void updateGenTable(GenTable genTable) {
  166. String options = JSON.toJSONString(genTable.getParams());
  167. genTable.setOptions(options);
  168. isMenu(genTable, BusinessType.UPDATE);
  169. int row = genTableMapper.updateGenTable(genTable);
  170. if (row > 0) {
  171. for (GenTableColumn cenTableColumn : genTable.getColumns()) {
  172. tableColumnService.updateGenTableColumn(cenTableColumn);
  173. }
  174. }
  175. remoteGenTableService.loadTable(new GenTable());
  176. }
  177. /**
  178. * 删除业务对象
  179. *
  180. * @param tableIds 需要删除的数据ID
  181. * @return 结果
  182. */
  183. @Override
  184. @Transactional(rollbackFor = Exception.class)
  185. public void deleteGenTableByIds(Long[] tableIds) {
  186. genTableMapper.deleteGenTableByIds(tableIds);
  187. genTableColumnMapper.deleteGenTableColumnByIds(tableIds);
  188. tableSqlService.deleteTableSqlByTableIds(tableIds);
  189. //删除关联关系
  190. genTableRelationMapper.deleteGenTableRelationByParentId(tableIds);
  191. remoteGenTableService.loadTable(new GenTable());
  192. }
  193. /**
  194. * 导入表结构
  195. *
  196. * @param tableList 导入表列表
  197. */
  198. @Override
  199. @Transactional
  200. public void importGenTable(List<GenTable> tableList) {
  201. String operName = SecurityUtils.getUsername();
  202. try {
  203. for (GenTable table : tableList) {
  204. String tableName = table.getTableName();
  205. GenUtils.initTable(table, operName);
  206. int row = genTableMapper.insertGenTable(table);
  207. if (row > 0) {
  208. // 保存列信息
  209. List<GenTableColumn> genTableColumns = genTableColumnMapper.selectDbTableColumnsByName(tableName);
  210. for (GenTableColumn column : genTableColumns) {
  211. GenUtils.initColumnField(column, table);
  212. genTableColumnMapper.insertGenTableColumn(column);
  213. }
  214. }
  215. }
  216. } catch (Exception e) {
  217. throw new CustomException("导入失败:" + e.getMessage());
  218. }
  219. }
  220. /**
  221. * 预览代码
  222. *
  223. * @param tableId 表编号
  224. * @return 预览数据列表
  225. */
  226. @Override
  227. public Map<String, String> previewCode(Long tableId) {
  228. Map<String, String> dataMap = new LinkedHashMap<>();
  229. // 查询表信息
  230. GenTable table = genTableMapper.selectGenTableById(tableId);
  231. // 设置主子表信息
  232. setSubTable(table);
  233. // 设置主键列信息
  234. setPkColumn(table);
  235. VelocityInitializer.initVelocity();
  236. VelocityContext context = VelocityUtils.prepareContext(table);
  237. // 获取模板列表
  238. List<String> templates = VelocityUtils.getTemplateList(table.getTplCategory());
  239. for (String template : templates) {
  240. // 渲染模板
  241. StringWriter sw = new StringWriter();
  242. Template tpl = Velocity.getTemplate(template, Constants.UTF8);
  243. tpl.merge(context, sw);
  244. dataMap.put(template, sw.toString());
  245. }
  246. return dataMap;
  247. }
  248. /**
  249. * 生成代码(下载方式)
  250. *
  251. * @param tableName 表名称
  252. * @return 数据
  253. */
  254. @Override
  255. public byte[] downloadCode(String tableName) {
  256. ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
  257. ZipOutputStream zip = new ZipOutputStream(outputStream);
  258. generatorCode(tableName, zip);
  259. IOUtils.closeQuietly(zip);
  260. return outputStream.toByteArray();
  261. }
  262. /**
  263. * 生成代码(自定义路径)
  264. *
  265. * @param tableName 表名称
  266. */
  267. @Override
  268. public void generatorCode(String tableName) {
  269. // 查询表信息
  270. GenTable table = genTableMapper.selectGenTableByName(tableName);
  271. // 设置主子表信息
  272. setSubTable(table);
  273. // 设置主键列信息
  274. setPkColumn(table);
  275. VelocityInitializer.initVelocity();
  276. VelocityContext context = VelocityUtils.prepareContext(table);
  277. // 获取模板列表
  278. List<String> templates = VelocityUtils.getTemplateList(table.getTplCategory());
  279. for (String template : templates) {
  280. if (!StringUtils.containsAny(template, "sql.vm", "api.js.vm", "index.vue.vm", "index-tree.vue.vm")) {
  281. // 渲染模板
  282. StringWriter sw = new StringWriter();
  283. Template tpl = Velocity.getTemplate(template, Constants.UTF8);
  284. tpl.merge(context, sw);
  285. try {
  286. String path = getGenPath(table, template);
  287. FileUtils.writeStringToFile(new File(path), sw.toString(), CharsetKit.UTF_8);
  288. } catch (IOException e) {
  289. throw new CustomException("渲染模板失败,表名:" + table.getTableName());
  290. }
  291. }
  292. }
  293. }
  294. /**
  295. * 同步数据库
  296. *
  297. * @param tableName 表名称
  298. */
  299. @Override
  300. @Transactional(rollbackFor = Exception.class)
  301. public void synchDb(String tableName) {
  302. GenTable table = genTableMapper.selectGenTableByName(tableName);
  303. //获取表字段集合
  304. List<GenTableColumn> tableColumns = table.getColumns();
  305. //获取列名称集合
  306. List<String> tableColumnNames = tableColumns.stream().map(GenTableColumn::getColumnName).collect(Collectors.toList());
  307. //根据表名称查询原列信息
  308. List<GenTableColumn> dbTableColumns = genTableColumnMapper.selectDbTableColumnsByName(tableName);
  309. if (StringUtils.isEmpty(dbTableColumns)) {
  310. throw new CustomException("同步数据失败,原表结构不存在");
  311. }
  312. //获取原表列名称集合
  313. List<String> dbTableColumnNames = dbTableColumns.stream().map(GenTableColumn::getColumnName).collect(Collectors.toList());
  314. dbTableColumns.forEach(column -> {
  315. if (!tableColumnNames.contains(column.getColumnName())) {
  316. GenUtils.initColumnField(column, table);
  317. genTableColumnMapper.insertGenTableColumn(column);
  318. }
  319. });
  320. List<GenTableColumn> delColumns = tableColumns.stream().filter(column -> !dbTableColumnNames.contains(column.getColumnName())).collect(Collectors.toList());
  321. if (StringUtils.isNotEmpty(delColumns)) {
  322. genTableColumnMapper.deleteGenTableColumns(delColumns);
  323. }
  324. }
  325. /**
  326. * 批量生成代码(下载方式)
  327. *
  328. * @param tableNames 表数组
  329. * @return 数据
  330. */
  331. @Override
  332. public byte[] downloadCode(String[] tableNames) {
  333. ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
  334. ZipOutputStream zip = new ZipOutputStream(outputStream);
  335. for (String tableName : tableNames) {
  336. generatorCode(tableName, zip);
  337. }
  338. IOUtils.closeQuietly(zip);
  339. return outputStream.toByteArray();
  340. }
  341. /**
  342. * 查询表信息并生成代码
  343. */
  344. private void generatorCode(String tableName, ZipOutputStream zip) {
  345. // 查询表信息
  346. GenTable table = genTableMapper.selectGenTableByName(tableName);
  347. // 设置主子表信息
  348. setSubTable(table);
  349. // 设置主键列信息
  350. setPkColumn(table);
  351. VelocityInitializer.initVelocity();
  352. VelocityContext context = VelocityUtils.prepareContext(table);
  353. // 获取模板列表
  354. List<String> templates = VelocityUtils.getTemplateList(table.getTplCategory());
  355. for (String template : templates) {
  356. // 渲染模板
  357. StringWriter sw = new StringWriter();
  358. Template tpl = Velocity.getTemplate(template, Constants.UTF8);
  359. tpl.merge(context, sw);
  360. try {
  361. // 添加到zip
  362. zip.putNextEntry(new ZipEntry(VelocityUtils.getFileName(template, table)));
  363. IOUtils.write(sw.toString(), zip, Constants.UTF8);
  364. IOUtils.closeQuietly(sw);
  365. zip.flush();
  366. zip.closeEntry();
  367. } catch (IOException e) {
  368. log.error("渲染模板失败,表名:" + table.getTableName(), e);
  369. }
  370. }
  371. }
  372. /**
  373. * 修改保存参数校验
  374. *
  375. * @param genTable 业务信息
  376. */
  377. @Override
  378. public void validateEdit(GenTable genTable) {
  379. if (GenConstants.TPL_TREE.equals(genTable.getTplCategory())) {
  380. String options = JSON.toJSONString(genTable.getParams());
  381. JSONObject paramsObj = JSONObject.parseObject(options);
  382. if (StringUtils.isEmpty(paramsObj.getString(GenConstants.TREE_CODE))) {
  383. throw new CustomException("树编码字段不能为空");
  384. } else if (StringUtils.isEmpty(paramsObj.getString(GenConstants.TREE_PARENT_CODE))) {
  385. throw new CustomException("树父编码字段不能为空");
  386. } else if (StringUtils.isEmpty(paramsObj.getString(GenConstants.TREE_NAME))) {
  387. throw new CustomException("树名称字段不能为空");
  388. } else if (GenConstants.TPL_SUB.equals(genTable.getTplCategory())) {
  389. if (StringUtils.isEmpty(genTable.getSubTableName())) {
  390. throw new CustomException("关联子表的表名不能为空");
  391. } else if (StringUtils.isEmpty(genTable.getSubTableFkName())) {
  392. throw new CustomException("子表关联的外键名不能为空");
  393. }
  394. }
  395. }
  396. }
  397. /**
  398. * 代码生成业务表新增
  399. * 注意解决事务问题
  400. *
  401. * @param genTable
  402. * @return
  403. */
  404. @Override
  405. public AjaxResult insertGenTable(GenTable genTable) {
  406. //新增表成功的时候,新增字段公共字段
  407. int i = genTableMapper.insertGenTable(genTable);
  408. if (i > 0) {
  409. Long id = insertCommonColumn(genTable.getTableId());
  410. if (id != -1) {
  411. genTable.setTablePrimaryKey(id);
  412. genTableMapper.updateGenTable(genTable);
  413. }
  414. //判断是否是菜单
  415. isMenu(genTable, BusinessType.INSERT);
  416. //新建表时新增建表语句
  417. TableSql tableSql = new TableSql();
  418. tableSql.setTableId(genTable.getTableId());
  419. tableSqlService.insertTableSql(tableSql);
  420. remoteGenTableService.loadTable(new GenTable());
  421. return AjaxResult.success();
  422. }
  423. return AjaxResult.error();
  424. }
  425. /**
  426. * 新建表时新增对应公共字段
  427. *
  428. * @param tableId
  429. */
  430. public Long insertCommonColumn(Long tableId) {
  431. int num = 1000;
  432. GenTableColumn genTableColumnLog = new GenTableColumn();
  433. GenTableColumn genTableColumnBaseInfo = new GenTableColumn();
  434. genTableColumnLog.setTableId(tableId);
  435. genTableColumnLog.setColumnName("log_info");
  436. genTableColumnLog.setColumnComment("日志信息");
  437. genTableColumnLog.setColumnType("varchar(255)");
  438. genTableColumnLog.setIsPk("0");
  439. genTableColumnLog.setIsIncrement("0");
  440. genTableColumnLog.setIsInsert("1");
  441. genTableColumnLog.setQueryType("LIKE");
  442. genTableColumnLog.setHtmlType("input");
  443. genTableColumnLog.setSort(num);
  444. genTableColumnLog.setCreateBy("admin");
  445. genTableColumnLog.setHtmlType("HR");
  446. genTableColumnLog.setMask("000000");
  447. genTableColumnLog.setCreateTime(DateUtils.getNowDate());
  448. genTableColumnMapper.insertGenTableColumn(genTableColumnLog);
  449. genTableColumnBaseInfo.setTableId(tableId);
  450. genTableColumnBaseInfo.setColumnName("base_info");
  451. genTableColumnBaseInfo.setColumnComment("基本信息");
  452. genTableColumnBaseInfo.setColumnType("varchar(255)");
  453. genTableColumnBaseInfo.setIsPk("0");
  454. genTableColumnBaseInfo.setIsIncrement("0");
  455. genTableColumnBaseInfo.setIsInsert("1");
  456. genTableColumnBaseInfo.setQueryType("LIKE");
  457. genTableColumnBaseInfo.setHtmlType("input");
  458. genTableColumnBaseInfo.setSort(20);
  459. genTableColumnBaseInfo.setCreateBy("admin");
  460. genTableColumnBaseInfo.setHtmlType("HR");
  461. genTableColumnBaseInfo.setMask("000000");
  462. genTableColumnBaseInfo.setCreateTime(DateUtils.getNowDate());
  463. genTableColumnMapper.insertGenTableColumn(genTableColumnBaseInfo);
  464. Long columnId = -1L;
  465. String[] columnName = new String[]{"id", "create_by", "create_time", "update_by", "update_time", "is_del"};
  466. String[] columnComment = new String[]{"编号", "创建者", "创建时间", "更新者", "更新时间", "是否删除"};
  467. String[] columnType = new String[]{"bigint(20)", "varchar(64)", "datetime", "varchar(64)", "datetime", "char(1)"};
  468. String[] htmlType = new String[]{"input", "input", "datetime", "input", "datetime", "select"};
  469. for (int i = 0; i < columnName.length; i++) {
  470. GenTableColumn genTableColumn = new GenTableColumn();
  471. genTableColumn.setTableId(tableId);
  472. genTableColumn.setColumnName(columnName[i]);
  473. genTableColumn.setColumnComment(columnComment[i]);
  474. genTableColumn.setColumnType(columnType[i]);
  475. genTableColumn.setIsPk("0");
  476. genTableColumn.setIsInsert("1");
  477. genTableColumn.setQueryType("EQ");
  478. genTableColumn.setHtmlType(htmlType[i]);
  479. genTableColumn.setSort(num + i);
  480. genTableColumn.setCreateBy("admin");
  481. genTableColumn.setCreateTime(DateUtils.getNowDate());
  482. genTableColumn.setHrParentId(genTableColumnBaseInfo.getColumnId());
  483. genTableColumn.setMask("000000");
  484. if (i == 0) {
  485. genTableColumn.setSort(1);
  486. genTableColumn.setIsPk("1");
  487. genTableColumn.setHrParentId(genTableColumnLog.getColumnId());
  488. }
  489. genTableColumnMapper.insertGenTableColumn(genTableColumn);
  490. //获得id字段的id
  491. if (i == 0) {
  492. columnId = genTableColumn.getColumnId();
  493. }
  494. }
  495. return columnId;
  496. }
  497. /**
  498. * 判断是否是菜单
  499. *
  500. * @param genTable
  501. */
  502. public void isMenu(GenTable genTable, BusinessType type) {
  503. if (type.equals(BusinessType.UPDATE)) {
  504. //先查询之前是否是菜单
  505. GenTable genTableOld = genTableMapper.selectGenTableById(genTable.getTableId());
  506. if (UserConstants.ISMENU.equals(genTableOld.getIsMenu())) {
  507. return;
  508. }
  509. }
  510. String isMenu = genTable.getIsMenu();
  511. if (StringUtils.isNotBlank(isMenu) && isMenu.equals(UserConstants.ISMENU)) {
  512. //生成主菜单
  513. SysMenu sysMenu = new SysMenu();
  514. //表描述当菜单名称
  515. sysMenu.setMenuName(genTable.getTableComment());
  516. sysMenu.setParentId(2007L);
  517. //路由地址(使用表名称)
  518. sysMenu.setPath(genTable.getTableName());
  519. //组件
  520. sysMenu.setComponent("system/surface/index");
  521. sysMenu.setMenuType("C");
  522. sysMenu.setOrderNum("0");
  523. sysMenu.setIcon("system");
  524. sysMenu.setCreateBy(SecurityUtils.getUsername());
  525. sysMenu.setSysTableName(genTable.getTableName());
  526. sysMenu.setStatus("1");
  527. AjaxResult add = remoteSysMenuService.add(sysMenu);
  528. Long parentId = 0L;
  529. if (add.size() > 2) {
  530. String id = String.valueOf(add.get("data")) ;
  531. parentId = Long.valueOf(id);
  532. }
  533. //获取菜单id
  534. String menuRole = genTable.getMenuRole();
  535. String[] strings = Convert.toStrArray("",menuRole);
  536. if (strings.length > 0) {
  537. for (int i = 0; i < strings.length; i++) {
  538. SysMenu menu = new SysMenu();
  539. menu.setParentId(parentId);
  540. menu.setMenuName(RoleEnum.getValue(strings[i]));
  541. menu.setOrderNum(String.valueOf(i + 1));
  542. menu.setMenuType("F");
  543. menu.setIcon("#");
  544. //路由
  545. menu.setPath("#");
  546. sysMenu.setCreateBy(SecurityUtils.getUsername());
  547. remoteSysMenuService.add(menu);
  548. }
  549. }
  550. }
  551. }
  552. /**
  553. * 设置主键列信息
  554. *
  555. * @param table 业务表信息
  556. */
  557. public void setPkColumn(GenTable table) {
  558. for (GenTableColumn column : table.getColumns()) {
  559. if (column.getIsPk().equals(UserConstants.INCREMENT)) {
  560. table.setPkColumn(column);
  561. break;
  562. }
  563. }
  564. if (StringUtils.isNull(table.getPkColumn())) {
  565. table.setPkColumn(table.getColumns().get(0));
  566. }
  567. if (GenConstants.TPL_SUB.equals(table.getTplCategory())) {
  568. for (GenTableColumn column : table.getSubTable().getColumns()) {
  569. if (column.getIsPk().equals(UserConstants.INCREMENT)) {
  570. table.getSubTable().setPkColumn(column);
  571. break;
  572. }
  573. }
  574. if (StringUtils.isNull(table.getSubTable().getPkColumn())) {
  575. table.getSubTable().setPkColumn(table.getSubTable().getColumns().get(0));
  576. }
  577. }
  578. }
  579. /**
  580. * 设置主子表信息
  581. *
  582. * @param table 业务表信息
  583. */
  584. public void setSubTable(GenTable table) {
  585. String subTableName = table.getSubTableName();
  586. if (StringUtils.isNotEmpty(subTableName)) {
  587. table.setSubTable(genTableMapper.selectGenTableByName(subTableName));
  588. }
  589. }
  590. /**
  591. * 设置代码生成其他选项值
  592. *
  593. * @param genTable 设置后的生成对象
  594. */
  595. public void setTableFromOptions(GenTable genTable) {
  596. JSONObject paramsObj = JSONObject.parseObject(genTable.getOptions());
  597. if (StringUtils.isNotNull(paramsObj)) {
  598. String treeCode = paramsObj.getString(GenConstants.TREE_CODE);
  599. String treeParentCode = paramsObj.getString(GenConstants.TREE_PARENT_CODE);
  600. String treeName = paramsObj.getString(GenConstants.TREE_NAME);
  601. String parentMenuId = paramsObj.getString(GenConstants.PARENT_MENU_ID);
  602. String parentMenuName = paramsObj.getString(GenConstants.PARENT_MENU_NAME);
  603. genTable.setTreeCode(treeCode);
  604. genTable.setTreeParentCode(treeParentCode);
  605. genTable.setTreeName(treeName);
  606. genTable.setParentMenuId(parentMenuId);
  607. genTable.setParentMenuName(parentMenuName);
  608. }
  609. }
  610. /**
  611. * 获取代码生成地址
  612. *
  613. * @param table 业务表信息
  614. * @param template 模板文件路径
  615. * @return 生成地址
  616. */
  617. public static String getGenPath(GenTable table, String template) {
  618. String genPath = table.getGenPath();
  619. if (StringUtils.equals(genPath, "/")) {
  620. return System.getProperty("user.dir") + File.separator + "src" + File.separator + VelocityUtils.getFileName(template, table);
  621. }
  622. return genPath + File.separator + VelocityUtils.getFileName(template, table);
  623. }
  624. /**
  625. * 校验表名称是否存在
  626. *
  627. * @param genTable
  628. * @return
  629. */
  630. @Override
  631. public String checkTableNameUnique(GenTable genTable) {
  632. List<GenTable> genTables = genTableMapper.selectGenTableList(genTable);
  633. if (genTables.size() > 0) {
  634. return UserConstants.NOT_UNIQUE;
  635. }
  636. return UserConstants.UNIQUE;
  637. }
  638. }