insight/src/Server/Insight.Server/Network/Handlers/Agent/ProcessorHandler.cs

87 lines
3.8 KiB
C#
Raw Normal View History

2023-09-21 22:10:55 +02:00
using Insight.Domain.Interfaces;
using Insight.Domain.Messages;
using Insight.Domain.Messages.Agent;
2023-09-21 18:58:32 +02:00
using Insight.Infrastructure;
using Insight.Infrastructure.Entities;
using MongoDB.Bson;
using MongoDB.Driver;
2023-09-21 22:10:55 +02:00
namespace Insight.Server.Network.Handlers.Agent;
public class ProcessorHandler : IMessageHandler<AgentSession>
2023-09-21 18:58:32 +02:00
{
2023-09-21 22:10:55 +02:00
private readonly IMongoDatabase _database;
public ProcessorHandler(IMongoDatabase database)
2023-09-21 18:58:32 +02:00
{
2023-09-21 22:10:55 +02:00
_database = database;
}
2023-09-21 18:58:32 +02:00
2023-09-21 22:10:55 +02:00
public async ValueTask HandleAsync<TMessage>(AgentSession sender, TMessage message, CancellationToken cancellationToken) where TMessage : IMessage
{
if (message is ProcessorList processors)
2023-09-21 18:58:32 +02:00
{
2023-09-21 22:10:55 +02:00
await OnProcessorsAsync(sender, processors, cancellationToken);
2023-09-21 18:58:32 +02:00
}
2023-09-21 22:10:55 +02:00
}
2023-09-21 18:58:32 +02:00
2023-09-21 22:10:55 +02:00
private async ValueTask OnProcessorsAsync(AgentSession session, List<Processor> processors, CancellationToken cancellationToken)
{
var agentEntity = await _database.Agent().Find(Builders<AgentEntity>.Filter.Eq(p => p.Id, session.Id)).FirstOrDefaultAsync(cancellationToken);
if (agentEntity is null) return;
2023-09-21 18:58:32 +02:00
2023-09-21 22:10:55 +02:00
var hostEntity = await _database.Host().Find(Builders<HostEntity>.Filter.Eq(p => p.Agent, agentEntity.Id)).FirstOrDefaultAsync(cancellationToken);
if (hostEntity is null) return;
2023-09-21 18:58:32 +02:00
2023-09-21 22:10:55 +02:00
var batch = ObjectId.GenerateNewId().ToString();
var date = DateTime.Now;
2023-09-21 18:58:32 +02:00
2023-09-21 22:10:55 +02:00
var bulk = new List<WriteModel<HostProcessorEntity>>();
2023-09-21 18:58:32 +02:00
2023-09-21 22:10:55 +02:00
if (processors is not null && processors.Any())
{
foreach (var processor in processors)
2023-09-21 18:58:32 +02:00
{
2023-09-21 22:10:55 +02:00
var filterDefinition = Builders<HostProcessorEntity>.Filter.And(new List<FilterDefinition<HostProcessorEntity>>
2023-09-21 18:58:32 +02:00
{
2023-09-21 22:10:55 +02:00
Builders<HostProcessorEntity>.Filter.Eq(x => x.Host, hostEntity.Id),
Builders<HostProcessorEntity>.Filter.Eq(x => x.Index, processor.Index)
2023-09-21 18:58:32 +02:00
});
2023-09-21 22:10:55 +02:00
var updateDefinition = Builders<HostProcessorEntity>.Update
.SetOnInsert(p => p.Insert, date)
.SetOnInsert(p => p.Host, hostEntity.Id)
.SetOnInsert(p => p.Index, processor.Index)
.Set(p => p.Update, date)
.Set(p => p.Batch, batch)
.Set(p => p.Company, processor.Manufacturer)
.Set(p => p.Name, processor.Name)
.Set(p => p.Socket, processor.Socket)
.Set(p => p.Serial, processor.SerialNumber)
.Set(p => p.Version, processor.Version)
.Set(p => p.Cores, processor.Cores)
.Set(p => p.LogicalCores, processor.LogicalCores)
.Set(p => p.Clock, processor.MaxSpeed)
.Set(p => p.CurrentClock, processor.CurrentSpeed)
.Set(p => p.L1Size, processor.L1Size)
.Set(p => p.L2Size, processor.L2Size)
.Set(p => p.L3Size, processor.L3Size)
.Set(p => p.Virtualization, processor.Virtualization)
.Set(p => p.PNP, processor.DeviceId);
2023-09-21 18:58:32 +02:00
2023-09-21 22:10:55 +02:00
bulk.Add(new UpdateOneModel<HostProcessorEntity>(filterDefinition, updateDefinition)
{
IsUpsert = true
});
}
2023-09-21 18:58:32 +02:00
}
2023-09-21 22:10:55 +02:00
bulk.Add(new DeleteManyModel<HostProcessorEntity>(Builders<HostProcessorEntity>.Filter.And(new List<FilterDefinition<HostProcessorEntity>>
{
Builders<HostProcessorEntity>.Filter.Eq(x => x.Host, hostEntity.Id),
Builders<HostProcessorEntity>.Filter.Ne(x => x.Batch, batch)
})));
var result = await _database.HostProcessor().BulkWriteAsync(bulk, cancellationToken: cancellationToken);
2023-09-21 18:58:32 +02:00
}
}