feat: flesh out member remove responder
This commit is contained in:
parent
516ce3a6e9
commit
b31a20bb81
8 changed files with 119 additions and 12 deletions
|
|
@ -6,16 +6,30 @@ namespace Catalogger.Backend.Cache.InMemoryCache;
|
|||
|
||||
public class AuditLogCache
|
||||
{
|
||||
private readonly ConcurrentDictionary<(Snowflake, Snowflake), ModactionData> _kicks = new();
|
||||
private readonly ConcurrentDictionary<(Snowflake, Snowflake), ModactionData> _bans = new();
|
||||
private readonly ConcurrentDictionary<(Snowflake GuildId, Snowflake TargetId), ActionData> _kicks = new();
|
||||
private readonly ConcurrentDictionary<(Snowflake GuildId, Snowflake TargetId), ActionData> _bans = new();
|
||||
|
||||
public void SetKick(Snowflake guildId, string targetId, Snowflake moderatorId, Optional<string> reason)
|
||||
{
|
||||
if (!DiscordSnowflake.TryParse(targetId, out var targetUser))
|
||||
throw new CataloggerError("Target ID was not a valid snowflake");
|
||||
|
||||
_kicks[(guildId, targetUser.Value)] = new ModactionData(moderatorId, reason.OrDefault());
|
||||
_kicks[(guildId, targetUser.Value)] = new ActionData(moderatorId, reason.OrDefault());
|
||||
}
|
||||
|
||||
public record struct ModactionData(Snowflake ModeratorId, string? Reason);
|
||||
public bool TryGetKick(Snowflake guildId, Snowflake targetId, out ActionData data) =>
|
||||
_kicks.TryGetValue((guildId, targetId), out data);
|
||||
|
||||
public void SetBan(Snowflake guildId, string targetId, Snowflake moderatorId, Optional<string> reason)
|
||||
{
|
||||
if (!DiscordSnowflake.TryParse(targetId, out var targetUser))
|
||||
throw new CataloggerError("Target ID was not a valid snowflake");
|
||||
|
||||
_bans[(guildId, targetUser.Value)] = new ActionData(moderatorId, reason.OrDefault());
|
||||
}
|
||||
|
||||
public bool TryGetBan(Snowflake guildId, Snowflake targetId, out ActionData data) =>
|
||||
_bans.TryGetValue((guildId, targetId), out data);
|
||||
|
||||
public record struct ActionData(Snowflake ModeratorId, string? Reason);
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue