FreeSqlCloudExtesions.cs 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. using Microsoft.Extensions.DependencyInjection;
  2. using System;
  3. using StackExchange.Profiling;
  4. using FreeSql;
  5. using FreeSql.Internal.CommonProvider;
  6. using ZhonTai.Admin.Core.Auth;
  7. using ZhonTai.Admin.Core.Configs;
  8. using ZhonTai.Admin.Core.Dto;
  9. using ZhonTai.Admin.Core.Entities;
  10. using ZhonTai.Admin.Domain.Tenant;
  11. using ZhonTai.Admin.Core.Consts;
  12. using ZhonTai.Admin.Core.Db.Transaction;
  13. namespace ZhonTai.Admin.Core.Db;
  14. public static class FreeSqlCloudExtesions
  15. {
  16. /// <summary>
  17. /// 创建FreeSql实例
  18. /// </summary>
  19. /// <param name="user"></param>
  20. /// <param name="appConfig"></param>
  21. /// <param name="dbConfig"></param>
  22. /// <param name="tenant"></param>
  23. /// <returns></returns>
  24. private static IFreeSql CreateFreeSql(IUser user, AppConfig appConfig, DbConfig dbConfig, CreateFreeSqlTenantDto tenant)
  25. {
  26. var freeSqlBuilder = new FreeSqlBuilder()
  27. .UseConnectionString(tenant.DbType.Value, tenant.ConnectionString)
  28. .UseAutoSyncStructure(false)
  29. .UseLazyLoading(false)
  30. .UseNoneCommandParameter(true);
  31. #region 监听所有命令
  32. if (dbConfig.MonitorCommand)
  33. {
  34. freeSqlBuilder.UseMonitorCommand(cmd => { }, (cmd, traceLog) =>
  35. {
  36. Console.WriteLine($"{cmd.CommandText}\r\n");
  37. });
  38. }
  39. #endregion 监听所有命令
  40. var fsql = freeSqlBuilder.Build();
  41. fsql.GlobalFilter.Apply<IDelete>(FilterNames.Delete, a => a.IsDeleted == false);
  42. //配置实体
  43. DbHelper.ConfigEntity(fsql, appConfig);
  44. #region 监听Curd操作
  45. if (dbConfig.Curd)
  46. {
  47. fsql.Aop.CurdBefore += (s, e) =>
  48. {
  49. if (appConfig.MiniProfiler)
  50. {
  51. MiniProfiler.Current.CustomTiming("CurdBefore", e.Sql);
  52. }
  53. Console.WriteLine($"{e.Sql}\r\n");
  54. };
  55. fsql.Aop.CurdAfter += (s, e) =>
  56. {
  57. if (appConfig.MiniProfiler)
  58. {
  59. MiniProfiler.Current.CustomTiming("CurdAfter", $"{e.ElapsedMilliseconds}");
  60. }
  61. Console.WriteLine($"{e.Sql}\r\n");
  62. };
  63. }
  64. #endregion 监听Curd操作
  65. #region 审计数据
  66. //计算服务器时间
  67. var selectProvider = fsql.Select<object>() as Select0Provider;
  68. var serverTime = fsql.Select<object>().WithSql($"select {selectProvider._commonUtils.NowUtc} a").First(a=> Convert.ToDateTime("a"));
  69. var timeOffset = DateTime.UtcNow.Subtract(serverTime);
  70. fsql.Aop.AuditValue += (s, e) =>
  71. {
  72. DbHelper.AuditValue(e, timeOffset, user);
  73. };
  74. #endregion 审计数据
  75. if (appConfig.Tenant)
  76. {
  77. fsql.GlobalFilter.Apply<ITenant>(FilterNames.Tenant, a => a.TenantId == user.TenantId);
  78. }
  79. return fsql;
  80. }
  81. /// <summary>
  82. /// 获得当前登录用户数据库
  83. /// </summary>
  84. /// <param name="cloud"></param>
  85. /// <param name="serviceProvider"></param>
  86. /// <returns></returns>
  87. public static IFreeSql GetCurrentDb(this FreeSqlCloud cloud, IServiceProvider serviceProvider)
  88. {
  89. var user = serviceProvider.GetRequiredService<IUser>();
  90. var appConfig = serviceProvider.GetRequiredService<AppConfig>();
  91. var tenantId = user.TenantId;
  92. if (appConfig.Tenant && tenantId.HasValue)
  93. {
  94. var dbKey = user.DbKey.NotNull() ? user.DbKey : (DbKeys.TenantDb + tenantId);
  95. var exists = cloud.ExistsRegister(dbKey);
  96. if (!exists)
  97. {
  98. var dbConfig = serviceProvider.GetRequiredService<DbConfig>();
  99. var tenantRepository = serviceProvider.GetRequiredService<ITenantRepository>();
  100. var tenant = tenantRepository.Select.DisableGlobalFilter(FilterNames.Tenant).WhereDynamic(tenantId).ToOne<CreateFreeSqlTenantDto>();
  101. cloud.Register(dbKey, () => CreateFreeSql(user, appConfig, dbConfig, tenant));
  102. }
  103. return cloud.Use(dbKey);
  104. }
  105. else
  106. {
  107. var masterDb = cloud.Use(DbKeys.MasterDb);
  108. return masterDb;
  109. }
  110. }
  111. /// <summary>
  112. /// 获得租户数据库
  113. /// </summary>
  114. /// <param name="cloud"></param>
  115. /// <param name="serviceProvider"></param>
  116. /// <param name="tenantId"></param>
  117. /// <returns></returns>
  118. public static IFreeSql GetTenantDb(this FreeSqlCloud cloud, IServiceProvider serviceProvider, long? tenantId = null)
  119. {
  120. if (!tenantId.HasValue)
  121. {
  122. return null;
  123. }
  124. var tenantRepository = serviceProvider.GetRequiredService<ITenantRepository>();
  125. var tenant = tenantRepository.Select.DisableGlobalFilter(FilterNames.Tenant).WhereDynamic(tenantId).ToOne<CreateFreeSqlTenantDto>();
  126. var dbKey = tenant.DbKey.NotNull() ? tenant.DbKey : (DbKeys.TenantDb + tenantId);
  127. var exists = cloud.ExistsRegister(dbKey);
  128. if (!exists)
  129. {
  130. var user = serviceProvider.GetRequiredService<IUser>();
  131. var dbConfig = serviceProvider.GetRequiredService<DbConfig>();
  132. var appConfig = serviceProvider.GetRequiredService<AppConfig>();
  133. cloud.Register(dbKey, () => CreateFreeSql(user, appConfig, dbConfig, tenant));
  134. }
  135. return cloud.Use(dbKey);
  136. }
  137. }