2021-10-11 01:06:43 +01:00
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Text;
|
|
|
|
|
using System.Threading;
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
using Microsoft.Extensions.Configuration;
|
|
|
|
|
using Microsoft.Extensions.Hosting;
|
|
|
|
|
using Microsoft.Extensions.Logging;
|
2021-10-11 18:17:36 +01:00
|
|
|
|
using Microsoft.Extensions.Options;
|
2021-10-11 01:06:43 +01:00
|
|
|
|
|
|
|
|
|
namespace Selector.CLI
|
|
|
|
|
{
|
|
|
|
|
class WatcherService : IHostedService
|
|
|
|
|
{
|
|
|
|
|
private readonly ILogger<WatcherService> Logger;
|
2021-10-11 18:17:36 +01:00
|
|
|
|
private readonly RootOptions Config;
|
2021-10-12 20:23:25 +01:00
|
|
|
|
private readonly IRefreshTokenFactoryProvider TokenFactoryProvider;
|
2021-10-11 01:06:43 +01:00
|
|
|
|
|
2021-10-11 23:19:19 +01:00
|
|
|
|
private Dictionary<string, IWatcherCollection> Watchers { get; set; } = new();
|
|
|
|
|
|
2021-10-12 20:23:25 +01:00
|
|
|
|
public WatcherService(IRefreshTokenFactoryProvider tokenFactoryProvider, ILogger<WatcherService> logger, IOptions<RootOptions> config)
|
2021-10-11 01:06:43 +01:00
|
|
|
|
{
|
|
|
|
|
Logger = logger;
|
2021-10-11 18:17:36 +01:00
|
|
|
|
Config = config.Value;
|
2021-10-12 20:23:25 +01:00
|
|
|
|
TokenFactoryProvider = tokenFactoryProvider;
|
|
|
|
|
|
|
|
|
|
TokenFactoryProvider.Initialise(Config.ClientId, Config.ClientSecret);
|
2021-10-11 01:06:43 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public Task StartAsync(CancellationToken cancellationToken)
|
|
|
|
|
{
|
|
|
|
|
Logger.LogInformation("Starting up");
|
|
|
|
|
|
2021-10-11 23:19:19 +01:00
|
|
|
|
Config.WatcherOptions.Instances.ForEach(i => Logger.LogInformation($"Config: {i.Type}"));
|
|
|
|
|
|
2021-10-11 01:06:43 +01:00
|
|
|
|
return Task.CompletedTask;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public Task StopAsync(CancellationToken cancellationToken)
|
|
|
|
|
{
|
|
|
|
|
Logger.LogInformation("Shutting down");
|
2021-10-11 23:19:19 +01:00
|
|
|
|
|
|
|
|
|
foreach((var key, var watcher) in Watchers)
|
|
|
|
|
{
|
|
|
|
|
Logger.LogInformation($"Stopping watcher collection: {key}");
|
|
|
|
|
watcher.Stop();
|
|
|
|
|
}
|
|
|
|
|
|
2021-10-11 01:06:43 +01:00
|
|
|
|
return Task.CompletedTask;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|