2024-12-27 16:43:55 +13:00
using System ;
2024-12-26 18:36:20 +13:00
using System.ComponentModel ;
2022-08-21 19:34:11 +12: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-08-21 19:34:11 +12:00
using DSharpPlus.Entities ;
2024-12-26 18:57:41 +13:00
using DSharpPlus.Exceptions ;
2024-12-27 16:22:30 +13:00
using SupportChild.Interviews ;
2022-08-21 19:34:11 +12:00
namespace SupportChild.Commands ;
2024-12-26 18:36:20 +13:00
[Command("admin")]
[Description("Administrative commands.")]
public class AdminCommands
2022-08-21 19:34:11 +12:00
{
2024-12-26 18:36:20 +13:00
[RequireGuild]
[Command("setticket")]
[Description("Turns a channel into a ticket. WARNING: Anyone will be able to delete the channel using /close.")]
public async Task SetTicket ( SlashCommandContext command ,
2024-12-27 16:43:55 +13:00
[Parameter("user")] [ Description ( "(Optional) The owner of the ticket." ) ] DiscordUser user = null )
2024-10-29 22:10:37 +13:00
{
// Check if ticket exists in the database
if ( Database . IsOpenTicket ( command . Channel . Id ) )
{
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 = "This channel is already a ticket."
} , true ) ;
return ;
}
2024-12-27 02:09:08 +13:00
DiscordUser ticketUser = user = = null ? command . User : user ;
2024-10-29 22:10:37 +13:00
long id = Database . NewTicket ( ticketUser . Id , 0 , command . Channel . Id ) ;
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 01:21:37 +13:00
Description = "Channel has been designated ticket " + id . ToString ( "00000" ) + "."
2024-10-29 22:10:37 +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 = command . Channel . Mention + " has been designated ticket " + id . ToString ( "00000" ) + " by " + command . Member ? . Mention + "." ,
Footer = new DiscordEmbedBuilder . EmbedFooter
{
Text = "Ticket: " + id . ToString ( "00000" )
}
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
}
2024-12-26 18:36:20 +13:00
[RequireGuild]
[Command("unsetticket")]
[Description("Deletes a ticket from the ticket system without deleting the channel.")]
public async Task UnsetTicket ( SlashCommandContext command ,
2024-12-27 16:43:55 +13:00
[Parameter("ticket-id")] [ Description ( "(Optional) Ticket to unset. Uses the channel you are in by default. Use ticket ID, not channel ID!" ) ] long ticketID = 0 )
2024-10-29 22:10:37 +13:00
{
Database . Ticket ticket ;
2024-12-27 16:43:55 +13:00
DiscordChannel channel = null ;
await command . DeferResponseAsync ( true ) ;
2024-10-29 22:10:37 +13:00
if ( ticketID = = 0 )
{
// Check if ticket exists in the database
if ( ! Database . TryGetOpenTicket ( command . Channel . Id , out ticket ) )
{
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 = "This channel is not a ticket!"
} , true ) ;
return ;
}
2024-12-27 16:43:55 +13:00
channel = command . Channel ;
2024-10-29 22:10:37 +13:00
}
else
{
// Check if ticket exists in the database
if ( ! Database . TryGetOpenTicketByID ( ( uint ) ticketID , out ticket ) )
{
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 = "There is no ticket with this ticket ID."
} , true ) ;
return ;
}
2024-12-27 16:43:55 +13:00
// Find the channel if it still exists
try
{
channel = await command . Guild . GetChannelAsync ( ticket . channelID ) ;
}
catch ( Exception ) { /*ignored*/ }
2024-10-29 22:10:37 +13:00
}
2024-12-27 16:43:55 +13:00
// If the channel exists, stop any ongoing interview
if ( channel ! = null )
{
await Interviewer . StopInterview ( channel ) ;
}
2024-10-29 22:10:37 +13:00
2024-12-27 16:43:55 +13:00
// Delete the ticket from the database and respond to command
2024-10-29 22:10:37 +13:00
if ( Database . DeleteOpenTicket ( ticket . id ) )
{
2024-12-26 18:36:20 +13:00
await command . RespondAsync ( new DiscordEmbedBuilder
2024-10-29 22:10:37 +13:00
{
Color = DiscordColor . Green ,
Description = "Channel has been undesignated as a ticket."
} ) ;
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 = command . Channel . Mention + " has been undesignated as a ticket by " + command . User . Mention + "." ,
Footer = new DiscordEmbedBuilder . EmbedFooter
{
Text = "Ticket: " + ticket . id . ToString ( "00000" )
}
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
}
else
{
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 = "Error: Failed removing ticket from database."
} , true ) ;
}
}
2024-12-26 20:47:07 +13:00
[RequireGuild]
2024-12-26 18:36:20 +13:00
[Command("reload")]
[Description("Reloads the bot config.")]
public async Task Reload ( SlashCommandContext command )
2024-10-29 22:10:37 +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 ,
Description = "Reloading bot application..."
} ) ;
2024-12-27 01:21:37 +13:00
try
{
DiscordChannel logChannel = await SupportChild . client . GetChannelAsync ( Config . logChannel ) ;
await logChannel . SendMessageAsync ( new DiscordEmbedBuilder
{
Color = DiscordColor . Green ,
Description = command . Channel . Mention + " reloaded the bot." ,
} ) ;
}
catch ( NotFoundException )
{
2024-12-27 16:53:40 +13:00
Logger . Error ( "Could not send message in log channel." ) ;
2024-12-27 01:21:37 +13:00
}
2024-10-29 22:10:37 +13:00
Logger . Log ( "Reloading bot..." ) ;
2024-12-26 20:12:50 +13:00
await SupportChild . Reload ( ) ;
2024-10-29 22:10:37 +13:00
}
2022-08-21 19:34:11 +12:00
}