70 lines
2.7 KiB
C#
70 lines
2.7 KiB
C#
using HermesSocketLibrary.Socket.Data;
|
|
using HermesSocketServer.Services;
|
|
|
|
namespace HermesSocketServer.Requests
|
|
{
|
|
public class RequestManager : IRequestManager
|
|
{
|
|
private readonly IDictionary<string, IRequest> _requests;
|
|
private readonly ChannelManager _channels;
|
|
private readonly Serilog.ILogger _logger;
|
|
|
|
|
|
public RequestManager(IEnumerable<IRequest> requests, ChannelManager channels, Serilog.ILogger logger)
|
|
{
|
|
_requests = requests.ToDictionary(r => r.Name, r => r);
|
|
_channels = channels;
|
|
_logger = logger;
|
|
}
|
|
|
|
public async Task<RequestResult> Grant(string sender, RequestMessage? message)
|
|
{
|
|
if (message == null || message.Type == null)
|
|
{
|
|
_logger.Debug($"Request type does not exist [id: {message?.RequestId ?? "null"}][nounce: {message?.Nounce ?? "null"}]");
|
|
return RequestResult.Failed("Request type does not exist.");
|
|
}
|
|
|
|
var channel = _channels.Get(sender);
|
|
if (channel == null)
|
|
{
|
|
_logger.Debug($"Channel does not exist [id: {message.RequestId}][nounce: {message.Nounce}]");
|
|
return RequestResult.Failed("Channel does not exist.");
|
|
}
|
|
|
|
if (!_requests.TryGetValue(message.Type, out IRequest? request) || request == null)
|
|
{
|
|
_logger.Warning($"Could not find request [type: {message.Type}]");
|
|
return RequestResult.Failed("Request does not exist.");
|
|
}
|
|
|
|
if (request.RequiredKeys.Any())
|
|
{
|
|
if (message.Data == null)
|
|
{
|
|
_logger.Debug($"Request is lacking data entries [id: {message.RequestId}][nounce: {message.Nounce}]");
|
|
return RequestResult.Failed($"Request is lacking data entries.");
|
|
}
|
|
|
|
foreach (var key in request.RequiredKeys)
|
|
{
|
|
if (!message.Data.ContainsKey(key))
|
|
{
|
|
_logger.Debug($"Request is missing '{key}' in its data entries [id: {message.RequestId}][nounce: {message.Nounce}]");
|
|
return RequestResult.Failed($"Request is missing '{key}' in its data entries.");
|
|
}
|
|
}
|
|
}
|
|
|
|
try
|
|
{
|
|
return await request.Grant(channel, message.Data ?? new Dictionary<string, object>());
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
_logger.Error(e, $"Failed to grant a request during processing [type: {message.Type}]");
|
|
return RequestResult.Failed("Failed to grant request during processing: " + e.Message);
|
|
}
|
|
}
|
|
}
|
|
} |