SysDatabaseService.cs 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255
  1. namespace Admin.NET.Core.Service;
  2. /// <summary>
  3. /// 系统数据库管理服务
  4. /// </summary>
  5. [ApiDescriptionSettings(Order = 250)]
  6. public class SysDatabaseService : IDynamicApiController, ITransient
  7. {
  8. private readonly ISqlSugarClient _db;
  9. private readonly IViewEngine _viewEngine;
  10. private readonly CodeGenOptions _codeGenOptions;
  11. public SysDatabaseService(ISqlSugarClient db,
  12. IViewEngine viewEngine,
  13. IOptions<CodeGenOptions> codeGenOptions)
  14. {
  15. _db = db;
  16. _viewEngine = viewEngine;
  17. _codeGenOptions = codeGenOptions.Value;
  18. }
  19. /// <summary>
  20. /// 获取库列表
  21. /// </summary>
  22. /// <returns></returns>
  23. [ApiDescriptionSettings(Name = "List")]
  24. [DisplayName("获取库列表")]
  25. public List<dynamic> GetList()
  26. {
  27. return App.GetOptions<DbConnectionOptions>().ConnectionConfigs.Select(u => u.ConfigId).ToList();
  28. }
  29. /// <summary>
  30. /// 获取字段列表
  31. /// </summary>
  32. /// <param name="tableName">表名</param>
  33. /// <param name="configId">ConfigId</param>
  34. /// <returns></returns>
  35. [AllowAnonymous]
  36. [ApiDescriptionSettings(Name = "ColumnList")]
  37. [DisplayName("获取字段列表")]
  38. public List<DbColumnOutput> GetColumnList(string tableName, string configId = SqlSugarConst.ConfigId)
  39. {
  40. var db = _db.AsTenant().GetConnectionScope(configId);
  41. if (string.IsNullOrWhiteSpace(tableName))
  42. return new List<DbColumnOutput>();
  43. return db.DbMaintenance.GetColumnInfosByTableName(tableName, false).Adapt<List<DbColumnOutput>>();
  44. }
  45. /// <summary>
  46. /// 增加列
  47. /// </summary>
  48. /// <param name="input"></param>
  49. [ApiDescriptionSettings(Name = "AddColumn")]
  50. [DisplayName("增加列")]
  51. public void AddColumn(DbColumnInput input)
  52. {
  53. var column = new DbColumnInfo
  54. {
  55. ColumnDescription = input.ColumnDescription,
  56. DbColumnName = input.DbColumnName,
  57. IsIdentity = input.IsIdentity == 1,
  58. IsNullable = input.IsNullable == 1,
  59. IsPrimarykey = input.IsPrimarykey == 1,
  60. Length = input.Length,
  61. DecimalDigits = input.DecimalDigits,
  62. DataType = input.DataType
  63. };
  64. var db = _db.AsTenant().GetConnectionScope(input.ConfigId);
  65. db.DbMaintenance.AddColumn(input.TableName, column);
  66. db.DbMaintenance.AddColumnRemark(input.DbColumnName, input.TableName, input.ColumnDescription);
  67. if (column.IsPrimarykey)
  68. db.DbMaintenance.AddPrimaryKey(input.TableName, input.DbColumnName);
  69. }
  70. /// <summary>
  71. /// 删除列
  72. /// </summary>
  73. /// <param name="input"></param>
  74. [ApiDescriptionSettings(Name = "DeleteColumn")]
  75. [DisplayName("删除列")]
  76. public void DeleteColumn(DeleteDbColumnInput input)
  77. {
  78. var db = _db.AsTenant().GetConnectionScope(input.ConfigId);
  79. db.DbMaintenance.DropColumn(input.TableName, input.DbColumnName);
  80. }
  81. /// <summary>
  82. /// 编辑列
  83. /// </summary>
  84. /// <param name="input"></param>
  85. [ApiDescriptionSettings(Name = "UpdateColumn")]
  86. [DisplayName("编辑列")]
  87. public void UpdateColumn(UpdateDbColumnInput input)
  88. {
  89. var db = _db.AsTenant().GetConnectionScope(input.ConfigId);
  90. db.DbMaintenance.RenameColumn(input.TableName, input.OldColumnName, input.ColumnName);
  91. if (db.DbMaintenance.IsAnyColumnRemark(input.ColumnName, input.TableName))
  92. db.DbMaintenance.DeleteColumnRemark(input.ColumnName, input.TableName);
  93. db.DbMaintenance.AddColumnRemark(input.ColumnName, input.TableName, string.IsNullOrWhiteSpace(input.Description) ? input.ColumnName : input.Description);
  94. }
  95. /// <summary>
  96. /// 获取表列表
  97. /// </summary>
  98. /// <param name="configId">ConfigId</param>
  99. /// <returns></returns>
  100. [ApiDescriptionSettings(Name = "TableList")]
  101. [DisplayName("获取表列表")]
  102. public List<DbTableInfo> GetTableList(string configId = SqlSugarConst.ConfigId)
  103. {
  104. var db = _db.AsTenant().GetConnectionScope(configId);
  105. return db.DbMaintenance.GetTableInfoList(false);
  106. }
  107. /// <summary>
  108. /// 增加表
  109. /// </summary>
  110. /// <param name="input"></param>
  111. [ApiDescriptionSettings(Name = "AddTable")]
  112. [DisplayName("增加表")]
  113. public void AddTable(DbTableInput input)
  114. {
  115. var columns = new List<DbColumnInfo>();
  116. if (input.DbColumnInfoList == null || !input.DbColumnInfoList.Any())
  117. throw Oops.Oh(ErrorCodeEnum.db1000);
  118. if (input.DbColumnInfoList.GroupBy(q => q.DbColumnName).Any(q => q.Count() > 1))
  119. throw Oops.Oh(ErrorCodeEnum.db1002);
  120. var config = App.GetOptions<DbConnectionOptions>().ConnectionConfigs.FirstOrDefault(u => u.ConfigId == input.ConfigId);
  121. input.DbColumnInfoList.ForEach(m =>
  122. {
  123. columns.Add(new DbColumnInfo
  124. {
  125. DbColumnName = config.EnableUnderLine ? UtilMethods.ToUnderLine(m.DbColumnName.Trim()) : m.DbColumnName.Trim(),
  126. DataType = m.DataType,
  127. Length = m.Length,
  128. ColumnDescription = m.ColumnDescription,
  129. IsNullable = m.IsNullable == 1,
  130. IsIdentity = m.IsIdentity == 1,
  131. IsPrimarykey = m.IsPrimarykey == 1,
  132. DecimalDigits = m.DecimalDigits
  133. });
  134. });
  135. var db = _db.AsTenant().GetConnectionScope(input.ConfigId);
  136. db.DbMaintenance.CreateTable(input.TableName, columns, false);
  137. if (db.CurrentConnectionConfig.DbType == SqlSugar.DbType.Sqlite || db.CurrentConnectionConfig.DbType == SqlSugar.DbType.MySql)
  138. return;
  139. if (columns.Any(m => m.IsPrimarykey))
  140. db.DbMaintenance.AddPrimaryKey(input.TableName, columns.FirstOrDefault(m => m.IsPrimarykey).DbColumnName);
  141. db.DbMaintenance.AddTableRemark(input.TableName, input.Description);
  142. input.DbColumnInfoList.ForEach(m =>
  143. {
  144. m.DbColumnName = config.EnableUnderLine ? UtilMethods.ToUnderLine(m.DbColumnName) : m.DbColumnName;
  145. db.DbMaintenance.AddColumnRemark(m.DbColumnName, input.TableName, string.IsNullOrWhiteSpace(m.ColumnDescription) ? m.DbColumnName : m.ColumnDescription);
  146. });
  147. }
  148. /// <summary>
  149. /// 删除表
  150. /// </summary>
  151. /// <param name="input"></param>
  152. [ApiDescriptionSettings(Name = "DeleteTable")]
  153. [DisplayName("删除表")]
  154. public void DeleteTable(DeleteDbTableInput input)
  155. {
  156. var db = _db.AsTenant().GetConnectionScope(input.ConfigId);
  157. db.DbMaintenance.DropTable(input.TableName);
  158. }
  159. /// <summary>
  160. /// 编辑表
  161. /// </summary>
  162. /// <param name="input"></param>
  163. [ApiDescriptionSettings(Name = "UpdateTable")]
  164. [DisplayName("编辑表")]
  165. public void UpdateTable(UpdateDbTableInput input)
  166. {
  167. var db = _db.AsTenant().GetConnectionScope(input.ConfigId);
  168. db.DbMaintenance.RenameTable(input.OldTableName, input.TableName);
  169. if (db.DbMaintenance.IsAnyTableRemark(input.TableName))
  170. db.DbMaintenance.DeleteTableRemark(input.TableName);
  171. db.DbMaintenance.AddTableRemark(input.TableName, input.Description);
  172. }
  173. /// <summary>
  174. /// 创建实体
  175. /// </summary>
  176. /// <param name="input"></param>
  177. [ApiDescriptionSettings(Name = "CreateEntity")]
  178. [DisplayName("创建实体")]
  179. public void CreateEntity(CreateEntityInput input)
  180. {
  181. input.Position = string.IsNullOrWhiteSpace(input.Position) ? "Admin.NET.Application" : input.Position;
  182. input.EntityName = input.EntityName;
  183. string[] dbColumnNames = _codeGenOptions.EntityBaseColumn[input.BaseClassName];
  184. var templatePath = GetEntityTemplatePath();
  185. var targetPath = GetEntityTargetPath(input);
  186. var db = _db.AsTenant().GetConnectionScope(input.ConfigId);
  187. DbTableInfo dbTableInfo = db.DbMaintenance.GetTableInfoList(false).FirstOrDefault(m => m.Name == input.TableName);
  188. if (dbTableInfo == null)
  189. throw Oops.Oh(ErrorCodeEnum.db1001);
  190. List<DbColumnInfo> dbColumnInfos = db.DbMaintenance.GetColumnInfosByTableName(input.TableName, false);
  191. dbColumnInfos.ForEach(m =>
  192. {
  193. m.DataType = CodeGenUtil.ConvertDataType(m);
  194. });
  195. if (_codeGenOptions.BaseEntityNames.Contains(input.BaseClassName, StringComparer.OrdinalIgnoreCase))
  196. dbColumnInfos = dbColumnInfos.Where(c => !dbColumnNames.Contains(c.DbColumnName, StringComparer.OrdinalIgnoreCase)).ToList();
  197. var tContent = File.ReadAllText(templatePath);
  198. var tResult = _viewEngine.RunCompileFromCached(tContent, new
  199. {
  200. NameSpace = $"{input.Position}.Entity",
  201. input.TableName,
  202. input.EntityName,
  203. BaseClassName = string.IsNullOrWhiteSpace(input.BaseClassName) ? "" : $" : {input.BaseClassName}",
  204. input.ConfigId,
  205. dbTableInfo.Description,
  206. TableField = dbColumnInfos
  207. });
  208. File.WriteAllText(targetPath, tResult, Encoding.UTF8);
  209. }
  210. /// <summary>
  211. /// 获取实体模板文件路径
  212. /// </summary>
  213. /// <returns></returns>
  214. private static string GetEntityTemplatePath()
  215. {
  216. var templatePath = App.WebHostEnvironment.WebRootPath + @"\Template\";
  217. return Path.Combine(templatePath, "Entity.cs.vm");
  218. }
  219. /// <summary>
  220. /// 设置生成实体文件路径
  221. /// </summary>
  222. /// <param name="input"></param>
  223. /// <returns></returns>
  224. private static string GetEntityTargetPath(CreateEntityInput input)
  225. {
  226. var backendPath = Path.Combine(new DirectoryInfo(App.WebHostEnvironment.ContentRootPath).Parent.FullName, input.Position, "Entity");
  227. if (!Directory.Exists(backendPath))
  228. Directory.CreateDirectory(backendPath);
  229. return Path.Combine(backendPath, input.EntityName + ".cs");
  230. }
  231. }