Use QSettings instead of settings struct

As it turns out, I am not intelligent.
This commit is contained in:
MangosArentLiterature 2021-06-19 23:05:33 -05:00
parent c4db245bec
commit 0e6efb18c0
4 changed files with 173 additions and 271 deletions

View File

@ -39,17 +39,13 @@ int main(int argc, char* argv[])
QCoreApplication::setApplicationVersion("banana"); QCoreApplication::setApplicationVersion("banana");
std::atexit(cleanup); std::atexit(cleanup);
if (ConfigManager::verifyServerConfig()) { // Verify server configuration is sound.
// Config is sound, so proceed with starting the server if (!ConfigManager::verifyServerConfig()) {
// Validate some of the config before passing it on
bool config_valid = ConfigManager::loadConfigSettings();
if (!config_valid) {
qCritical() << "config.ini is invalid!"; qCritical() << "config.ini is invalid!";
qCritical() << "Exiting server due to configuration issue."; qCritical() << "Exiting server due to configuration issue.";
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
QCoreApplication::quit(); QCoreApplication::quit();
} }
else { else {
if (ConfigManager::advertiseServer()) { if (ConfigManager::advertiseServer()) {
advertiser = advertiser =
@ -66,11 +62,6 @@ int main(int argc, char* argv[])
} }
server->start(); server->start();
} }
} else {
qCritical() << "Exiting server due to configuration issue.";
exit(EXIT_FAILURE);
QCoreApplication::quit();
}
return app.exec(); return app.exec();
} }

View File

@ -43,22 +43,6 @@ class ConfigManager {
*/ */
static bool verifyServerConfig(); static bool verifyServerConfig();
/**
* @brief Begins loading server settings from config.ini.
*
* @return True if the settings were successfully loaded, false otherwise.
*/
static bool loadConfigSettings();
/**
* @brief Reloads server settings from config.ini that can be reloaded. This is also called by `loadConfigSettings` to finish setting loading.
*
* @return True if the server settings were successfully reloaded, false otherwise.
*
* @see loadConfigSettings
*/
static bool reloadConfigSettings();
/** /**
* @brief Returns true if the server should advertise to the master server. * @brief Returns true if the server should advertise to the master server.
* *
@ -332,6 +316,11 @@ class ConfigManager {
*/ */
static void setMotd(const QString f_motd); static void setMotd(const QString f_motd);
/**
* @brief Reload the server configuration.
*/
static void reloadSettings();
private: private:
/** /**
* @brief Checks if a file exists and is valid. * @brief Checks if a file exists and is valid.
@ -352,57 +341,24 @@ private:
static bool dirExists(const QFileInfo& dir); static bool dirExists(const QFileInfo& dir);
/** /**
* @brief A struct containing the server settings. * @brief A struct for storing QStringLists loaded from command configuration files.
*/ */
struct server_settings { struct CommandSettings {
// Options QStringList magic_8ball; //!< Contains answers for /8ball, found in config/text/8ball.txt
bool advertise; //!< Whether the server should advertise to the master server. QStringList praises; //!< Contains command praises, found in config/text/praises.txt
int max_players; //!< Max number of players that can connect at once. QStringList reprimands; //!< Contains command reprimands, found in config/text/reprimands.txt
QString ms_ip; //!< IP of the master server. QStringList gimps; //!< Contains phrases for /gimp, found in config/text/gimp.txt
int ms_port; //!< Port of the master server.
int port; //!< Server port.
QString server_description; //!< Server description.
QString server_name; //!< Server name.
QString motd; //!< Server Message of the Day.
bool webao_enable; //!< Whether the server should accept WebAO connections.
int webao_port; //!< Websocket port.
DataTypes::AuthType auth; //!< Server authorization type.
QString modpass; //!< Server moderator password.
int logbuffer; //!< Logbuffer length.
DataTypes::LogType logging; //!< Server logging type.
int maximum_statements; //!< Max testimony recorder statements.
int multiclient_limit; //!< Max number of multiclient connections.
int maximum_characters; //!< Max characters in a message.
int message_floodguard; //!< Message floodguard length.
QUrl asset_url; //!< Server asset URL.
int afk_timeout; //!< Server AFK timeout length.
// Dice
int max_value; //!< Max dice sides.
int max_dice; //!< Max amount of dice.
// Discord
bool webhook_enabled; //!< Whether the Discord webhook is enabled.
QString webhook_url; //!< URL of the Discord webhook.
QString webhook_content; //!< The content to send to the Discord webhook.
bool webhook_sendfile; //!< Whether to send log files to the Discord webhook.
// Password
bool password_requirements; //!< Whether to enforce password requirements.
int pass_min_length; //!< Minimum length of passwords.
int pass_max_length; //!< Maximum length of passwords.
bool pass_required_mix_case; //!< Whether passwords require mixed case.
bool pass_required_numbers; //!< Whether passwords require numbers.
bool pass_required_special; //!< Whether passwords require special characters.
bool pass_can_contain_username; //!< Whether passwords can contain the username.
// config/text/
QStringList magic_8ball_answers; //!< List of 8ball answers, from 8ball.txt
QStringList praise_list; //!< List of praises, from praise.txt
QStringList reprimands_list; //!< List of reprimands, from reprimands.txt
QStringList gimp_list; //!< List of gimp phrases, from gimp.txt
}; };
/**
* @brief Contains the settings required for various commands.
*/
static CommandSettings* m_commands;
/** /**
* @brief Stores all server configuration values. * @brief Stores all server configuration values.
*/ */
static server_settings* m_settings; static QSettings* m_settings;
/** /**
* @brief Returns a stringlist with the contents of a .txt file from config/text/. * @brief Returns a stringlist with the contents of a .txt file from config/text/.

View File

@ -411,7 +411,7 @@ void AOClient::cmdBanInfo(int argc, QStringList argv)
void AOClient::cmdReload(int argc, QStringList argv) void AOClient::cmdReload(int argc, QStringList argv)
{ {
ConfigManager::reloadConfigSettings(); ConfigManager::reloadSettings();
emit server->reloadRequest(ConfigManager::serverName(), ConfigManager::serverDescription()); emit server->reloadRequest(ConfigManager::serverName(), ConfigManager::serverDescription());
sendServerMessage("Reloaded configurations"); sendServerMessage("Reloaded configurations");
} }

View File

@ -17,7 +17,8 @@
////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////
#include "include/config_manager.h" #include "include/config_manager.h"
ConfigManager::server_settings* ConfigManager::m_settings = new server_settings(); QSettings* ConfigManager::m_settings = new QSettings("config/config.ini", QSettings::IniFormat);
ConfigManager::CommandSettings* ConfigManager::m_commands = new CommandSettings();
bool ConfigManager::verifyServerConfig() bool ConfigManager::verifyServerConfig()
{ {
@ -47,166 +48,50 @@ bool ConfigManager::verifyServerConfig()
qCritical() << "areas.ini is invalid!"; qCritical() << "areas.ini is invalid!";
return false; return false;
} }
return true;
}
bool ConfigManager::loadConfigSettings() // Verify config settings
{ m_settings->beginGroup("Options");
QSettings l_config("config/config.ini", QSettings::IniFormat);
l_config.setIniCodec("UTF-8");
l_config.beginGroup("Options");
bool ok; bool ok;
m_settings->ms_port = l_config.value("ms_port", "27016").toInt(&ok); m_settings->value("ms_port", 27016).toInt(&ok);
if (!ok) { if (!ok) {
qCritical("ms_port is not a valid port!"); qCritical("ms_port is not a valid port!");
return false; return false;
} }
m_settings->port = l_config.value("port", "27016").toInt(&ok); m_settings->value("port", 27016).toInt(&ok);
if (!ok) { if (!ok) {
qCritical("port is not a valid port!"); qCritical("port is not a valid port!");
return false; return false;
} }
m_settings->webao_enable = l_config.value("webao_enable", "true").toBool(); bool web_ao = m_settings->value("webao_enable", false).toBool();
if (!m_settings->webao_enable) { if (!web_ao) {
m_settings->webao_port = -1; m_settings->setValue("webao_port", -1);
} }
else { else {
m_settings->webao_port = l_config.value("webao_port", "27017").toInt(&ok); m_settings->value("webao_port", 27017).toInt(&ok);
if (!ok) { if (!ok) {
qCritical("webao_port is not a valid port!"); qCritical("webao_port is not a valid port!");
return false; return false;
} }
} }
m_settings->ms_ip = l_config.value("ms_ip", "master.aceattorneyonline.com").toString(); QString l_auth = m_settings->value("auth", "simple").toString().toLower();
m_settings->advertise = l_config.value("advertise", "true").toBool(); if (!(l_auth == "simple" || l_auth == "advanced")) {
l_config.endGroup();
if (reloadConfigSettings())
return true;
else
return false;
}
bool ConfigManager::reloadConfigSettings()
{
QSettings l_config("config/config.ini", QSettings::IniFormat);
l_config.setIniCodec("UTF-8");
l_config.beginGroup("Options");
bool ok;
// Options
m_settings->max_players = l_config.value("max_players", "100").toInt(&ok);
if (!ok) {
qWarning("max_players is not an int!");
m_settings->max_players = 100;
}
m_settings->server_description = l_config.value("server_description", "This is my flashy new server!").toString();
m_settings->server_name = l_config.value("server_name", "An Unnamed Server").toString();
m_settings->motd = l_config.value("motd", "MOTD not set").toString();
QString l_auth = l_config.value("auth", "simple").toString();
if (l_auth == "simple" || l_auth == "advanced") {
m_settings->auth = toDataType<DataTypes::AuthType>(l_auth);
}
else {
qCritical("auth is not a valid auth type!"); qCritical("auth is not a valid auth type!");
return false; return false;
} }
m_settings->modpass = l_config.value("modpass", "changeme").toString(); m_settings->endGroup();
m_settings->logbuffer = l_config.value("logbuffer", "500").toInt(&ok); m_commands->magic_8ball = (loadConfigFile("8ball"));
if (!ok) { m_commands->praises = (loadConfigFile("praise"));
qWarning("logbuffer is not an int!"); m_commands->reprimands = (loadConfigFile("reprimands"));
m_settings->logbuffer = 500; m_commands->gimps = (loadConfigFile("gimp"));
}
QString l_log = l_config.value("logging", "modcall").toString();
if (l_log == "modcall" || l_log == "full") {
m_settings->logging = toDataType<DataTypes::LogType>(l_log);
}
else {
qWarning("logging is not a valid log type!");
m_settings->logging = DataTypes::LogType::MODCALL;
}
m_settings->maximum_statements = l_config.value("maximum_statements", "10").toInt(&ok);
if (!ok) {
qWarning("maximum_statements is not an int!");
m_settings->maximum_statements = 10;
}
m_settings->multiclient_limit = l_config.value("multiclient_limit", "15").toInt(&ok);
if (!ok) {
qWarning("multiclient_limit is not an int!");
m_settings->multiclient_limit = 15;
}
m_settings->maximum_characters = l_config.value("maximum_characters", "256").toInt(&ok);
if (!ok) {
qWarning("maximum_characters is not an int!");
m_settings->maximum_characters = 256;
}
m_settings->message_floodguard = l_config.value("message_floodguard", "250").toInt(&ok);
if (!ok) {
qWarning("message_floodguard is not an in!");
m_settings->message_floodguard = 250;
}
m_settings->asset_url = l_config.value("asset_url", "").toString().toUtf8();
if (!m_settings->asset_url.isValid()) {
qWarning("asset_url is not a valid url!");
m_settings->asset_url = NULL;
}
l_config.endGroup();
// Dice
l_config.beginGroup("Dice");
m_settings->max_value = l_config.value("max_value", "100").toInt(&ok);
if (!ok) {
qWarning("max_value is not an int!");
m_settings->max_value = 100;
}
m_settings->max_dice = l_config.value("max_dice", "100").toInt(&ok);
if (!ok) {
qWarning("max_dice is not an int!");
m_settings->max_dice = 100;
}
l_config.endGroup();
// Discord
l_config.beginGroup("Discord");
m_settings->webhook_enabled = l_config.value("webhook_enabled", "false").toBool();
m_settings->webhook_url = l_config.value("webhook_url", "Your webhook url here.").toString();
m_settings->webhook_sendfile = l_config.value("webhook_sendfile", "false").toBool();
m_settings->webhook_content = l_config.value("webhook_content", "").toString();
l_config.endGroup();
// Password
l_config.beginGroup("Password");
m_settings->password_requirements = l_config.value("password_requirements", "true").toBool();
m_settings->pass_min_length = l_config.value("pass_min_length", "8").toInt(&ok);
if (!ok) {
qWarning("pass_min_length is not an int!");
m_settings->pass_min_length = 8;
}
m_settings->pass_max_length = l_config.value("pass_max_length", "0").toInt(&ok);
if (!ok) {
qWarning("pass_max_length is not an int!");
m_settings->pass_max_length = 0;
}
m_settings->pass_required_mix_case = l_config.value("pass_required_mix_case", "true").toBool();
m_settings->pass_required_numbers = l_config.value("pass_required_numbers", "true").toBool();
m_settings->pass_required_special = l_config.value("pass_required_special", "true").toBool();
m_settings->pass_can_contain_username = l_config.value("pass_can_contain_username", "false").toBool();
m_settings->afk_timeout = l_config.value("afk_timeout", "300").toInt(&ok);
if (!ok) {
qWarning("afk_timeout is not an int!");
m_settings->afk_timeout = 300;
}
l_config.endGroup();
m_settings->magic_8ball_answers = (loadConfigFile("8ball"));
m_settings->praise_list = (loadConfigFile("praise"));
m_settings->reprimands_list = (loadConfigFile("reprimands"));
m_settings->gimp_list = (loadConfigFile("gimp"));
return true; return true;
} }
void ConfigManager::reloadSettings()
{
m_settings->sync();
}
QStringList ConfigManager::loadConfigFile(const QString filename) QStringList ConfigManager::loadConfigFile(const QString filename)
{ {
QStringList stringlist; QStringList stringlist;
@ -221,201 +106,271 @@ QStringList ConfigManager::loadConfigFile(const QString filename)
bool ConfigManager::advertiseServer() bool ConfigManager::advertiseServer()
{ {
return m_settings->advertise; return m_settings->value("Options/advertise", true).toBool();
} }
int ConfigManager::maxPlayers() int ConfigManager::maxPlayers()
{ {
return m_settings->max_players; bool ok;
int l_players = m_settings->value("Options/max_players", 100).toInt(&ok);
if (!ok) {
qWarning("max_players is not an int!");
l_players = 100;
}
return l_players;
} }
QString ConfigManager::masterServerIP() QString ConfigManager::masterServerIP()
{ {
return m_settings->ms_ip; return m_settings->value("Options/ms_ip", "master.aceattorneyonline.com").toString();
} }
int ConfigManager::masterServerPort() int ConfigManager::masterServerPort()
{ {
return m_settings->ms_port; return m_settings->value("Options/ms_port", 27016).toInt();
} }
int ConfigManager::serverPort() int ConfigManager::serverPort()
{ {
return m_settings->port; return m_settings->value("Options/port", 27016).toInt();
} }
QString ConfigManager::serverDescription() QString ConfigManager::serverDescription()
{ {
return m_settings->server_description; return m_settings->value("Options/server_description", "This is my flashy new server!").toString();
} }
QString ConfigManager::serverName() QString ConfigManager::serverName()
{ {
return m_settings->server_name; return m_settings->value("Options/server_name", "An Unnamed Server").toString();
} }
QString ConfigManager::motd() QString ConfigManager::motd()
{ {
return m_settings->motd; return m_settings->value("Options/motd", "MOTD not set").toString();
} }
bool ConfigManager::webaoEnabled() bool ConfigManager::webaoEnabled()
{ {
return m_settings->webao_enable; return m_settings->value("Options/webao_enable", false).toBool();
} }
int ConfigManager::webaoPort() int ConfigManager::webaoPort()
{ {
return m_settings->webao_port; return m_settings->value("Options/webao_port", 27017).toInt();
} }
DataTypes::AuthType ConfigManager::authType() DataTypes::AuthType ConfigManager::authType()
{ {
return m_settings->auth; QString l_auth = m_settings->value("Options/auth", "simple").toString();
return toDataType<DataTypes::AuthType>(l_auth);
} }
QString ConfigManager::modpass() QString ConfigManager::modpass()
{ {
return m_settings->modpass; return m_settings->value("Options/modpass", "changeme").toString();
} }
int ConfigManager::logBuffer() int ConfigManager::logBuffer()
{ {
return m_settings->logbuffer; bool ok;
int l_buffer = m_settings->value("Options/logbuffer", 500).toInt(&ok);
if (!ok) {
qWarning("logbuffer is not an int!");
l_buffer = 500;
}
return l_buffer;
} }
DataTypes::LogType ConfigManager::loggingType() DataTypes::LogType ConfigManager::loggingType()
{ {
return m_settings->logging; QString l_log = m_settings->value("Options/logging", "modcall").toString();
return toDataType<DataTypes::LogType>(l_log);
} }
int ConfigManager::maxStatements() int ConfigManager::maxStatements()
{ {
return m_settings->maximum_statements; bool ok;
int l_max = m_settings->value("Options/maximum_statements", 10).toInt(&ok);
if (!ok) {
qWarning("maximum_statements is not an int!");
l_max = 10;
}
return l_max;
} }
int ConfigManager::multiClientLimit() int ConfigManager::multiClientLimit()
{ {
return m_settings->multiclient_limit; bool ok;
int l_limit = m_settings->value("Options/multiclient_limit", 15).toInt(&ok);
if (!ok) {
qWarning("multiclient_limit is not an int!");
l_limit = 15;
}
return l_limit;
} }
int ConfigManager::maxCharacters() int ConfigManager::maxCharacters()
{ {
return m_settings->maximum_characters; bool ok;
int l_max = m_settings->value("Options/maximum_characters", 256).toInt(&ok);
if (!ok) {
qWarning("maximum_characters is not an int!");
l_max = 256;
}
return l_max;
} }
int ConfigManager::messageFloodguard() int ConfigManager::messageFloodguard()
{ {
return m_settings->message_floodguard; bool ok;
int l_flood = m_settings->value("Options/message_floodguard", 250).toInt(&ok);
if (!ok) {
qWarning("message_floodguard is not an int!");
l_flood = 250;
}
return l_flood;
} }
QUrl ConfigManager::assetUrl() QUrl ConfigManager::assetUrl()
{ {
return m_settings->asset_url; QByteArray l_url = m_settings->value("Options/asset_url", "").toString().toUtf8();
if (QUrl(l_url).isValid()) {
return QUrl(l_url);
}
else {
qWarning("asset_url is not a valid url!");
return QUrl(NULL);
}
} }
int ConfigManager::diceMaxValue() int ConfigManager::diceMaxValue()
{ {
return m_settings->max_value; bool ok;
int l_value = m_settings->value("Dice/max_value", 100).toInt(&ok);
if (!ok) {
qWarning("max_value is not an int!");
l_value = 100;
}
return l_value;
} }
int ConfigManager::diceMaxDice() int ConfigManager::diceMaxDice()
{ {
return m_settings->max_dice; bool ok;
int l_dice = m_settings->value("Dice/max_dice", 100).toInt(&ok);
if (!ok) {
qWarning("max_dice is not an int!");
l_dice = 100;
}
return l_dice;
} }
bool ConfigManager::discordWebhookEnabled() bool ConfigManager::discordWebhookEnabled()
{ {
return m_settings->webao_enable; return m_settings->value("Discord/webhook_enabled", false).toBool();
} }
QString ConfigManager::discordWebhookUrl() QString ConfigManager::discordWebhookUrl()
{ {
return m_settings->webhook_url; return m_settings->value("Discord/webhook_url", "").toString();
} }
QString ConfigManager::discordWebhookContent() QString ConfigManager::discordWebhookContent()
{ {
return m_settings->webhook_content; return m_settings->value("Discord/webhook_content", "").toString();
} }
bool ConfigManager::discordWebhookSendFile() bool ConfigManager::discordWebhookSendFile()
{ {
return m_settings->webhook_sendfile; return m_settings->value("Discord/webhook_sendfile", false).toBool();
} }
bool ConfigManager::passwordRequirements() bool ConfigManager::passwordRequirements()
{ {
return m_settings->password_requirements; return m_settings->value("Password/password_requirements", true).toBool();
} }
int ConfigManager::passwordMinLength() int ConfigManager::passwordMinLength()
{ {
return m_settings->pass_min_length; bool ok;
int l_min = m_settings->value("Password/pass_min_length", 8).toInt(&ok);
if (!ok) {
qWarning("pass_min_length is not an int!");
l_min = 8;
}
return l_min;
} }
int ConfigManager::passwordMaxLength() int ConfigManager::passwordMaxLength()
{ {
return m_settings->pass_max_length; bool ok;
int l_max = m_settings->value("Password/pass_max_length", 0).toInt(&ok);
if (!ok) {
qWarning("pass_max_length is not an int!");
l_max = 0;
}
return l_max;
} }
bool ConfigManager::passwordRequireMixCase() bool ConfigManager::passwordRequireMixCase()
{ {
return m_settings->pass_required_mix_case; return m_settings->value("Password/pass_required_mix_case", true).toBool();
} }
bool ConfigManager::passwordRequireNumbers() bool ConfigManager::passwordRequireNumbers()
{ {
return m_settings->pass_required_numbers; return m_settings->value("Password/pass_required_numbers", true).toBool();
} }
bool ConfigManager::passwordRequireSpecialCharacters() bool ConfigManager::passwordRequireSpecialCharacters()
{ {
return m_settings->pass_required_special; return m_settings->value("Password/pass_required_special", true).toBool();
} }
bool ConfigManager::passwordCanContainUsername() bool ConfigManager::passwordCanContainUsername()
{ {
return m_settings->pass_can_contain_username; return m_settings->value("Password/pass_can_contain_username", false).toBool();
} }
int ConfigManager::afkTimeout() int ConfigManager::afkTimeout()
{ {
return m_settings->afk_timeout; bool ok;
int l_afk = m_settings->value("Options/afk_timeout", 300).toInt(&ok);
if (!ok) {
qWarning("afk_timeout is not an int!");
l_afk = 300;
}
return l_afk;
} }
void ConfigManager::setAuthType(const DataTypes::AuthType f_auth) void ConfigManager::setAuthType(const DataTypes::AuthType f_auth)
{ {
QSettings l_config("config/config.ini", QSettings::IniFormat); m_settings->setValue("Options/auth", fromDataType<DataTypes::AuthType>(f_auth).toLower());
l_config.setIniCodec("UTF-8");
l_config.beginGroup("Options");
l_config.setValue("auth", fromDataType<DataTypes::AuthType>(f_auth).toLower());
m_settings->auth = f_auth;
} }
QStringList ConfigManager::magic8BallAnswers() QStringList ConfigManager::magic8BallAnswers()
{ {
return m_settings->magic_8ball_answers; return m_commands->magic_8ball;
} }
QStringList ConfigManager::praiseList() QStringList ConfigManager::praiseList()
{ {
return m_settings->praise_list; return m_commands->praises;
} }
QStringList ConfigManager::reprimandsList() QStringList ConfigManager::reprimandsList()
{ {
return m_settings->reprimands_list; return m_commands->reprimands;
} }
QStringList ConfigManager::gimpList() QStringList ConfigManager::gimpList()
{ {
return m_settings->gimp_list; return m_commands->gimps;
} }
void ConfigManager::setMotd(const QString f_motd) void ConfigManager::setMotd(const QString f_motd)
{ {
m_settings->motd = f_motd; m_settings->setValue("Options/motd", f_motd);
} }
bool ConfigManager::fileExists(const QFileInfo &f_file) bool ConfigManager::fileExists(const QFileInfo &f_file)