2024-08-13 13:08:50 +02:00
|
|
|
using Catalogger.Backend.Database.Models;
|
|
|
|
|
using Catalogger.Backend.Extensions;
|
|
|
|
|
using Remora.Rest.Core;
|
|
|
|
|
|
|
|
|
|
namespace Catalogger.Backend.Database.Queries;
|
|
|
|
|
|
|
|
|
|
public static class QueryExtensions
|
|
|
|
|
{
|
|
|
|
|
public static async ValueTask<Guild> GetGuildAsync(this DatabaseContext db, Snowflake id,
|
|
|
|
|
CancellationToken ct = default) => await db.GetGuildAsync(id.ToUlong(), ct);
|
|
|
|
|
|
|
|
|
|
public static async ValueTask<Guild> GetGuildAsync(this DatabaseContext db, Optional<Snowflake> id,
|
|
|
|
|
CancellationToken ct = default) => await db.GetGuildAsync(id.ToUlong(), ct);
|
|
|
|
|
|
|
|
|
|
public static async ValueTask<Guild> GetGuildAsync(this DatabaseContext db, ulong id,
|
|
|
|
|
CancellationToken ct = default)
|
|
|
|
|
{
|
2024-08-21 17:31:39 +02:00
|
|
|
var guild = await db.Guilds.FindAsync([id], ct);
|
2024-08-13 16:48:54 +02:00
|
|
|
if (guild == null) throw new CataloggerError("Guild not found, was not initialized during guild create");
|
2024-08-13 13:08:50 +02:00
|
|
|
return guild;
|
|
|
|
|
}
|
2024-08-21 17:31:39 +02:00
|
|
|
|
|
|
|
|
public static async Task<Watchlist?> GetWatchlistEntryAsync(this DatabaseContext db, Snowflake guildId,
|
|
|
|
|
Snowflake userId, CancellationToken ct = default) =>
|
|
|
|
|
await db.Watchlists.FindAsync([guildId.Value, userId.Value], ct);
|
2024-08-13 13:08:50 +02:00
|
|
|
}
|