61 lines
1.6 KiB
C#
61 lines
1.6 KiB
C#
|
|
using Avalonia_API.Configuration;
|
|||
|
|
using Avalonia_API.Extensions;
|
|||
|
|
using Avalonia_Common.Infrastructure;
|
|||
|
|
using Avalonia_EFCore.Database;
|
|||
|
|
using Avalonia_Services.Core;
|
|||
|
|
using Serilog;
|
|||
|
|
|
|||
|
|
// 初始化日志系统
|
|||
|
|
Log.Logger = LoggingConfiguration.CreateDefaultLogger(logDir: "logs");
|
|||
|
|
Log.Information("Avalonia-API 正在启动...");
|
|||
|
|
|
|||
|
|
try
|
|||
|
|
{
|
|||
|
|
var builder = WebApplication.CreateBuilder(args);
|
|||
|
|
|
|||
|
|
// 使用 Serilog 作为日志提供程序
|
|||
|
|
builder.Host.UseSerilog();
|
|||
|
|
|
|||
|
|
// Add services to the container.
|
|||
|
|
builder.Services.AddControllers();
|
|||
|
|
builder.Services.AddOpenApi();
|
|||
|
|
|
|||
|
|
// 注册统一端点及业务服务(入口在 Avalonia-Services/Endpoints/AppEndpoints.cs)
|
|||
|
|
builder.Services.AddUnifiedApiServices(builder.Configuration);
|
|||
|
|
|
|||
|
|
var app = builder.Build();
|
|||
|
|
|
|||
|
|
// 初始化数据库(自动迁移 + 种子数据)
|
|||
|
|
app.Services.InitializeDatabase<AppDataContext>();
|
|||
|
|
|
|||
|
|
var endpoints = app.Services.GetRequiredService<ServiceEndpointCollection>();
|
|||
|
|
|
|||
|
|
// Configure the HTTP request pipeline.
|
|||
|
|
if (app.Environment.IsDevelopment())
|
|||
|
|
{
|
|||
|
|
app.MapOpenApi();
|
|||
|
|
app.UseSwaggerUI(options =>
|
|||
|
|
{
|
|||
|
|
options.SwaggerEndpoint("/openapi/v1.json", "Avalonia API v1");
|
|||
|
|
options.RoutePrefix = "swagger";
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
app.UseHttpsRedirection();
|
|||
|
|
app.UseAuthentication();
|
|||
|
|
app.UseAuthorization();
|
|||
|
|
|
|||
|
|
// 将统一端点映射到 ASP.NET Core 路由
|
|||
|
|
app.MapUnifiedEndpoints(endpoints, app.Services);
|
|||
|
|
|
|||
|
|
app.Run();
|
|||
|
|
}
|
|||
|
|
catch (Exception ex)
|
|||
|
|
{
|
|||
|
|
Log.Fatal(ex, "Avalonia-API 启动失败");
|
|||
|
|
}
|
|||
|
|
finally
|
|||
|
|
{
|
|||
|
|
Log.CloseAndFlush();
|
|||
|
|
}
|