2022-04-18 10:52:03 +00:00
|
|
|
|
using System;
|
2022-02-21 08:40:09 +00:00
|
|
|
|
using System.IO;
|
2022-08-21 07:33:27 +00:00
|
|
|
|
using DSharpPlus;
|
|
|
|
|
using Microsoft.Extensions.Logging;
|
2022-02-21 08:40:09 +00:00
|
|
|
|
using Newtonsoft.Json.Linq;
|
|
|
|
|
using YamlDotNet.Serialization;
|
|
|
|
|
|
2022-08-21 07:33:27 +00:00
|
|
|
|
namespace SupportChild;
|
|
|
|
|
|
|
|
|
|
internal static class Config
|
2022-02-21 08:40:09 +00:00
|
|
|
|
{
|
2022-08-21 07:33:27 +00:00
|
|
|
|
internal static string token = "";
|
|
|
|
|
internal static ulong logChannel;
|
|
|
|
|
internal static string welcomeMessage = "";
|
2024-10-29 09:10:37 +00:00
|
|
|
|
internal static LogLevel logLevel = LogLevel.Information;
|
|
|
|
|
internal static TimestampFormat timestampFormat = TimestampFormat.RelativeTime;
|
|
|
|
|
internal static bool randomAssignment = false;
|
|
|
|
|
internal static bool randomAssignRoleOverride = false;
|
|
|
|
|
internal static string presenceType = "Playing";
|
|
|
|
|
internal static string presenceText = "";
|
|
|
|
|
internal static bool newCommandUsesSelector = false;
|
|
|
|
|
internal static int ticketLimit = 5;
|
2022-02-21 08:40:09 +00:00
|
|
|
|
|
2024-10-29 09:10:37 +00:00
|
|
|
|
internal static bool ticketUpdatedNotifications = false;
|
|
|
|
|
internal static double ticketUpdatedNotificationDelay = 0.0;
|
|
|
|
|
internal static bool assignmentNotifications = false;
|
|
|
|
|
internal static bool closingNotifications = false;
|
2022-02-21 08:40:09 +00:00
|
|
|
|
|
2024-10-29 09:10:37 +00:00
|
|
|
|
internal static string hostName = "127.0.0.1";
|
|
|
|
|
internal static int port = 3306;
|
|
|
|
|
internal static string database = "supportchild";
|
|
|
|
|
internal static string username = "supportchild";
|
|
|
|
|
internal static string password = "";
|
2022-02-21 08:40:09 +00:00
|
|
|
|
|
2024-10-29 09:10:37 +00:00
|
|
|
|
public static void LoadConfig()
|
|
|
|
|
{
|
|
|
|
|
// Writes default config to file if it does not already exist
|
|
|
|
|
if (!File.Exists("./config.yml"))
|
|
|
|
|
{
|
2024-10-29 09:25:03 +00:00
|
|
|
|
File.WriteAllText("./config.yml", Utilities.ReadManifestData("default_config.yml"));
|
2024-10-29 09:10:37 +00:00
|
|
|
|
}
|
2022-02-21 08:40:09 +00:00
|
|
|
|
|
2024-10-29 09:10:37 +00:00
|
|
|
|
// Reads config contents into FileStream
|
|
|
|
|
FileStream stream = File.OpenRead("./config.yml");
|
2022-02-21 08:40:09 +00:00
|
|
|
|
|
2024-10-29 09:10:37 +00:00
|
|
|
|
// Converts the FileStream into a YAML object
|
|
|
|
|
IDeserializer deserializer = new DeserializerBuilder().Build();
|
|
|
|
|
object yamlObject = deserializer.Deserialize(new StreamReader(stream)) ?? "";
|
2022-02-21 08:40:09 +00:00
|
|
|
|
|
2024-10-29 09:10:37 +00:00
|
|
|
|
// Converts the YAML object into a JSON object as the YAML ones do not support traversal or selection of nodes by name
|
|
|
|
|
ISerializer serializer = new SerializerBuilder().JsonCompatible().Build();
|
|
|
|
|
JObject json = JObject.Parse(serializer.Serialize(yamlObject));
|
2022-02-21 08:40:09 +00:00
|
|
|
|
|
2024-10-29 09:10:37 +00:00
|
|
|
|
// Sets up the bot
|
|
|
|
|
token = json.SelectToken("bot.token")?.Value<string>() ?? "";
|
|
|
|
|
logChannel = json.SelectToken("bot.log-channel")?.Value<ulong>() ?? 0;
|
|
|
|
|
welcomeMessage = json.SelectToken("bot.welcome-message")?.Value<string>() ?? "";
|
|
|
|
|
string stringLogLevel = json.SelectToken("bot.console-log-level")?.Value<string>() ?? "";
|
2022-02-21 08:40:09 +00:00
|
|
|
|
|
2024-10-29 09:10:37 +00:00
|
|
|
|
if (!Enum.TryParse(stringLogLevel, true, out logLevel))
|
|
|
|
|
{
|
|
|
|
|
logLevel = LogLevel.Information;
|
|
|
|
|
Logger.Warn("Log level '" + stringLogLevel + "' invalid, using 'Information' instead.");
|
|
|
|
|
}
|
2022-02-21 08:40:09 +00:00
|
|
|
|
|
2024-10-29 09:10:37 +00:00
|
|
|
|
string stringTimestampFormat = json.SelectToken("bot.timestamp-format")?.Value<string>() ?? "RelativeTime";
|
2022-08-21 07:33:27 +00:00
|
|
|
|
|
2024-10-29 09:10:37 +00:00
|
|
|
|
if (!Enum.TryParse(stringTimestampFormat, true, out timestampFormat))
|
|
|
|
|
{
|
|
|
|
|
timestampFormat = TimestampFormat.RelativeTime;
|
|
|
|
|
Logger.Warn("Timestamp '" + stringTimestampFormat + "' invalid, using 'RelativeTime' instead.");
|
|
|
|
|
}
|
2022-08-21 07:33:27 +00:00
|
|
|
|
|
2024-10-29 09:10:37 +00:00
|
|
|
|
randomAssignment = json.SelectToken("bot.random-assignment")?.Value<bool>() ?? false;
|
|
|
|
|
randomAssignRoleOverride = json.SelectToken("bot.random-assign-role-override")?.Value<bool>() ?? false;
|
|
|
|
|
presenceType = json.SelectToken("bot.presence-type")?.Value<string>() ?? "Playing";
|
|
|
|
|
presenceText = json.SelectToken("bot.presence-text")?.Value<string>() ?? "";
|
|
|
|
|
newCommandUsesSelector = json.SelectToken("bot.new-command-uses-selector")?.Value<bool>() ?? false;
|
|
|
|
|
ticketLimit = json.SelectToken("bot.ticket-limit")?.Value<int>() ?? 5;
|
2022-08-21 07:33:27 +00:00
|
|
|
|
|
2024-10-29 09:10:37 +00:00
|
|
|
|
ticketUpdatedNotifications = json.SelectToken("notifications.ticket-updated")?.Value<bool>() ?? false;
|
|
|
|
|
ticketUpdatedNotificationDelay = json.SelectToken("notifications.ticket-updated-delay")?.Value<double>() ?? 0.0;
|
|
|
|
|
assignmentNotifications = json.SelectToken("notifications.assignment")?.Value<bool>() ?? false;
|
|
|
|
|
closingNotifications = json.SelectToken("notifications.closing")?.Value<bool>() ?? false;
|
2022-08-21 07:33:27 +00:00
|
|
|
|
|
2024-10-29 09:10:37 +00:00
|
|
|
|
// Reads database info
|
|
|
|
|
hostName = json.SelectToken("database.address")?.Value<string>() ?? "";
|
|
|
|
|
port = json.SelectToken("database.port")?.Value<int>() ?? 3306;
|
|
|
|
|
database = json.SelectToken("database.name")?.Value<string>() ?? "supportchild";
|
|
|
|
|
username = json.SelectToken("database.user")?.Value<string>() ?? "supportchild";
|
|
|
|
|
password = json.SelectToken("database.password")?.Value<string>() ?? "";
|
|
|
|
|
}
|
2022-05-17 13:11:57 +00:00
|
|
|
|
}
|