2020-05-09 03:56:06 +00:00
|
|
|
|
using System;
|
2020-05-09 13:04:38 +00:00
|
|
|
|
using System.Globalization;
|
2020-05-09 03:56:06 +00:00
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
using Microsoft.AspNetCore.Mvc;
|
|
|
|
|
using Microsoft.Extensions.Logging;
|
|
|
|
|
using Wabbajack.Common;
|
|
|
|
|
using Wabbajack.Server.DataLayer;
|
|
|
|
|
using Wabbajack.Server.DTOs;
|
|
|
|
|
using WebSocketSharp;
|
|
|
|
|
using LogLevel = Microsoft.Extensions.Logging.LogLevel;
|
|
|
|
|
|
|
|
|
|
namespace Wabbajack.BuildServer.Controllers
|
|
|
|
|
{
|
|
|
|
|
[ApiController]
|
|
|
|
|
[Route("/metrics")]
|
|
|
|
|
public class MetricsController : ControllerBase
|
|
|
|
|
{
|
|
|
|
|
private SqlService _sql;
|
|
|
|
|
private ILogger<MetricsController> _logger;
|
|
|
|
|
|
|
|
|
|
public MetricsController(ILogger<MetricsController> logger, SqlService sql)
|
|
|
|
|
{
|
|
|
|
|
_sql = sql;
|
|
|
|
|
_logger = logger;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[HttpGet]
|
2020-05-09 13:04:38 +00:00
|
|
|
|
[Route("{subject}/{value}")]
|
|
|
|
|
public async Task<Result> LogMetricAsync(string subject, string value)
|
2020-05-09 03:56:06 +00:00
|
|
|
|
{
|
|
|
|
|
var date = DateTime.UtcNow;
|
2020-05-09 13:04:38 +00:00
|
|
|
|
await Log(date, subject, value, Request.Headers[Consts.MetricsKeyHeader].FirstOrDefault());
|
2020-05-09 03:56:06 +00:00
|
|
|
|
return new Result { Timestamp = date};
|
|
|
|
|
}
|
|
|
|
|
|
2020-05-09 13:04:38 +00:00
|
|
|
|
[HttpGet]
|
|
|
|
|
[Route("report/{subject}")]
|
|
|
|
|
public async Task<IActionResult> MetricsReport(string subject)
|
|
|
|
|
{
|
|
|
|
|
var results = (await _sql.MetricsReport(subject))
|
|
|
|
|
.GroupBy(m => m.Subject)
|
|
|
|
|
.Select(g => new MetricResult
|
|
|
|
|
{
|
|
|
|
|
SeriesName = g.Key,
|
|
|
|
|
Labels = g.Select(m => m.Date.ToString(CultureInfo.InvariantCulture)).ToList(),
|
|
|
|
|
Values = g.Select(m => m.Count).ToList()
|
|
|
|
|
});
|
|
|
|
|
return Ok(results.ToList());
|
|
|
|
|
}
|
|
|
|
|
|
2020-05-09 03:56:06 +00:00
|
|
|
|
private async Task Log(DateTime timestamp, string action, string subject, string metricsKey = null)
|
|
|
|
|
{
|
|
|
|
|
_logger.Log(LogLevel.Information, $"Log - {timestamp} {action} {subject} {metricsKey}");
|
|
|
|
|
await _sql.IngestMetric(new Metric
|
|
|
|
|
{
|
|
|
|
|
Timestamp = timestamp, Action = action, Subject = subject, MetricsKey = metricsKey
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public class Result
|
|
|
|
|
{
|
|
|
|
|
public DateTime Timestamp { get; set; }
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|