FreeSqlCloudExtesions.cs 5.7 KB

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