From 1c9c8af2c5b110533debbcdc55fc6bf5be6d40d4 Mon Sep 17 00:00:00 2001 From: Toastie Date: Sat, 17 Aug 2024 18:45:31 +1200 Subject: [PATCH] cleaned up inrole and whosplaying commands a little --- .../Modules/Searches/{ => Osu}/OsuCommands.cs | 0 .../Modules/Searches/{ => Osu}/OsuService.cs | 0 .../Modules/Searches/SearchesService.cs | 6 --- src/EllieBot/Modules/Utility/Utility.cs | 48 +++++++++---------- 4 files changed, 23 insertions(+), 31 deletions(-) rename src/EllieBot/Modules/Searches/{ => Osu}/OsuCommands.cs (100%) rename src/EllieBot/Modules/Searches/{ => Osu}/OsuService.cs (100%) diff --git a/src/EllieBot/Modules/Searches/OsuCommands.cs b/src/EllieBot/Modules/Searches/Osu/OsuCommands.cs similarity index 100% rename from src/EllieBot/Modules/Searches/OsuCommands.cs rename to src/EllieBot/Modules/Searches/Osu/OsuCommands.cs diff --git a/src/EllieBot/Modules/Searches/OsuService.cs b/src/EllieBot/Modules/Searches/Osu/OsuService.cs similarity index 100% rename from src/EllieBot/Modules/Searches/OsuService.cs rename to src/EllieBot/Modules/Searches/Osu/OsuService.cs diff --git a/src/EllieBot/Modules/Searches/SearchesService.cs b/src/EllieBot/Modules/Searches/SearchesService.cs index b8dd2e5..05f2d90 100644 --- a/src/EllieBot/Modules/Searches/SearchesService.cs +++ b/src/EllieBot/Modules/Searches/SearchesService.cs @@ -21,9 +21,7 @@ public class SearchesService : IEService public List MagicItems { get; } = []; private readonly IHttpClientFactory _httpFactory; private readonly IGoogleApiService _google; - private readonly IImageCache _imgs; private readonly IBotCache _c; - private readonly FontProvider _fonts; private readonly IBotCredsProvider _creds; private readonly EllieRandom _rng; private readonly List _yomamaJokes; @@ -34,17 +32,13 @@ public class SearchesService : IEService public SearchesService( IGoogleApiService google, - IImageCache images, IBotCache c, IHttpClientFactory factory, - FontProvider fonts, IBotCredsProvider creds) { _httpFactory = factory; _google = google; - _imgs = images; _c = c; - _fonts = fonts; _creds = creds; _rng = new(); diff --git a/src/EllieBot/Modules/Utility/Utility.cs b/src/EllieBot/Modules/Utility/Utility.cs index 26f3426..d670707 100644 --- a/src/EllieBot/Modules/Utility/Utility.cs +++ b/src/EllieBot/Modules/Utility/Utility.cs @@ -31,7 +31,6 @@ public partial class Utility : EllieModule PropertyNamingPolicy = LowerCaseNamingPolicy.Default }; - private static SemaphoreSlim sem = new(1, 1); private readonly DiscordSocketClient _client; private readonly ICoordinator _coord; private readonly IStatsService _stats; @@ -115,10 +114,8 @@ public partial class Utility : EllieModule var rng = new EllieRandom(); var arr = await Task.Run(() => socketGuild.Users - .Where(u => u.Activities.FirstOrDefault() - ?.Name?.Trim() - .ToUpperInvariant() - == game) + .Where(u => u.Activities.Any(x + => x.Name is not null && x.Name.ToUpperInvariant() == game)) .Select(u => u.Username) .OrderBy(_ => rng.Next()) .Take(60) @@ -154,9 +151,16 @@ public partial class Utility : EllieModule CacheMode.CacheOnly ); - var roleUsers = users.Where(u => role is null ? u.RoleIds.Count == 1 : u.RoleIds.Contains(role.Id)) - .Select(u => $"{u.Mention} {Format.Spoiler(Format.Code(u.Username))}") - .ToArray(); + users = role is null + ? users + : users.Where(u => u.RoleIds.Contains(role.Id)).ToList(); + + + var roleUsers = new List(users.Count); + foreach (var u in users) + { + roleUsers.Add($"{u.Mention} {Format.Spoiler(Format.Code(u.Username))}"); + } await Response() .Paginated() @@ -168,10 +172,11 @@ public partial class Utility : EllieModule if (pageUsers.Count == 0) return _sender.CreateEmbed().WithOkColor().WithDescription(GetText(strs.no_user_on_this_page)); + var roleName = Format.Bold(role?.Name ?? "No Role"); + return _sender.CreateEmbed() .WithOkColor() - .WithTitle(GetText(strs.inrole_list(Format.Bold(role?.Name ?? "No Role"), - roleUsers.Length))) + .WithTitle(GetText(strs.inrole_list(roleName, roleUsers.Count))) .WithDescription(string.Join("\n", pageUsers)); }) .SendAsync(); @@ -674,24 +679,17 @@ public partial class Utility : EllieModule } [Cmd] + [Ratelimit(3)] public async Task Ping() { - await sem.WaitAsync(5000); - try - { - var sw = Stopwatch.StartNew(); - var msg = await Response().Text("🏓").SendAsync(); - sw.Stop(); - msg.DeleteAfter(0); + var sw = Stopwatch.StartNew(); + var msg = await Response().Text("🏓").SendAsync(); + sw.Stop(); + msg.DeleteAfter(0); - await Response() - .Confirm($"{Format.Bold(ctx.User.ToString())} 🏓 {(int)sw.Elapsed.TotalMilliseconds}ms") - .SendAsync(); - } - finally - { - sem.Release(); - } + await Response() + .Confirm($"{Format.Bold(ctx.User.ToString())} 🏓 {(int)sw.Elapsed.TotalMilliseconds}ms") + .SendAsync(); } [Cmd]