mirror of
https://github.com/TeamOctolings/Octobot.git
synced 2025-04-19 16:33:36 +03:00
Profile last 4 commands
Signed-off-by: mctaylors <cantsendmails@mctaylors.ru>
This commit is contained in:
parent
6a81bafa23
commit
5d87be844e
1 changed files with 85 additions and 14 deletions
|
@ -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 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 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)
|
||||||
|
@ -118,9 +133,11 @@ public class ToolsCommandGroup : CommandGroup
|
||||||
DateTimeOffset? communicationDisabledUntil = null;
|
DateTimeOffset? communicationDisabledUntil = null;
|
||||||
if (guildMemberResult.IsDefined(out var guildMember))
|
if (guildMemberResult.IsDefined(out var guildMember))
|
||||||
{
|
{
|
||||||
|
_profiler.Push("append_guild");
|
||||||
communicationDisabledUntil = guildMember.CommunicationDisabledUntil.OrDefault(null);
|
communicationDisabledUntil = guildMember.CommunicationDisabledUntil.OrDefault(null);
|
||||||
|
|
||||||
embedColor = AppendGuildInformation(embedColor, guildMember, builder);
|
embedColor = AppendGuildInformation(embedColor, guildMember, builder);
|
||||||
|
_profiler.Pop();
|
||||||
}
|
}
|
||||||
|
|
||||||
var wasMuted = (memberData.MutedUntil is not null && DateTimeOffset.UtcNow <= memberData.MutedUntil) ||
|
var wasMuted = (memberData.MutedUntil is not null && DateTimeOffset.UtcNow <= memberData.MutedUntil) ||
|
||||||
|
@ -130,11 +147,13 @@ public class ToolsCommandGroup : CommandGroup
|
||||||
|
|
||||||
if (wasMuted || wasBanned || wasKicked)
|
if (wasMuted || wasBanned || wasKicked)
|
||||||
{
|
{
|
||||||
|
_profiler.Push("append_punishments");
|
||||||
builder.Append("### ")
|
builder.Append("### ")
|
||||||
.AppendLine(Markdown.Bold(Messages.UserInfoPunishments));
|
.AppendLine(Markdown.Bold(Messages.UserInfoPunishments));
|
||||||
|
|
||||||
embedColor = AppendPunishmentsInformation(wasMuted, wasKicked, wasBanned, memberData,
|
embedColor = AppendPunishmentsInformation(wasMuted, wasKicked, wasBanned, memberData,
|
||||||
builder, embedColor, communicationDisabledUntil);
|
builder, embedColor, communicationDisabledUntil);
|
||||||
|
_profiler.Pop();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!guildMemberResult.IsSuccess && !wasBanned)
|
if (!guildMemberResult.IsSuccess && !wasBanned)
|
||||||
|
@ -145,6 +164,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 +174,8 @@ public class ToolsCommandGroup : CommandGroup
|
||||||
.WithFooter($"ID: {target.ID.ToString()}")
|
.WithFooter($"ID: {target.ID.ToString()}")
|
||||||
.Build();
|
.Build();
|
||||||
|
|
||||||
return await _feedback.SendContextualEmbedResultAsync(embed, ct: ct);
|
_profiler.Pop();
|
||||||
|
return await _profiler.PopWithResult(_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 +288,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 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 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 +350,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 +361,8 @@ public class ToolsCommandGroup : CommandGroup
|
||||||
.WithFooter($"ID: {guild.ID.ToString()}")
|
.WithFooter($"ID: {guild.ID.ToString()}")
|
||||||
.Build();
|
.Build();
|
||||||
|
|
||||||
return _feedback.SendContextualEmbedResultAsync(embed, ct: ct);
|
_profiler.Pop();
|
||||||
|
return _profiler.PopWithResult(_feedback.SendContextualEmbedResultAsync(embed, ct: ct));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -345,26 +382,37 @@ 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.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 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");
|
||||||
|
_profiler.Push("random_number_get");
|
||||||
const long secondDefault = 0;
|
const long secondDefault = 0;
|
||||||
var second = secondNullable ?? secondDefault;
|
var second = secondNullable ?? secondDefault;
|
||||||
|
|
||||||
|
@ -373,6 +421,8 @@ public class ToolsCommandGroup : CommandGroup
|
||||||
|
|
||||||
var i = Random.Shared.NextInt64(min, max + 1);
|
var i = Random.Shared.NextInt64(min, max + 1);
|
||||||
|
|
||||||
|
_profiler.Pop();
|
||||||
|
_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 +446,16 @@ 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);
|
_profiler.Pop();
|
||||||
|
return _profiler.PopWithResult(_feedback.SendContextualEmbedResultAsync(embed, ct: ct));
|
||||||
}
|
}
|
||||||
|
|
||||||
private static readonly TimestampStyle[] AllStyles =
|
private static readonly TimestampStyle[] AllStyles =
|
||||||
|
@ -431,31 +484,42 @@ 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 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 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))
|
||||||
{
|
{
|
||||||
|
@ -467,11 +531,15 @@ public class ToolsCommandGroup : CommandGroup
|
||||||
return await _feedback.SendContextualEmbedResultAsync(failedEmbed, ct: CancellationToken);
|
return await _feedback.SendContextualEmbedResultAsync(failedEmbed, ct: CancellationToken);
|
||||||
}
|
}
|
||||||
|
|
||||||
return await SendTimestampAsync(offset, executor, CancellationToken);
|
_profiler.Pop();
|
||||||
|
_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 +556,15 @@ 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);
|
_profiler.Pop();
|
||||||
|
return _profiler.PopWithResult(_feedback.SendContextualEmbedResultAsync(embed, ct: ct));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue