move classes around, name caches more consistently, add more caches
This commit is contained in:
parent
e86b37ce2a
commit
e17dcf90a1
30 changed files with 443 additions and 51 deletions
|
|
@ -1,4 +1,5 @@
|
|||
using Catalogger.Backend.Cache;
|
||||
using Catalogger.Backend.Cache.InMemoryCache;
|
||||
using Catalogger.Backend.Database;
|
||||
using Catalogger.Backend.Database.Queries;
|
||||
using Catalogger.Backend.Extensions;
|
||||
|
|
@ -13,8 +14,8 @@ namespace Catalogger.Backend.Bot.Responders.Channels;
|
|||
|
||||
public class ChannelCreateResponder(
|
||||
DatabaseContext db,
|
||||
RoleCacheService roleCache,
|
||||
ChannelCacheService channelCache,
|
||||
RoleCache roleCache,
|
||||
ChannelCache channelCache,
|
||||
WebhookExecutorService webhookExecutor) : IResponder<IChannelCreate>
|
||||
{
|
||||
public async Task<Result> RespondAsync(IChannelCreate ch, CancellationToken ct = default)
|
||||
|
|
|
|||
|
|
@ -1,26 +1,27 @@
|
|||
using System.Diagnostics;
|
||||
using Catalogger.Backend.Cache;
|
||||
using Catalogger.Backend.Cache.InMemoryCache;
|
||||
using Catalogger.Backend.Database;
|
||||
using Catalogger.Backend.Database.Models;
|
||||
using Catalogger.Backend.Extensions;
|
||||
using Catalogger.Backend.Services;
|
||||
using Remora.Discord.API.Abstractions.Gateway.Events;
|
||||
using Remora.Discord.API.Gateway.Events;
|
||||
using Remora.Discord.Extensions.Embeds;
|
||||
using Remora.Discord.Gateway.Responders;
|
||||
using Remora.Results;
|
||||
|
||||
namespace Catalogger.Backend.Bot.Responders;
|
||||
namespace Catalogger.Backend.Bot.Responders.Guilds;
|
||||
|
||||
public class GuildCreateResponder(
|
||||
Config config,
|
||||
ILogger logger,
|
||||
DatabaseContext db,
|
||||
GuildCacheService guildCache,
|
||||
RoleCacheService roleCache,
|
||||
ChannelCacheService channelCache,
|
||||
WebhookExecutorService webhookExecutor)
|
||||
: IResponder<IGuildCreate>, IResponder<GuildDelete>
|
||||
GuildCache guildCache,
|
||||
RoleCache roleCache,
|
||||
ChannelCache channelCache,
|
||||
WebhookExecutorService webhookExecutor,
|
||||
IMemberCache memberCache,
|
||||
GuildFetchService guildFetchService)
|
||||
: IResponder<IGuildCreate>, IResponder<IGuildDelete>
|
||||
{
|
||||
private readonly ILogger _logger = logger.ForContext<GuildCreateResponder>();
|
||||
|
||||
|
|
@ -37,6 +38,9 @@ public class GuildCreateResponder(
|
|||
guildCache.Set(guild);
|
||||
foreach (var c in guild.Channels) channelCache.Set(c, guild.ID);
|
||||
foreach (var r in guild.Roles) roleCache.Set(r, guild.ID);
|
||||
|
||||
if (!await memberCache.IsGuildCachedAsync(guild.ID))
|
||||
guildFetchService.EnqueueGuild(guild.ID);
|
||||
}
|
||||
else
|
||||
{
|
||||
|
|
@ -71,7 +75,7 @@ public class GuildCreateResponder(
|
|||
return Result.Success;
|
||||
}
|
||||
|
||||
public async Task<Result> RespondAsync(GuildDelete evt, CancellationToken ct = default)
|
||||
public async Task<Result> RespondAsync(IGuildDelete evt, CancellationToken ct = default)
|
||||
{
|
||||
if (evt.IsUnavailable.OrDefault(false))
|
||||
{
|
||||
|
|
@ -0,0 +1,27 @@
|
|||
using Catalogger.Backend.Cache;
|
||||
using Remora.Discord.API.Abstractions.Gateway.Events;
|
||||
using Remora.Discord.Gateway.Responders;
|
||||
using Remora.Results;
|
||||
|
||||
namespace Catalogger.Backend.Bot.Responders.Guilds;
|
||||
|
||||
public class GuildMembersChunkResponder(ILogger logger, IMemberCache memberCache) : IResponder<IGuildMembersChunk>
|
||||
{
|
||||
private readonly ILogger _logger = logger.ForContext<GuildMembersChunkResponder>();
|
||||
|
||||
public async Task<Result> RespondAsync(IGuildMembersChunk evt, CancellationToken ct = default)
|
||||
{
|
||||
_logger.Debug("Received chunk {ChunkIndex} / {ChunkCount} for guild {GuildId}", evt.ChunkIndex + 1,
|
||||
evt.ChunkCount, evt.GuildID);
|
||||
|
||||
await memberCache.SetManyAsync(evt.GuildID, evt.Members);
|
||||
|
||||
if (evt.ChunkIndex == evt.ChunkCount - 1)
|
||||
{
|
||||
_logger.Debug("Final chunk for guild {GuildId} received, marking as cached", evt.GuildID);
|
||||
await memberCache.MarkAsCachedAsync(evt.GuildID);
|
||||
}
|
||||
|
||||
return Result.Success;
|
||||
}
|
||||
}
|
||||
|
|
@ -1,16 +1,15 @@
|
|||
using System.Text.RegularExpressions;
|
||||
using App.Metrics;
|
||||
using Catalogger.Backend.Cache;
|
||||
using Catalogger.Backend.Cache.InMemoryCache;
|
||||
using Catalogger.Backend.Database;
|
||||
using Catalogger.Backend.Database.Models;
|
||||
using Catalogger.Backend.Database.Queries;
|
||||
using Catalogger.Backend.Extensions;
|
||||
using Catalogger.Backend.Services;
|
||||
using Humanizer;
|
||||
using Remora.Discord.API;
|
||||
using Remora.Discord.API.Abstractions.Gateway.Events;
|
||||
using Remora.Discord.Gateway.Responders;
|
||||
using Remora.Rest.Core;
|
||||
using Remora.Results;
|
||||
|
||||
namespace Catalogger.Backend.Bot.Responders;
|
||||
|
|
@ -20,7 +19,7 @@ public class MessageCreateResponder(
|
|||
Config config,
|
||||
DatabaseContext db,
|
||||
MessageRepository messageRepository,
|
||||
UserCacheService userCache,
|
||||
UserCache userCache,
|
||||
PkMessageHandler pkMessageHandler,
|
||||
IMetrics metrics)
|
||||
: IResponder<IMessageCreate>
|
||||
|
|
|
|||
|
|
@ -1,4 +1,5 @@
|
|||
using Catalogger.Backend.Cache;
|
||||
using Catalogger.Backend.Cache.InMemoryCache;
|
||||
using Catalogger.Backend.Database;
|
||||
using Catalogger.Backend.Database.Queries;
|
||||
using Catalogger.Backend.Extensions;
|
||||
|
|
@ -22,8 +23,8 @@ public class MessageDeleteResponder(
|
|||
DatabaseContext db,
|
||||
MessageRepository messageRepository,
|
||||
WebhookExecutorService webhookExecutor,
|
||||
ChannelCacheService channelCache,
|
||||
UserCacheService userCache,
|
||||
ChannelCache channelCache,
|
||||
UserCache userCache,
|
||||
IClock clock,
|
||||
PluralkitApiService pluralkitApi) : IResponder<IMessageDelete>
|
||||
{
|
||||
|
|
|
|||
|
|
@ -1,4 +1,5 @@
|
|||
using Catalogger.Backend.Cache;
|
||||
using Catalogger.Backend.Cache.InMemoryCache;
|
||||
using Catalogger.Backend.Database;
|
||||
using Catalogger.Backend.Database.Queries;
|
||||
using Catalogger.Backend.Extensions;
|
||||
|
|
@ -17,8 +18,8 @@ namespace Catalogger.Backend.Bot.Responders;
|
|||
public class MessageUpdateResponder(
|
||||
ILogger logger,
|
||||
DatabaseContext db,
|
||||
ChannelCacheService channelCache,
|
||||
UserCacheService userCache,
|
||||
ChannelCache channelCache,
|
||||
UserCache userCache,
|
||||
MessageRepository messageRepository,
|
||||
WebhookExecutorService webhookExecutor,
|
||||
PluralkitApiService pluralkitApi) : IResponder<IMessageUpdate>
|
||||
|
|
@ -60,7 +61,8 @@ public class MessageUpdateResponder(
|
|||
return Result.Success;
|
||||
}
|
||||
|
||||
if (oldMessage.Content == msg.Content) return Result.Success;
|
||||
if (oldMessage.Content == msg.Content ||
|
||||
(oldMessage.Content == "None" && string.IsNullOrEmpty(msg.Content))) return Result.Success;
|
||||
|
||||
var user = msg.Author;
|
||||
if (msg.Author.ID != oldMessage.UserId)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue