mirror of
https://github.com/btcpayserver/btcpayserver.git
synced 2025-01-19 05:33:31 +01:00
87 lines
3.4 KiB
C#
87 lines
3.4 KiB
C#
using System;
|
|
using System.Threading;
|
|
using System.Threading.Tasks;
|
|
using BTCPayServer.Configuration;
|
|
using BTCPayServer.Logging;
|
|
using Microsoft.Extensions.Hosting;
|
|
using Microsoft.Extensions.Logging;
|
|
|
|
namespace BTCPayServer.HostedServices
|
|
{
|
|
public class CheckConfigurationHostedService : IHostedService
|
|
{
|
|
public Logs Logs { get; }
|
|
|
|
private readonly BTCPayServerOptions _options;
|
|
Task _testingConnection;
|
|
readonly CancellationTokenSource _cancellationTokenSource = new CancellationTokenSource();
|
|
|
|
public CheckConfigurationHostedService(BTCPayServerOptions options, Logs logs)
|
|
{
|
|
Logs = logs;
|
|
_options = options;
|
|
}
|
|
|
|
public bool CanUseSSH { get; private set; }
|
|
|
|
public Task StartAsync(CancellationToken cancellationToken)
|
|
{
|
|
_testingConnection = TestConnection();
|
|
return Task.CompletedTask;
|
|
}
|
|
|
|
async Task TestConnection()
|
|
{
|
|
TimeSpan nextWait = TimeSpan.FromSeconds(10);
|
|
retry:
|
|
var canUseSSH = false;
|
|
if (_options.SSHSettings != null)
|
|
{
|
|
Logs.Configuration.LogInformation($"SSH settings detected, testing connection to {_options.SSHSettings.Username}@{_options.SSHSettings.Server} on port {_options.SSHSettings.Port} ...");
|
|
try
|
|
{
|
|
using var connection = await _options.SSHSettings.ConnectAsync(_cancellationTokenSource.Token);
|
|
await connection.DisconnectAsync(_cancellationTokenSource.Token);
|
|
Logs.Configuration.LogInformation($"SSH connection succeeded");
|
|
canUseSSH = true;
|
|
}
|
|
catch (Renci.SshNet.Common.SshAuthenticationException ex)
|
|
{
|
|
Logs.Configuration.LogWarning($"SSH invalid credentials ({ex.Message})");
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
var message = ex.Message;
|
|
if (ex is AggregateException aggrEx && aggrEx.InnerException?.Message != null)
|
|
{
|
|
message = aggrEx.InnerException.Message;
|
|
}
|
|
Logs.Configuration.LogWarning($"SSH connection issue of type {ex.GetType().Name}: {message}");
|
|
}
|
|
if (!canUseSSH)
|
|
{
|
|
Logs.Configuration.LogWarning($"Retrying SSH connection in {(int)nextWait.TotalSeconds} seconds");
|
|
await Task.Delay(nextWait, _cancellationTokenSource.Token);
|
|
nextWait = TimeSpan.FromSeconds(nextWait.TotalSeconds * 2);
|
|
if (nextWait > TimeSpan.FromMinutes(10.0))
|
|
nextWait = TimeSpan.FromMinutes(10.0);
|
|
goto retry;
|
|
}
|
|
}
|
|
CanUseSSH = canUseSSH;
|
|
}
|
|
|
|
public async Task StopAsync(CancellationToken cancellationToken)
|
|
{
|
|
_cancellationTokenSource.Cancel();
|
|
try
|
|
{
|
|
// Renci SSH sometimes is deadlocking, so we just wait at most 5 seconds
|
|
await Task.WhenAny(_testingConnection, Task.Delay(5000, _cancellationTokenSource.Token));
|
|
}
|
|
catch { }
|
|
Logs.PayServer.LogInformation($"{this.GetType().Name} successfully exited...");
|
|
}
|
|
}
|
|
}
|