2023-09-07 19:49:36 +02:00
|
|
|
|
using Microsoft.Extensions.Logging;
|
2023-09-08 20:41:11 +02:00
|
|
|
|
using server.Types.ClientReport;
|
2023-09-07 19:49:36 +02:00
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Text;
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
|
|
|
|
|
namespace server.Database
|
|
|
|
|
{
|
2023-09-09 17:36:19 +02:00
|
|
|
|
public class ClientReport
|
2023-09-07 19:49:36 +02:00
|
|
|
|
{
|
|
|
|
|
private ILogger _logger;
|
|
|
|
|
|
|
|
|
|
private enum ReportCodes
|
|
|
|
|
{
|
|
|
|
|
MODULE_VERIFICATION_CHECKSUM_FAILURE = 10,
|
|
|
|
|
PROCESS_THREAD_START_FAILURE = 20,
|
|
|
|
|
PAGE_PROTECTION_FAILURE = 30,
|
|
|
|
|
PATTERN_SCAN_FAILURE = 40,
|
|
|
|
|
NMI_CALLBACK_FAILURE = 50,
|
|
|
|
|
MODULE_VERIFICATION_FAILURE = 60,
|
|
|
|
|
MODULE_VERIFICATION_SUCCESS = 70
|
|
|
|
|
}
|
|
|
|
|
|
2023-09-08 21:06:13 +02:00
|
|
|
|
public ClientReport(ILogger<ClientReport> logger)
|
2023-09-07 19:49:36 +02:00
|
|
|
|
{
|
|
|
|
|
_logger = logger;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void InsertReport<T>(T report, int reportCode)
|
|
|
|
|
{
|
|
|
|
|
if (report == null)
|
|
|
|
|
{
|
|
|
|
|
_logger.LogError("Report is null");
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
switch (reportCode)
|
|
|
|
|
{
|
|
|
|
|
case (int)ReportCodes.MODULE_VERIFICATION_CHECKSUM_FAILURE:
|
|
|
|
|
InsertReportWithCode10((MODULE_VERIFICATION_CHECKSUM_FAILURE)Convert.ChangeType(report, typeof(MODULE_VERIFICATION_CHECKSUM_FAILURE)));
|
|
|
|
|
break;
|
|
|
|
|
default:
|
|
|
|
|
_logger.LogError("Unknown report code: {0}", reportCode);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void InsertReportWithCode10(MODULE_VERIFICATION_CHECKSUM_FAILURE report)
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|