Catalogger.NET/Catalogger.Backend/Services/GuildFetchService.cs

52 lines
1.6 KiB
C#
Raw Normal View History

using System.Collections.Concurrent;
2024-08-24 19:02:19 +02:00
using Catalogger.Backend.Bot;
using Catalogger.Backend.Cache;
using Humanizer;
using Remora.Discord.API.Abstractions.Rest;
using Remora.Discord.API.Gateway.Commands;
using Remora.Discord.Gateway;
using Remora.Rest.Core;
namespace Catalogger.Backend.Services;
public class GuildFetchService(
ILogger logger,
2024-08-24 19:02:19 +02:00
ShardedGatewayClient client,
IDiscordRestGuildAPI guildApi,
2024-10-09 17:35:11 +02:00
IInviteCache inviteCache
) : BackgroundService
{
private readonly ILogger _logger = logger.ForContext<GuildFetchService>();
private readonly ConcurrentQueue<Snowflake> _guilds = new();
protected override async Task ExecuteAsync(CancellationToken stoppingToken)
{
using var timer = new PeriodicTimer(500.Milliseconds());
while (await timer.WaitForNextTickAsync(stoppingToken))
{
2024-10-09 17:35:11 +02:00
if (!_guilds.TryPeek(out var guildId))
continue;
_logger.Debug("Fetching members and invites for guild {GuildId}", guildId);
2024-08-24 19:02:19 +02:00
client.ClientFor(guildId).SubmitCommand(new RequestGuildMembers(guildId, "", 0));
var res = await guildApi.GetGuildInvitesAsync(guildId, stoppingToken);
if (res.Error != null)
{
_logger.Error("Fetching invites for guild {GuildId}: {Error}", guildId, res.Error);
}
else
{
await inviteCache.SetAsync(guildId, res.Entity);
}
_guilds.TryDequeue(out _);
}
}
public void EnqueueGuild(Snowflake guildId)
{
2024-10-09 17:35:11 +02:00
if (!_guilds.Contains(guildId))
_guilds.Enqueue(guildId);
}
2024-10-09 17:35:11 +02:00
}