2022-04-18 22:52:03 +12:00
using System ;
2022-02-21 21:40:09 +13:00
using System.Linq ;
using System.Collections.Generic ;
2024-10-29 23:12:51 +13:00
using System.Security.Cryptography ;
2022-08-21 19:33:27 +12:00
using DSharpPlus ;
2023-03-24 01:21:20 +13:00
using MySqlConnector ;
2024-12-26 18:07:36 +13:00
using Newtonsoft.Json ;
2024-12-26 20:12:50 +13:00
using Newtonsoft.Json.Serialization ;
2022-02-21 21:40:09 +13:00
2022-08-21 19:33:27 +12:00
namespace SupportChild ;
public static class Database
2022-02-21 21:40:09 +13:00
{
2023-03-24 01:21:20 +13:00
private static string connectionString = "" ;
public static void SetConnectionString ( string host , int port , string database , string username , string password )
{
connectionString = "server=" + host +
";database=" + database +
";port=" + port +
";userid=" + username +
";password=" + password ;
}
public static MySqlConnection GetConnection ( )
{
return new MySqlConnection ( connectionString ) ;
}
public static long GetNumberOfTickets ( )
{
try
{
using MySqlConnection c = GetConnection ( ) ;
using MySqlCommand countTickets = new MySqlCommand ( "SELECT COUNT(*) FROM tickets" , c ) ;
c . Open ( ) ;
return ( long ) countTickets . ExecuteScalar ( ) ;
}
catch ( Exception e )
{
Logger . Error ( "Error occured when attempting to count number of open tickets: " + e ) ;
}
return - 1 ;
}
public static long GetNumberOfClosedTickets ( )
{
try
{
using MySqlConnection c = GetConnection ( ) ;
using MySqlCommand countTickets = new MySqlCommand ( "SELECT COUNT(*) FROM ticket_history" , c ) ;
c . Open ( ) ;
return ( long ) countTickets . ExecuteScalar ( ) ;
}
catch ( Exception e )
{
Logger . Error ( "Error occured when attempting to count number of open tickets: " + e ) ;
}
return - 1 ;
}
public static void SetupTables ( )
{
using MySqlConnection c = GetConnection ( ) ;
using MySqlCommand createTickets = new MySqlCommand (
"CREATE TABLE IF NOT EXISTS tickets(" +
"id INT UNSIGNED NOT NULL PRIMARY KEY AUTO_INCREMENT," +
"created_time DATETIME NOT NULL," +
"creator_id BIGINT UNSIGNED NOT NULL," +
"assigned_staff_id BIGINT UNSIGNED NOT NULL DEFAULT 0," +
"summary VARCHAR(5000) NOT NULL," +
"channel_id BIGINT UNSIGNED NOT NULL UNIQUE," +
"INDEX(created_time, assigned_staff_id, channel_id))" ,
c ) ;
using MySqlCommand createTicketHistory = new MySqlCommand (
"CREATE TABLE IF NOT EXISTS ticket_history(" +
"id INT UNSIGNED NOT NULL PRIMARY KEY," +
"created_time DATETIME NOT NULL," +
"closed_time DATETIME NOT NULL," +
"creator_id BIGINT UNSIGNED NOT NULL," +
"assigned_staff_id BIGINT UNSIGNED NOT NULL DEFAULT 0," +
"summary VARCHAR(5000) NOT NULL," +
"channel_id BIGINT UNSIGNED NOT NULL UNIQUE," +
"INDEX(created_time, closed_time, channel_id))" ,
c ) ;
using MySqlCommand createBlacklisted = new MySqlCommand (
"CREATE TABLE IF NOT EXISTS blacklisted_users(" +
"user_id BIGINT UNSIGNED NOT NULL PRIMARY KEY," +
"time DATETIME NOT NULL," +
"moderator_id BIGINT UNSIGNED NOT NULL," +
"INDEX(user_id, time))" ,
c ) ;
using MySqlCommand createStaffList = new MySqlCommand (
"CREATE TABLE IF NOT EXISTS staff(" +
"user_id BIGINT UNSIGNED NOT NULL PRIMARY KEY," +
"name VARCHAR(256) NOT NULL," +
"active BOOLEAN NOT NULL DEFAULT true)" ,
c ) ;
using MySqlCommand createMessages = new MySqlCommand (
"CREATE TABLE IF NOT EXISTS messages(" +
"identifier VARCHAR(256) NOT NULL PRIMARY KEY," +
"user_id BIGINT UNSIGNED NOT NULL," +
"message VARCHAR(5000) NOT NULL)" ,
c ) ;
using MySqlCommand createCategories = new MySqlCommand (
"CREATE TABLE IF NOT EXISTS categories(" +
"name VARCHAR(256) NOT NULL UNIQUE," +
"category_id BIGINT UNSIGNED NOT NULL PRIMARY KEY)" ,
c ) ;
2024-12-26 18:07:36 +13:00
using MySqlCommand createInterviews = new MySqlCommand (
"CREATE TABLE IF NOT EXISTS interviews(" +
"channel_id BIGINT UNSIGNED NOT NULL PRIMARY KEY," +
"interview JSON NOT NULL)" ,
c ) ;
2023-03-24 01:21:20 +13:00
c . Open ( ) ;
createTickets . ExecuteNonQuery ( ) ;
createBlacklisted . ExecuteNonQuery ( ) ;
createTicketHistory . ExecuteNonQuery ( ) ;
createStaffList . ExecuteNonQuery ( ) ;
createMessages . ExecuteNonQuery ( ) ;
createCategories . ExecuteNonQuery ( ) ;
2024-12-26 18:07:36 +13:00
createInterviews . ExecuteNonQuery ( ) ;
2023-03-24 01:21:20 +13:00
}
public static bool IsOpenTicket ( ulong channelID )
{
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand selection = new MySqlCommand ( @"SELECT * FROM tickets WHERE channel_id=@channel_id" , c ) ;
selection . Parameters . AddWithValue ( "@channel_id" , channelID ) ;
selection . Prepare ( ) ;
MySqlDataReader results = selection . ExecuteReader ( ) ;
// Check if ticket exists in the database
if ( ! results . Read ( ) )
{
return false ;
}
results . Close ( ) ;
return true ;
}
public static bool TryGetOpenTicket ( ulong channelID , out Ticket ticket )
{
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand selection = new MySqlCommand ( @"SELECT * FROM tickets WHERE channel_id=@channel_id" , c ) ;
selection . Parameters . AddWithValue ( "@channel_id" , channelID ) ;
selection . Prepare ( ) ;
MySqlDataReader results = selection . ExecuteReader ( ) ;
// Check if ticket exists in the database
if ( ! results . Read ( ) )
{
ticket = null ;
return false ;
}
ticket = new Ticket ( results ) ;
results . Close ( ) ;
return true ;
}
public static bool TryGetOpenTicketByID ( uint id , out Ticket ticket )
{
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand selection = new MySqlCommand ( @"SELECT * FROM tickets WHERE id=@id" , c ) ;
selection . Parameters . AddWithValue ( "@id" , id ) ;
selection . Prepare ( ) ;
MySqlDataReader results = selection . ExecuteReader ( ) ;
// Check if open ticket exists in the database
if ( results . Read ( ) )
{
ticket = new Ticket ( results ) ;
results . Close ( ) ;
return true ;
}
results . Close ( ) ;
ticket = null ;
return false ;
}
public static bool TryGetClosedTicket ( uint id , out Ticket ticket )
{
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand selection = new MySqlCommand ( @"SELECT * FROM ticket_history WHERE id=@id" , c ) ;
selection . Parameters . AddWithValue ( "@id" , id ) ;
selection . Prepare ( ) ;
MySqlDataReader results = selection . ExecuteReader ( ) ;
// Check if closed ticket exists in the database
if ( results . Read ( ) )
{
ticket = new Ticket ( results ) ;
results . Close ( ) ;
return true ;
}
ticket = null ;
results . Close ( ) ;
return false ;
}
public static bool TryGetOpenTickets ( ulong userID , out List < Ticket > tickets )
{
tickets = null ;
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand selection = new MySqlCommand ( @"SELECT * FROM tickets WHERE creator_id=@creator_id" , c ) ;
selection . Parameters . AddWithValue ( "@creator_id" , userID ) ;
selection . Prepare ( ) ;
MySqlDataReader results = selection . ExecuteReader ( ) ;
if ( ! results . Read ( ) )
{
return false ;
}
tickets = new List < Ticket > { new Ticket ( results ) } ;
while ( results . Read ( ) )
{
tickets . Add ( new Ticket ( results ) ) ;
}
results . Close ( ) ;
return true ;
}
public static bool TryGetOpenTickets ( out List < Ticket > tickets )
{
tickets = null ;
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand selection = new MySqlCommand ( @"SELECT * FROM tickets ORDER BY channel_id ASC" , c ) ;
selection . Prepare ( ) ;
MySqlDataReader results = selection . ExecuteReader ( ) ;
if ( ! results . Read ( ) )
{
return false ;
}
tickets = new List < Ticket > { new Ticket ( results ) } ;
while ( results . Read ( ) )
{
tickets . Add ( new Ticket ( results ) ) ;
}
results . Close ( ) ;
return true ;
}
public static bool TryGetClosedTickets ( ulong userID , out List < Ticket > tickets )
{
tickets = null ;
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand selection = new MySqlCommand ( @"SELECT * FROM ticket_history WHERE creator_id=@creator_id" , c ) ;
selection . Parameters . AddWithValue ( "@creator_id" , userID ) ;
selection . Prepare ( ) ;
MySqlDataReader results = selection . ExecuteReader ( ) ;
if ( ! results . Read ( ) )
{
return false ;
}
tickets = new List < Ticket > { new Ticket ( results ) } ;
while ( results . Read ( ) )
{
tickets . Add ( new Ticket ( results ) ) ;
}
results . Close ( ) ;
return true ;
}
public static bool TryGetAssignedTickets ( ulong staffID , out List < Ticket > tickets )
{
tickets = null ;
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand selection = new MySqlCommand ( @"SELECT * FROM tickets WHERE assigned_staff_id=@assigned_staff_id" , c ) ;
selection . Parameters . AddWithValue ( "@assigned_staff_id" , staffID ) ;
selection . Prepare ( ) ;
MySqlDataReader results = selection . ExecuteReader ( ) ;
if ( ! results . Read ( ) )
{
return false ;
}
tickets = new List < Ticket > { new Ticket ( results ) } ;
while ( results . Read ( ) )
{
tickets . Add ( new Ticket ( results ) ) ;
}
results . Close ( ) ;
return true ;
}
public static long NewTicket ( ulong memberID , ulong staffID , ulong ticketID )
{
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand cmd = new MySqlCommand ( @"INSERT INTO tickets (created_time, creator_id, assigned_staff_id, summary, channel_id) VALUES (UTC_TIMESTAMP(), @creator_id, @assigned_staff_id, @summary, @channel_id);" , c ) ;
cmd . Parameters . AddWithValue ( "@creator_id" , memberID ) ;
cmd . Parameters . AddWithValue ( "@assigned_staff_id" , staffID ) ;
cmd . Parameters . AddWithValue ( "@summary" , "" ) ;
cmd . Parameters . AddWithValue ( "@channel_id" , ticketID ) ;
cmd . ExecuteNonQuery ( ) ;
return cmd . LastInsertedId ;
}
public static void ArchiveTicket ( Ticket ticket )
{
// Check if ticket already exists in the archive
if ( TryGetClosedTicket ( ticket . id , out Ticket _ ) )
{
using MySqlConnection c = GetConnection ( ) ;
using MySqlCommand deleteTicket = new MySqlCommand ( @"DELETE FROM ticket_history WHERE id=@id OR channel_id=@channel_id" , c ) ;
deleteTicket . Parameters . AddWithValue ( "@id" , ticket . id ) ;
deleteTicket . Parameters . AddWithValue ( "@channel_id" , ticket . channelID ) ;
c . Open ( ) ;
deleteTicket . Prepare ( ) ;
deleteTicket . ExecuteNonQuery ( ) ;
}
// Create an entry in the ticket history database
using MySqlConnection conn = GetConnection ( ) ;
using MySqlCommand archiveTicket = new MySqlCommand ( @"INSERT INTO ticket_history (id, created_time, closed_time, creator_id, assigned_staff_id, summary, channel_id) VALUES (@id, @created_time, UTC_TIMESTAMP(), @creator_id, @assigned_staff_id, @summary, @channel_id);" , conn ) ;
archiveTicket . Parameters . AddWithValue ( "@id" , ticket . id ) ;
archiveTicket . Parameters . AddWithValue ( "@created_time" , ticket . channelID . GetSnowflakeTime ( ) ) ;
archiveTicket . Parameters . AddWithValue ( "@creator_id" , ticket . creatorID ) ;
archiveTicket . Parameters . AddWithValue ( "@assigned_staff_id" , ticket . assignedStaffID ) ;
archiveTicket . Parameters . AddWithValue ( "@summary" , ticket . summary ) ;
archiveTicket . Parameters . AddWithValue ( "@channel_id" , ticket . channelID ) ;
conn . Open ( ) ;
archiveTicket . Prepare ( ) ;
archiveTicket . ExecuteNonQuery ( ) ;
}
public static bool DeleteOpenTicket ( uint ticketID )
{
try
{
using MySqlConnection c = GetConnection ( ) ;
using MySqlCommand deletion = new MySqlCommand ( @"DELETE FROM tickets WHERE id=@id" , c ) ;
deletion . Parameters . AddWithValue ( "@id" , ticketID ) ;
c . Open ( ) ;
deletion . Prepare ( ) ;
return deletion . ExecuteNonQuery ( ) > 0 ;
}
catch ( MySqlException )
{
return false ;
}
}
public static bool IsBlacklisted ( ulong userID )
{
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand selection = new MySqlCommand ( @"SELECT * FROM blacklisted_users WHERE user_id=@user_id" , c ) ;
selection . Parameters . AddWithValue ( "@user_id" , userID ) ;
selection . Prepare ( ) ;
MySqlDataReader results = selection . ExecuteReader ( ) ;
// Check if user is blacklisted
if ( results . Read ( ) )
{
results . Close ( ) ;
return true ;
}
results . Close ( ) ;
return false ;
}
public static bool Blacklist ( ulong blacklistedID , ulong staffID )
{
try
{
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand cmd = new MySqlCommand ( @"INSERT INTO blacklisted_users (user_id,time,moderator_id) VALUES (@user_id, UTC_TIMESTAMP(), @moderator_id);" , c ) ;
cmd . Parameters . AddWithValue ( "@user_id" , blacklistedID ) ;
cmd . Parameters . AddWithValue ( "@moderator_id" , staffID ) ;
cmd . Prepare ( ) ;
return cmd . ExecuteNonQuery ( ) > 0 ;
}
catch ( MySqlException )
{
return false ;
}
}
public static bool Unblacklist ( ulong blacklistedID )
{
try
{
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand cmd = new MySqlCommand ( @"DELETE FROM blacklisted_users WHERE user_id=@user_id" , c ) ;
cmd . Parameters . AddWithValue ( "@user_id" , blacklistedID ) ;
cmd . Prepare ( ) ;
return cmd . ExecuteNonQuery ( ) > 0 ;
}
catch ( MySqlException )
{
return false ;
}
}
public static bool AssignStaff ( Ticket ticket , ulong staffID )
{
try
{
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand update = new MySqlCommand ( @"UPDATE tickets SET assigned_staff_id = @assigned_staff_id WHERE id = @id" , c ) ;
update . Parameters . AddWithValue ( "@assigned_staff_id" , staffID ) ;
update . Parameters . AddWithValue ( "@id" , ticket . id ) ;
update . Prepare ( ) ;
return update . ExecuteNonQuery ( ) > 0 ;
}
catch ( MySqlException )
{
return false ;
}
}
public static bool UnassignStaff ( Ticket ticket )
{
return AssignStaff ( ticket , 0 ) ;
}
public static bool SetStaffActive ( ulong staffID , bool active )
{
try
{
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
MySqlCommand update = new MySqlCommand ( @"UPDATE staff SET active = @active WHERE user_id = @user_id" , c ) ;
update . Parameters . AddWithValue ( "@user_id" , staffID ) ;
update . Parameters . AddWithValue ( "@active" , active ) ;
update . Prepare ( ) ;
return update . ExecuteNonQuery ( ) > 0 ;
}
catch ( MySqlException )
{
return false ;
}
}
public static StaffMember GetRandomActiveStaff ( params ulong [ ] ignoredUserIDs )
{
List < StaffMember > staffMembers = GetActiveStaff ( ignoredUserIDs ) ;
2024-10-29 23:12:51 +13:00
return staffMembers . Any ( ) ? staffMembers [ RandomNumberGenerator . GetInt32 ( staffMembers . Count ) ] : null ;
2023-03-24 01:21:20 +13:00
}
public static List < StaffMember > GetActiveStaff ( params ulong [ ] ignoredUserIDs )
{
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
2024-10-29 22:34:41 +13:00
using MySqlCommand selection = new MySqlCommand ( @"SELECT * FROM staff WHERE active = true AND user_id NOT IN (@user_ids)" , c ) ;
selection . Parameters . AddWithValue ( "@user_ids" , string . Join ( "," , ignoredUserIDs ) ) ;
2023-03-24 01:21:20 +13:00
selection . Prepare ( ) ;
MySqlDataReader results = selection . ExecuteReader ( ) ;
// Check if staff exists in the database
if ( ! results . Read ( ) )
{
return new List < StaffMember > ( ) ;
}
List < StaffMember > staffMembers = new List < StaffMember > { new StaffMember ( results ) } ;
while ( results . Read ( ) )
{
staffMembers . Add ( new StaffMember ( results ) ) ;
}
results . Close ( ) ;
return staffMembers ;
}
public static List < StaffMember > GetAllStaff ( params ulong [ ] ignoredUserIDs )
{
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
2024-10-29 22:34:41 +13:00
using MySqlCommand selection = new MySqlCommand ( @"SELECT * FROM staff WHERE user_id NOT IN (@user_ids)" , c ) ;
selection . Parameters . AddWithValue ( "@user_ids" , string . Join ( "," , ignoredUserIDs ) ) ;
2023-03-24 01:21:20 +13:00
selection . Prepare ( ) ;
MySqlDataReader results = selection . ExecuteReader ( ) ;
// Check if staff exist in the database
if ( ! results . Read ( ) )
{
return new List < StaffMember > ( ) ;
}
List < StaffMember > staffMembers = new List < StaffMember > { new StaffMember ( results ) } ;
while ( results . Read ( ) )
{
staffMembers . Add ( new StaffMember ( results ) ) ;
}
results . Close ( ) ;
return staffMembers ;
}
public static bool IsStaff ( ulong staffID )
{
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand selection = new MySqlCommand ( @"SELECT * FROM staff WHERE user_id=@user_id" , c ) ;
selection . Parameters . AddWithValue ( "@user_id" , staffID ) ;
selection . Prepare ( ) ;
MySqlDataReader results = selection . ExecuteReader ( ) ;
// Check if ticket exists in the database
if ( ! results . Read ( ) )
{
return false ;
}
results . Close ( ) ;
return true ;
}
public static bool TryGetStaff ( ulong staffID , out StaffMember staffMember )
{
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand selection = new MySqlCommand ( @"SELECT * FROM staff WHERE user_id=@user_id" , c ) ;
selection . Parameters . AddWithValue ( "@user_id" , staffID ) ;
selection . Prepare ( ) ;
MySqlDataReader results = selection . ExecuteReader ( ) ;
// Check if ticket exists in the database
if ( ! results . Read ( ) )
{
staffMember = null ;
return false ;
}
staffMember = new StaffMember ( results ) ;
results . Close ( ) ;
return true ;
}
public static List < Message > GetAllMessages ( )
{
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand selection = new MySqlCommand ( @"SELECT * FROM messages" , c ) ;
selection . Prepare ( ) ;
MySqlDataReader results = selection . ExecuteReader ( ) ;
// Check if messages exist in the database
if ( ! results . Read ( ) )
{
return new List < Message > ( ) ;
}
List < Message > messages = new List < Message > { new Message ( results ) } ;
while ( results . Read ( ) )
{
messages . Add ( new Message ( results ) ) ;
}
results . Close ( ) ;
return messages ;
}
public static bool TryGetMessage ( string identifier , out Message message )
{
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand selection = new MySqlCommand ( @"SELECT * FROM messages WHERE identifier=@identifier" , c ) ;
selection . Parameters . AddWithValue ( "@identifier" , identifier ) ;
selection . Prepare ( ) ;
MySqlDataReader results = selection . ExecuteReader ( ) ;
// Check if ticket exists in the database
if ( ! results . Read ( ) )
{
message = null ;
return false ;
}
message = new Message ( results ) ;
results . Close ( ) ;
return true ;
}
public static bool AddMessage ( string identifier , ulong userID , string message )
{
try
{
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand cmd = new MySqlCommand ( @"INSERT INTO messages (identifier,user_id,message) VALUES (@identifier, @user_id, @message);" , c ) ;
cmd . Parameters . AddWithValue ( "@identifier" , identifier ) ;
cmd . Parameters . AddWithValue ( "@user_id" , userID ) ;
cmd . Parameters . AddWithValue ( "@message" , message ) ;
cmd . Prepare ( ) ;
return cmd . ExecuteNonQuery ( ) > 0 ;
}
catch ( MySqlException )
{
return false ;
}
}
public static bool RemoveMessage ( string identifier )
{
try
{
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand cmd = new MySqlCommand ( @"DELETE FROM messages WHERE identifier=@identifier" , c ) ;
cmd . Parameters . AddWithValue ( "@identifier" , identifier ) ;
cmd . Prepare ( ) ;
return cmd . ExecuteNonQuery ( ) > 0 ;
}
catch ( MySqlException )
{
return false ;
}
}
public static List < Category > GetAllCategories ( )
{
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand selection = new MySqlCommand ( @"SELECT * FROM categories" , c ) ;
selection . Prepare ( ) ;
MySqlDataReader results = selection . ExecuteReader ( ) ;
// Check if messages exist in the database
if ( ! results . Read ( ) )
{
return new List < Category > ( ) ;
}
List < Category > categories = new List < Category > { new Category ( results ) } ;
while ( results . Read ( ) )
{
categories . Add ( new Category ( results ) ) ;
}
results . Close ( ) ;
return categories ;
}
public static bool TryGetCategory ( ulong categoryID , out Category message )
{
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand selection = new MySqlCommand ( @"SELECT * FROM categories WHERE category_id=@category_id" , c ) ;
selection . Parameters . AddWithValue ( "@category_id" , categoryID ) ;
selection . Prepare ( ) ;
MySqlDataReader results = selection . ExecuteReader ( ) ;
// Check if ticket exists in the database
if ( ! results . Read ( ) )
{
message = null ;
return false ;
}
message = new Category ( results ) ;
results . Close ( ) ;
return true ;
}
public static bool TryGetCategory ( string name , out Category message )
{
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand selection = new MySqlCommand ( @"SELECT * FROM categories WHERE name=@name" , c ) ;
selection . Parameters . AddWithValue ( "@name" , name ) ;
selection . Prepare ( ) ;
MySqlDataReader results = selection . ExecuteReader ( ) ;
// Check if ticket exists in the database
if ( ! results . Read ( ) )
{
message = null ;
return false ;
}
message = new Category ( results ) ;
results . Close ( ) ;
return true ;
}
public static bool AddCategory ( string name , ulong categoryID )
{
try
{
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand cmd = new MySqlCommand ( @"INSERT INTO categories (name,category_id) VALUES (@name, @category_id);" , c ) ;
cmd . Parameters . AddWithValue ( "@name" , name ) ;
cmd . Parameters . AddWithValue ( "@category_id" , categoryID ) ;
cmd . Prepare ( ) ;
return cmd . ExecuteNonQuery ( ) > 0 ;
}
catch ( MySqlException )
{
return false ;
}
}
public static bool RemoveCategory ( ulong categoryID )
{
try
{
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand cmd = new MySqlCommand ( @"DELETE FROM categories WHERE category_id=@category_id" , c ) ;
cmd . Parameters . AddWithValue ( "@category_id" , categoryID ) ;
cmd . Prepare ( ) ;
return cmd . ExecuteNonQuery ( ) > 0 ;
}
catch ( MySqlException )
{
return false ;
}
}
2024-12-26 20:12:50 +13:00
public static string GetInterviewTemplatesJSON ( )
2024-12-26 19:50:47 +13:00
{
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand selection = new MySqlCommand ( "SELECT * FROM interviews WHERE channel_id=0" , c ) ;
selection . Prepare ( ) ;
MySqlDataReader results = selection . ExecuteReader ( ) ;
// Check if messages exist in the database
if ( ! results . Read ( ) )
{
return "{}" ;
}
string templates = results . GetString ( "interview" ) ;
results . Close ( ) ;
return templates ;
}
2024-12-26 20:38:17 +13:00
// Still returns true if there are no templates, returns false if the templates are invalid.
public static bool TryGetInterviewTemplates ( out Dictionary < ulong , Interviewer . InterviewQuestion > templates )
2024-12-26 20:12:50 +13:00
{
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand selection = new MySqlCommand ( "SELECT * FROM interviews WHERE channel_id=0" , c ) ;
selection . Prepare ( ) ;
MySqlDataReader results = selection . ExecuteReader ( ) ;
// Check if messages exist in the database
if ( ! results . Read ( ) )
{
2024-12-26 20:38:17 +13:00
templates = new Dictionary < ulong , Interviewer . InterviewQuestion > ( ) ;
return true ;
2024-12-26 20:12:50 +13:00
}
2024-12-26 20:38:17 +13:00
string templatesString = results . GetString ( "interview" ) ;
2024-12-26 20:12:50 +13:00
results . Close ( ) ;
2024-12-26 20:38:17 +13:00
try
2024-12-26 20:12:50 +13:00
{
2024-12-26 20:38:17 +13:00
templates = JsonConvert . DeserializeObject < Dictionary < ulong , Interviewer . InterviewQuestion > > ( templatesString , new JsonSerializerSettings
2024-12-26 20:12:50 +13:00
{
2024-12-26 20:38:17 +13:00
Error = delegate ( object sender , ErrorEventArgs args )
{
Logger . Error ( "Error occured when trying to read interview templates from database: " + args . ErrorContext . Error . Message ) ;
Logger . Debug ( "Detailed exception:" , args . ErrorContext . Error ) ;
args . ErrorContext . Handled = false ;
}
} ) ;
return true ;
}
catch ( Exception )
{
templates = null ;
return false ;
}
2024-12-26 20:12:50 +13:00
}
2024-12-26 19:50:47 +13:00
public static bool SetInterviewTemplates ( string templates )
{
try
{
string query ;
if ( TryGetInterview ( 0 , out _ ) )
{
query = "UPDATE interviews SET interview = @interview WHERE channel_id = 0" ;
}
else
{
query = "INSERT INTO interviews (channel_id,interview) VALUES (0, @interview)" ;
}
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand cmd = new MySqlCommand ( query , c ) ;
cmd . Parameters . AddWithValue ( "@interview" , templates ) ;
cmd . Prepare ( ) ;
return cmd . ExecuteNonQuery ( ) > 0 ;
}
catch ( MySqlException )
{
return false ;
}
}
2024-12-26 18:07:36 +13:00
public static Dictionary < ulong , Interviewer . InterviewQuestion > GetAllInterviews ( )
{
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand selection = new MySqlCommand ( "SELECT * FROM interviews" , c ) ;
selection . Prepare ( ) ;
MySqlDataReader results = selection . ExecuteReader ( ) ;
// Check if messages exist in the database
if ( ! results . Read ( ) )
{
return new Dictionary < ulong , Interviewer . InterviewQuestion > ( ) ;
}
2024-12-26 19:50:47 +13:00
Dictionary < ulong , Interviewer . InterviewQuestion > questions = new ( ) ;
do
2024-12-26 18:07:36 +13:00
{
2024-12-26 20:24:32 +13:00
try
2024-12-26 19:50:47 +13:00
{
2024-12-26 20:24:32 +13:00
// Channel ID 0 is the interview template, don't read it here.
if ( results . GetUInt64 ( "channel_id" ) ! = 0 )
{
questions . Add ( results . GetUInt64 ( "channel_id" ) , JsonConvert . DeserializeObject < Interviewer . InterviewQuestion > ( results . GetString ( "interview" ) ) ) ;
}
2024-12-26 19:50:47 +13:00
}
2024-12-26 20:24:32 +13:00
catch ( Exception e )
{
2024-12-26 20:38:17 +13:00
Logger . Warn ( "Error occured when trying to read interview from database, it will not be loaded until manually fixed in the database.\nError message: " + e . Message ) ;
2024-12-26 20:24:32 +13:00
Logger . Debug ( "Detailed exception:" , e ) ;
}
2024-12-26 18:07:36 +13:00
}
2024-12-26 19:50:47 +13:00
while ( results . Read ( ) ) ;
2024-12-26 18:07:36 +13:00
results . Close ( ) ;
return questions ;
}
public static bool SaveInterview ( ulong channelID , Interviewer . InterviewQuestion interview )
{
try
{
2024-12-26 19:50:47 +13:00
string query ;
2024-12-26 18:07:36 +13:00
if ( TryGetInterview ( channelID , out _ ) )
{
2024-12-26 19:50:47 +13:00
query = "UPDATE interviews SET interview = @interview WHERE channel_id = @channel_id" ;
2024-12-26 18:07:36 +13:00
}
else
{
2024-12-26 19:50:47 +13:00
query = "INSERT INTO interviews (channel_id,interview) VALUES (@channel_id, @interview)" ;
2024-12-26 18:07:36 +13:00
}
2024-12-26 19:50:47 +13:00
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand cmd = new MySqlCommand ( query , c ) ;
cmd . Parameters . AddWithValue ( "@channel_id" , channelID ) ;
2024-12-26 20:28:39 +13:00
cmd . Parameters . AddWithValue ( "@interview" , JsonConvert . SerializeObject ( interview , Formatting . Indented ) ) ;
2024-12-26 19:50:47 +13:00
cmd . Prepare ( ) ;
return cmd . ExecuteNonQuery ( ) > 0 ;
2024-12-26 18:07:36 +13:00
}
catch ( MySqlException )
{
return false ;
}
}
public static bool TryGetInterview ( ulong channelID , out Interviewer . InterviewQuestion interview )
{
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand selection = new MySqlCommand ( @"SELECT * FROM interviews WHERE channel_id=@channel_id" , c ) ;
selection . Parameters . AddWithValue ( "@channel_id" , channelID ) ;
selection . Prepare ( ) ;
MySqlDataReader results = selection . ExecuteReader ( ) ;
// Check if ticket exists in the database
if ( ! results . Read ( ) )
{
interview = null ;
return false ;
}
interview = JsonConvert . DeserializeObject < Interviewer . InterviewQuestion > ( results . GetString ( "interview" ) ) ;
results . Close ( ) ;
return true ;
}
2024-12-26 20:12:50 +13:00
public static bool TryDeleteInterview ( ulong channelID )
{
try
{
using MySqlConnection c = GetConnection ( ) ;
c . Open ( ) ;
using MySqlCommand deletion = new MySqlCommand ( @"DELETE FROM interviews WHERE channel_id=@channel_id" , c ) ;
deletion . Parameters . AddWithValue ( "@channel_id" , channelID ) ;
deletion . Prepare ( ) ;
return deletion . ExecuteNonQuery ( ) > 0 ;
}
catch ( MySqlException )
{
return false ;
}
}
2023-03-24 01:21:20 +13:00
public class Ticket
{
public uint id ;
public ulong creatorID ;
public ulong assignedStaffID ;
public string summary ;
public ulong channelID ;
public Ticket ( MySqlDataReader reader )
{
id = reader . GetUInt32 ( "id" ) ;
creatorID = reader . GetUInt64 ( "creator_id" ) ;
assignedStaffID = reader . GetUInt64 ( "assigned_staff_id" ) ;
summary = reader . GetString ( "summary" ) ;
channelID = reader . GetUInt64 ( "channel_id" ) ;
}
public string DiscordRelativeTime ( )
{
return Formatter . Timestamp ( channelID . GetSnowflakeTime ( ) , Config . timestampFormat ) ;
}
}
public class StaffMember
{
public ulong userID ;
public string name ;
public bool active ;
public StaffMember ( MySqlDataReader reader )
{
userID = reader . GetUInt64 ( "user_id" ) ;
name = reader . GetString ( "name" ) ;
active = reader . GetBoolean ( "active" ) ;
}
}
public class Message
{
public string identifier ;
public ulong userID ;
public string message ;
public Message ( MySqlDataReader reader )
{
identifier = reader . GetString ( "identifier" ) ;
userID = reader . GetUInt64 ( "user_id" ) ;
message = reader . GetString ( "message" ) ;
}
}
public class Category
{
public string name ;
public ulong id ;
public Category ( MySqlDataReader reader )
{
name = reader . GetString ( "name" ) ;
id = reader . GetUInt64 ( "category_id" ) ;
}
}
2022-05-18 01:09:25 +12:00
}