SysCodeGen.cs 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  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. [SugarColumn(IsIgnore = true)]
  44. public string DbNickName
  45. {
  46. get
  47. {
  48. try
  49. {
  50. var dbOptions = App.GetConfig<DbConnectionOptions>("DbConnection", true);
  51. var config = dbOptions.ConnectionConfigs.FirstOrDefault(m => m.ConfigId.ToString() == ConfigId);
  52. return config.DbNickName;
  53. }
  54. catch (Exception)
  55. {
  56. return null;
  57. }
  58. }
  59. }
  60. /// <summary>
  61. /// 数据库名(保留字段)
  62. /// </summary>
  63. [SugarColumn(ColumnDescription = "数据库库名", Length = 64)]
  64. [MaxLength(64)]
  65. public string? DbName { get; set; }
  66. /// <summary>
  67. /// 数据库类型
  68. /// </summary>
  69. [SugarColumn(ColumnDescription = "数据库类型", Length = 64)]
  70. [MaxLength(64)]
  71. public string? DbType { get; set; }
  72. /// <summary>
  73. /// 数据库链接
  74. /// </summary>
  75. [SugarColumn(ColumnDescription = "数据库链接", Length = 256)]
  76. [MaxLength(256)]
  77. public string? ConnectionString { get; set; }
  78. /// <summary>
  79. /// 数据库表名
  80. /// </summary>
  81. [SugarColumn(ColumnDescription = "数据库表名", Length = 128)]
  82. [MaxLength(128)]
  83. public string? TableName { get; set; }
  84. /// <summary>
  85. /// 命名空间
  86. /// </summary>
  87. [SugarColumn(ColumnDescription = "命名空间", Length = 128)]
  88. [MaxLength(128)]
  89. public string? NameSpace { get; set; }
  90. /// <summary>
  91. /// 业务名
  92. /// </summary>
  93. [SugarColumn(ColumnDescription = "业务名", Length = 128)]
  94. [MaxLength(128)]
  95. public string? BusName { get; set; }
  96. /// <summary>
  97. /// 表唯一字段配置
  98. /// </summary>
  99. [SugarColumn(ColumnDescription = "表唯一字段配置", Length = 512)]
  100. [MaxLength(128)]
  101. public string? TableUniqueConfig { get; set; }
  102. /// <summary>
  103. /// 是否生成菜单
  104. /// </summary>
  105. [SugarColumn(ColumnDescription = "是否生成菜单")]
  106. public bool GenerateMenu { get; set; } = true;
  107. /// <summary>
  108. /// 菜单图标
  109. /// </summary>
  110. [SugarColumn(ColumnDescription = "菜单图标", Length = 32)]
  111. public string? MenuIcon { get; set; } = "ele-Menu";
  112. /// <summary>
  113. /// 菜单编码
  114. /// </summary>
  115. [SugarColumn(ColumnDescription = "菜单编码")]
  116. public long? MenuPid { get; set; }
  117. /// <summary>
  118. /// 页面目录
  119. /// </summary>
  120. [SugarColumn(ColumnDescription = "页面目录", Length = 32)]
  121. public string? PagePath { get; set; }
  122. /// <summary>
  123. /// 支持打印类型
  124. /// </summary>
  125. [SugarColumn(ColumnDescription = "支持打印类型", Length = 32)]
  126. [MaxLength(32)]
  127. public string? PrintType { get; set; }
  128. /// <summary>
  129. /// 打印模版名称
  130. /// </summary>
  131. [SugarColumn(ColumnDescription = "打印模版名称", Length = 32)]
  132. [MaxLength(32)]
  133. public string? PrintName { get; set; }
  134. /// <summary>
  135. /// 表唯一字段列表
  136. /// </summary>
  137. [SugarColumn(IsIgnore = true)]
  138. public virtual List<TableUniqueConfigItem> TableUniqueList => string.IsNullOrWhiteSpace(TableUniqueConfig) ? null : JSON.Deserialize<List<TableUniqueConfigItem>>(TableUniqueConfig);
  139. }