using FastGithub;
using Microsoft.Extensions.Logging;
using System;
using System.Diagnostics;
using System.IO;
using System.Linq;
using System.Runtime.InteropServices;
namespace FastGithub.HttpServer.Certs.CaCertInstallers
{
abstract class CaCertInstallerOfLinux : ICaCertInstaller
{
private readonly ILogger logger;
///
/// 更新工具文件名
///
protected abstract string CaCertUpdatePath { get; }
///
/// 证书根目录
///
protected abstract string CaCertStorePath { get; }
[DllImport("libc", SetLastError = true)]
private static extern uint geteuid();
public CaCertInstallerOfLinux(ILogger logger)
{
this.logger = logger;
}
///
/// 是否支持
///
///
public bool IsSupported()
{
return OperatingSystem.IsLinux() && File.Exists(CaCertUpdatePath);
}
///
/// 安装ca证书
///
/// 证书文件路径
public void Install(string caCertFilePath)
{
var destCertFilePath = Path.Combine(CaCertStorePath, Path.GetFileName(caCertFilePath));
if (File.Exists(destCertFilePath) && File.ReadAllBytes(caCertFilePath).SequenceEqual(File.ReadAllBytes(destCertFilePath)))
{
return;
}
if (geteuid() != 0)
{
logger.LogWarning($"无法自动安装CA证书{caCertFilePath}:没有root权限");
return;
}
try
{
Directory.CreateDirectory(CaCertStorePath);
foreach (var item in Directory.GetFiles(CaCertStorePath, "fastgithub.*"))
{
File.Delete(item);
}
File.Copy(caCertFilePath, destCertFilePath, overwrite: true);
Process.Start(CaCertUpdatePath).WaitForExit();
logger.LogInformation($"已自动向系统安装CA证书{caCertFilePath}");
}
catch (Exception ex)
{
File.Delete(destCertFilePath);
logger.LogWarning(ex.Message, "自动安装CA证书异常");
}
}
}
}