chore: format with csharpier
This commit is contained in:
parent
2f516dcb73
commit
4f54077c68
59 changed files with 2000 additions and 942 deletions
|
|
@ -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
|
||||
);
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue