2022-04-18 22:52:03 +12:00
using System ;
2022-02-21 21:40:09 +13:00
using System.Collections.Generic ;
2024-12-26 18:36:20 +13:00
using System.ComponentModel ;
2022-02-21 21:40:09 +13:00
using System.IO ;
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 ;
using DSharpPlus.Exceptions ;
2022-08-21 19:34:11 +12:00
namespace SupportChild.Commands ;
2024-12-26 18:36:20 +13:00
public class TranscriptCommand
2022-02-21 21:40:09 +13:00
{
2024-12-26 18:36:20 +13:00
[RequireGuild]
[Command("transcript")]
[Description("Creates a transcript of a ticket.")]
public async Task OnExecute ( SlashCommandContext command , [ Parameter ( "ticket-id" ) ] [ Description ( "(Optional) Ticket number to get transcript of." ) ] long ticketID = 0 )
2024-10-29 22:10:37 +13:00
{
2024-12-26 18:36:20 +13:00
await command . DeferResponseAsync ( true ) ;
2024-10-29 22:10:37 +13:00
Database . Ticket ticket ;
if ( ticketID = = 0 ) // If there are no arguments use current channel
{
if ( Database . TryGetOpenTicket ( command . Channel . Id , out ticket ) )
{
try
{
await Transcriber . ExecuteAsync ( command . Channel . Id , ticket . id ) ;
}
catch ( Exception )
{
await command . EditResponseAsync ( new DiscordWebhookBuilder ( ) . AddEmbed ( new DiscordEmbedBuilder
{
Color = DiscordColor . Red ,
Description = "ERROR: Could not save transcript file. Aborting..."
} ) ) ;
throw ;
}
}
else
{
await command . EditResponseAsync ( new DiscordWebhookBuilder ( ) . AddEmbed ( new DiscordEmbedBuilder
{
Color = DiscordColor . Red ,
Description = "This channel is not a ticket."
} ) ) ;
return ;
}
}
else
{
// If the ticket is still open, generate a new fresh transcript
if ( Database . TryGetOpenTicketByID ( ( uint ) ticketID , out ticket ) & & ticket ? . creatorID = = command . Member . Id )
{
try
{
await Transcriber . ExecuteAsync ( command . Channel . Id , ticket . id ) ;
}
catch ( Exception )
{
await command . EditResponseAsync ( new DiscordWebhookBuilder ( ) . AddEmbed ( new DiscordEmbedBuilder
{
Color = DiscordColor . Red ,
Description = "ERROR: Could not save transcript file. Aborting..."
} ) ) ;
throw ;
}
2022-02-21 21:40:09 +13:00
2024-10-29 22:10:37 +13:00
}
// If there is no open or closed ticket, send an error. If there is a closed ticket we will simply use the old transcript from when the ticket was closed.
else if ( ! Database . TryGetClosedTicket ( ( uint ) ticketID , out ticket ) | | ( ticket ? . creatorID ! = command . Member . Id & & ! Database . IsStaff ( command . Member . Id ) ) )
{
await command . EditResponseAsync ( new DiscordWebhookBuilder ( ) . AddEmbed ( new DiscordEmbedBuilder
{
Color = DiscordColor . Red ,
Description = "Could not find a closed ticket with that number which you opened.\n(Use the /list command to see all your tickets)"
} ) ) ;
return ;
}
}
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 using FileStream file = new FileStream ( Transcriber . GetPath ( ticket . id ) , FileMode . Open , FileAccess . Read ) ;
2022-08-21 19:34:11 +12:00
2024-10-29 22:10:37 +13:00
DiscordMessageBuilder message = new DiscordMessageBuilder ( ) ;
2024-10-29 22:52:02 +13:00
message . AddEmbed ( new DiscordEmbedBuilder
2024-10-29 22:10:37 +13:00
{
Color = DiscordColor . Green ,
2024-12-27 01:21:37 +13:00
Description = "Transcript generated by " + command . User . Mention + "." ,
Footer = new DiscordEmbedBuilder . EmbedFooter
{
Text = "Ticket: " + ticket . id . ToString ( "00000" )
}
2024-10-29 22:10:37 +13:00
} ) ;
message . AddFiles ( new Dictionary < string , Stream > { { Transcriber . GetFilename ( ticket . id ) , file } } ) ;
2022-02-21 21:40:09 +13:00
2024-10-29 22:10:37 +13:00
await logChannel . SendMessageAsync ( message ) ;
}
2024-12-26 18:57:41 +13:00
catch ( NotFoundException )
{
Logger . Error ( "Could not find the log channel." ) ;
}
2022-02-21 21:40:09 +13:00
2024-10-29 22:10:37 +13:00
try
{
// Send transcript in a direct message
await using FileStream file = new FileStream ( Transcriber . GetPath ( ticket . id ) , FileMode . Open , FileAccess . Read ) ;
2022-02-21 21:40:09 +13:00
2024-10-29 22:10:37 +13:00
DiscordMessageBuilder directMessage = new DiscordMessageBuilder ( ) ;
2024-10-29 22:52:02 +13:00
directMessage . AddEmbed ( new DiscordEmbedBuilder
2024-10-29 22:10:37 +13:00
{
Color = DiscordColor . Green ,
Description = "Transcript generated!\n"
} ) ;
directMessage . AddFiles ( new Dictionary < string , Stream > { { Transcriber . GetFilename ( ticket . id ) , file } } ) ;
2022-08-21 19:34:11 +12:00
2024-10-29 22:10:37 +13:00
await command . Member . SendMessageAsync ( directMessage ) ;
}
catch ( UnauthorizedException )
{
await command . EditResponseAsync ( new DiscordWebhookBuilder ( ) . AddEmbed ( new DiscordEmbedBuilder
{
Color = DiscordColor . Red ,
Description = "Not allowed to send direct message to you, please check your privacy settings.\n"
} ) ) ;
return ;
}
2022-08-21 19:34:11 +12:00
2024-10-29 22:10:37 +13:00
await command . EditResponseAsync ( new DiscordWebhookBuilder ( ) . AddEmbed ( new DiscordEmbedBuilder
{
Color = DiscordColor . Green ,
Description = "Transcript sent!\n"
} ) ) ;
}
2022-05-19 23:38:59 +12:00
}