using FastGithub.Configuration; using FastGithub.ReverseProxy; using Microsoft.AspNetCore.Connections; using Microsoft.AspNetCore.Hosting; using Microsoft.AspNetCore.Server.Kestrel.Core; using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.Logging; using System; using System.Net; using System.Security.Authentication; namespace FastGithub { /// /// Kestrel扩展 /// public static class KestrelServerOptionsExtensions { /// /// 监听http的反向代理 /// /// public static void ListenHttpReverseProxy(this KestrelServerOptions kestrel) { const int HTTP_PORT = 80; if (LocalMachine.CanListenTcp(HTTP_PORT) == false) { var loggerFactory = kestrel.ApplicationServices.GetRequiredService(); var logger = loggerFactory.CreateLogger($"{nameof(FastGithub)}.{nameof(ReverseProxy)}"); logger.LogWarning($"由于tcp端口{HTTP_PORT}已经被其它进程占用,http反向代理功能将受限"); } else { kestrel.Listen(IPAddress.Any, HTTP_PORT); } } /// /// 监听https的反向代理 /// /// public static void ListenHttpsReverseProxy(this KestrelServerOptions kestrel) { const int HTTPS_PORT = 443; if (OperatingSystem.IsWindows()) { TcpTable.KillPortOwner(HTTPS_PORT); } if (LocalMachine.CanListenTcp(HTTPS_PORT) == false) { throw new FastGithubException($"由于tcp端口{HTTPS_PORT}已经被其它进程占用,{nameof(FastGithub)}无法进行必须的https反向代理"); } var certService = kestrel.ApplicationServices.GetRequiredService(); certService.CreateCaCertIfNotExists(); certService.InstallAndTrustCaCert(); kestrel.Listen(IPAddress.Any, HTTPS_PORT, listen => listen.UseHttps(https => { if (OperatingSystem.IsWindows() && Environment.OSVersion.Version < new Version(6, 2)) { https.SslProtocols = SslProtocols.Tls12 | SslProtocols.Tls13; } https.ServerCertificateSelector = (ctx, domain) => certService.GetOrCreateServerCert(domain); })); } /// /// 监听github的ssh的代理 /// /// public static void ListenGithubSshProxy(this KestrelServerOptions kestrel) { const int SSH_PORT = 22; if (LocalMachine.CanListenTcp(SSH_PORT) == false) { var loggerFactory = kestrel.ApplicationServices.GetRequiredService(); var logger = loggerFactory.CreateLogger($"{nameof(FastGithub)}.{nameof(ReverseProxy)}"); logger.LogWarning($"由于tcp端口{SSH_PORT}已经被其它进程占用,github的ssh代理功能将受限"); } else { kestrel.Listen(IPAddress.Any, SSH_PORT, listen => listen.UseConnectionHandler()); } } } }