Heartbeat before each performance message
Updated readme
This commit is contained in:
@ -12,7 +12,39 @@ internal static partial class HelperGatusToMona {
|
||||
private static string GetFile(AppSettings appSettings) =>
|
||||
Path.Combine(appSettings.GatusToMonaConfiguration.Directory, appSettings.GatusConfiguration.FileName);
|
||||
|
||||
internal static bool UpdateCount(AppSettings appSettings, ILogger<Worker> logger, CancellationToken cancellationToken) {
|
||||
internal static void Heartbeat(AppSettings appSettings, IHttpClientFactory httpClientFactory, ILogger<Worker> logger, State state, CancellationToken cancellationToken) {
|
||||
_MonIn ??= MonIn.GetInstance(httpClientFactory);
|
||||
CreateEmptyFile(appSettings);
|
||||
Task<HttpResponseMessage> httpResponseMessage = _MonIn.SendStatus(appSettings.MonAConfiguration.Site,
|
||||
appSettings.MonAConfiguration.Resource,
|
||||
appSettings.MonAConfiguration.StateName,
|
||||
state);
|
||||
httpResponseMessage.Wait(cancellationToken);
|
||||
logger.LogInformation("Line {line}: {OriginalString} => {Resource} : {StateName} ; {state}",
|
||||
99,
|
||||
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<string> body = httpResponseMessage.Result.Content.ReadAsStringAsync(cancellationToken);
|
||||
body.Wait(cancellationToken);
|
||||
logger.LogInformation("Line {line}: {Result}",
|
||||
10,
|
||||
body.Result);
|
||||
}
|
||||
|
||||
private static void CreateEmptyFile(AppSettings appSettings) {
|
||||
if (!Directory.Exists(appSettings.GatusToMonaConfiguration.Directory))
|
||||
_ = Directory.CreateDirectory(appSettings.GatusToMonaConfiguration.Directory);
|
||||
string file = GetFile(appSettings);
|
||||
File.WriteAllText(file, string.Empty);
|
||||
}
|
||||
|
||||
internal static bool UpdateCount(AppSettings appSettings, IHttpClientFactory httpClientFactory, ILogger<Worker> logger, CancellationToken cancellationToken) {
|
||||
_MonIn ??= MonIn.GetInstance(httpClientFactory);
|
||||
Heartbeat(appSettings, httpClientFactory, logger, State.Up, cancellationToken);
|
||||
ReadOnlyCollection<string> successMatches = GetSuccessMatches(appSettings, logger, cancellationToken);
|
||||
SendPerformanceMessage(appSettings, logger, successMatches, cancellationToken);
|
||||
return true;
|
||||
@ -35,10 +67,15 @@ internal static partial class HelperGatusToMona {
|
||||
continue;
|
||||
if (value[^1] is not '0' and not '1')
|
||||
continue;
|
||||
logger.LogDebug(value);
|
||||
logger.LogInformation("Line {line}: {value}",
|
||||
39,
|
||||
value);
|
||||
if (line.EndsWith('1'))
|
||||
results.Add(string.Concat('{', value));
|
||||
}
|
||||
logger.LogInformation("Line {line}: {results}",
|
||||
45,
|
||||
string.Join(Environment.NewLine, results));
|
||||
return results.AsReadOnly();
|
||||
}
|
||||
|
||||
@ -67,33 +104,19 @@ internal static partial class HelperGatusToMona {
|
||||
value,
|
||||
description: string.Empty);
|
||||
httpResponseMessage.Wait(cancellationToken);
|
||||
logger.LogInformation("Line {line}: {OriginalString} => {Resource} : {performanceName} ; {value}",
|
||||
76,
|
||||
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<string> body = httpResponseMessage.Result.Content.ReadAsStringAsync(cancellationToken);
|
||||
body.Wait(cancellationToken);
|
||||
logger.LogDebug(body.Result);
|
||||
}
|
||||
|
||||
internal static void Heartbeat(AppSettings appSettings, IHttpClientFactory httpClientFactory, ILogger<Worker> logger, State state, CancellationToken cancellationToken) {
|
||||
_MonIn ??= MonIn.GetInstance(httpClientFactory);
|
||||
CreateEmptyFile(appSettings);
|
||||
Task<HttpResponseMessage> httpResponseMessage = _MonIn.SendStatus(appSettings.MonAConfiguration.Site,
|
||||
appSettings.MonAConfiguration.Resource,
|
||||
appSettings.MonAConfiguration.StateName,
|
||||
state);
|
||||
httpResponseMessage.Wait(cancellationToken);
|
||||
if (httpResponseMessage.Result.StatusCode != System.Net.HttpStatusCode.OK)
|
||||
throw new Exception(httpResponseMessage.Result.StatusCode.ToString());
|
||||
Task<string> body = httpResponseMessage.Result.Content.ReadAsStringAsync(cancellationToken);
|
||||
body.Wait(cancellationToken);
|
||||
logger.LogDebug(body.Result);
|
||||
}
|
||||
|
||||
private static void CreateEmptyFile(AppSettings appSettings) {
|
||||
if (!Directory.Exists(appSettings.GatusToMonaConfiguration.Directory))
|
||||
_ = Directory.CreateDirectory(appSettings.GatusToMonaConfiguration.Directory);
|
||||
string file = GetFile(appSettings);
|
||||
File.WriteAllText(file, string.Empty);
|
||||
logger.LogInformation("Line {line}: {Result}",
|
||||
86,
|
||||
body.Result);
|
||||
}
|
||||
|
||||
}
|
Reference in New Issue
Block a user