using JiShe.CollectBus.Migration.Host.HealthChecks; using JiShe.CollectBus.Migration.Host.Swaggers; using Microsoft.AspNetCore.Authentication.JwtBearer; using Microsoft.AspNetCore.DataProtection; using Microsoft.Extensions.Diagnostics.HealthChecks; using Microsoft.IdentityModel.Tokens; using Microsoft.OpenApi.Models; using StackExchange.Redis; using System.Text; using Volo.Abp.AspNetCore.Auditing; using Volo.Abp.Auditing; using Volo.Abp.Caching; using Volo.Abp.Modularity; namespace JiShe.CollectBus.Migration.Host { public partial class CollectBusMigrationHostModule { /// /// Configures the JWT authentication. /// /// The context. /// The configuration. private void ConfigureJwtAuthentication(ServiceConfigurationContext context, IConfiguration configuration) { context.Services.AddAuthentication(options => { options.DefaultAuthenticateScheme = JwtBearerDefaults.AuthenticationScheme; options.DefaultChallengeScheme = JwtBearerDefaults.AuthenticationScheme; }) .AddJwtBearer(options => { options.TokenValidationParameters = new TokenValidationParameters() { // 是否开启签名认证 ValidateIssuerSigningKey = true, ValidateIssuer = true, ValidateAudience = true, ValidateLifetime = true, ClockSkew = TimeSpan.Zero, ValidIssuer = configuration["Jwt:Issuer"], ValidAudience = configuration["Jwt:Audience"], IssuerSigningKey = new SymmetricSecurityKey( Encoding.ASCII.GetBytes(configuration["Jwt:SecurityKey"])) }; options.Events = new JwtBearerEvents { OnMessageReceived = currentContext => { var path = currentContext.HttpContext.Request.Path; if (path.StartsWithSegments("/login")) { return Task.CompletedTask; } var accessToken = string.Empty; if (currentContext.HttpContext.Request.Headers.ContainsKey("Authorization")) { accessToken = currentContext.HttpContext.Request.Headers["Authorization"]; if (!string.IsNullOrWhiteSpace(accessToken)) { accessToken = accessToken.Split(" ").LastOrDefault(); } } if (string.IsNullOrWhiteSpace(accessToken)) { accessToken = currentContext.Request.Query["access_token"].FirstOrDefault(); } if (string.IsNullOrWhiteSpace(accessToken)) { accessToken = currentContext.Request.Cookies[@CollectBusMigrationHostConst.DefaultCookieName]; } currentContext.Token = accessToken; currentContext.Request.Headers.Remove("Authorization"); currentContext.Request.Headers.Add("Authorization", $"Bearer {accessToken}"); return Task.CompletedTask; } }; }); } /// /// Configures the cache. /// /// The context. private void ConfigureCache(ServiceConfigurationContext context) { Configure( options => { options.KeyPrefix = "CollectBus:"; }); var configuration = context.Services.GetConfiguration(); var redis = ConnectionMultiplexer.Connect($"{configuration.GetValue("Redis:Configuration")},defaultdatabase={configuration.GetValue("Redis:DefaultDB")}"); context.Services .AddDataProtection() .PersistKeysToStackExchangeRedis(redis, "CollectBus-Protection-Keys"); } /// /// Configures the swagger services. /// /// The context. /// The configuration. private void ConfigureSwaggerServices(ServiceConfigurationContext context, IConfiguration configuration) { context.Services.AddSwaggerGen( options => { configuration.GetSection("SwaggerConfig").Get>()?.ForEach(group => { options.SwaggerDoc(group.GroupName, new OpenApiInfo { Title = group.Title, Version = group.Version }); }); options.DocInclusionPredicate((docName, apiDes) => { if (docName == "Basic" && string.IsNullOrWhiteSpace(apiDes.GroupName)) return true; return docName == apiDes.GroupName; }); options.EnableAnnotations(); options.DocumentFilter(); options.SchemaFilter(); var xmlPaths = Directory.GetFiles(AppContext.BaseDirectory, "*.xml") .Where(a => a.EndsWith("Application.xml") || a.EndsWith("Application.Contracts.xml") || a.EndsWith("httpApi.xml") || a.EndsWith("Host.xml")) .Distinct() .ToList(); foreach (var xml in xmlPaths) options.IncludeXmlComments(xml, true); }); } /// /// Configures the audit log. /// /// The context. private void ConfigureAuditLog(ServiceConfigurationContext context) { Configure ( options => { options.IsEnabled = false; //options.EntityHistorySelectors.AddAllEntities(); options.ApplicationName = "JiShe.CollectBus.Migration"; } ); Configure( options => { options.IgnoredUrls.Add("/AuditLogs/page"); options.IgnoredUrls.Add("/hangfire/stats"); options.IgnoredUrls.Add("/hangfire/recurring/trigger"); options.IgnoredUrls.Add("/cap"); options.IgnoredUrls.Add("/"); }); } /// /// Configures the custom. /// /// The context. /// The configuration. private void ConfigureCustom(ServiceConfigurationContext context, IConfiguration configuration) { context.Services.AddSingleton(); } /// /// Configures the network. /// /// The context. /// The configuration. public void ConfigureNetwork(ServiceConfigurationContext context, IConfiguration configuration) { //context.Services.AddTcpService(config => //{ // config.SetListenIPHosts(int.Parse(configuration["TCP:ClientPort"] ?? "10500")) // //.SetTcpDataHandlingAdapter(()=>new StandardFixedHeaderDataHandlingAdapter()) // //.SetGetDefaultNewId(() => Guid.NewGuid().ToString())//定义ClientId的生成策略 // .ConfigurePlugins(a => // { // a.Add(); // a.Add(); // a.Add(); // }); //}); //context.Services.AddUdpSession(config => //{ // config.SetBindIPHost(int.Parse(configuration["UDP:ClientPort"] ?? "10500")) // .ConfigurePlugins(a => // { // a.Add(); // a.Add(); // }) // .UseBroadcast() // .SetUdpDataHandlingAdapter(() => new NormalUdpDataHandlingAdapter()); //}); } /// /// 健康检查 /// /// /// private void ConfigureHealthChecks(ServiceConfigurationContext context, IConfiguration configuration) { if (!configuration.GetValue("HealthChecks:IsEnable")) return; context.Services.AddHealthChecks() .AddRedis(configuration.GetValue("Redis:Configuration") ?? string.Empty, "Redis", HealthStatus.Unhealthy) .AddCheck("IoTDB"); context.Services .AddHealthChecksUI(options => { options.AddHealthCheckEndpoint("JiSheCollectBusMigration", "/health"); // 映射本地端点 }) .AddInMemoryStorage(); } } }