71 lines
No EOL
2.7 KiB
C#
71 lines
No EOL
2.7 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.ComponentModel;
|
|
using System.Threading.Tasks;
|
|
using DSharpPlus.Commands;
|
|
using DSharpPlus.Commands.ContextChecks;
|
|
using DSharpPlus.Commands.Processors.SlashCommands;
|
|
using DSharpPlus.Entities;
|
|
using MySqlConnector;
|
|
|
|
namespace SupportChild.Commands;
|
|
|
|
public class RemoveStaffCommand
|
|
{
|
|
[RequireGuild]
|
|
[Command("removestaff")]
|
|
[Description("Removes a staff member.")]
|
|
public async Task OnExecute(SlashCommandContext command,
|
|
[Parameter("user")][Description("User to remove from staff.")] DiscordUser user)
|
|
{
|
|
if (!Database.IsStaff(user.Id))
|
|
{
|
|
await command.RespondAsync(new DiscordEmbedBuilder
|
|
{
|
|
Color = DiscordColor.Red,
|
|
Description = "User is already not registered as staff."
|
|
}, true);
|
|
return;
|
|
}
|
|
|
|
await command.DeferResponseAsync(true);
|
|
|
|
if (Database.TryGetAssignedTickets(user.Id, out List<Database.Ticket> assignedTickets))
|
|
{
|
|
foreach (Database.Ticket assignedTicket in assignedTickets)
|
|
{
|
|
Database.UnassignStaff(assignedTicket);
|
|
try
|
|
{
|
|
DiscordChannel ticketChannel = await SupportChild.client.GetChannelAsync(assignedTicket.channelID);
|
|
await ticketChannel.SendMessageAsync(new DiscordEmbedBuilder
|
|
{
|
|
Color = DiscordColor.Green,
|
|
Description = "Unassigned <@" + assignedTicket.assignedStaffID + "> from ticket."
|
|
});
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
Logger.Error("Error when trying to send message about unassigning staff member from ticket-" + assignedTicket.id.ToString("00000"), e);
|
|
}
|
|
|
|
await LogChannel.Success("<@" + assignedTicket.assignedStaffID + "> was unassigned from <#" + assignedTicket.channelID + "> by " + command.User.Mention + ".", assignedTicket.id);
|
|
}
|
|
}
|
|
|
|
await using MySqlConnection c = Database.GetConnection();
|
|
c.Open();
|
|
MySqlCommand deletion = new MySqlCommand(@"DELETE FROM staff WHERE user_id=@user_id", c);
|
|
deletion.Parameters.AddWithValue("@user_id", user.Id);
|
|
await deletion.PrepareAsync();
|
|
deletion.ExecuteNonQuery();
|
|
|
|
await command.RespondAsync(new DiscordEmbedBuilder
|
|
{
|
|
Color = DiscordColor.Green,
|
|
Description = "User was removed from staff."
|
|
}, true);
|
|
|
|
await LogChannel.Success(user.Mention + " was removed from staff by " + command.User.Mention + ".");
|
|
}
|
|
} |