2020-12-22 13:15:26 +01:00
|
|
|
using Myriad.Gateway;
|
2020-05-02 01:52:52 +02:00
|
|
|
|
2020-06-11 23:20:46 +02:00
|
|
|
using PluralKit.Core;
|
|
|
|
|
|
|
|
|
|
using Serilog;
|
2020-05-02 01:52:52 +02:00
|
|
|
|
2021-11-26 21:10:56 -05:00
|
|
|
namespace PluralKit.Bot;
|
|
|
|
|
|
|
|
|
|
// Double duty :)
|
|
|
|
|
public class MessageDeleted: IEventHandler<MessageDeleteEvent>, IEventHandler<MessageDeleteBulkEvent>
|
2020-05-02 01:52:52 +02:00
|
|
|
{
|
2021-11-26 21:10:56 -05:00
|
|
|
private static readonly TimeSpan MessageDeleteDelay = TimeSpan.FromSeconds(15);
|
|
|
|
|
|
|
|
|
|
private readonly IDatabase _db;
|
|
|
|
|
private readonly ModelRepository _repo;
|
|
|
|
|
private readonly ILogger _logger;
|
|
|
|
|
private readonly LastMessageCacheService _lastMessage;
|
|
|
|
|
|
|
|
|
|
public MessageDeleted(ILogger logger, IDatabase db, ModelRepository repo, LastMessageCacheService lastMessage)
|
2020-05-02 01:52:52 +02:00
|
|
|
{
|
2021-11-26 21:10:56 -05:00
|
|
|
_db = db;
|
|
|
|
|
_repo = repo;
|
|
|
|
|
_lastMessage = lastMessage;
|
|
|
|
|
_logger = logger.ForContext<MessageDeleted>();
|
|
|
|
|
}
|
2021-08-27 11:03:47 -04:00
|
|
|
|
2022-01-14 18:39:03 -05:00
|
|
|
public Task Handle(int shardId, MessageDeleteEvent evt)
|
2021-11-26 21:10:56 -05:00
|
|
|
{
|
|
|
|
|
// Delete deleted webhook messages from the data store
|
|
|
|
|
// Most of the data in the given message is wrong/missing, so always delete just to be sure.
|
2020-05-02 01:52:52 +02:00
|
|
|
|
2021-11-26 21:10:56 -05:00
|
|
|
async Task Inner()
|
2020-05-02 01:52:52 +02:00
|
|
|
{
|
2021-11-26 21:10:56 -05:00
|
|
|
await Task.Delay(MessageDeleteDelay);
|
2024-11-25 02:06:27 -07:00
|
|
|
|
|
|
|
|
var message = await _repo.GetMessage(evt.Id);
|
|
|
|
|
if (message == null) return;
|
|
|
|
|
|
|
|
|
|
if (message.Member.HasValue)
|
|
|
|
|
{
|
|
|
|
|
var memberFull = await _repo.GetMember(message.Member.Value);
|
|
|
|
|
await _repo.UpdateMemberForDeletedMessage(message.Member.Value, memberFull.MessageCount);
|
|
|
|
|
}
|
|
|
|
|
|
2021-11-26 21:10:56 -05:00
|
|
|
await _repo.DeleteMessage(evt.Id);
|
2020-05-02 01:52:52 +02:00
|
|
|
}
|
2021-08-27 11:03:47 -04:00
|
|
|
|
2021-11-26 21:10:56 -05:00
|
|
|
_lastMessage.HandleMessageDeletion(evt.ChannelId, evt.Id);
|
2020-11-18 15:01:32 +01:00
|
|
|
|
2021-11-26 21:10:56 -05:00
|
|
|
// 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-05-02 01:52:52 +02:00
|
|
|
|
2022-01-14 18:39:03 -05:00
|
|
|
public Task Handle(int shardId, MessageDeleteBulkEvent evt)
|
2021-11-26 21:10:56 -05:00
|
|
|
{
|
|
|
|
|
// Same as above, but bulk
|
|
|
|
|
async Task Inner()
|
2020-05-02 01:52:52 +02:00
|
|
|
{
|
2021-11-26 21:10:56 -05:00
|
|
|
await Task.Delay(MessageDeleteDelay);
|
2020-12-23 02:19:02 +01:00
|
|
|
|
2021-11-26 21:10:56 -05:00
|
|
|
_logger.Information("Bulk deleting {Count} messages in channel {Channel}",
|
|
|
|
|
evt.Ids.Length, evt.ChannelId);
|
|
|
|
|
await _repo.DeleteMessagesBulk(evt.Ids);
|
2024-11-25 02:09:40 -07:00
|
|
|
|
|
|
|
|
// get all the messages from the database
|
|
|
|
|
var messages = await _repo.GetMessagesBulk(evt.Ids);
|
|
|
|
|
|
|
|
|
|
// make a dictionary of every member id associated with a message and how many messages it's associated with
|
|
|
|
|
var memberMessageCounts = new Dictionary<MemberId, int>();
|
|
|
|
|
foreach (PKMessage msg in messages)
|
|
|
|
|
{
|
|
|
|
|
if (!msg.Member.HasValue) continue;
|
|
|
|
|
if (memberMessageCounts.ContainsKey(msg.Member.Value))
|
|
|
|
|
memberMessageCounts[msg.Member.Value] = memberMessageCounts[msg.Member.Value] + 1;
|
|
|
|
|
else
|
|
|
|
|
memberMessageCounts[msg.Member.Value] = 1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// go through each member id in dictionary and decrement that member's message count by appropriate amount
|
|
|
|
|
foreach (MemberId member in memberMessageCounts.Keys)
|
|
|
|
|
{
|
|
|
|
|
await _repo.UpdateMemberForDeletedMessage(member, (await _repo.GetMember(member)).MessageCount, memberMessageCounts[member]);
|
|
|
|
|
}
|
|
|
|
|
|
2020-05-02 01:52:52 +02:00
|
|
|
}
|
2021-11-26 21:10:56 -05:00
|
|
|
|
|
|
|
|
_lastMessage.HandleMessageDeletion(evt.ChannelId, evt.Ids.ToList());
|
|
|
|
|
_ = Inner();
|
|
|
|
|
return Task.CompletedTask;
|
2020-05-02 01:52:52 +02:00
|
|
|
}
|
2021-11-26 21:10:56 -05:00
|
|
|
|
2020-05-02 01:52:52 +02:00
|
|
|
}
|