using HermesSocketLibrary.db; using HermesSocketLibrary.Requests.Messages; using HermesSocketServer.Models; using ILogger = Serilog.ILogger; namespace HermesSocketServer.Requests { public class GetRedemptions : IRequest { public string Name => "get_redemptions"; public string[] RequiredKeys => []; private readonly Database _database; private readonly ILogger _logger; public GetRedemptions(Database database, ILogger logger) { _database = database; _logger = logger; } public async Task<RequestResult> Grant(Channel channel, IDictionary<string, object> data) { var temp = new Dictionary<string, object>() { { "user", channel.Id } }; var redemptions = new List<Redemption>(); string sql = $"SELECT id, \"redemptionId\", \"actionName\", \"order\", state FROM \"Redemption\" WHERE \"userId\" = @user"; await _database.Execute(sql, temp, (r) => redemptions.Add(new Redemption() { Id = r.GetGuid(0).ToString("D"), RedemptionId = r.GetString(1), ActionName = r.GetString(2), Order = r.GetInt32(3), State = r.GetBoolean(4) })); _logger.Information($"Fetched all redemptions for channel [channel: {channel.Id}]"); return RequestResult.Successful(redemptions, notifyClientsOnAccount: false); } } }