using System; using System.ComponentModel; using System.Threading.Tasks; using DSharpPlus.Commands; using DSharpPlus.Commands.ContextChecks; using DSharpPlus.Commands.Processors.SlashCommands; using DSharpPlus.Entities; using DSharpPlus.Exceptions; using MySqlConnector; namespace SupportChild.Commands; public class AddStaffCommand { [RequireGuild] [Command("addstaff")] [Description("Adds a new staff member.")] public async Task OnExecute(SlashCommandContext command, [Parameter("user")][Description("User to add to staff.")] DiscordUser user) { DiscordMember staffMember = null; try { staffMember = user == null ? command.Member : await command.Guild.GetMemberAsync(user.Id); if (staffMember == null) { await command.RespondAsync(new DiscordEmbedBuilder { Color = DiscordColor.Red, Description = "Could not find that user in this server." }, true); return; } } catch (Exception) { await command.RespondAsync(new DiscordEmbedBuilder { Color = DiscordColor.Red, Description = "Could not find that user in this server." }, true); return; } await using MySqlConnection c = Database.GetConnection(); MySqlCommand cmd = Database.IsStaff(staffMember.Id) ? new MySqlCommand(@"UPDATE staff SET name = @name WHERE user_id = @user_id", c) : new MySqlCommand(@"INSERT INTO staff (user_id, name) VALUES (@user_id, @name);", c); c.Open(); cmd.Parameters.AddWithValue("@user_id", staffMember.Id); cmd.Parameters.AddWithValue("@name", staffMember.DisplayName); cmd.ExecuteNonQuery(); cmd.Dispose(); await command.RespondAsync(new DiscordEmbedBuilder { Color = DiscordColor.Green, Description = staffMember.Mention + " was added to staff." }); try { // Log it if the log channel exists DiscordChannel logChannel = await SupportChild.client.GetChannelAsync(Config.logChannel); await logChannel.SendMessageAsync(new DiscordEmbedBuilder { Color = DiscordColor.Green, Description = staffMember.Mention + " was added to staff by " + command.User.Mention + "." }); } catch (NotFoundException) { Logger.Error("Could not send message in log channel."); } } }