Startup.cs 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. using FastGithub.Configuration;
  2. using FastGithub.FlowAnalyze;
  3. using Microsoft.AspNetCore.Builder;
  4. using Microsoft.AspNetCore.Hosting;
  5. using Microsoft.AspNetCore.Http;
  6. using Microsoft.Extensions.Configuration;
  7. using Microsoft.Extensions.DependencyInjection;
  8. using Microsoft.Extensions.Hosting;
  9. using Serilog;
  10. using Serilog.Sinks.Network;
  11. using System;
  12. using System.Collections.Generic;
  13. using System.Diagnostics.CodeAnalysis;
  14. using System.IO;
  15. using System.Net;
  16. using System.Text.Json;
  17. namespace FastGithub
  18. {
  19. /// <summary>
  20. /// 启动项
  21. /// </summary>
  22. static class Startup
  23. {
  24. /// <summary>
  25. /// 配置通用主机
  26. /// </summary>
  27. /// <param name="builder"></param>
  28. public static void ConfigureHost(this WebApplicationBuilder builder)
  29. {
  30. builder.Host.UseSystemd().UseWindowsService();
  31. builder.Host.UseSerilog((hosting, logger) =>
  32. {
  33. var template = "{Timestamp:O} [{Level:u3}]{NewLine}{SourceContext}{NewLine}{Message:lj}{NewLine}{Exception}{NewLine}";
  34. logger
  35. .ReadFrom.Configuration(hosting.Configuration)
  36. .Enrich.FromLogContext()
  37. .WriteTo.Console(outputTemplate: template)
  38. .WriteTo.File(Path.Combine("logs", @"log.txt"), rollingInterval: RollingInterval.Day, outputTemplate: template);
  39. var udpLoggerPort = hosting.Configuration.GetValue(nameof(AppOptions.UdpLoggerPort), 38457);
  40. logger.WriteTo.UDPSink(IPAddress.Loopback, udpLoggerPort);
  41. });
  42. }
  43. /// <summary>
  44. /// 配置web主机
  45. /// </summary>
  46. /// <param name="builder"></param>
  47. public static void ConfigureWebHost(this WebApplicationBuilder builder)
  48. {
  49. builder.WebHost.UseShutdownTimeout(TimeSpan.FromSeconds(1d));
  50. builder.WebHost.UseKestrel(kestrel =>
  51. {
  52. kestrel.NoLimit();
  53. if (OperatingSystem.IsWindows())
  54. {
  55. kestrel.ListenHttpsReverseProxy();
  56. kestrel.ListenHttpReverseProxy();
  57. kestrel.ListenSshReverseProxy();
  58. kestrel.ListenGitReverseProxy();
  59. }
  60. else
  61. {
  62. kestrel.ListenHttpProxy();
  63. }
  64. });
  65. }
  66. /// <summary>
  67. /// 配置配置
  68. /// </summary>
  69. /// <param name="builder"></param>
  70. public static void ConfigureConfiguration(this WebApplicationBuilder builder)
  71. {
  72. const string APPSETTINGS = "appsettings";
  73. if (Directory.Exists(APPSETTINGS) == true)
  74. {
  75. foreach (var file in Directory.GetFiles(APPSETTINGS, "appsettings.*.json"))
  76. {
  77. var jsonFile = Path.Combine(APPSETTINGS, Path.GetFileName(file));
  78. builder.Configuration.AddJsonFile(jsonFile, true, true);
  79. }
  80. }
  81. }
  82. /// <summary>
  83. /// 配置服务
  84. /// </summary>
  85. /// <param name="builder"></param>
  86. [DynamicDependency(DynamicallyAccessedMemberTypes.All, typeof(Dictionary<string, DomainConfig>))]
  87. public static void ConfigureServices(this WebApplicationBuilder builder)
  88. {
  89. var services = builder.Services;
  90. var configuration = builder.Configuration;
  91. services.Configure<AppOptions>(configuration);
  92. services.Configure<FastGithubOptions>(configuration.GetSection(nameof(FastGithub)));
  93. services.AddConfiguration();
  94. services.AddDomainResolve();
  95. services.AddHttpClient();
  96. services.AddReverseProxy();
  97. services.AddFlowAnalyze();
  98. services.AddHostedService<AppHostedService>();
  99. if (OperatingSystem.IsWindows())
  100. {
  101. services.AddPacketIntercept();
  102. }
  103. }
  104. /// <summary>
  105. /// 配置应用
  106. /// </summary>
  107. /// <param name="app"></param>
  108. public static void ConfigureApp(this WebApplication app)
  109. {
  110. app.UseHttpProxyPac();
  111. app.UseRequestLogging();
  112. app.UseHttpReverseProxy();
  113. app.UseRouting();
  114. app.DisableRequestLogging();
  115. app.MapGet("/flowStatistics", context =>
  116. {
  117. var flowStatistics = context.RequestServices.GetRequiredService<IFlowAnalyzer>().GetFlowStatistics();
  118. var json = JsonSerializer.Serialize(flowStatistics, FlowStatisticsContext.Default.FlowStatistics);
  119. return context.Response.WriteAsync(json);
  120. });
  121. }
  122. }
  123. }