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 = true;
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();
}
}
}