PluralKit/PluralKit.Core/Models/ModelQueryExt.cs

30 lines
1.6 KiB
C#
Raw Normal View History

#nullable enable
2020-06-13 11:58:27 +00:00
using System.Threading.Tasks;
using Dapper;
namespace PluralKit.Core
{
public static class ModelQueryExt
{
2020-06-14 19:37:04 +00:00
public static Task<PKSystem?> QuerySystem(this IPKConnection conn, SystemId id) =>
2020-06-13 17:42:04 +00:00
conn.QueryFirstOrDefaultAsync<PKSystem?>("select * from systems where id = @id", new {id});
2020-06-14 19:37:04 +00:00
public static Task<PKMember?> QueryMember(this IPKConnection conn, MemberId id) =>
conn.QueryFirstOrDefaultAsync<PKMember?>("select * from members where id = @id", new {id});
public static Task<GuildConfig> QueryOrInsertGuildConfig(this IPKConnection conn, ulong guild) =>
conn.QueryFirstAsync<GuildConfig>("insert into servers (id) values (@guild) on conflict (id) do update set id = @guild returning *", new {guild});
2020-06-14 19:37:04 +00:00
public static Task<SystemGuildSettings> QueryOrInsertSystemGuildConfig(this IPKConnection conn, ulong guild, SystemId system) =>
conn.QueryFirstAsync<SystemGuildSettings>(
"insert into member_guild (guild, member) values (@guild, @member) on conflict (guild, member) do update set guild = @guild, member = @member returning *",
new {guild, system});
public static Task<MemberGuildSettings> QueryOrInsertMemberGuildConfig(
2020-06-14 19:37:04 +00:00
this IPKConnection conn, ulong guild, MemberId member) =>
conn.QueryFirstAsync<MemberGuildSettings>(
"insert into member_guild (guild, member) values (@guild, @member) on conflict (guild, member) do update set guild = @guild, member = @member returning *",
new {guild, member});
2020-06-13 11:58:27 +00:00
}
}