2024-06-24 22:21:59 +00:00
|
|
|
using HermesSocketLibrary.db;
|
|
|
|
using HermesSocketLibrary.Socket.Data;
|
|
|
|
using ILogger = Serilog.ILogger;
|
|
|
|
|
|
|
|
namespace HermesSocketServer.Socket.Handlers
|
|
|
|
{
|
|
|
|
public class ChatterHandler : ISocketHandler
|
|
|
|
{
|
2024-08-10 19:36:32 +00:00
|
|
|
public int OperationCode { get; } = 6;
|
2024-06-24 22:21:59 +00:00
|
|
|
private readonly Database _database;
|
|
|
|
private readonly HashSet<long> _chatters;
|
|
|
|
private readonly ChatterMessage[] _array;
|
|
|
|
private readonly ILogger _logger;
|
|
|
|
|
|
|
|
private readonly object _lock;
|
|
|
|
private int _index;
|
|
|
|
|
|
|
|
public ChatterHandler(Database database, ILogger logger)
|
|
|
|
{
|
|
|
|
_database = database;
|
|
|
|
_logger = logger;
|
|
|
|
_chatters = new HashSet<long>(1001);
|
|
|
|
_array = new ChatterMessage[1000];
|
|
|
|
_index = -1;
|
|
|
|
_lock = new object();
|
|
|
|
}
|
|
|
|
|
|
|
|
public async Task Execute<T>(WebSocketUser sender, T message, HermesSocketManager sockets)
|
|
|
|
{
|
2024-08-10 19:36:32 +00:00
|
|
|
if (message is not ChatterMessage data || sender.Id == null)
|
2024-06-24 22:21:59 +00:00
|
|
|
return;
|
|
|
|
|
|
|
|
lock (_lock)
|
|
|
|
{
|
|
|
|
if (_chatters.Contains(data.Id))
|
|
|
|
return;
|
|
|
|
|
|
|
|
_chatters.Add(data.Id);
|
|
|
|
|
|
|
|
if (_index == _array.Length - 1)
|
|
|
|
_index = -1;
|
|
|
|
|
|
|
|
_array[++_index] = data;
|
|
|
|
}
|
|
|
|
|
|
|
|
try
|
|
|
|
{
|
2024-08-10 19:36:32 +00:00
|
|
|
string sql = "INSERT INTO \"Chatter\" (id, name) VALUES (@idd, @name) ON CONFLICT (id) DO UPDATE SET name = @name";
|
2024-06-24 22:21:59 +00:00
|
|
|
await _database.Execute(sql, new Dictionary<string, object>() { { "idd", data.Id }, { "name", data.Name } });
|
|
|
|
}
|
|
|
|
catch (Exception e)
|
|
|
|
{
|
|
|
|
_logger.Error(e, "Failed to add chatter.");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|