DbConnectionOptions.cs 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  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. public sealed class DbConnectionOptions : IConfigurableOptions<DbConnectionOptions>
  11. {
  12. /// <summary>
  13. /// 启用控制台打印SQL
  14. /// </summary>
  15. public bool EnableConsoleSql { get; set; }
  16. /// <summary>
  17. /// 超级管理员是否忽略逻辑删除过滤器
  18. /// </summary>
  19. public bool SuperAdminIgnoreIDeletedFilter { get; set; }
  20. /// <summary>
  21. /// 数据库集合
  22. /// </summary>
  23. public List<DbConnectionConfig> ConnectionConfigs { get; set; }
  24. public void PostConfigure(DbConnectionOptions options, IConfiguration configuration)
  25. {
  26. foreach (var dbConfig in options.ConnectionConfigs)
  27. {
  28. if (dbConfig.ConfigId == null || string.IsNullOrWhiteSpace(dbConfig.ConfigId.ToString()))
  29. dbConfig.ConfigId = SqlSugarConst.MainConfigId;
  30. }
  31. }
  32. }
  33. /// <summary>
  34. /// 数据库连接配置
  35. /// </summary>
  36. public sealed class DbConnectionConfig : ConnectionConfig
  37. {
  38. /// <summary>
  39. /// 数据库名称
  40. /// </summary>
  41. public string DbNickName { get; set; }
  42. /// <summary>
  43. /// 数据库配置
  44. /// </summary>
  45. public DbSettings DbSettings { get; set; }
  46. /// <summary>
  47. /// 表配置
  48. /// </summary>
  49. public TableSettings TableSettings { get; set; }
  50. /// <summary>
  51. /// 种子配置
  52. /// </summary>
  53. public SeedSettings SeedSettings { get; set; }
  54. /// <summary>
  55. /// 隔离方式
  56. /// </summary>
  57. public TenantTypeEnum TenantType { get; set; } = TenantTypeEnum.Id;
  58. /// <summary>
  59. /// 数据库存储目录(仅SqlServer支持指定目录创建)
  60. /// </summary>
  61. public string DatabaseDirectory { get; set; }
  62. }
  63. /// <summary>
  64. /// 数据库配置
  65. /// </summary>
  66. public sealed class DbSettings
  67. {
  68. /// <summary>
  69. /// 启用库表初始化
  70. /// </summary>
  71. public bool EnableInitDb { get; set; }
  72. /// <summary>
  73. /// 启用视图初始化
  74. /// </summary>
  75. public bool EnableInitView { get; set; }
  76. /// <summary>
  77. /// 启用库表差异日志
  78. /// </summary>
  79. public bool EnableDiffLog { get; set; }
  80. /// <summary>
  81. /// 启用驼峰转下划线
  82. /// </summary>
  83. public bool EnableUnderLine { get; set; }
  84. /// <summary>
  85. /// 启用数据库连接串加密策略
  86. /// </summary>
  87. public bool EnableConnStringEncrypt { get; set; }
  88. }
  89. /// <summary>
  90. /// 表配置
  91. /// </summary>
  92. public sealed class TableSettings
  93. {
  94. /// <summary>
  95. /// 启用表初始化
  96. /// </summary>
  97. public bool EnableInitTable { get; set; }
  98. /// <summary>
  99. /// 启用表增量更新
  100. /// </summary>
  101. public bool EnableIncreTable { get; set; }
  102. }
  103. /// <summary>
  104. /// 种子配置
  105. /// </summary>
  106. public sealed class SeedSettings
  107. {
  108. /// <summary>
  109. /// 启用种子初始化
  110. /// </summary>
  111. public bool EnableInitSeed { get; set; }
  112. /// <summary>
  113. /// 启用种子增量更新
  114. /// </summary>
  115. public bool EnableIncreSeed { get; set; }
  116. }