SupportChild/Config.cs

111 lines
5.4 KiB
C#
Raw Normal View History

2022-04-18 22:52:03 +12:00
using System;
2022-02-21 21:40:09 +13:00
using System.IO;
2022-08-21 19:33:27 +12:00
using DSharpPlus;
using Microsoft.Extensions.Logging;
2022-02-21 21:40:09 +13:00
using Newtonsoft.Json.Linq;
using YamlDotNet.Serialization;
2022-08-21 19:33:27 +12:00
namespace SupportChild;
internal static class Config
2022-02-21 21:40:09 +13:00
{
2022-08-21 19:33:27 +12:00
internal static string token = "";
internal static ulong logChannel;
internal static string welcomeMessage = "";
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;
internal static bool pinFirstMessage = false;
2022-02-21 21:40:09 +13: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 21:40:09 +13:00
2024-12-26 23:47:55 +13:00
internal static bool interviewsEnabled = false;
internal static bool deleteMessagesAfterSummary = false;
internal static bool deleteMessagesAfterNoSummary = false;
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 21:40:09 +13:00
private static string configPath = "./config.yml";
public static void LoadConfig()
{
if (!string.IsNullOrEmpty(SupportChild.commandLineArgs.configPath))
{
configPath = SupportChild.commandLineArgs.configPath;
}
Logger.Log("Loading config \"" + Path.GetFullPath(configPath) + "\"");
// Writes default config to file if it does not already exist
if (!File.Exists(configPath))
{
File.WriteAllText(configPath, Utilities.ReadManifestData("default_config.yml"));
}
2022-02-21 21:40:09 +13:00
// Reads config contents into FileStream
FileStream stream = File.OpenRead(configPath);
2022-02-21 21:40:09 +13:00
// Converts the FileStream into a YAML object
IDeserializer deserializer = new DeserializerBuilder().Build();
object yamlObject = deserializer.Deserialize(new StreamReader(stream)) ?? "";
2022-02-21 21:40:09 +13: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 21:40:09 +13: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 21:40:09 +13:00
2024-12-26 18:41:36 +13:00
if (!Enum.TryParse(stringLogLevel, true, out LogLevel logLevel))
{
logLevel = LogLevel.Information;
2024-12-26 23:47:55 +13:00
Logger.Warn("Log level '" + stringLogLevel + "' is invalid, using 'Information' instead.");
}
2024-12-26 18:41:36 +13:00
Logger.SetLogLevel(logLevel);
2022-02-21 21:40:09 +13:00
string stringTimestampFormat = json.SelectToken("bot.timestamp-format")?.Value<string>() ?? "RelativeTime";
if (!Enum.TryParse(stringTimestampFormat, true, out timestampFormat))
{
timestampFormat = TimestampFormat.RelativeTime;
2024-12-26 23:47:55 +13:00
Logger.Warn("Timestamp '" + stringTimestampFormat + "' is invalid, using 'RelativeTime' instead.");
}
2022-08-21 19:33:27 +12: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;
pinFirstMessage = json.SelectToken("bot.pin-first-message")?.Value<bool>() ?? false;
2022-08-21 19:33:27 +12: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 19:33:27 +12:00
2024-12-26 23:47:55 +13:00
interviewsEnabled = json.SelectToken("interviews.enabled")?.Value<bool>() ?? false;
deleteMessagesAfterSummary = json.SelectToken("interviews.delete-messages-after-summary")?.Value<bool>() ?? false;
deleteMessagesAfterNoSummary = json.SelectToken("interviews.delete-messages-after-no-summary")?.Value<bool>() ?? false;
// 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-18 01:11:57 +12:00
}