SysCodeGen.cs 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157
  1. // Admin.NET 项目的版权、商标、专利和其他相关权利均受相应法律法规的保护。使用本项目应遵守相关法律法规和许可证的要求。
  2. //
  3. // 本项目主要遵循 MIT 许可证和 Apache 许可证(版本 2.0)进行分发和使用。许可证位于源代码树根目录中的 LICENSE-MIT 和 LICENSE-APACHE 文件。
  4. //
  5. // 不得利用本项目从事危害国家安全、扰乱社会秩序、侵犯他人合法权益等法律法规禁止的活动!任何基于本项目二次开发而产生的一切法律纠纷和责任,我们不承担任何责任!
  6. namespace Admin.NET.Core;
  7. /// <summary>
  8. /// 代码生成表
  9. /// </summary>
  10. [SugarTable(null, "代码生成表")]
  11. [SysTable]
  12. [SugarIndex("index_{table}_B", nameof(BusName), OrderByType.Asc)]
  13. [SugarIndex("index_{table}_T", nameof(TableName), OrderByType.Asc)]
  14. public partial class SysCodeGen : EntityBase
  15. {
  16. /// <summary>
  17. /// 作者姓名
  18. /// </summary>
  19. [SugarColumn(ColumnDescription = "作者姓名", Length = 32)]
  20. [MaxLength(32)]
  21. public string? AuthorName { get; set; }
  22. /// <summary>
  23. /// 是否移除表前缀
  24. /// </summary>
  25. [SugarColumn(ColumnDescription = "是否移除表前缀", Length = 8)]
  26. [MaxLength(8)]
  27. public string? TablePrefix { get; set; }
  28. /// <summary>
  29. /// 生成方式
  30. /// </summary>
  31. [SugarColumn(ColumnDescription = "生成方式", Length = 32)]
  32. [MaxLength(32)]
  33. public string? GenerateType { get; set; }
  34. /// <summary>
  35. /// 库定位器名
  36. /// </summary>
  37. [SugarColumn(ColumnDescription = "库定位器名", Length = 64)]
  38. [MaxLength(64)]
  39. public string? ConfigId { get; set; }
  40. /// <summary>
  41. /// 库名
  42. /// </summary>
  43. public string DbNickName
  44. {
  45. get
  46. {
  47. try
  48. {
  49. var dbOptions = App.GetConfig<DbConnectionOptions>("DbConnection", true);
  50. var config = dbOptions.ConnectionConfigs.FirstOrDefault(m => m.ConfigId.ToString() == ConfigId);
  51. return config.DbNickName;
  52. }
  53. catch (Exception)
  54. {
  55. return null;
  56. }
  57. }
  58. }
  59. /// <summary>
  60. /// 数据库名(保留字段)
  61. /// </summary>
  62. [SugarColumn(ColumnDescription = "数据库库名", Length = 64)]
  63. [MaxLength(64)]
  64. public string? DbName { get; set; }
  65. /// <summary>
  66. /// 数据库类型
  67. /// </summary>
  68. [SugarColumn(ColumnDescription = "数据库类型", Length = 64)]
  69. [MaxLength(64)]
  70. public string? DbType { get; set; }
  71. /// <summary>
  72. /// 数据库链接
  73. /// </summary>
  74. [SugarColumn(ColumnDescription = "数据库链接", Length = 256)]
  75. [MaxLength(256)]
  76. public string? ConnectionString { get; set; }
  77. /// <summary>
  78. /// 数据库表名
  79. /// </summary>
  80. [SugarColumn(ColumnDescription = "数据库表名", Length = 128)]
  81. [MaxLength(128)]
  82. public string? TableName { get; set; }
  83. /// <summary>
  84. /// 命名空间
  85. /// </summary>
  86. [SugarColumn(ColumnDescription = "命名空间", Length = 128)]
  87. [MaxLength(128)]
  88. public string? NameSpace { get; set; }
  89. /// <summary>
  90. /// 业务名
  91. /// </summary>
  92. [SugarColumn(ColumnDescription = "业务名", Length = 128)]
  93. [MaxLength(128)]
  94. public string? BusName { get; set; }
  95. /// <summary>
  96. /// 表唯一字段配置
  97. /// </summary>
  98. [SugarColumn(ColumnDescription = "表唯一字段配置", Length = 512)]
  99. [MaxLength(128)]
  100. public string? TableUniqueConfig { get; set; }
  101. /// <summary>
  102. /// 是否生成菜单
  103. /// </summary>
  104. [SugarColumn(ColumnDescription = "是否生成菜单")]
  105. public bool GenerateMenu { get; set; } = true;
  106. /// <summary>
  107. /// 菜单图标
  108. /// </summary>
  109. [SugarColumn(ColumnDescription = "菜单图标", Length = 32)]
  110. public string? MenuIcon { get; set; } = "ele-Menu";
  111. /// <summary>
  112. /// 菜单编码
  113. /// </summary>
  114. [SugarColumn(ColumnDescription = "菜单编码")]
  115. public long? MenuPid { get; set; }
  116. /// <summary>
  117. /// 页面目录
  118. /// </summary>
  119. [SugarColumn(ColumnDescription = "页面目录", Length = 32)]
  120. public string? PagePath { get; set; }
  121. /// <summary>
  122. /// 支持打印类型
  123. /// </summary>
  124. [SugarColumn(ColumnDescription = "支持打印类型", Length = 32)]
  125. [MaxLength(32)]
  126. public string? PrintType { get; set; }
  127. /// <summary>
  128. /// 打印模版名称
  129. /// </summary>
  130. [SugarColumn(ColumnDescription = "打印模版名称", Length = 32)]
  131. [MaxLength(32)]
  132. public string? PrintName { get; set; }
  133. /// <summary>
  134. /// 表唯一字段列表
  135. /// </summary>
  136. [SugarColumn(IsIgnore = true)]
  137. public virtual List<TableUniqueConfigItem> TableUniqueList => string.IsNullOrWhiteSpace(TableUniqueConfig) ? null : JSON.Deserialize<List<TableUniqueConfigItem>>(TableUniqueConfig);
  138. }