2022-04-18 22:52:03 +12:00
using System ;
2024-12-26 18:36:20 +13:00
using System.ComponentModel ;
2022-02-21 21:40:09 +13:00
using System.Threading.Tasks ;
2024-12-26 18:36:20 +13:00
using DSharpPlus.Commands ;
using DSharpPlus.Commands.ContextChecks ;
using DSharpPlus.Commands.Processors.SlashCommands ;
2022-02-21 21:40:09 +13:00
using DSharpPlus.Entities ;
2024-12-26 18:57:41 +13:00
using DSharpPlus.Exceptions ;
2023-03-24 01:21:20 +13:00
using MySqlConnector ;
2022-02-21 21:40:09 +13:00
2022-08-21 19:34:11 +12:00
namespace SupportChild.Commands ;
2024-12-26 18:36:20 +13:00
public class AddStaffCommand
2022-02-21 21:40:09 +13:00
{
2024-12-26 18:36:20 +13:00
[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 )
2024-10-29 22:10:37 +13:00
{
DiscordMember staffMember = null ;
try
{
staffMember = user = = null ? command . Member : await command . Guild . GetMemberAsync ( user . Id ) ;
2022-02-21 21:40:09 +13:00
2024-10-29 22:10:37 +13:00
if ( staffMember = = null )
{
2024-12-26 18:36:20 +13:00
await command . RespondAsync ( new DiscordEmbedBuilder
2024-10-29 22:10:37 +13:00
{
Color = DiscordColor . Red ,
Description = "Could not find that user in this server."
} , true ) ;
return ;
}
}
catch ( Exception )
{
2024-12-26 18:36:20 +13:00
await command . RespondAsync ( new DiscordEmbedBuilder
2024-10-29 22:10:37 +13:00
{
Color = DiscordColor . Red ,
Description = "Could not find that user in this server."
} , true ) ;
return ;
}
2022-02-21 21:40:09 +13:00
2024-12-27 18:18:23 +13:00
bool alreadyStaff = Database . IsStaff ( staffMember . Id ) ;
2024-10-29 22:10:37 +13:00
await using MySqlConnection c = Database . GetConnection ( ) ;
2024-12-27 18:18:23 +13:00
MySqlCommand cmd = alreadyStaff ? 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 ) ;
2022-02-21 21:40:09 +13:00
2024-10-29 22:10:37 +13:00
c . Open ( ) ;
cmd . Parameters . AddWithValue ( "@user_id" , staffMember . Id ) ;
cmd . Parameters . AddWithValue ( "@name" , staffMember . DisplayName ) ;
cmd . ExecuteNonQuery ( ) ;
cmd . Dispose ( ) ;
2022-02-21 21:40:09 +13:00
2024-12-26 18:36:20 +13:00
await command . RespondAsync ( new DiscordEmbedBuilder
2024-10-29 22:10:37 +13:00
{
Color = DiscordColor . Green ,
2024-12-27 18:18:23 +13:00
Description = alreadyStaff ? staffMember . Mention + " is already a staff member, refreshed username in database." : staffMember . Mention + " was added to staff."
2024-12-27 18:15:54 +13:00
} , true ) ;
2022-02-21 21:40:09 +13:00
2024-12-26 18:57:41 +13:00
try
2024-10-29 22:10:37 +13:00
{
2024-12-26 18:57:41 +13:00
// Log it if the log channel exists
DiscordChannel logChannel = await SupportChild . client . GetChannelAsync ( Config . logChannel ) ;
2024-10-29 22:10:37 +13:00
await logChannel . SendMessageAsync ( new DiscordEmbedBuilder
{
Color = DiscordColor . Green ,
2024-12-27 01:21:37 +13:00
Description = staffMember . Mention + " was added to staff by " + command . User . Mention + "."
2024-10-29 22:10:37 +13:00
} ) ;
}
2024-12-26 18:57:41 +13:00
catch ( NotFoundException )
{
2024-12-27 16:53:40 +13:00
Logger . Error ( "Could not send message in log channel." ) ;
2024-12-26 18:57:41 +13:00
}
2024-10-29 22:10:37 +13:00
}
2022-05-19 23:38:59 +12:00
}