PluralKit/PluralKit.Bot/Handlers/MessageDeleted.cs

62 lines
1.9 KiB
C#
Raw Normal View History

using System;
using System.Threading.Tasks;
2020-12-22 12:15:26 +00:00
using Myriad.Gateway;
using PluralKit.Core;
using Serilog;
namespace PluralKit.Bot
{
// Double duty :)
2020-12-22 12:15:26 +00:00
public class MessageDeleted: IEventHandler<MessageDeleteEvent>, IEventHandler<MessageDeleteBulkEvent>
{
private static readonly TimeSpan MessageDeleteDelay = TimeSpan.FromSeconds(15);
2020-08-29 11:46:27 +00:00
private readonly IDatabase _db;
private readonly ModelRepository _repo;
private readonly ILogger _logger;
2020-08-29 11:46:27 +00:00
public MessageDeleted(ILogger logger, IDatabase db, ModelRepository repo)
{
2020-08-29 11:46:27 +00:00
_db = db;
_repo = repo;
_logger = logger.ForContext<MessageDeleted>();
}
2020-12-22 12:15:26 +00:00
public Task Handle(Shard shard, MessageDeleteEvent evt)
{
// Delete deleted webhook messages from the data store
2020-08-29 11:46:27 +00:00
// Most of the data in the given message is wrong/missing, so always delete just to be sure.
async Task Inner()
{
await Task.Delay(MessageDeleteDelay);
2020-12-22 12:15:26 +00:00
// TODO
await _db.Execute(c => _repo.DeleteMessage(c, evt.Id));
}
// Fork a task to delete the message after a short delay
// to allow for lookups to happen for a little while after deletion
_ = Inner();
return Task.CompletedTask;
}
2020-12-22 12:15:26 +00:00
public Task Handle(Shard shard, MessageDeleteBulkEvent evt)
{
// Same as above, but bulk
async Task Inner()
{
await Task.Delay(MessageDeleteDelay);
_logger.Information("Bulk deleting {Count} messages in channel {Channel}",
evt.Ids.Length, evt.ChannelId);
await _db.Execute(c => _repo.DeleteMessagesBulk(c, evt.Ids));
}
_ = Inner();
return Task.CompletedTask;
}
}
}