Program.cs 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. using Microsoft.Extensions.Hosting.WindowsServices;
  2. using Serilog;
  3. using SharedKernel;
  4. using Admin.Extensions;
  5. using Admin.Pages.Shared.Layout;
  6. using Admin.Middlewares;
  7. using Application;
  8. using Infrastructure;
  9. var builder = WebApplication.CreateBuilder(args);
  10. var settings = builder.Configuration.Get<AppSettings>()!;
  11. if (!WindowsServiceHelpers.IsWindowsService())
  12. {
  13. Console.Title = settings.App.Name;
  14. }
  15. Console.WriteLine($"ENV={builder.Environment.EnvironmentName}");
  16. Console.WriteLine($"현재 시간: {DateTime.Now} / {TimeZoneInfo.Local.Id}");
  17. builder.Host.UseWindowsService();
  18. // Serilog — Production에서만 파일 로그
  19. if (builder.Environment.IsProduction())
  20. {
  21. Log.Logger = new LoggerConfiguration()
  22. .ReadFrom.Configuration(builder.Configuration)
  23. .WriteTo.File("logs/admin-.log",
  24. rollingInterval: RollingInterval.Day,
  25. retainedFileCountLimit: 30,
  26. outputTemplate: "{Timestamp:yyyy-MM-dd HH:mm:ss.fff} [{Level:u3}] {Message:lj}{NewLine}{Exception}")
  27. .CreateLogger();
  28. builder.Host.UseSerilog();
  29. }
  30. // Add services to the container.
  31. var mvcBuilder = builder.Services.AddRazorPages(options =>
  32. {
  33. options.Conventions.AuthorizeFolder("/");
  34. options.Conventions.AllowAnonymousToAreaFolder("Identity", "/Account");
  35. });
  36. // 프로그램 설정 값 배치
  37. builder.Services.Configure<AppSettings>(builder.Configuration);
  38. // DB 연결
  39. builder.Services.AddApplication().AddAdminInfrastructure(builder.Configuration);
  40. // 관리자 레이아웃
  41. builder.Services.AddScoped<ILayoutDataProvider, LayoutDataProvider>();
  42. // 인증 및 권한 부여
  43. builder.Services.AddAdminForwardedHeaders(settings); // 리버스 프록시 및 접근 제어
  44. builder.Services.AddAdminIdentity(settings); // 관리자단 Identity 인증 및 비밀번호 정책
  45. builder.Logging.AddConsole(); // 터미널에 로그 출력
  46. if (builder.Environment.IsDevelopment())
  47. {
  48. builder.Logging.AddDebug(); // 디버깅 창에 로그 출력
  49. }
  50. /**
  51. * =======================================================================================================================================================
  52. */
  53. var app = builder.Build();
  54. // 초기 관리자 계정 시드
  55. await app.SeedAdminAccountAsync();
  56. /**
  57. * =======================================================================================================================================================
  58. */
  59. // 환경변수 불러오기
  60. var env = Environment.GetEnvironmentVariable("environmentVariables");
  61. app.Use(async (context, next) =>
  62. {
  63. context.Items["env"] = env; // 환경변수를 static 변수로 저장
  64. await next();
  65. });
  66. /**
  67. * =======================================================================================================================================================
  68. */
  69. // Configure the HTTP request pipeline.
  70. if (!app.Environment.IsDevelopment())
  71. {
  72. app.UseExceptionHandler("/Error");
  73. // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.
  74. app.UseHsts();
  75. }
  76. app.UseHttpsRedirection();
  77. app.UseRouting();
  78. app.UseAuthentication();
  79. app.UseAuthorization();
  80. // 메뉴 기반 역할 권한 체크
  81. app.UseMiddleware<MenuAuthorizationMiddleware>();
  82. // 관리자 접속 기록
  83. app.UseMiddleware<AdminAccessLogMiddleware>();
  84. app.MapStaticAssets();
  85. app.MapRazorPages().WithStaticAssets();
  86. app.Run();