using System; using System.Threading.Tasks; using Microsoft.AspNetCore.Builder; using Microsoft.Extensions.Logging; using Wabbajack.BuildServer; namespace Wabbajack.Server.Services { public interface IStartable { public void Start(); } public abstract class AbstractService : IStartable { protected AppSettings _settings; private TimeSpan _delay; protected ILogger _logger; protected QuickSync _quickSync; private bool _isSetup; public AbstractService(ILogger logger, AppSettings settings, QuickSync quickSync, TimeSpan delay) { _settings = settings; _delay = delay; _logger = logger; _quickSync = quickSync; _isSetup = false; } public virtual async Task Setup() { } public void Start() { if (_settings.RunBackEndJobs) { Task.Run(async () => { await Setup(); _isSetup = true; while (true) { await _quickSync.ResetToken(); try { _logger.LogInformation($"Running: {GetType().Name}"); await Execute(); } catch (Exception ex) { _logger.LogError(ex, "Running Service Loop"); } var token = await _quickSync.GetToken(); try { await Task.Delay(_delay, token); } catch (TaskCanceledException) { } } }); } } public abstract Task Execute(); } public static class AbstractServiceExtensions { public static void UseService(this IApplicationBuilder b) { var poll = (IStartable)b.ApplicationServices.GetService(typeof(T)); poll.Start(); } } }