chore: format with csharpier
This commit is contained in:
parent
2f516dcb73
commit
4f54077c68
59 changed files with 2000 additions and 942 deletions
|
|
@ -10,7 +10,8 @@ public class RedisInviteCache(RedisService redisService) : IInviteCache
|
|||
{
|
||||
public async Task<IEnumerable<IInvite>> TryGetAsync(Snowflake guildId)
|
||||
{
|
||||
var redisInvites = await redisService.GetAsync<List<RedisInvite>>(InvitesKey(guildId)) ?? [];
|
||||
var redisInvites =
|
||||
await redisService.GetAsync<List<RedisInvite>>(InvitesKey(guildId)) ?? [];
|
||||
return redisInvites.Select(r => r.ToRemoraInvite());
|
||||
}
|
||||
|
||||
|
|
@ -25,15 +26,26 @@ internal record RedisInvite(
|
|||
RedisPartialGuild? Guild,
|
||||
RedisPartialChannel? Channel,
|
||||
RedisUser? Inviter,
|
||||
DateTimeOffset? ExpiresAt)
|
||||
DateTimeOffset? ExpiresAt
|
||||
)
|
||||
{
|
||||
public static RedisInvite FromIInvite(IInvite invite) => new(invite.Code,
|
||||
invite.Guild.Map(RedisPartialGuild.FromIPartialGuild).OrDefault(),
|
||||
invite.Channel != null ? RedisPartialChannel.FromIPartialChannel(invite.Channel) : null,
|
||||
invite.Inviter.Map(RedisUser.FromIUser).OrDefault(), invite.ExpiresAt.OrDefault());
|
||||
public static RedisInvite FromIInvite(IInvite invite) =>
|
||||
new(
|
||||
invite.Code,
|
||||
invite.Guild.Map(RedisPartialGuild.FromIPartialGuild).OrDefault(),
|
||||
invite.Channel != null ? RedisPartialChannel.FromIPartialChannel(invite.Channel) : null,
|
||||
invite.Inviter.Map(RedisUser.FromIUser).OrDefault(),
|
||||
invite.ExpiresAt.OrDefault()
|
||||
);
|
||||
|
||||
public Invite ToRemoraInvite() => new(Code, Guild?.ToRemoraPartialGuild() ?? new Optional<IPartialGuild>(),
|
||||
Channel?.ToRemoraPartialChannel(), Inviter?.ToRemoraUser() ?? new Optional<IUser>(), ExpiresAt: ExpiresAt);
|
||||
public Invite ToRemoraInvite() =>
|
||||
new(
|
||||
Code,
|
||||
Guild?.ToRemoraPartialGuild() ?? new Optional<IPartialGuild>(),
|
||||
Channel?.ToRemoraPartialChannel(),
|
||||
Inviter?.ToRemoraUser() ?? new Optional<IUser>(),
|
||||
ExpiresAt: ExpiresAt
|
||||
);
|
||||
}
|
||||
|
||||
internal record RedisPartialGuild(ulong Id, string? Name)
|
||||
|
|
@ -41,7 +53,8 @@ internal record RedisPartialGuild(ulong Id, string? Name)
|
|||
public static RedisPartialGuild FromIPartialGuild(IPartialGuild guild) =>
|
||||
new(guild.ID.Value.Value, guild.Name.OrDefault(null));
|
||||
|
||||
public PartialGuild ToRemoraPartialGuild() => new(DiscordSnowflake.New(Id), Name ?? new Optional<string>());
|
||||
public PartialGuild ToRemoraPartialGuild() =>
|
||||
new(DiscordSnowflake.New(Id), Name ?? new Optional<string>());
|
||||
}
|
||||
|
||||
internal record RedisPartialChannel(ulong Id, string? Name)
|
||||
|
|
@ -50,4 +63,4 @@ internal record RedisPartialChannel(ulong Id, string? Name)
|
|||
new(channel.ID.Value.Value, channel.Name.OrDefault(null));
|
||||
|
||||
public PartialChannel ToRemoraPartialChannel() => new(DiscordSnowflake.New(Id), Name: Name);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -10,29 +10,45 @@ public class RedisMemberCache(RedisService redisService) : IMemberCache
|
|||
{
|
||||
public async Task<IGuildMember?> TryGetAsync(Snowflake guildId, Snowflake userId)
|
||||
{
|
||||
var redisMember = await redisService.GetHashAsync<RedisMember>(GuildMembersKey(guildId), userId.ToString());
|
||||
var redisMember = await redisService.GetHashAsync<RedisMember>(
|
||||
GuildMembersKey(guildId),
|
||||
userId.ToString()
|
||||
);
|
||||
return redisMember?.ToRemoraMember();
|
||||
}
|
||||
|
||||
public async Task SetAsync(Snowflake guildId, IGuildMember member)
|
||||
{
|
||||
if (!member.User.IsDefined())
|
||||
throw new CataloggerError("Member with undefined User passed to RedisMemberCache.SetAsync");
|
||||
await redisService.SetHashAsync(GuildMembersKey(guildId), member.User.Value.ID.ToString(),
|
||||
RedisMember.FromIGuildMember(member));
|
||||
throw new CataloggerError(
|
||||
"Member with undefined User passed to RedisMemberCache.SetAsync"
|
||||
);
|
||||
await redisService.SetHashAsync(
|
||||
GuildMembersKey(guildId),
|
||||
member.User.Value.ID.ToString(),
|
||||
RedisMember.FromIGuildMember(member)
|
||||
);
|
||||
}
|
||||
|
||||
public async Task SetManyAsync(Snowflake guildId, IReadOnlyList<IGuildMember> members)
|
||||
{
|
||||
if (members.Any(m => !m.User.IsDefined()))
|
||||
throw new CataloggerError("Member with undefined User passed to RedisMemberCache.SetAsync");
|
||||
throw new CataloggerError(
|
||||
"Member with undefined User passed to RedisMemberCache.SetAsync"
|
||||
);
|
||||
var redisMembers = members.Select(RedisMember.FromIGuildMember).ToList();
|
||||
|
||||
await redisService.SetHashAsync(GuildMembersKey(guildId), redisMembers, m => m.User.Id.ToString());
|
||||
await redisService.SetHashAsync(
|
||||
GuildMembersKey(guildId),
|
||||
redisMembers,
|
||||
m => m.User.Id.ToString()
|
||||
);
|
||||
}
|
||||
|
||||
public async Task RemoveAsync(Snowflake guildId, Snowflake userId) =>
|
||||
await redisService.GetDatabase().HashDeleteAsync(GuildMembersKey(guildId), userId.ToString());
|
||||
await redisService
|
||||
.GetDatabase()
|
||||
.HashDeleteAsync(GuildMembersKey(guildId), userId.ToString());
|
||||
|
||||
public async Task<bool> IsGuildCachedAsync(Snowflake guildId) =>
|
||||
await redisService.GetDatabase().SetContainsAsync(GuildCacheKey, guildId.ToString());
|
||||
|
|
@ -44,6 +60,7 @@ public class RedisMemberCache(RedisService redisService) : IMemberCache
|
|||
await redisService.GetDatabase().SetRemoveAsync(GuildCacheKey, guildId.ToString());
|
||||
|
||||
private const string GuildCacheKey = "cached-guilds";
|
||||
|
||||
private static string GuildMembersKey(Snowflake guildId) => $"guild-members:{guildId}";
|
||||
}
|
||||
|
||||
|
|
@ -56,16 +73,37 @@ internal record RedisMember(
|
|||
DateTimeOffset? PremiumSince,
|
||||
GuildMemberFlags Flags,
|
||||
bool? IsPending,
|
||||
DateTimeOffset? CommunicationDisabledUntil)
|
||||
DateTimeOffset? CommunicationDisabledUntil
|
||||
)
|
||||
{
|
||||
public static RedisMember FromIGuildMember(IGuildMember member) => new(
|
||||
RedisUser.FromIUser(member.User.Value), member.Nickname.OrDefault(null), member.Avatar.OrDefault(null)?.Value,
|
||||
member.Roles.ToArray(), member.JoinedAt, member.PremiumSince.OrDefault(null), member.Flags,
|
||||
member.IsPending.OrDefault(null), member.CommunicationDisabledUntil.OrDefault(null));
|
||||
public static RedisMember FromIGuildMember(IGuildMember member) =>
|
||||
new(
|
||||
RedisUser.FromIUser(member.User.Value),
|
||||
member.Nickname.OrDefault(null),
|
||||
member.Avatar.OrDefault(null)?.Value,
|
||||
member.Roles.ToArray(),
|
||||
member.JoinedAt,
|
||||
member.PremiumSince.OrDefault(null),
|
||||
member.Flags,
|
||||
member.IsPending.OrDefault(null),
|
||||
member.CommunicationDisabledUntil.OrDefault(null)
|
||||
);
|
||||
|
||||
public GuildMember ToRemoraMember() => new(User.ToRemoraUser(), Nickname,
|
||||
Avatar != null ? new ImageHash(Avatar) : null, Roles, JoinedAt, PremiumSince, false, false, Flags,
|
||||
IsPending, default, CommunicationDisabledUntil);
|
||||
public GuildMember ToRemoraMember() =>
|
||||
new(
|
||||
User.ToRemoraUser(),
|
||||
Nickname,
|
||||
Avatar != null ? new ImageHash(Avatar) : null,
|
||||
Roles,
|
||||
JoinedAt,
|
||||
PremiumSince,
|
||||
false,
|
||||
false,
|
||||
Flags,
|
||||
IsPending,
|
||||
default,
|
||||
CommunicationDisabledUntil
|
||||
);
|
||||
}
|
||||
|
||||
internal record RedisUser(
|
||||
|
|
@ -76,13 +114,30 @@ internal record RedisUser(
|
|||
string? Avatar,
|
||||
bool IsBot,
|
||||
bool IsSystem,
|
||||
string? Banner)
|
||||
string? Banner
|
||||
)
|
||||
{
|
||||
public static RedisUser FromIUser(IUser user) => new(user.ID.Value, user.Username, user.Discriminator,
|
||||
user.GlobalName.OrDefault(null), user.Avatar?.Value, user.IsBot.OrDefault(false),
|
||||
user.IsSystem.OrDefault(false), user.Banner.OrDefault(null)?.Value);
|
||||
public static RedisUser FromIUser(IUser user) =>
|
||||
new(
|
||||
user.ID.Value,
|
||||
user.Username,
|
||||
user.Discriminator,
|
||||
user.GlobalName.OrDefault(null),
|
||||
user.Avatar?.Value,
|
||||
user.IsBot.OrDefault(false),
|
||||
user.IsSystem.OrDefault(false),
|
||||
user.Banner.OrDefault(null)?.Value
|
||||
);
|
||||
|
||||
public User ToRemoraUser() => new(DiscordSnowflake.New(Id), Username, Discriminator, GlobalName,
|
||||
Avatar != null ? new ImageHash(Avatar) : null, IsBot, IsSystem,
|
||||
Banner: Banner != null ? new ImageHash(Banner) : null);
|
||||
}
|
||||
public User ToRemoraUser() =>
|
||||
new(
|
||||
DiscordSnowflake.New(Id),
|
||||
Username,
|
||||
Discriminator,
|
||||
GlobalName,
|
||||
Avatar != null ? new ImageHash(Avatar) : null,
|
||||
IsBot,
|
||||
IsSystem,
|
||||
Banner: Banner != null ? new ImageHash(Banner) : null
|
||||
);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -12,4 +12,4 @@ public class RedisWebhookCache(RedisService redisService) : IWebhookCache
|
|||
await redisService.SetAsync(WebhookKey(channelId), webhook, 24.Hours());
|
||||
|
||||
private static string WebhookKey(ulong channelId) => $"webhook:{channelId}";
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue