2025-06-06 14:15:31 +08:00
|
|
|
|
using JiShe.CollectBus.Common;
|
2024-12-19 16:07:07 +08:00
|
|
|
|
using JiShe.CollectBus.Host.HealthChecks;
|
|
|
|
|
|
using JiShe.CollectBus.Host.Swaggers;
|
2025-06-09 11:21:35 +08:00
|
|
|
|
using JiShe.ServicePro.FreeRedisProvider;
|
2025-06-06 14:15:31 +08:00
|
|
|
|
using JiShe.ServicePro.ServerOptions;
|
2025-06-09 11:21:35 +08:00
|
|
|
|
using Microsoft.AspNetCore.DataProtection;
|
2024-12-19 16:07:07 +08:00
|
|
|
|
using Microsoft.AspNetCore.Diagnostics.HealthChecks;
|
2025-06-09 11:21:35 +08:00
|
|
|
|
using Microsoft.Extensions.Hosting.Internal;
|
2024-12-19 16:07:07 +08:00
|
|
|
|
using Swashbuckle.AspNetCore.SwaggerUI;
|
|
|
|
|
|
using Volo.Abp;
|
|
|
|
|
|
using Volo.Abp.AspNetCore.Authentication.JwtBearer;
|
2025-06-13 17:42:49 +08:00
|
|
|
|
using Volo.Abp.AspNetCore.Mvc.AntiForgery;
|
2024-12-19 16:07:07 +08:00
|
|
|
|
using Volo.Abp.AspNetCore.Serilog;
|
|
|
|
|
|
using Volo.Abp.Autofac;
|
|
|
|
|
|
using Volo.Abp.Caching.StackExchangeRedis;
|
|
|
|
|
|
using Volo.Abp.Modularity;
|
|
|
|
|
|
using Volo.Abp.Swashbuckle;
|
2025-04-22 21:01:28 +08:00
|
|
|
|
using Volo.Abp.Timing;
|
2024-12-19 16:07:07 +08:00
|
|
|
|
|
|
|
|
|
|
namespace JiShe.CollectBus.Host
|
|
|
|
|
|
{
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
///
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
[DependsOn(typeof(CollectBusHttpApiModule),
|
|
|
|
|
|
typeof(AbpAutofacModule),
|
|
|
|
|
|
typeof(AbpAspNetCoreAuthenticationJwtBearerModule),
|
|
|
|
|
|
typeof(AbpAspNetCoreSerilogModule),
|
|
|
|
|
|
typeof(AbpSwashbuckleModule),
|
2025-04-22 21:01:28 +08:00
|
|
|
|
typeof(AbpTimingModule),
|
2024-12-19 16:07:07 +08:00
|
|
|
|
typeof(CollectBusApplicationModule),
|
2025-06-06 14:15:31 +08:00
|
|
|
|
typeof(AbpCachingStackExchangeRedisModule)
|
2024-12-19 16:07:07 +08:00
|
|
|
|
)]
|
|
|
|
|
|
public partial class CollectBusHostModule : AbpModule
|
|
|
|
|
|
{
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// ConfigureServices
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="context"></param>
|
|
|
|
|
|
public override void ConfigureServices(ServiceConfigurationContext context)
|
|
|
|
|
|
{
|
|
|
|
|
|
var configuration = context.Services.GetConfiguration();
|
|
|
|
|
|
ConfigureSwaggerServices(context, configuration);
|
|
|
|
|
|
ConfigureNetwork(context, configuration);
|
|
|
|
|
|
ConfigureJwtAuthentication(context, configuration);
|
2025-06-06 14:15:31 +08:00
|
|
|
|
//ConfigureHangfire(context);
|
|
|
|
|
|
//ConfigureAuditLog(context);
|
2024-12-19 16:07:07 +08:00
|
|
|
|
ConfigureCustom(context, configuration);
|
2025-04-23 14:46:19 +08:00
|
|
|
|
ConfigureHealthChecks(context, configuration);
|
2025-04-22 21:01:28 +08:00
|
|
|
|
Configure<AbpClockOptions>(options => { options.Kind = DateTimeKind.Local; });
|
2025-04-25 09:28:20 +08:00
|
|
|
|
|
|
|
|
|
|
Configure<ServerApplicationOptions>(options =>
|
|
|
|
|
|
{
|
|
|
|
|
|
configuration.GetSection(nameof(ServerApplicationOptions)).Bind(options);
|
|
|
|
|
|
});
|
|
|
|
|
|
|
2025-06-09 11:21:35 +08:00
|
|
|
|
context.Services
|
|
|
|
|
|
.AddDataProtection()
|
|
|
|
|
|
.PersistKeysToStackFreeRedis("JiSheCollectBus-Protection-Keys");
|
|
|
|
|
|
|
2025-06-13 17:42:49 +08:00
|
|
|
|
// DOTO:abp swagger调用抽风 提示 The antiforgery token could not be decrypted.
|
|
|
|
|
|
Configure<AbpAntiForgeryOptions>(options =>
|
|
|
|
|
|
{
|
|
|
|
|
|
options.TokenCookie.Expiration = TimeSpan.Zero;
|
|
|
|
|
|
options.AutoValidate = false; //表示不验证防伪令牌
|
|
|
|
|
|
});
|
|
|
|
|
|
|
2024-12-19 16:07:07 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// OnApplicationInitialization
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="context"></param>
|
|
|
|
|
|
public override void OnApplicationInitialization(ApplicationInitializationContext context)
|
|
|
|
|
|
{
|
|
|
|
|
|
var app = context.GetApplicationBuilder();
|
|
|
|
|
|
var configuration = context.GetConfiguration();
|
|
|
|
|
|
var env = context.GetEnvironment();
|
|
|
|
|
|
app.UseCorrelationId();
|
|
|
|
|
|
app.UseStaticFiles();
|
|
|
|
|
|
app.UseRouting();
|
|
|
|
|
|
app.UseCors(CollectBusHostConst.DefaultCorsPolicyName);
|
|
|
|
|
|
app.UseAuthentication();
|
|
|
|
|
|
app.UseAuthorization();
|
2025-06-09 11:21:35 +08:00
|
|
|
|
if (env.IsDevelopment())
|
|
|
|
|
|
{
|
2024-12-19 16:07:07 +08:00
|
|
|
|
app.UseSwagger();
|
|
|
|
|
|
app.UseAbpSwaggerUI(options =>
|
|
|
|
|
|
{
|
|
|
|
|
|
configuration.GetSection("SwaggerConfig").Get<List<SwaggerConfig>>()?.ForEach(group =>
|
|
|
|
|
|
{
|
|
|
|
|
|
options.SwaggerEndpoint($"/swagger/{group.GroupName}/swagger.json", group.Title); //分组显示
|
|
|
|
|
|
});
|
|
|
|
|
|
options.DocExpansion(DocExpansion.None);
|
|
|
|
|
|
options.DefaultModelsExpandDepth(-1);
|
|
|
|
|
|
});
|
2025-06-09 11:21:35 +08:00
|
|
|
|
}
|
2024-12-19 16:07:07 +08:00
|
|
|
|
app.UseAuditing();
|
|
|
|
|
|
app.UseAbpSerilogEnrichers();
|
|
|
|
|
|
app.UseUnitOfWork();
|
2025-06-06 14:15:31 +08:00
|
|
|
|
//app.UseHangfireDashboard("/hangfire", new DashboardOptions
|
|
|
|
|
|
//{
|
|
|
|
|
|
// IgnoreAntiforgeryToken = true
|
|
|
|
|
|
//});
|
2024-12-19 16:07:07 +08:00
|
|
|
|
app.UseConfiguredEndpoints(endpoints =>
|
|
|
|
|
|
{
|
2025-04-23 14:46:19 +08:00
|
|
|
|
if (!configuration.GetValue<bool>("HealthChecks:IsEnable")) return;
|
2024-12-19 16:07:07 +08:00
|
|
|
|
endpoints.MapHealthChecks("/health", new HealthCheckOptions
|
|
|
|
|
|
{
|
|
|
|
|
|
Predicate = _ => true,
|
|
|
|
|
|
ResponseWriter = HealthCheckResponse.Writer
|
|
|
|
|
|
});
|
2025-04-23 14:46:19 +08:00
|
|
|
|
endpoints.MapHealthChecksUI(options =>
|
|
|
|
|
|
{
|
|
|
|
|
|
options.UIPath = "/health-ui";
|
|
|
|
|
|
});
|
2024-12-19 16:07:07 +08:00
|
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|