chore: format with csharpier
This commit is contained in:
parent
2f516dcb73
commit
4f54077c68
59 changed files with 2000 additions and 942 deletions
|
|
@ -7,4 +7,4 @@ public interface IInviteCache
|
|||
{
|
||||
public Task<IEnumerable<IInvite>> TryGetAsync(Snowflake guildId);
|
||||
public Task SetAsync(Snowflake guildId, IEnumerable<IInvite> invites);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -12,4 +12,4 @@ public interface IMemberCache
|
|||
public Task<bool> IsGuildCachedAsync(Snowflake guildId);
|
||||
public Task MarkAsCachedAsync(Snowflake guildId);
|
||||
public Task MarkAsUncachedAsync(Snowflake guildId);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -10,13 +10,21 @@ public interface IWebhookCache
|
|||
Task<Webhook?> GetWebhookAsync(ulong channelId);
|
||||
Task SetWebhookAsync(ulong channelId, Webhook webhook);
|
||||
|
||||
public async Task<Webhook> GetOrFetchWebhookAsync(ulong channelId, Func<Snowflake, Task<IWebhook>> fetch)
|
||||
public async Task<Webhook> GetOrFetchWebhookAsync(
|
||||
ulong channelId,
|
||||
Func<Snowflake, Task<IWebhook>> fetch
|
||||
)
|
||||
{
|
||||
var webhook = await GetWebhookAsync(channelId);
|
||||
if (webhook != null) return webhook.Value;
|
||||
if (webhook != null)
|
||||
return webhook.Value;
|
||||
|
||||
var discordWebhook = await fetch(DiscordSnowflake.New(channelId));
|
||||
webhook = new Webhook { Id = discordWebhook.ID.ToUlong(), Token = discordWebhook.Token.Value };
|
||||
webhook = new Webhook
|
||||
{
|
||||
Id = discordWebhook.ID.ToUlong(),
|
||||
Token = discordWebhook.Token.Value,
|
||||
};
|
||||
await SetWebhookAsync(channelId, webhook.Value);
|
||||
return webhook.Value;
|
||||
}
|
||||
|
|
@ -26,4 +34,4 @@ public struct Webhook
|
|||
{
|
||||
public required ulong Id { get; init; }
|
||||
public required string Token { get; init; }
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -6,10 +6,21 @@ namespace Catalogger.Backend.Cache.InMemoryCache;
|
|||
|
||||
public class AuditLogCache
|
||||
{
|
||||
private readonly ConcurrentDictionary<(Snowflake GuildId, Snowflake TargetId), ActionData> _kicks = new();
|
||||
private readonly ConcurrentDictionary<(Snowflake GuildId, Snowflake TargetId), ActionData> _bans = new();
|
||||
private readonly ConcurrentDictionary<
|
||||
(Snowflake GuildId, Snowflake TargetId),
|
||||
ActionData
|
||||
> _kicks = new();
|
||||
private readonly ConcurrentDictionary<
|
||||
(Snowflake GuildId, Snowflake TargetId),
|
||||
ActionData
|
||||
> _bans = new();
|
||||
|
||||
public void SetKick(Snowflake guildId, string targetId, Snowflake moderatorId, Optional<string> reason)
|
||||
public void SetKick(
|
||||
Snowflake guildId,
|
||||
string targetId,
|
||||
Snowflake moderatorId,
|
||||
Optional<string> reason
|
||||
)
|
||||
{
|
||||
if (!DiscordSnowflake.TryParse(targetId, out var targetUser))
|
||||
throw new CataloggerError("Target ID was not a valid snowflake");
|
||||
|
|
@ -20,16 +31,21 @@ public class AuditLogCache
|
|||
public bool TryGetKick(Snowflake guildId, Snowflake targetId, out ActionData data) =>
|
||||
_kicks.TryGetValue((guildId, targetId), out data);
|
||||
|
||||
public void SetBan(Snowflake guildId, string targetId, Snowflake moderatorId, Optional<string> reason)
|
||||
public void SetBan(
|
||||
Snowflake guildId,
|
||||
string targetId,
|
||||
Snowflake moderatorId,
|
||||
Optional<string> reason
|
||||
)
|
||||
{
|
||||
if (!DiscordSnowflake.TryParse(targetId, out var targetUser))
|
||||
throw new CataloggerError("Target ID was not a valid snowflake");
|
||||
|
||||
_bans[(guildId, targetUser.Value)] = new ActionData(moderatorId, reason.OrDefault());
|
||||
}
|
||||
|
||||
|
||||
public bool TryGetBan(Snowflake guildId, Snowflake targetId, out ActionData data) =>
|
||||
_bans.TryGetValue((guildId, targetId), out data);
|
||||
|
||||
public record struct ActionData(Snowflake ModeratorId, string? Reason);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -17,18 +17,21 @@ public class ChannelCache
|
|||
_channels[channel.ID] = channel;
|
||||
if (guildId == null)
|
||||
{
|
||||
if (!channel.GuildID.TryGet(out var snowflake)) return;
|
||||
if (!channel.GuildID.TryGet(out var snowflake))
|
||||
return;
|
||||
guildId = snowflake;
|
||||
}
|
||||
|
||||
// Add to set of guild channels
|
||||
_guildChannels.AddOrUpdate(guildId.Value,
|
||||
_guildChannels.AddOrUpdate(
|
||||
guildId.Value,
|
||||
_ => [channel.ID],
|
||||
(_, l) =>
|
||||
{
|
||||
l.Add(channel.ID);
|
||||
return l;
|
||||
});
|
||||
}
|
||||
);
|
||||
}
|
||||
|
||||
public bool TryGet(Snowflake id, [NotNullWhen(true)] out IChannel? channel) =>
|
||||
|
|
@ -37,13 +40,18 @@ public class ChannelCache
|
|||
public void Remove(Snowflake? guildId, Snowflake id, out IChannel? channel)
|
||||
{
|
||||
_channels.Remove(id, out channel);
|
||||
if (guildId == null) return;
|
||||
if (guildId == null)
|
||||
return;
|
||||
// Remove from set of guild channels
|
||||
_guildChannels.AddOrUpdate(guildId.Value, _ => [], (_, s) =>
|
||||
{
|
||||
s.Remove(id);
|
||||
return s;
|
||||
});
|
||||
_guildChannels.AddOrUpdate(
|
||||
guildId.Value,
|
||||
_ => [],
|
||||
(_, s) =>
|
||||
{
|
||||
s.Remove(id);
|
||||
return s;
|
||||
}
|
||||
);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
|
|
@ -54,6 +62,8 @@ public class ChannelCache
|
|||
public IEnumerable<IChannel> GuildChannels(Snowflake guildId) =>
|
||||
!_guildChannels.TryGetValue(guildId, out var channelIds)
|
||||
? []
|
||||
: channelIds.Select(id => _channels.GetValueOrDefault(id))
|
||||
.Where(c => c != null).Select(c => c!);
|
||||
}
|
||||
: channelIds
|
||||
.Select(id => _channels.GetValueOrDefault(id))
|
||||
.Where(c => c != null)
|
||||
.Select(c => c!);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -12,6 +12,10 @@ public class GuildCache
|
|||
public int Size => _guilds.Count;
|
||||
|
||||
public void Set(IGuild guild) => _guilds[guild.ID] = guild;
|
||||
public bool Remove(Snowflake id, [NotNullWhen(true)] out IGuild? guild) => _guilds.Remove(id, out guild);
|
||||
public bool TryGet(Snowflake id, [NotNullWhen(true)] out IGuild? guild) => _guilds.TryGetValue(id, out guild);
|
||||
}
|
||||
|
||||
public bool Remove(Snowflake id, [NotNullWhen(true)] out IGuild? guild) =>
|
||||
_guilds.Remove(id, out guild);
|
||||
|
||||
public bool TryGet(Snowflake id, [NotNullWhen(true)] out IGuild? guild) =>
|
||||
_guilds.TryGetValue(id, out guild);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -8,13 +8,14 @@ public class InMemoryInviteCache : IInviteCache
|
|||
{
|
||||
private readonly ConcurrentDictionary<Snowflake, IEnumerable<IInvite>> _invites = new();
|
||||
|
||||
public Task<IEnumerable<IInvite>> TryGetAsync(Snowflake guildId) => _invites.TryGetValue(guildId, out var invites)
|
||||
? Task.FromResult(invites)
|
||||
: Task.FromResult<IEnumerable<IInvite>>([]);
|
||||
public Task<IEnumerable<IInvite>> TryGetAsync(Snowflake guildId) =>
|
||||
_invites.TryGetValue(guildId, out var invites)
|
||||
? Task.FromResult(invites)
|
||||
: Task.FromResult<IEnumerable<IInvite>>([]);
|
||||
|
||||
public Task SetAsync(Snowflake guildId, IEnumerable<IInvite> invites)
|
||||
{
|
||||
_invites[guildId] = invites;
|
||||
return Task.CompletedTask;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -19,7 +19,9 @@ public class InMemoryMemberCache : IMemberCache
|
|||
public Task SetAsync(Snowflake guildId, IGuildMember member)
|
||||
{
|
||||
if (!member.User.IsDefined())
|
||||
throw new CataloggerError("Member with undefined User passed to InMemoryMemberCache.SetAsync");
|
||||
throw new CataloggerError(
|
||||
"Member with undefined User passed to InMemoryMemberCache.SetAsync"
|
||||
);
|
||||
_members[(guildId, member.User.Value.ID)] = member;
|
||||
return Task.CompletedTask;
|
||||
}
|
||||
|
|
@ -36,7 +38,8 @@ public class InMemoryMemberCache : IMemberCache
|
|||
return Task.CompletedTask;
|
||||
}
|
||||
|
||||
public Task<bool> IsGuildCachedAsync(Snowflake guildId) => Task.FromResult(_guilds.ContainsKey(guildId));
|
||||
public Task<bool> IsGuildCachedAsync(Snowflake guildId) =>
|
||||
Task.FromResult(_guilds.ContainsKey(guildId));
|
||||
|
||||
public Task MarkAsCachedAsync(Snowflake guildId)
|
||||
{
|
||||
|
|
@ -49,4 +52,4 @@ public class InMemoryMemberCache : IMemberCache
|
|||
_guilds.Remove(guildId, out _);
|
||||
return Task.CompletedTask;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -18,4 +18,4 @@ public class InMemoryWebhookCache : IWebhookCache
|
|||
_cache[channelId] = webhook;
|
||||
return Task.CompletedTask;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -16,13 +16,15 @@ public class RoleCache
|
|||
{
|
||||
_roles[role.ID] = role;
|
||||
// Add to set of guild channels
|
||||
_guildRoles.AddOrUpdate(guildId,
|
||||
_guildRoles.AddOrUpdate(
|
||||
guildId,
|
||||
_ => [role.ID],
|
||||
(_, l) =>
|
||||
{
|
||||
l.Add(role.ID);
|
||||
return l;
|
||||
});
|
||||
}
|
||||
);
|
||||
}
|
||||
|
||||
public bool TryGet(Snowflake id, [NotNullWhen(true)] out IRole? role) =>
|
||||
|
|
@ -32,16 +34,21 @@ public class RoleCache
|
|||
{
|
||||
_roles.Remove(id, out role);
|
||||
// Remove from set of guild channels
|
||||
_guildRoles.AddOrUpdate(guildId, _ => [], (_, s) =>
|
||||
{
|
||||
s.Remove(id);
|
||||
return s;
|
||||
});
|
||||
_guildRoles.AddOrUpdate(
|
||||
guildId,
|
||||
_ => [],
|
||||
(_, s) =>
|
||||
{
|
||||
s.Remove(id);
|
||||
return s;
|
||||
}
|
||||
);
|
||||
}
|
||||
|
||||
public void RemoveGuild(Snowflake guildId)
|
||||
{
|
||||
if (!_guildRoles.TryGetValue(guildId, out var roleIds)) return;
|
||||
if (!_guildRoles.TryGetValue(guildId, out var roleIds))
|
||||
return;
|
||||
foreach (var id in roleIds)
|
||||
{
|
||||
_roles.Remove(id, out _);
|
||||
|
|
@ -58,6 +65,8 @@ public class RoleCache
|
|||
public IEnumerable<IRole> GuildRoles(Snowflake guildId) =>
|
||||
!_guildRoles.TryGetValue(guildId, out var roleIds)
|
||||
? []
|
||||
: roleIds.Select(id => _roles.GetValueOrDefault(id))
|
||||
.Where(r => r != null).Select(r => r!);
|
||||
}
|
||||
: roleIds
|
||||
.Select(id => _roles.GetValueOrDefault(id))
|
||||
.Where(r => r != null)
|
||||
.Select(r => r!);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -13,13 +13,16 @@ public class UserCache(IDiscordRestUserAPI userApi)
|
|||
|
||||
public int Size => _cacheSize;
|
||||
|
||||
public async Task<IUser?> GetUserAsync(Snowflake userId) => await _cache.GetOrAddAsync(userId.ToString(),
|
||||
async () =>
|
||||
{
|
||||
var user = await userApi.GetUserAsync(userId).GetOrThrow();
|
||||
Interlocked.Increment(ref _cacheSize);
|
||||
return user;
|
||||
});
|
||||
public async Task<IUser?> GetUserAsync(Snowflake userId) =>
|
||||
await _cache.GetOrAddAsync(
|
||||
userId.ToString(),
|
||||
async () =>
|
||||
{
|
||||
var user = await userApi.GetUserAsync(userId).GetOrThrow();
|
||||
Interlocked.Increment(ref _cacheSize);
|
||||
return user;
|
||||
}
|
||||
);
|
||||
|
||||
public void UpdateUser(IUser user) => _cache.Add(user.ID.ToString(), user);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -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