1
0
Fork 1
mirror of https://github.com/TeamOctolings/Octobot.git synced 2025-04-20 00:43:36 +03:00

Profile ToolsCommandGroup (#254)

Contribution to #244

---------

Signed-off-by: mctaylors <cantsendmails@mctaylors.ru>
This commit is contained in:
Macintxsh 2024-01-28 16:19:46 +03:00 committed by GitHub
parent 6a81bafa23
commit 40282ecfb8
Signed by: GitHub
GPG key ID: B5690EEEBB952194
2 changed files with 86 additions and 22 deletions

View file

@ -119,6 +119,7 @@ public class SettingsCommandGroup : CommandGroup
private Task<Result> SendSettingsListAsync(JsonNode cfg, IUser bot, int page, private Task<Result> SendSettingsListAsync(JsonNode cfg, IUser bot, int page,
CancellationToken ct = default) CancellationToken ct = default)
{ {
_profiler.Push("main");
var description = new StringBuilder(); var description = new StringBuilder();
var footer = new StringBuilder(); var footer = new StringBuilder();
@ -164,6 +165,7 @@ public class SettingsCommandGroup : CommandGroup
.WithFooter(footer.ToString()) .WithFooter(footer.ToString())
.Build(); .Build();
_profiler.Pop();
return _profiler.PopWithResult(_feedback.SendContextualEmbedResultAsync(embed, ct: ct)); return _profiler.PopWithResult(_feedback.SendContextualEmbedResultAsync(embed, ct: ct));
} }

View file

@ -6,6 +6,7 @@ using Octobot.Data;
using Octobot.Extensions; using Octobot.Extensions;
using Octobot.Parsers; using Octobot.Parsers;
using Octobot.Services; using Octobot.Services;
using Octobot.Services.Profiler;
using Remora.Commands.Attributes; using Remora.Commands.Attributes;
using Remora.Commands.Groups; using Remora.Commands.Groups;
using Remora.Discord.API.Abstractions.Objects; using Remora.Discord.API.Abstractions.Objects;
@ -31,17 +32,19 @@ public class ToolsCommandGroup : CommandGroup
private readonly IDiscordRestGuildAPI _guildApi; private readonly IDiscordRestGuildAPI _guildApi;
private readonly GuildDataService _guildData; private readonly GuildDataService _guildData;
private readonly IDiscordRestUserAPI _userApi; private readonly IDiscordRestUserAPI _userApi;
private readonly Profiler _profiler;
public ToolsCommandGroup( public ToolsCommandGroup(
ICommandContext context, IFeedbackService feedback, ICommandContext context, IFeedbackService feedback,
GuildDataService guildData, IDiscordRestGuildAPI guildApi, GuildDataService guildData, IDiscordRestGuildAPI guildApi,
IDiscordRestUserAPI userApi, IDiscordRestChannelAPI channelApi) IDiscordRestUserAPI userApi, IDiscordRestChannelAPI channelApi, Profiler profiler)
{ {
_context = context; _context = context;
_guildData = guildData; _guildData = guildData;
_feedback = feedback; _feedback = feedback;
_guildApi = guildApi; _guildApi = guildApi;
_userApi = userApi; _userApi = userApi;
_profiler = profiler;
} }
/// <summary> /// <summary>
@ -73,32 +76,44 @@ public class ToolsCommandGroup : CommandGroup
[Description("User to show info about")] [Description("User to show info about")]
IUser? target = null) IUser? target = null)
{ {
_profiler.Push("userinfo_command");
_profiler.Push("preparation");
if (!_context.TryGetContextIDs(out var guildId, out _, out var executorId)) if (!_context.TryGetContextIDs(out var guildId, out _, out var executorId))
{ {
return new ArgumentInvalidError(nameof(_context), "Unable to retrieve necessary IDs from command context"); return _profiler.ReportWithResult(new ArgumentInvalidError(nameof(_context),
"Unable to retrieve necessary IDs from command context"));
} }
_profiler.Push("current_user_get");
var botResult = await _userApi.GetCurrentUserAsync(CancellationToken); var botResult = await _userApi.GetCurrentUserAsync(CancellationToken);
if (!botResult.IsDefined(out var bot)) if (!botResult.IsDefined(out var bot))
{ {
return Result.FromError(botResult); return _profiler.ReportWithResult(Result.FromError(botResult));
} }
_profiler.Pop();
_profiler.Push("executor_get");
var executorResult = await _userApi.GetUserAsync(executorId, CancellationToken); var executorResult = await _userApi.GetUserAsync(executorId, CancellationToken);
if (!executorResult.IsDefined(out var executor)) if (!executorResult.IsDefined(out var executor))
{ {
return Result.FromError(executorResult); return _profiler.ReportWithResult(Result.FromError(executorResult));
} }
_profiler.Pop();
_profiler.Push("guild_settings_get");
var data = await _guildData.GetData(guildId, CancellationToken); var data = await _guildData.GetData(guildId, CancellationToken);
Messages.Culture = GuildSettings.Language.Get(data.Settings); Messages.Culture = GuildSettings.Language.Get(data.Settings);
_profiler.Pop();
return await ShowUserInfoAsync(target ?? executor, bot, data, guildId, CancellationToken); _profiler.Pop();
return _profiler.ReportWithResult(await ShowUserInfoAsync(target ?? executor, bot, data, guildId, CancellationToken));
} }
private async Task<Result> ShowUserInfoAsync( private async Task<Result> ShowUserInfoAsync(
IUser target, IUser bot, GuildData data, Snowflake guildId, CancellationToken ct = default) IUser target, IUser bot, GuildData data, Snowflake guildId, CancellationToken ct = default)
{ {
_profiler.Push("main");
_profiler.Push("builder_construction");
var builder = new StringBuilder().AppendLine($"### <@{target.ID}>"); var builder = new StringBuilder().AppendLine($"### <@{target.ID}>");
if (target.GlobalName is not null) if (target.GlobalName is not null)
@ -114,7 +129,9 @@ public class ToolsCommandGroup : CommandGroup
var embedColor = ColorsList.Cyan; var embedColor = ColorsList.Cyan;
_profiler.Push("guild_member_get");
var guildMemberResult = await _guildApi.GetGuildMemberAsync(guildId, target.ID, ct); var guildMemberResult = await _guildApi.GetGuildMemberAsync(guildId, target.ID, ct);
_profiler.Pop();
DateTimeOffset? communicationDisabledUntil = null; DateTimeOffset? communicationDisabledUntil = null;
if (guildMemberResult.IsDefined(out var guildMember)) if (guildMemberResult.IsDefined(out var guildMember))
{ {
@ -145,6 +162,8 @@ public class ToolsCommandGroup : CommandGroup
embedColor = ColorsList.Default; embedColor = ColorsList.Default;
} }
_profiler.Pop();
_profiler.Push("embed_send");
var embed = new EmbedBuilder().WithSmallTitle( var embed = new EmbedBuilder().WithSmallTitle(
string.Format(Messages.InformationAbout, target.GetTag()), bot) string.Format(Messages.InformationAbout, target.GetTag()), bot)
.WithDescription(builder.ToString()) .WithDescription(builder.ToString())
@ -153,7 +172,7 @@ public class ToolsCommandGroup : CommandGroup
.WithFooter($"ID: {target.ID.ToString()}") .WithFooter($"ID: {target.ID.ToString()}")
.Build(); .Build();
return await _feedback.SendContextualEmbedResultAsync(embed, ct: ct); return _profiler.PopWithResult(await _feedback.SendContextualEmbedResultAsync(embed, ct: ct));
} }
private static Color AppendPunishmentsInformation(bool wasMuted, bool wasKicked, bool wasBanned, private static Color AppendPunishmentsInformation(bool wasMuted, bool wasKicked, bool wasBanned,
@ -266,31 +285,43 @@ public class ToolsCommandGroup : CommandGroup
[UsedImplicitly] [UsedImplicitly]
public async Task<Result> ExecuteGuildInfoAsync() public async Task<Result> ExecuteGuildInfoAsync()
{ {
_profiler.Push("guildinfo_command");
_profiler.Push("preparation");
if (!_context.TryGetContextIDs(out var guildId, out _, out _)) if (!_context.TryGetContextIDs(out var guildId, out _, out _))
{ {
return new ArgumentInvalidError(nameof(_context), "Unable to retrieve necessary IDs from command context"); return _profiler.ReportWithResult(new ArgumentInvalidError(nameof(_context),
"Unable to retrieve necessary IDs from command context"));
} }
_profiler.Push("current_user_get");
var botResult = await _userApi.GetCurrentUserAsync(CancellationToken); var botResult = await _userApi.GetCurrentUserAsync(CancellationToken);
if (!botResult.IsDefined(out var bot)) if (!botResult.IsDefined(out var bot))
{ {
return Result.FromError(botResult); return _profiler.ReportWithResult(Result.FromError(botResult));
} }
_profiler.Pop();
_profiler.Push("guild_get");
var guildResult = await _guildApi.GetGuildAsync(guildId, ct: CancellationToken); var guildResult = await _guildApi.GetGuildAsync(guildId, ct: CancellationToken);
if (!guildResult.IsDefined(out var guild)) if (!guildResult.IsDefined(out var guild))
{ {
return Result.FromError(guildResult); return _profiler.ReportWithResult(Result.FromError(guildResult));
} }
_profiler.Pop();
_profiler.Push("guild_settings_get");
var data = await _guildData.GetData(guildId, CancellationToken); var data = await _guildData.GetData(guildId, CancellationToken);
Messages.Culture = GuildSettings.Language.Get(data.Settings); Messages.Culture = GuildSettings.Language.Get(data.Settings);
_profiler.Pop();
return await ShowGuildInfoAsync(bot, guild, CancellationToken); _profiler.Pop();
return _profiler.ReportWithResult(await ShowGuildInfoAsync(bot, guild, CancellationToken));
} }
private Task<Result> ShowGuildInfoAsync(IUser bot, IGuild guild, CancellationToken ct) private Task<Result> ShowGuildInfoAsync(IUser bot, IGuild guild, CancellationToken ct)
{ {
_profiler.Push("main");
_profiler.Push("builder_construction");
var description = new StringBuilder().AppendLine($"## {guild.Name}"); var description = new StringBuilder().AppendLine($"## {guild.Name}");
if (guild.Description is not null) if (guild.Description is not null)
@ -316,6 +347,8 @@ public class ToolsCommandGroup : CommandGroup
embedColor = ColorsList.Magenta; embedColor = ColorsList.Magenta;
} }
_profiler.Pop();
_profiler.Push("embed_send");
var embed = new EmbedBuilder().WithSmallTitle( var embed = new EmbedBuilder().WithSmallTitle(
string.Format(Messages.InformationAbout, guild.Name), bot) string.Format(Messages.InformationAbout, guild.Name), bot)
.WithDescription(description.ToString()) .WithDescription(description.ToString())
@ -325,7 +358,7 @@ public class ToolsCommandGroup : CommandGroup
.WithFooter($"ID: {guild.ID.ToString()}") .WithFooter($"ID: {guild.ID.ToString()}")
.Build(); .Build();
return _feedback.SendContextualEmbedResultAsync(embed, ct: ct); return _profiler.PopWithResult(_feedback.SendContextualEmbedResultAsync(embed, ct: ct));
} }
/// <summary> /// <summary>
@ -345,26 +378,35 @@ public class ToolsCommandGroup : CommandGroup
[Description("Second number (Default: 0)")] [Description("Second number (Default: 0)")]
long? second = null) long? second = null)
{ {
_profiler.Push("userinfo_command");
_profiler.Push("preparation");
if (!_context.TryGetContextIDs(out var guildId, out _, out var executorId)) if (!_context.TryGetContextIDs(out var guildId, out _, out var executorId))
{ {
return new ArgumentInvalidError(nameof(_context), "Unable to retrieve necessary IDs from command context"); return _profiler.ReportWithResult(new ArgumentInvalidError(nameof(_context),
"Unable to retrieve necessary IDs from command context"));
} }
_profiler.Push("executor_get");
var executorResult = await _userApi.GetUserAsync(executorId, CancellationToken); var executorResult = await _userApi.GetUserAsync(executorId, CancellationToken);
if (!executorResult.IsDefined(out var executor)) if (!executorResult.IsDefined(out var executor))
{ {
return Result.FromError(executorResult); return _profiler.ReportWithResult(Result.FromError(executorResult));
} }
_profiler.Pop();
_profiler.Push("guild_settings_get");
var data = await _guildData.GetData(guildId, CancellationToken); var data = await _guildData.GetData(guildId, CancellationToken);
Messages.Culture = GuildSettings.Language.Get(data.Settings); Messages.Culture = GuildSettings.Language.Get(data.Settings);
_profiler.Pop();
return await SendRandomNumberAsync(first, second, executor, CancellationToken); _profiler.Pop();
return _profiler.ReportWithResult(await SendRandomNumberAsync(first, second, executor, CancellationToken));
} }
private Task<Result> SendRandomNumberAsync(long first, long? secondNullable, private Task<Result> SendRandomNumberAsync(long first, long? secondNullable,
IUser executor, CancellationToken ct) IUser executor, CancellationToken ct)
{ {
_profiler.Push("main");
const long secondDefault = 0; const long secondDefault = 0;
var second = secondNullable ?? secondDefault; var second = secondNullable ?? secondDefault;
@ -373,6 +415,7 @@ public class ToolsCommandGroup : CommandGroup
var i = Random.Shared.NextInt64(min, max + 1); var i = Random.Shared.NextInt64(min, max + 1);
_profiler.Push("builder_construction");
var description = new StringBuilder().Append("# ").Append(i); var description = new StringBuilder().Append("# ").Append(i);
description.AppendLine().AppendBulletPoint(string.Format( description.AppendLine().AppendBulletPoint(string.Format(
@ -396,13 +439,15 @@ public class ToolsCommandGroup : CommandGroup
embedColor = ColorsList.Red; embedColor = ColorsList.Red;
} }
_profiler.Pop();
_profiler.Push("embed_send");
var embed = new EmbedBuilder().WithSmallTitle( var embed = new EmbedBuilder().WithSmallTitle(
string.Format(Messages.RandomTitle, executor.GetTag()), executor) string.Format(Messages.RandomTitle, executor.GetTag()), executor)
.WithDescription(description.ToString()) .WithDescription(description.ToString())
.WithColour(embedColor) .WithColour(embedColor)
.Build(); .Build();
return _feedback.SendContextualEmbedResultAsync(embed, ct: ct); return _profiler.PopWithResult(_feedback.SendContextualEmbedResultAsync(embed, ct: ct));
} }
private static readonly TimestampStyle[] AllStyles = private static readonly TimestampStyle[] AllStyles =
@ -431,47 +476,62 @@ public class ToolsCommandGroup : CommandGroup
[Description("Offset from current time")] [Option("offset")] [Description("Offset from current time")] [Option("offset")]
string? stringOffset = null) string? stringOffset = null)
{ {
_profiler.Push("timestamp_command");
_profiler.Push("preparation");
if (!_context.TryGetContextIDs(out var guildId, out _, out var executorId)) if (!_context.TryGetContextIDs(out var guildId, out _, out var executorId))
{ {
return new ArgumentInvalidError(nameof(_context), "Unable to retrieve necessary IDs from command context"); return _profiler.ReportWithResult(new ArgumentInvalidError(nameof(_context),
"Unable to retrieve necessary IDs from command context"));
} }
_profiler.Push("current_user_get");
var botResult = await _userApi.GetCurrentUserAsync(CancellationToken); var botResult = await _userApi.GetCurrentUserAsync(CancellationToken);
if (!botResult.IsDefined(out var bot)) if (!botResult.IsDefined(out var bot))
{ {
return Result.FromError(botResult); return _profiler.ReportWithResult(Result.FromError(botResult));
} }
_profiler.Pop();
_profiler.Push("executor_get");
var executorResult = await _userApi.GetUserAsync(executorId, CancellationToken); var executorResult = await _userApi.GetUserAsync(executorId, CancellationToken);
if (!executorResult.IsDefined(out var executor)) if (!executorResult.IsDefined(out var executor))
{ {
return Result.FromError(executorResult); return _profiler.ReportWithResult(Result.FromError(executorResult));
} }
_profiler.Pop();
_profiler.Push("guild_settings_get");
var data = await _guildData.GetData(guildId, CancellationToken); var data = await _guildData.GetData(guildId, CancellationToken);
Messages.Culture = GuildSettings.Language.Get(data.Settings); Messages.Culture = GuildSettings.Language.Get(data.Settings);
_profiler.Pop();
if (stringOffset is null) if (stringOffset is null)
{ {
return await SendTimestampAsync(null, executor, CancellationToken); _profiler.Pop();
return _profiler.ReportWithResult(await SendTimestampAsync(null, executor, CancellationToken));
} }
_profiler.Push("parse_input");
var parseResult = TimeSpanParser.TryParse(stringOffset); var parseResult = TimeSpanParser.TryParse(stringOffset);
if (!parseResult.IsDefined(out var offset)) if (!parseResult.IsDefined(out var offset))
{ {
_profiler.Push("not_parsed_send");
var failedEmbed = new EmbedBuilder() var failedEmbed = new EmbedBuilder()
.WithSmallTitle(Messages.InvalidTimeSpan, bot) .WithSmallTitle(Messages.InvalidTimeSpan, bot)
.WithColour(ColorsList.Red) .WithColour(ColorsList.Red)
.Build(); .Build();
return await _feedback.SendContextualEmbedResultAsync(failedEmbed, ct: CancellationToken); return _profiler.ReportWithResult(await _feedback.SendContextualEmbedResultAsync(failedEmbed, ct: CancellationToken));
} }
return await SendTimestampAsync(offset, executor, CancellationToken); _profiler.Pop();
return _profiler.ReportWithResult(await SendTimestampAsync(offset, executor, CancellationToken));
} }
private Task<Result> SendTimestampAsync(TimeSpan? offset, IUser executor, CancellationToken ct) private Task<Result> SendTimestampAsync(TimeSpan? offset, IUser executor, CancellationToken ct)
{ {
_profiler.Push("main");
_profiler.Push("builder_construction");
var timestamp = DateTimeOffset.UtcNow.Add(offset ?? TimeSpan.Zero).ToUnixTimeSeconds(); var timestamp = DateTimeOffset.UtcNow.Add(offset ?? TimeSpan.Zero).ToUnixTimeSeconds();
var description = new StringBuilder().Append("# ").AppendLine(timestamp.ToString()); var description = new StringBuilder().Append("# ").AppendLine(timestamp.ToString());
@ -488,12 +548,14 @@ public class ToolsCommandGroup : CommandGroup
.Append(" → ").AppendLine(markdownTimestamp); .Append(" → ").AppendLine(markdownTimestamp);
} }
_profiler.Pop();
_profiler.Push("embed_send");
var embed = new EmbedBuilder().WithSmallTitle( var embed = new EmbedBuilder().WithSmallTitle(
string.Format(Messages.TimestampTitle, executor.GetTag()), executor) string.Format(Messages.TimestampTitle, executor.GetTag()), executor)
.WithDescription(description.ToString()) .WithDescription(description.ToString())
.WithColour(ColorsList.Blue) .WithColour(ColorsList.Blue)
.Build(); .Build();
return _feedback.SendContextualEmbedResultAsync(embed, ct: ct); return _profiler.PopWithResult(_feedback.SendContextualEmbedResultAsync(embed, ct: ct));
} }
} }