2023-09-13 11:25:08 +02:00
|
|
|
|
using Logging;
|
|
|
|
|
using System.Globalization;
|
2023-09-11 11:59:33 +02:00
|
|
|
|
|
2023-09-13 11:25:08 +02:00
|
|
|
|
namespace MetricsPlugin
|
|
|
|
|
{
|
|
|
|
|
public class MetricsDownloader
|
|
|
|
|
{
|
|
|
|
|
private readonly ILog log;
|
2023-09-11 11:59:33 +02:00
|
|
|
|
|
2023-09-13 11:25:08 +02:00
|
|
|
|
public MetricsDownloader(ILog log)
|
|
|
|
|
{
|
|
|
|
|
this.log = log;
|
|
|
|
|
}
|
2023-09-11 11:59:33 +02:00
|
|
|
|
|
2023-09-13 11:25:08 +02:00
|
|
|
|
public LogFile? DownloadAllMetrics(string targetName, IMetricsAccess access)
|
|
|
|
|
{
|
|
|
|
|
var metrics = access.GetAllMetrics();
|
|
|
|
|
if (metrics == null || metrics.Sets.Length == 0 || metrics.Sets.All(s => s.Values.Length == 0)) return null;
|
2023-09-11 11:59:33 +02:00
|
|
|
|
|
2023-09-13 11:25:08 +02:00
|
|
|
|
var headers = new[] { "timestamp" }.Concat(metrics.Sets.Select(s => s.Name)).ToArray();
|
|
|
|
|
var map = CreateValueMap(metrics);
|
2023-09-11 11:59:33 +02:00
|
|
|
|
|
2023-09-13 11:25:08 +02:00
|
|
|
|
return WriteToFile(targetName, headers, map);
|
|
|
|
|
}
|
2023-09-11 11:59:33 +02:00
|
|
|
|
|
2023-09-13 11:25:08 +02:00
|
|
|
|
private LogFile WriteToFile(string nodeName, string[] headers, Dictionary<DateTime, List<string>> map)
|
|
|
|
|
{
|
|
|
|
|
var file = log.CreateSubfile("csv");
|
|
|
|
|
log.Log($"Downloading metrics for {nodeName} to file {file.FullFilename}");
|
2023-09-11 11:59:33 +02:00
|
|
|
|
|
2023-09-13 11:25:08 +02:00
|
|
|
|
file.WriteRaw(string.Join(",", headers));
|
2023-09-11 11:59:33 +02:00
|
|
|
|
|
2023-09-13 11:25:08 +02:00
|
|
|
|
foreach (var pair in map)
|
|
|
|
|
{
|
|
|
|
|
file.WriteRaw(string.Join(",", new[] { FormatTimestamp(pair.Key) }.Concat(pair.Value)));
|
|
|
|
|
}
|
2023-09-11 11:59:33 +02:00
|
|
|
|
|
2023-09-13 11:25:08 +02:00
|
|
|
|
return file;
|
|
|
|
|
}
|
2023-09-11 11:59:33 +02:00
|
|
|
|
|
2023-09-13 11:25:08 +02:00
|
|
|
|
private Dictionary<DateTime, List<string>> CreateValueMap(Metrics metrics)
|
|
|
|
|
{
|
|
|
|
|
var map = CreateForAllTimestamps(metrics);
|
|
|
|
|
foreach (var metric in metrics.Sets)
|
|
|
|
|
{
|
|
|
|
|
AddToMap(map, metric);
|
|
|
|
|
}
|
|
|
|
|
return map;
|
2023-09-11 11:59:33 +02:00
|
|
|
|
|
2023-09-13 11:25:08 +02:00
|
|
|
|
}
|
2023-09-11 11:59:33 +02:00
|
|
|
|
|
2023-09-13 11:25:08 +02:00
|
|
|
|
private Dictionary<DateTime, List<string>> CreateForAllTimestamps(Metrics metrics)
|
|
|
|
|
{
|
|
|
|
|
var result = new Dictionary<DateTime, List<string>>();
|
|
|
|
|
var timestamps = metrics.Sets.SelectMany(s => s.Values).Select(v => v.Timestamp).Distinct().ToArray();
|
|
|
|
|
foreach (var timestamp in timestamps) result.Add(timestamp, new List<string>());
|
|
|
|
|
return result;
|
|
|
|
|
}
|
2023-09-11 11:59:33 +02:00
|
|
|
|
|
2023-09-13 11:25:08 +02:00
|
|
|
|
private void AddToMap(Dictionary<DateTime, List<string>> map, MetricsSet metric)
|
|
|
|
|
{
|
|
|
|
|
foreach (var key in map.Keys)
|
|
|
|
|
{
|
|
|
|
|
map[key].Add(GetValueAtTimestamp(key, metric));
|
|
|
|
|
}
|
|
|
|
|
}
|
2023-09-11 11:59:33 +02:00
|
|
|
|
|
2023-09-13 11:25:08 +02:00
|
|
|
|
private string GetValueAtTimestamp(DateTime key, MetricsSet metric)
|
|
|
|
|
{
|
|
|
|
|
var value = metric.Values.SingleOrDefault(v => v.Timestamp == key);
|
|
|
|
|
if (value == null) return "";
|
|
|
|
|
return value.Value.ToString(CultureInfo.InvariantCulture);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private string FormatTimestamp(DateTime key)
|
|
|
|
|
{
|
|
|
|
|
var origin = new DateTime(1970, 1, 1, 0, 0, 0, 0, DateTimeKind.Utc);
|
|
|
|
|
var diff = key - origin;
|
|
|
|
|
return Math.Floor(diff.TotalSeconds).ToString(CultureInfo.InvariantCulture);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|