using HermesSocketServer.Models; using ILogger = Serilog.ILogger; namespace HermesSocketServer.Requests { public class UpdatePolicy : IRequest { public string Name => "update_policy"; public string[] RequiredKeys => ["id", "groupId", "path", "count", "span"]; private ILogger _logger; public UpdatePolicy(ILogger logger) { _logger = logger; } public Task Grant(Channel channel, IDictionary data) { var id = Guid.Parse(data["id"].ToString()!); string groupId = data["groupId"].ToString()!; string path = data["path"].ToString()!; int count = int.Parse(data["count"].ToString()!); int span = int.Parse(data["span"].ToString()!); bool result = channel.Policies.Set(id.ToString(), new PolicyMessage() { Id = id, UserId = channel.Id, GroupId = Guid.Parse(groupId), Path = path, Usage = count, Span = span, }); if (result) { var policy = channel.Policies.Get(id.ToString()); _logger.Information($"Updated policy to channel [policy id: {id}][group id: {groupId}][path: {path}][count: {count}][span: {span}][channel: {channel.Id}]"); return Task.FromResult(RequestResult.Successful(policy)); } return Task.FromResult(RequestResult.Failed("Something went wrong when updating the cache.")); } } }