From ff998f9603b1310c37667ec15e82873ba27950f9 Mon Sep 17 00:00:00 2001 From: "mikep@034E8FF1ED4D1F6" Date: Sat, 11 Oct 2025 15:39:44 -0700 Subject: [PATCH] Remove MonA --- Helpers/HelperGatusToMona.cs | 99 +++--------- Infineon/Monitoring/MonA/IMonIn.cs | 144 ----------------- Infineon/Monitoring/MonA/MonIn.cs | 250 ----------------------------- Infineon/Monitoring/MonA/State.cs | 10 -- Models/GatusConfiguration.cs | 4 +- Models/MonAConfiguration.cs | 2 +- Worker.cs | 8 +- 7 files changed, 28 insertions(+), 489 deletions(-) delete mode 100644 Infineon/Monitoring/MonA/IMonIn.cs delete mode 100644 Infineon/Monitoring/MonA/MonIn.cs delete mode 100644 Infineon/Monitoring/MonA/State.cs diff --git a/Helpers/HelperGatusToMona.cs b/Helpers/HelperGatusToMona.cs index 39ba398..c51a2a1 100644 --- a/Helpers/HelperGatusToMona.cs +++ b/Helpers/HelperGatusToMona.cs @@ -1,42 +1,17 @@ using System.Collections.ObjectModel; using System.Net.Http.Headers; -using Gatus.To.MonA.Infineon.Monitoring.MonA; using Gatus.To.MonA.Models; namespace Gatus.To.MonA.Helpers; internal static partial class HelperGatusToMona { - private static IMonIn? _MonIn; private static HttpClient? _HttpClient; private static string GetFile(AppSettings appSettings) => Path.Combine(appSettings.GatusToMonaConfiguration.Directory, appSettings.GatusConfiguration.FileName); - internal static void Heartbeat(AppSettings appSettings, IHttpClientFactory httpClientFactory, ILogger logger, State state, CancellationToken cancellationToken) { - _MonIn ??= MonIn.GetInstance(httpClientFactory); - CreateEmptyFile(appSettings); - Task httpResponseMessage = _MonIn.SendStatus(appSettings.MonAConfiguration.Site, - appSettings.MonAConfiguration.Resource, - appSettings.MonAConfiguration.StateName, - state); - httpResponseMessage.Wait(cancellationToken); - logger.LogInformation("Line {line}: {OriginalString} => {Resource} : {StateName} ; {state}", - 26, - httpResponseMessage.Result.RequestMessage.RequestUri.OriginalString, - appSettings.MonAConfiguration.Resource, - appSettings.MonAConfiguration.StateName, - state); - if (httpResponseMessage.Result.StatusCode != System.Net.HttpStatusCode.OK) - throw new Exception(httpResponseMessage.Result.StatusCode.ToString()); - Task body = httpResponseMessage.Result.Content.ReadAsStringAsync(cancellationToken); - body.Wait(cancellationToken); - logger.LogInformation("Line {line}: {Result}", - 36, - body.Result); - } - private static void CreateEmptyFile(AppSettings appSettings) { if (!Directory.Exists(appSettings.GatusToMonaConfiguration.Directory)) _ = Directory.CreateDirectory(appSettings.GatusToMonaConfiguration.Directory); @@ -45,12 +20,9 @@ internal static partial class HelperGatusToMona { } internal static bool UpdateCount(AppSettings appSettings, IHttpClientFactory httpClientFactory, ILogger logger, CancellationToken cancellationToken) { - _MonIn ??= MonIn.GetInstance(httpClientFactory); _HttpClient ??= httpClientFactory.CreateClient(); - Heartbeat(appSettings, httpClientFactory, logger, State.Up, cancellationToken); ReadOnlyCollection successMatches = GetSuccessMatches(appSettings, logger, cancellationToken); - double value = GetValue(appSettings, successMatches); - SendPerformanceMessage(appSettings, logger, value, cancellationToken); + decimal value = GetValue(appSettings, successMatches); SendPerformanceMessage(appSettings, logger, _HttpClient, value, cancellationToken); return true; } @@ -99,66 +71,41 @@ internal static partial class HelperGatusToMona { return results.AsReadOnly(); } - private static double GetValue(AppSettings appSettings, ReadOnlyCollection successMatches) { - double result; - double v = successMatches.Count / appSettings.MonAConfiguration.Expected; + private static decimal GetValue(AppSettings appSettings, ReadOnlyCollection successMatches) { + decimal result; + decimal v = successMatches.Count / appSettings.MonAConfiguration.Expected; result = Math.Round(v, 3) * 100; return result; } - private static void SendPerformanceMessage(AppSettings appSettings, ILogger logger, double value, CancellationToken cancellationToken) { - string performanceName = string.Concat(appSettings.MonAConfiguration.Resource, appSettings.MonAConfiguration.Suffix); - Task httpResponseMessage = _MonIn.SendPerformanceMessage(appSettings.MonAConfiguration.Site, - appSettings.MonAConfiguration.Resource, - performanceName, - value, - description: string.Empty); - httpResponseMessage.Wait(cancellationToken); - logger.LogInformation("Line {line}: {OriginalString} => {Resource} : {performanceName} ; {value}", - 118, - httpResponseMessage.Result.RequestMessage.RequestUri.OriginalString, - appSettings.MonAConfiguration.Resource, - performanceName, - value); - if (httpResponseMessage.Result.StatusCode != System.Net.HttpStatusCode.OK) - throw new Exception(httpResponseMessage.Result.StatusCode.ToString()); - Task body = httpResponseMessage.Result.Content.ReadAsStringAsync(cancellationToken); - body.Wait(cancellationToken); - logger.LogInformation("Line {line}: {Result}", - 128, - body.Result); - } - - private static void SendPerformanceMessage(AppSettings appSettings, ILogger logger, HttpClient httpClient, double value, CancellationToken cancellationToken) { - Task httpResponseMessage; + private static void SendPerformanceMessage(AppSettings appSettings, ILogger logger, HttpClient httpClient, decimal value, CancellationToken cancellationToken) { string success = value == 100 ? "true" : "false"; string error = value == 100 ? string.Empty : $"value: {value}%;"; - httpClient.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Bearer", appSettings.GatusConfiguration.Token); - httpResponseMessage = httpClient.PostAsync($"{appSettings.GatusConfiguration.BaseUniformResourceLocator}/api/v1/endpoints/{appSettings.GatusConfiguration.Key}/external?success={success}&error={error}", null, cancellationToken); + // httpClient.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Bearer", appSettings.GatusConfiguration.Token); + // httpResponseMessage = httpClient.PostAsync($"{appSettings.GatusConfiguration.BaseUniformResourceLocator}/api/v1/endpoints/{appSettings.GatusConfiguration.Key}/external?success={success}&error={error}", null, cancellationToken); + // httpResponseMessage.Wait(cancellationToken); + // logger.LogInformation("Line {line}: {OriginalString} => {Resource} : {Key} ; {value}", + // 140, + // httpResponseMessage.Result.RequestMessage.RequestUri.OriginalString, + // appSettings.MonAConfiguration.Resource, + // appSettings.GatusConfiguration.Key, + // value); + // if (httpResponseMessage.Result.StatusCode != System.Net.HttpStatusCode.OK) + // throw new Exception(httpResponseMessage.Result.StatusCode.ToString()); + // if (!string.IsNullOrEmpty(appSettings.GatusToGatusConfiguration.BaseUniformResourceLocator) + // && !string.IsNullOrEmpty(appSettings.GatusToGatusConfiguration.Key) + // && !string.IsNullOrEmpty(appSettings.GatusToGatusConfiguration.Token)) { } + httpClient.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Bearer", appSettings.GatusToGatusConfiguration.Token); + Task httpResponseMessage = httpClient.PostAsync($"{appSettings.GatusToGatusConfiguration.BaseUniformResourceLocator}/api/v1/endpoints/{appSettings.GatusToGatusConfiguration.Key}/external?success={success}&error={error}", null, cancellationToken); httpResponseMessage.Wait(cancellationToken); logger.LogInformation("Line {line}: {OriginalString} => {Resource} : {Key} ; {value}", - 140, + 154, httpResponseMessage.Result.RequestMessage.RequestUri.OriginalString, appSettings.MonAConfiguration.Resource, - appSettings.GatusConfiguration.Key, + appSettings.GatusToGatusConfiguration.Key, value); if (httpResponseMessage.Result.StatusCode != System.Net.HttpStatusCode.OK) throw new Exception(httpResponseMessage.Result.StatusCode.ToString()); - if (!string.IsNullOrEmpty(appSettings.GatusToGatusConfiguration.BaseUniformResourceLocator) - && !string.IsNullOrEmpty(appSettings.GatusToGatusConfiguration.Key) - && !string.IsNullOrEmpty(appSettings.GatusToGatusConfiguration.Token)) { - httpClient.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Bearer", appSettings.GatusToGatusConfiguration.Token); - httpResponseMessage = httpClient.PostAsync($"{appSettings.GatusToGatusConfiguration.BaseUniformResourceLocator}/api/v1/endpoints/{appSettings.GatusToGatusConfiguration.Key}/external?success={success}&error={error}", null, cancellationToken); - httpResponseMessage.Wait(cancellationToken); - logger.LogInformation("Line {line}: {OriginalString} => {Resource} : {Key} ; {value}", - 154, - httpResponseMessage.Result.RequestMessage.RequestUri.OriginalString, - appSettings.MonAConfiguration.Resource, - appSettings.GatusConfiguration.Key, - value); - if (httpResponseMessage.Result.StatusCode != System.Net.HttpStatusCode.OK) - throw new Exception(httpResponseMessage.Result.StatusCode.ToString()); - } } } \ No newline at end of file diff --git a/Infineon/Monitoring/MonA/IMonIn.cs b/Infineon/Monitoring/MonA/IMonIn.cs deleted file mode 100644 index db2255b..0000000 --- a/Infineon/Monitoring/MonA/IMonIn.cs +++ /dev/null @@ -1,144 +0,0 @@ -namespace Gatus.To.MonA.Infineon.Monitoring.MonA; - -public interface IMonIn { - Task SendStatus(string site, string resource, string stateName, State state); - - Task SendStatus(string site, - DateTime timeStamp, - string resource, - string stateName, - State state); - - Task SendStatus(string site, - string resource, - string stateName, - State state, - string description); - - Task SendStatus(string site, - DateTime timeStamp, - string resource, - string stateName, - State state, - string description); - - Task SendStatus(string site, - string resource, - string subResource, - string stateName, - State state); - - Task SendStatus(string site, - DateTime timeStamp, - string resource, - string subResource, - string stateName, - State state); - - Task SendStatus(string site, - string resource, - string subResource, - string stateName, - State state, - string description); - - Task SendStatus(string site, - DateTime? timeStamp, - string resource, - string subResource, - string stateName, - State state, - string description); - - Task SendPerformanceMessage(string site, - string resource, - string performanceName, - double value); - - Task SendPerformanceMessage(string site, - DateTime? timeStamp, - string resource, - string performanceName, - double value); - - Task SendPerformanceMessage(string site, - string resource, - string performanceName, - double value, - string description); - - Task SendPerformanceMessage(string site, - DateTime? timeStamp, - string resource, - string performanceName, - double value, - string description); - - Task SendPerformanceMessage(string site, - DateTime? timeStamp, - string resource, - string performanceName, - double value, - int? interval); - - Task SendPerformanceMessage(string site, - string resource, - DateTime? timeStamp, - string performanceName, - double value, - string unit); - - Task SendPerformanceMessage(string site, - DateTime? timeStamp, - string resource, - string performanceName, - double value, - string unit, - int? interval); - - Task SendPerformanceMessage(string site, - string resource, - string subResource, - string performanceName, - double value); - - Task SendPerformanceMessage(string site, - DateTime? timeStamp, - string resource, - string subResource, - string performanceName, - double value); - - Task SendPerformanceMessage(string site, - string resource, - string subResource, - string performanceName, - double value, - string description); - - Task SendPerformanceMessage(string site, - DateTime? timeStamp, - string resource, - string subResource, - string performanceName, - double value, - int? interval); - - Task SendPerformanceMessage(string site, - DateTime? timeStamp, - string resource, - string subResource, - string performanceName, - double value, - string unit); - - Task SendPerformanceMessage(string site, - DateTime? timeStamp, - string resource, - string subResource, - string performanceName, - double value, - string description, - string unit, - int? interval); -} \ No newline at end of file diff --git a/Infineon/Monitoring/MonA/MonIn.cs b/Infineon/Monitoring/MonA/MonIn.cs deleted file mode 100644 index 7ff2faa..0000000 --- a/Infineon/Monitoring/MonA/MonIn.cs +++ /dev/null @@ -1,250 +0,0 @@ -using System.Globalization; -using System.Text; - -namespace Gatus.To.MonA.Infineon.Monitoring.MonA; - -public class MonIn : IMonIn { - private readonly string _MonInUrl; - private readonly HttpClient _HttpClient; - private static CultureInfo? _CultureInfo; - private static readonly Dictionary _Instances = []; - public const string MonInUrl = "http://moninhttp.{0}.infineon.com/input/text"; - private static readonly DateTime _Utc1970DateTime = new(1970, 1, 1, 0, 0, 0, DateTimeKind.Utc); - - public Task SendStatus(string site, string resource, string stateName, State state) => - SendStatus(site, new DateTime?(), resource, string.Empty, stateName, state, string.Empty); - - public Task SendStatus(string site, - DateTime timeStamp, - string resource, - string stateName, - State state) => - SendStatus(site, new DateTime?(timeStamp), resource, string.Empty, stateName, state, string.Empty); - - public Task SendStatus(string site, - string resource, - string stateName, - State state, - string description) => - SendStatus(site, new DateTime?(), resource, string.Empty, stateName, state, description); - - public Task SendStatus(string site, - DateTime timeStamp, - string resource, - string stateName, - State state, - string description) => - SendStatus(site, new DateTime?(timeStamp), resource, string.Empty, stateName, state, description); - - public Task SendStatus(string site, - string resource, - string subResource, - string stateName, - State state) => - SendStatus(site, new DateTime?(), resource, subResource, stateName, state, string.Empty); - - public Task SendStatus(string site, - DateTime timeStamp, - string resource, - string subResource, - string stateName, - State state) => - SendStatus(site, new DateTime?(timeStamp), resource, subResource, stateName, state, string.Empty); - - public Task SendStatus(string site, - string resource, - string subResource, - string stateName, - State state, - string description) => - SendStatus(site, new DateTime?(), resource, subResource, stateName, state, description); - - public Task SendStatus( - string site, - DateTime? timeStamp, - string resource, - string subResource, - string stateName, - State state, - string description) { - string statusMessage = CreateStatusMessage(site, timeStamp, resource, subResource, stateName, state.ToString(), description); - StringContent stringContent = new(statusMessage, Encoding.UTF8, "application/text"); - lock (_HttpClient) - return _HttpClient.PostAsync(string.Format(_MonInUrl, site), stringContent); - } - - public Task SendPerformanceMessage(string site, - string resource, - string performanceName, - double value) => - SendPerformanceMessage(site, new DateTime?(), resource, string.Empty, performanceName, value, string.Empty, string.Empty, new int?()); - - public Task SendPerformanceMessage(string site, - DateTime? timeStamp, - string resource, - string performanceName, - double value) => - SendPerformanceMessage(site, timeStamp, resource, string.Empty, performanceName, value, string.Empty, string.Empty, new int?()); - - public Task SendPerformanceMessage(string site, - string resource, - string performanceName, - double value, - string description) => - SendPerformanceMessage(site, new DateTime?(), resource, string.Empty, performanceName, value, description, string.Empty, new int?()); - - public Task SendPerformanceMessage(string site, - DateTime? timeStamp, - string resource, - string performanceName, - double value, - string description) => - SendPerformanceMessage(site, timeStamp, resource, string.Empty, performanceName, value, description, string.Empty, new int?()); - - public Task SendPerformanceMessage(string site, - DateTime? timeStamp, - string resource, - string performanceName, - double value, - int? interval) => - SendPerformanceMessage(site, timeStamp, resource, string.Empty, performanceName, value, string.Empty, string.Empty, interval); - - public Task SendPerformanceMessage(string site, - string resource, - DateTime? timeStamp, - string performanceName, - double value, - string unit) => - SendPerformanceMessage(site, timeStamp, resource, string.Empty, performanceName, value, string.Empty, unit, new int?()); - - public Task SendPerformanceMessage(string site, - DateTime? timeStamp, - string resource, - string performanceName, - double value, - string unit, - int? interval) => - SendPerformanceMessage(site, timeStamp, resource, string.Empty, performanceName, value, string.Empty, unit, interval); - - public Task SendPerformanceMessage(string site, - string resource, - string subResource, - string performanceName, - double value) => - SendPerformanceMessage(site, new DateTime?(), resource, subResource, performanceName, value, string.Empty, string.Empty, new int?()); - - public Task SendPerformanceMessage(string site, - DateTime? timeStamp, - string resource, - string subResource, - string performanceName, - double value) => - SendPerformanceMessage(site, timeStamp, resource, subResource, performanceName, value, string.Empty, string.Empty, new int?()); - - public Task SendPerformanceMessage(string site, - string resource, - string subResource, - string performanceName, - double value, - string description) => - SendPerformanceMessage(site, new DateTime?(), resource, subResource, performanceName, value, description, string.Empty, new int?()); - - public Task SendPerformanceMessage(string site, - DateTime? timeStamp, - string resource, - string subResource, - string performanceName, - double value, - int? interval) => - SendPerformanceMessage(site, timeStamp, resource, subResource, performanceName, value, string.Empty, string.Empty, interval); - - public Task SendPerformanceMessage(string site, - DateTime? timeStamp, - string resource, - string subResource, - string performanceName, - double value, - string unit) => - SendPerformanceMessage(site, timeStamp, resource, subResource, performanceName, value, string.Empty, unit, new int?()); - - public Task SendPerformanceMessage(string site, - DateTime? timeStamp, - string resource, - string subResource, - string performanceName, - double value, - string description, - string unit, - int? interval) { - string performanceMessage = CreatePerformanceMessage(site, timeStamp, resource, subResource, performanceName, value, description, unit, interval); - StringContent stringContent = new(performanceMessage, Encoding.UTF8, "application/text"); - lock (_HttpClient) - return _HttpClient.PostAsync(string.Format(_MonInUrl, site), stringContent); - } - - private static string CreateStatusMessage(string site, - DateTime? timeStamp, - string resource, - string subResource, - string stateName, - string state, - string description) { - StringBuilder stringBuilder = new(); - if (string.IsNullOrEmpty(subResource)) - _ = stringBuilder.AppendFormat(_CultureInfo, "> {0} {1} \"{2}\" \"{3}\" {4} \n{5}", site.Trim(), timeStamp.HasValue ? GetDateTimeNowAsPosix(timeStamp.Value) : (object)"now", resource.Trim(), stateName.Trim(), state.Trim(), description.Trim()); - else - _ = stringBuilder.AppendFormat(_CultureInfo, "> {0} {1} \"{2}\" \"{3}\" \"{4}\" {5} \n{6}", site.Trim(), timeStamp.HasValue ? GetDateTimeNowAsPosix(timeStamp.Value) : (object)"now", resource.Trim(), subResource.Trim(), stateName.Trim(), state.Trim(), description.Trim()); - return stringBuilder.ToString(); - } - - private static string CreatePerformanceMessage(string site, - DateTime? timeStamp, - string resource, - string subResource, - string performanceName, - double value, - string description, - string unit, - int? interval) { - StringBuilder stringBuilder = new(); - if (string.IsNullOrEmpty(subResource)) { - if (unit.Equals(string.Empty) && !interval.HasValue) - _ = stringBuilder.AppendFormat(_CultureInfo, "> {0} {1} \"{2}\" \"{3}\" {4} \n{5}", site.Trim(), timeStamp.HasValue ? GetDateTimeNowAsPosix(timeStamp.Value) : (object)"now", resource.Trim(), performanceName.Trim(), value, description.Trim()); - else - _ = stringBuilder.AppendFormat(_CultureInfo, "> {0} {1} \"{2}\" \"{3}\" {4} {5} {{interval={6}, unit={7}}}\n", site.Trim(), timeStamp.HasValue ? GetDateTimeNowAsPosix(timeStamp.Value) : (object)"now", resource.Trim(), performanceName.Trim(), value, description.Trim(), interval.HasValue ? interval.Value.ToString() : (object)string.Empty, unit.Trim()); - } else if (unit.Equals(string.Empty) && !interval.HasValue) - _ = stringBuilder.AppendFormat(_CultureInfo, "> {0} {1} \"{2}\" \"{3}\" \"{4}\" {5} \n{6}", site.Trim(), timeStamp.HasValue ? GetDateTimeNowAsPosix(timeStamp.Value) : (object)"now", resource.Trim(), subResource.Trim(), performanceName.Trim(), value, description.Trim()); - else - _ = stringBuilder.AppendFormat(_CultureInfo, "> {0} {1} \"{2}\" \"{3}\" \"{4}\" {5} {6} {{interval={7}, unit={8}}}\n", site.Trim(), timeStamp.HasValue ? GetDateTimeNowAsPosix(timeStamp.Value) : (object)"now", resource.Trim(), subResource.Trim(), performanceName.Trim(), value, description.Trim(), interval.HasValue ? interval.Value.ToString() : (object)string.Empty, unit.Trim()); - return stringBuilder.ToString(); - } - - public static MonIn GetInstance(IHttpClientFactory httpClientFactory, string url = MonInUrl) { - MonIn instance; - if (_Instances.ContainsKey(url)) { - instance = _Instances[url]; - } else { - lock (_Instances) { - if (!_Instances.ContainsKey(url)) { - instance = new MonIn(httpClientFactory, url); - _Instances.Add(url, instance); - } else - instance = _Instances[url]; - } - } - return instance; - } - - private MonIn(IHttpClientFactory httpClientFactory, string url) { - _MonInUrl = url; - _CultureInfo = new CultureInfo("en-US"); - _HttpClient = httpClientFactory.CreateClient(); - } - - private static string GetDateTimeNowAsPosix(DateTime timeStamp) { - if (timeStamp > DateTime.Now) - timeStamp = DateTime.Now; - return ((int)timeStamp.ToUniversalTime().Subtract(_Utc1970DateTime).TotalSeconds).ToString(CultureInfo.InvariantCulture); - } - -} \ No newline at end of file diff --git a/Infineon/Monitoring/MonA/State.cs b/Infineon/Monitoring/MonA/State.cs deleted file mode 100644 index b844053..0000000 --- a/Infineon/Monitoring/MonA/State.cs +++ /dev/null @@ -1,10 +0,0 @@ -namespace Gatus.To.MonA.Infineon.Monitoring.MonA; - -public enum State { - Up, - Ok, - Warning, - Critical, - Down, - Unknown, -} \ No newline at end of file diff --git a/Models/GatusConfiguration.cs b/Models/GatusConfiguration.cs index 15cb7e8..ae044cd 100644 --- a/Models/GatusConfiguration.cs +++ b/Models/GatusConfiguration.cs @@ -5,9 +5,7 @@ namespace Gatus.To.MonA.Models; public record GatusConfiguration(string BaseUniformResourceLocator, string FileName, - string Key, - string Metric, - string Token) { + string Metric) { public override string ToString() { string result = JsonSerializer.Serialize(this, GatusConfigurationSourceGenerationContext.Default.GatusConfiguration); diff --git a/Models/MonAConfiguration.cs b/Models/MonAConfiguration.cs index f633400..5d5b9ea 100644 --- a/Models/MonAConfiguration.cs +++ b/Models/MonAConfiguration.cs @@ -3,7 +3,7 @@ using System.Text.Json.Serialization; namespace Gatus.To.MonA.Models; -public record MonAConfiguration(int Expected, +public record MonAConfiguration(decimal Expected, int Minutes, string Resource, string Site, diff --git a/Worker.cs b/Worker.cs index 67ffd3d..75fd6b0 100644 --- a/Worker.cs +++ b/Worker.cs @@ -22,15 +22,13 @@ public partial class Worker : BackgroundService { _IsWindowsService = collection.Contains(nameof(WindowsServiceLifetime)); } - public override Task StopAsync(CancellationToken cancellationToken) { - if (_AppSettings.GatusToMonaConfiguration.Helper == nameof(Helpers.HelperGatusToMona)) - Helpers.HelperGatusToMona.Heartbeat(_AppSettings, _HttpClientFactory, _Logger, Infineon.Monitoring.MonA.State.Down, cancellationToken); - return base.StopAsync(cancellationToken); - } + public override Task StopAsync(CancellationToken cancellationToken) => + base.StopAsync(cancellationToken); private async Task Body(CancellationToken cancellationToken) { if (!_IsWindowsService) { _Logger.LogInformation("Set break point and skip to run {_AppSettings.GatusToMonaConfiguration.Helper}!", _AppSettings.GatusToMonaConfiguration.Helper); + BodyInner(cancellationToken); throw new EvaluateException($"Set break point and skip to run {_AppSettings.GatusToMonaConfiguration.Helper}!"); } if (!_IsWindowsService) {