StartupExtensions.cs 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262
  1. using System.IO.Compression;
  2. using System.Reflection;
  3. using FluentValidation;
  4. using FluentValidation.AspNetCore;
  5. using Hotline.Api.Realtimes;
  6. using Hotline.Application;
  7. using Hotline.Application.Contracts;
  8. using Hotline.NewRock;
  9. using Hotline.Permissions;
  10. using Hotline.Repository.SqlSugar.Extensions;
  11. using Microsoft.AspNetCore.Authorization;
  12. using Microsoft.AspNetCore.Identity;
  13. using Serilog;
  14. using Mapster;
  15. using Tr.Sdk;
  16. using XF.Domain.Dependency;
  17. using XF.Domain.Filters;
  18. using XF.Domain.Options;
  19. using XF.EasyCaching;
  20. using XF.Utility.MQ;
  21. using Hotline.Ai.Jths;
  22. using Hotline.Api.Sdk;
  23. using Hotline.CallCenter.Configs;
  24. using Hotline.Wex;
  25. using Hotline.Application.CallCenter.Calls;
  26. using Hotline.Application.CallCenter;
  27. using Hotline.Authentications;
  28. using Hotline.CallCenter.Calls;
  29. using Swashbuckle.AspNetCore.SwaggerUI;
  30. using Hotline.Configurations;
  31. using Hotline.DI;
  32. using Hotline.Share.Tools;
  33. using Hotline.Settings.TimeLimitDomain.ExpireTimeSupplier;
  34. using Hotline.Api.Middleware;
  35. using XF.Domain.Authentications;
  36. using Hotline.XingTang;
  37. using Hotline.Logger;
  38. using HotPot.Mvc.Filters;
  39. using Microsoft.AspNetCore.ResponseCompression;
  40. using Senparc.Weixin.RegisterServices;
  41. using Senparc.Weixin.AspNet;
  42. using Hotline.WeChat;
  43. namespace Hotline.Api;
  44. internal static class StartupExtensions
  45. {
  46. const string CorsOrigins = "CorsOrigins";
  47. internal static WebApplication ConfigureServices(this WebApplicationBuilder builder)
  48. {
  49. var services = builder.Services;
  50. var configuration = builder.Configuration;
  51. services.AddHttpContextAccessor();
  52. #if DEBUG
  53. builder.WebHost.UseUrls("http://*:50100");
  54. #endif
  55. services.Configure<IdentityConfiguration>(d => configuration.GetSection(nameof(IdentityConfiguration)).Bind(d));
  56. var appConfigurationSection = configuration.GetRequiredSection(nameof(AppConfiguration));
  57. var appConfiguration = appConfigurationSection.Get<AppConfiguration>();
  58. if (appConfiguration is null) throw new ArgumentNullException(nameof(appConfiguration));
  59. services.Configure<AppConfiguration>(d => appConfigurationSection.Bind(d));
  60. var callCenterConfigurationSection = configuration.GetRequiredSection(nameof(CallCenterConfiguration));
  61. var callCenterConfiguration = callCenterConfigurationSection.Get<CallCenterConfiguration>();
  62. services.Configure<CallCenterConfiguration>(d => callCenterConfigurationSection.Bind(d));
  63. services.Configure<CityBaseConfiguration>(d => configuration.GetSection(nameof(CityBaseConfiguration)).Bind(d));
  64. //services.Configure<SendSmsConfiguration>(d => configuration.GetSection("SendSms").Bind(d));
  65. // Add services to the container.
  66. services
  67. .BatchInjectServices(d =>
  68. {
  69. var attr = d.GetCustomAttribute(typeof(InjectionAttribute)) as InjectionAttribute;
  70. if (attr is null) return true;
  71. return attr.IsEnable(appConfiguration.AppScope,
  72. appConfiguration.GetDefaultAppScopeConfiguration().CallCenterType);
  73. })
  74. .RegisterRepository()
  75. .AddApplication()
  76. .AddScoped(typeof(IPasswordHasher<>), typeof(PasswordHasher<>))
  77. .AddHttpClient()
  78. ;
  79. services.AddKeyedScoped<ISessionContext, ProvinceSessionContext>(ProvinceSessionContext.Key)
  80. .AddKeyedScoped<ISessionContext, Police110SessionContext>(Police110SessionContext.Key)
  81. ;
  82. //cache
  83. services.AddCache(d =>
  84. {
  85. var cacheConfig = configuration.GetSection("Cache").Get<CacheOptions>();
  86. cacheConfig.Adapt(d);
  87. d.Prefix = "Hotline";
  88. d.TopicName = "hotline-topic";
  89. });
  90. //Authentication
  91. services.RegisterAuthentication(configuration);
  92. services.AddControllers(options =>
  93. {
  94. options.Filters.Add<UnifyResponseFilter>();
  95. options.Filters.Add<UserFriendlyExceptionFilter>();
  96. options.Filters.Add<ErrorHandlingFilter>();
  97. })
  98. ;
  99. // Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbuckle
  100. services.AddEndpointsApiExplorer();
  101. //swagger
  102. services.RegisterSwagger();
  103. //signalR
  104. services.RegisterSignalR(configuration);
  105. /* CORS */
  106. services.RegisterCors(configuration, CorsOrigins);
  107. //mapster
  108. services.RegisterMapper();
  109. //mediatr
  110. services.RegisterMediatR(appConfiguration);
  111. //app scope
  112. switch (appConfiguration.AppScope)
  113. {
  114. case AppDefaults.AppScope.YiBin:
  115. //jths
  116. services.AddAiJths(appConfiguration.YiBin.AiQuality.Url);
  117. services.AddAiVisitService(
  118. appConfiguration.YiBin.AiVisit.Url,
  119. appConfiguration.YiBin.AiVisit.Appkey,
  120. appConfiguration.YiBin.AiVisit.ServiceVersion);
  121. //宜宾企业服务
  122. services.AddYbEnterpriseSdk(appConfiguration.YiBin.Enterprise.AddressUrl)
  123. .AddKeyedScoped<ISessionContext, YbEnterpriseSessionContext>(YbEnterpriseSessionContext.Key)
  124. .AddKeyedScoped<ISessionContext, ZzptSessionContext>(ZzptSessionContext.Key);
  125. break;
  126. case AppDefaults.AppScope.ZiGong:
  127. break;
  128. case AppDefaults.AppScope.LuZhou:
  129. break;
  130. }
  131. //callcenter
  132. var callcenterType = appConfiguration.GetDefaultAppScopeConfiguration().CallCenterType;
  133. switch (callcenterType)
  134. {
  135. case AppDefaults.CallCenterType.XunShi:
  136. services.AddNewRock(callCenterConfiguration.NewRock);
  137. break;
  138. case AppDefaults.CallCenterType.WeiErXin:
  139. services
  140. .AddWex(callCenterConfiguration.Wex)
  141. .AddWexDb(configuration);
  142. break;
  143. case AppDefaults.CallCenterType.TianRun:
  144. services
  145. .AddScoped<ICallApplication, TianRunCallApplication>()
  146. .AddScoped<ITrApplication, TrApplication>()
  147. .AddHostedService<CurrentWaitNumService>()
  148. .AddHostedService<TelsStatusRefreshService>()
  149. .AddTrSdk(callCenterConfiguration.TianRun.Address,
  150. callCenterConfiguration.TianRun.Username,
  151. callCenterConfiguration.TianRun.Password);
  152. break;
  153. case AppDefaults.CallCenterType.XingTang:
  154. services.AddXingTangDb(callCenterConfiguration.XingTang)
  155. .AddXingTangSDK()
  156. .AddScoped<ICallApplication, XingTangCallApplication>()
  157. .AddScoped<CallIdManager>()
  158. ;
  159. break;
  160. default:
  161. break;
  162. }
  163. //sqlsugar
  164. services.AddSqlSugar(configuration);
  165. //validator
  166. services.AddFluentValidationAutoValidation(config =>
  167. {
  168. config.DisableDataAnnotationsValidation = true;
  169. })
  170. .AddValidatorsFromAssembly(typeof(AppContractsStartupExtensions).Assembly);
  171. //mq
  172. services.AddMq(configuration);
  173. //job
  174. services.RegisterJob(appConfiguration);
  175. //compression
  176. services.RejisterCompression();
  177. services.AddSingleton<IAuthorizationPolicyProvider, AuthorizationPolicyProvider>();
  178. services.AddSingleton<IAuthorizationHandler, PermissionHandler>();
  179. services.AddScoped<ExpireTimeFactory>();
  180. services.AddScoped<IExpireTimeSupplier, DaySupplier>();
  181. services.AddScoped<IExpireTimeSupplier, WorkDaySupplier>();
  182. services.AddScoped<IExpireTimeSupplier, HourSupplier>();
  183. services.AddScoped<Users.IThirdIdentiyService, WeChatService>();
  184. services.AddSenparcWeixin(configuration);
  185. //services.AddScoped<LogFilterAttribute>();
  186. //ServiceLocator.Instance = services.BuildServiceProvider();
  187. return builder.Build();
  188. }
  189. internal static WebApplication ConfigurePipelines(this WebApplication app)
  190. {
  191. app.UseSerilogRequestLogging();
  192. // Configure the HTTP request pipeline.
  193. var swaggerEnable = app.Configuration.GetSection("Swagger").Get<bool>();
  194. if (swaggerEnable)
  195. {
  196. app.UseSwagger();
  197. app.UseSwaggerUI();
  198. //app.UseSwaggerUI(c =>
  199. //{
  200. // //c.DocExpansion(DocExpansion.None);
  201. // //c.SwaggerEndpoint("/swagger/v1/swagger.json", "My API V1");
  202. //});
  203. }
  204. app.UseCors(CorsOrigins);
  205. app.UseAuthentication();
  206. app.UseAuthorization();
  207. //app.MapHub<CallCenterHub>("/hubs/callcenter");
  208. app.MapHub<HotlineHub>("/hubs/hotline");
  209. app.MapControllers()
  210. .RequireAuthorization();
  211. //app.MapSubscribeHandler();
  212. var registerService = app.UseSenparcWeixin(app.Environment, null, null,
  213. register => { },
  214. (register, weixinSetting) => { }
  215. );
  216. // 记录交互日志
  217. //app.UseRequestResponseLogging(app.Configuration);
  218. app.UseResponseCompression();
  219. return app;
  220. }
  221. }