2020-01-18 22:09:32 +00:00
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
2020-03-10 20:41:45 +00:00
|
|
|
|
using System.Linq;
|
2020-01-18 22:09:32 +00:00
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
using Alphaleonis.Win32.Filesystem;
|
|
|
|
|
using GraphQL;
|
|
|
|
|
using Microsoft.AspNetCore.Mvc;
|
2020-01-08 04:41:50 +00:00
|
|
|
|
using Microsoft.Extensions.Logging;
|
2020-01-18 22:09:32 +00:00
|
|
|
|
using MongoDB.Driver;
|
2020-03-10 20:41:45 +00:00
|
|
|
|
using Org.BouncyCastle.Ocsp;
|
|
|
|
|
using Wabbajack.BuildServer.Model.Models;
|
2020-01-08 04:41:50 +00:00
|
|
|
|
using Wabbajack.BuildServer.Models;
|
2020-01-18 22:09:32 +00:00
|
|
|
|
using Wabbajack.Common;
|
2020-01-08 04:41:50 +00:00
|
|
|
|
|
|
|
|
|
namespace Wabbajack.BuildServer.Controllers
|
|
|
|
|
{
|
2020-01-10 02:06:11 +00:00
|
|
|
|
[ApiController]
|
2020-01-08 04:41:50 +00:00
|
|
|
|
public abstract class AControllerBase<T> : ControllerBase
|
|
|
|
|
{
|
|
|
|
|
protected readonly DBContext Db;
|
2020-01-10 02:06:11 +00:00
|
|
|
|
protected readonly ILogger<T> Logger;
|
2020-03-10 20:41:45 +00:00
|
|
|
|
protected readonly SqlService SQL;
|
2020-01-08 04:41:50 +00:00
|
|
|
|
|
2020-03-10 20:41:45 +00:00
|
|
|
|
protected AControllerBase(ILogger<T> logger, DBContext db, SqlService sql)
|
2020-01-08 04:41:50 +00:00
|
|
|
|
{
|
|
|
|
|
Db = db;
|
|
|
|
|
Logger = logger;
|
2020-03-10 20:41:45 +00:00
|
|
|
|
SQL = sql;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
protected async Task Metric(string verb, string subject)
|
|
|
|
|
{
|
|
|
|
|
await SQL.IngestMetric(new Metric
|
|
|
|
|
{
|
|
|
|
|
MetricsKey = Request.Headers[Consts.MetricsKeyHeader].FirstOrDefault(),
|
|
|
|
|
Subject = subject,
|
|
|
|
|
Action = verb,
|
|
|
|
|
Timestamp = DateTime.UtcNow
|
|
|
|
|
});
|
2020-01-08 04:41:50 +00:00
|
|
|
|
}
|
2020-01-18 22:09:32 +00:00
|
|
|
|
|
|
|
|
|
|
2020-01-08 04:41:50 +00:00
|
|
|
|
}
|
|
|
|
|
}
|