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
|
|
|
|
|
{
|
2024-10-09 17:35:11 +02:00
|
|
|
public static async ValueTask<Guild> GetGuildAsync(
|
|
|
|
|
this DatabaseContext db,
|
|
|
|
|
Snowflake id,
|
|
|
|
|
CancellationToken ct = default
|
|
|
|
|
) => await db.GetGuildAsync(id.ToUlong(), ct);
|
2024-08-13 13:08:50 +02:00
|
|
|
|
2024-10-09 17:35:11 +02:00
|
|
|
public static async ValueTask<Guild> GetGuildAsync(
|
|
|
|
|
this DatabaseContext db,
|
|
|
|
|
Optional<Snowflake> id,
|
|
|
|
|
CancellationToken ct = default
|
|
|
|
|
) => await db.GetGuildAsync(id.ToUlong(), ct);
|
2024-08-13 13:08:50 +02:00
|
|
|
|
2024-10-09 17:35:11 +02:00
|
|
|
public static async ValueTask<Guild> GetGuildAsync(
|
|
|
|
|
this DatabaseContext db,
|
|
|
|
|
ulong id,
|
|
|
|
|
CancellationToken ct = default
|
|
|
|
|
)
|
2024-08-13 13:08:50 +02:00
|
|
|
{
|
2024-08-21 17:31:39 +02:00
|
|
|
var guild = await db.Guilds.FindAsync([id], ct);
|
2024-10-09 17:35:11 +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
|
|
|
|
2024-10-09 17:35:11 +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);
|
|
|
|
|
}
|