linux不读取发行版名称

This commit is contained in:
老九 2021-11-13 11:09:30 +08:00
parent 68d585a3b7
commit b824ffece1
10 changed files with 52 additions and 101 deletions

View File

@ -8,32 +8,40 @@ namespace FastGithub.HttpServer
{ {
abstract class CaCertInstallerOfLinux : ICaCertInstaller abstract class CaCertInstallerOfLinux : ICaCertInstaller
{ {
const string OS_RELEASE_FILE = "/etc/os-release"; private readonly ILogger logger;
/// <summary> /// <summary>
/// 更新工具文件名 /// 更新工具文件名
/// </summary> /// </summary>
public abstract string CertUpdateFileName { get; } protected abstract string CertToolName { get; }
/// <summary> /// <summary>
/// 证书根目录 /// 证书根目录
/// </summary> /// </summary>
public abstract string RootCertPath { get; } protected abstract string CertStorePath { get; }
public CaCertInstallerOfLinux(ILogger logger)
{
this.logger = logger;
}
/// <summary> /// <summary>
/// 是否支持 /// 是否支持
/// </summary> /// </summary>
/// <returns></returns> /// <returns></returns>
public abstract bool IsSupported(); public bool IsSupported()
{
return OperatingSystem.IsLinux() && File.Exists(this.CertToolName);
}
/// <summary> /// <summary>
/// 安装ca证书 /// 安装ca证书
/// </summary> /// </summary>
/// <param name="caCertFilePath">证书文件路径</param> /// <param name="caCertFilePath">证书文件路径</param>
/// <param name="logger"></param> public void Install(string caCertFilePath)
public void Install(string caCertFilePath, ILogger logger)
{ {
var destCertFilePath = Path.Combine(this.RootCertPath, "fastgithub.crt"); var destCertFilePath = Path.Combine(this.CertStorePath, "fastgithub.crt");
if (File.Exists(destCertFilePath) && File.ReadAllBytes(caCertFilePath).SequenceEqual(File.ReadAllBytes(destCertFilePath))) if (File.Exists(destCertFilePath) && File.ReadAllBytes(caCertFilePath).SequenceEqual(File.ReadAllBytes(destCertFilePath)))
{ {
return; return;
@ -41,45 +49,21 @@ namespace FastGithub.HttpServer
if (Environment.UserName != "root") if (Environment.UserName != "root")
{ {
logger.LogWarning($"无法自动安装CA证书{caCertFilePath}因为没有root权限"); this.logger.LogWarning($"无法自动安装CA证书{caCertFilePath}因为没有root权限");
return; return;
} }
try try
{ {
Directory.CreateDirectory(this.RootCertPath); Directory.CreateDirectory(this.CertStorePath);
File.Copy(caCertFilePath, destCertFilePath, overwrite: true); File.Copy(caCertFilePath, destCertFilePath, overwrite: true);
Process.Start(this.CertUpdateFileName).WaitForExit(); Process.Start(this.CertToolName).WaitForExit();
} }
catch (Exception ex) catch (Exception ex)
{ {
File.Delete(destCertFilePath); File.Delete(destCertFilePath);
logger.LogWarning(ex.Message, "自动安装证书异常"); this.logger.LogWarning(ex.Message, "自动安装证书异常");
} }
} }
/// <summary>
/// 是否为某个发行版
/// </summary>
/// <param name="name"></param>
/// <returns></returns>
protected static bool IsReleasName(string name)
{
if (File.Exists(OS_RELEASE_FILE) == false)
{
return false;
}
foreach (var line in File.ReadAllLines(OS_RELEASE_FILE))
{
if (line.StartsWith("NAME=") && line.Contains(name))
{
return true;
}
}
return false;
}
} }
} }

View File

@ -1,16 +0,0 @@
using System;
namespace FastGithub.HttpServer
{
sealed class CaCertInstallerOfLinuxCentOS : CaCertInstallerOfLinuxRedHat
{
/// <summary>
/// 是否支持
/// </summary>
/// <returns></returns>
public override bool IsSupported()
{
return OperatingSystem.IsLinux() && IsReleasName("CentOS");
}
}
}

View File

@ -1,20 +1,16 @@
using System; using Microsoft.Extensions.Logging;
namespace FastGithub.HttpServer namespace FastGithub.HttpServer
{ {
class CaCertInstallerOfLinuxDebian : CaCertInstallerOfLinux sealed class CaCertInstallerOfLinuxDebian : CaCertInstallerOfLinux
{ {
public override string RootCertPath => "/usr/local/share/ca-certificates"; protected override string CertToolName => "update-ca-certificates";
public override string CertUpdateFileName => "update-ca-certificates"; protected override string CertStorePath => "/usr/local/share/ca-certificates";
/// <summary> public CaCertInstallerOfLinuxDebian(ILogger<CaCertInstallerOfLinuxDebian> logger)
/// 是否支持 : base(logger)
/// </summary>
/// <returns></returns>
public override bool IsSupported()
{ {
return OperatingSystem.IsLinux() && IsReleasName("Debian");
} }
} }
} }

View File

@ -1,20 +1,16 @@
using System; using Microsoft.Extensions.Logging;
namespace FastGithub.HttpServer namespace FastGithub.HttpServer
{ {
class CaCertInstallerOfLinuxRedHat : CaCertInstallerOfLinux sealed class CaCertInstallerOfLinuxRedHat : CaCertInstallerOfLinux
{ {
public override string RootCertPath => "/etc/pki/ca-trust/source/anchors"; protected override string CertToolName => "update-ca-trust";
public override string CertUpdateFileName => "update-ca-trust"; protected override string CertStorePath => "/etc/pki/ca-trust/source/anchors";
/// <summary> public CaCertInstallerOfLinuxRedHat(ILogger<CaCertInstallerOfLinuxRedHat> logger)
/// 是否支持 : base(logger)
/// </summary>
/// <returns></returns>
public override bool IsSupported()
{ {
return OperatingSystem.IsLinux() && IsReleasName("Red Hat");
} }
} }
} }

View File

@ -1,16 +0,0 @@
using System;
namespace FastGithub.HttpServer
{
sealed class CaCertInstallerOfLinuxUbuntu : CaCertInstallerOfLinuxDebian
{
/// <summary>
/// 是否支持
/// </summary>
/// <returns></returns>
public override bool IsSupported()
{
return OperatingSystem.IsLinux() && IsReleasName("Ubuntu");
}
}
}

View File

@ -5,6 +5,13 @@ namespace FastGithub.HttpServer
{ {
sealed class CaCertInstallerOfMacOS : ICaCertInstaller sealed class CaCertInstallerOfMacOS : ICaCertInstaller
{ {
private readonly ILogger<CaCertInstallerOfMacOS> logger;
public CaCertInstallerOfMacOS(ILogger<CaCertInstallerOfMacOS> logger)
{
this.logger = logger;
}
/// <summary> /// <summary>
/// 是否支持 /// 是否支持
/// </summary> /// </summary>
@ -18,10 +25,9 @@ namespace FastGithub.HttpServer
/// 安装ca证书 /// 安装ca证书
/// </summary> /// </summary>
/// <param name="caCertFilePath">证书文件路径</param> /// <param name="caCertFilePath">证书文件路径</param>
/// <param name="logger"></param> public void Install(string caCertFilePath)
public void Install(string caCertFilePath, ILogger logger)
{ {
logger.LogWarning($"请手动安装CA证书然后设置信任CA证书{caCertFilePath}"); this.logger.LogWarning($"请手动安装CA证书然后设置信任CA证书{caCertFilePath}");
} }
} }
} }

View File

@ -6,6 +6,13 @@ namespace FastGithub.HttpServer
{ {
sealed class CaCertInstallerOfWindows : ICaCertInstaller sealed class CaCertInstallerOfWindows : ICaCertInstaller
{ {
private readonly Logger<CaCertInstallerOfWindows> logger;
public CaCertInstallerOfWindows(Logger<CaCertInstallerOfWindows> logger)
{
this.logger = logger;
}
/// <summary> /// <summary>
/// 是否支持 /// 是否支持
/// </summary> /// </summary>
@ -19,8 +26,7 @@ namespace FastGithub.HttpServer
/// 安装ca证书 /// 安装ca证书
/// </summary> /// </summary>
/// <param name="caCertFilePath">证书文件路径</param> /// <param name="caCertFilePath">证书文件路径</param>
/// <param name="logger"></param> public void Install(string caCertFilePath)
public void Install(string caCertFilePath, ILogger logger)
{ {
try try
{ {
@ -44,7 +50,7 @@ namespace FastGithub.HttpServer
} }
catch (Exception) catch (Exception)
{ {
logger.LogWarning($"请手动安装CA证书{caCertFilePath}到“将所有的证书都放入下列存储”\\“受信任的根证书颁发机构”"); this.logger.LogWarning($"请手动安装CA证书{caCertFilePath}到“将所有的证书都放入下列存储”\\“受信任的根证书颁发机构”");
} }
} }
} }

View File

@ -76,7 +76,7 @@ namespace FastGithub.HttpServer
var installer = this.certInstallers.FirstOrDefault(item => item.IsSupported()); var installer = this.certInstallers.FirstOrDefault(item => item.IsSupported());
if (installer != null) if (installer != null)
{ {
installer.Install(this.CaCerFilePath, this.logger); installer.Install(this.CaCerFilePath);
} }
else else
{ {

View File

@ -1,6 +1,4 @@
using Microsoft.Extensions.Logging; namespace FastGithub.HttpServer
namespace FastGithub.HttpServer
{ {
/// <summary> /// <summary>
/// CA证书安装器 /// CA证书安装器
@ -17,7 +15,6 @@ namespace FastGithub.HttpServer
/// 安装ca证书 /// 安装ca证书
/// </summary> /// </summary>
/// <param name="caCertFilePath">证书文件路径</param> /// <param name="caCertFilePath">证书文件路径</param>
/// <param name="logger"></param> void Install(string caCertFilePath);
void Install(string caCertFilePath,ILogger logger);
} }
} }

View File

@ -21,9 +21,7 @@ namespace FastGithub
.AddSingleton<ICaCertInstaller, CaCertInstallerOfMacOS>() .AddSingleton<ICaCertInstaller, CaCertInstallerOfMacOS>()
.AddSingleton<ICaCertInstaller, CaCertInstallerOfWindows>() .AddSingleton<ICaCertInstaller, CaCertInstallerOfWindows>()
.AddSingleton<ICaCertInstaller, CaCertInstallerOfLinuxRedHat>() .AddSingleton<ICaCertInstaller, CaCertInstallerOfLinuxRedHat>()
.AddSingleton<ICaCertInstaller, CaCertInstallerOfLinuxCentOS>()
.AddSingleton<ICaCertInstaller, CaCertInstallerOfLinuxDebian>() .AddSingleton<ICaCertInstaller, CaCertInstallerOfLinuxDebian>()
.AddSingleton<ICaCertInstaller, CaCertInstallerOfLinuxUbuntu>()
.AddSingleton<HttpProxyMiddleware>() .AddSingleton<HttpProxyMiddleware>()
.AddSingleton<RequestLoggingMiddleware>() .AddSingleton<RequestLoggingMiddleware>()
.AddSingleton<HttpReverseProxyMiddleware>(); .AddSingleton<HttpReverseProxyMiddleware>();