|
@@ -1,4 +1,6 @@
|
|
using Microsoft.Extensions.Hosting;
|
|
using Microsoft.Extensions.Hosting;
|
|
|
|
+using Microsoft.Extensions.Logging;
|
|
|
|
+using System;
|
|
using System.Collections.Generic;
|
|
using System.Collections.Generic;
|
|
using System.Runtime.Versioning;
|
|
using System.Runtime.Versioning;
|
|
using System.Threading;
|
|
using System.Threading;
|
|
@@ -14,18 +16,26 @@ namespace FastGithub.PacketIntercept
|
|
{
|
|
{
|
|
private readonly IDnsInterceptor dnsInterceptor;
|
|
private readonly IDnsInterceptor dnsInterceptor;
|
|
private readonly IEnumerable<IDnsConflictSolver> conflictSolvers;
|
|
private readonly IEnumerable<IDnsConflictSolver> conflictSolvers;
|
|
|
|
+ private readonly ILogger<DnsInterceptHostedService> logger;
|
|
|
|
+ private readonly IHost host;
|
|
|
|
|
|
/// <summary>
|
|
/// <summary>
|
|
/// dns拦截后台服务
|
|
/// dns拦截后台服务
|
|
- /// </summary>
|
|
|
|
|
|
+ /// </summary>
|
|
/// <param name="dnsInterceptor"></param>
|
|
/// <param name="dnsInterceptor"></param>
|
|
/// <param name="conflictSolvers"></param>
|
|
/// <param name="conflictSolvers"></param>
|
|
|
|
+ /// <param name="logger"></param>
|
|
|
|
+ /// <param name="host"></param>
|
|
public DnsInterceptHostedService(
|
|
public DnsInterceptHostedService(
|
|
IDnsInterceptor dnsInterceptor,
|
|
IDnsInterceptor dnsInterceptor,
|
|
- IEnumerable<IDnsConflictSolver> conflictSolvers)
|
|
|
|
|
|
+ IEnumerable<IDnsConflictSolver> conflictSolvers,
|
|
|
|
+ ILogger<DnsInterceptHostedService> logger,
|
|
|
|
+ IHost host)
|
|
{
|
|
{
|
|
this.dnsInterceptor = dnsInterceptor;
|
|
this.dnsInterceptor = dnsInterceptor;
|
|
this.conflictSolvers = conflictSolvers;
|
|
this.conflictSolvers = conflictSolvers;
|
|
|
|
+ this.logger = logger;
|
|
|
|
+ this.host = host;
|
|
}
|
|
}
|
|
|
|
|
|
/// <summary>
|
|
/// <summary>
|
|
@@ -61,9 +71,18 @@ namespace FastGithub.PacketIntercept
|
|
/// </summary>
|
|
/// </summary>
|
|
/// <param name="stoppingToken"></param>
|
|
/// <param name="stoppingToken"></param>
|
|
/// <returns></returns>
|
|
/// <returns></returns>
|
|
- protected override Task ExecuteAsync(CancellationToken stoppingToken)
|
|
|
|
|
|
+ protected override async Task ExecuteAsync(CancellationToken stoppingToken)
|
|
{
|
|
{
|
|
- return this.dnsInterceptor.InterceptAsync(stoppingToken);
|
|
|
|
|
|
+ try
|
|
|
|
+ {
|
|
|
|
+ await this.dnsInterceptor.InterceptAsync(stoppingToken);
|
|
|
|
+ }
|
|
|
|
+ catch (Exception ex)
|
|
|
|
+ {
|
|
|
|
+ stoppingToken.ThrowIfCancellationRequested();
|
|
|
|
+ this.logger.LogError(ex, "dns拦截器异常");
|
|
|
|
+ await this.host.StopAsync(stoppingToken);
|
|
|
|
+ }
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|