Implement Webhook for Ban Information

Co-Authored-By: Rose Witchaven <32779090+in1tiate@users.noreply.github.com>
This commit is contained in:
Salanto 2021-07-31 15:31:28 +02:00
parent f2943c5ebe
commit 9e824e1256
8 changed files with 68 additions and 1 deletions

View File

@ -94,6 +94,9 @@ webhook_sendfile=false
; Additional text to send with the webhook message. Usually for adding tags for role. Ensure the format is <@&[RoleID]>.
webhook_content=
; Enables the ban webhook.
webhook_ban_enabled = false
[Password]
; Whether or not to enforce password requirements. Only applicable under advanced authorization.
password_requirements = true

View File

@ -218,6 +218,13 @@ class ConfigManager {
*/
static bool discordWebhookSendFile();
/**
* @brief Returns true if the discord ban webhook is enabled.
*
* @return See short description.
*/
static bool discordBanWebhookEnabled();
/**
* @brief Returns true if password requirements should be enforced.
*

View File

@ -71,6 +71,18 @@ public:
*/
QJsonDocument constructModcallJson(const QString& f_name, const QString& f_area, const QString& f_reason) const;
/**
* @brief Constructs a new JSON document for bans.
*
* @param f_ipid The IPID of the client.
* @param f_moderator The name of the moderator banning.
* @param f_duration The date the ban expires.
* @param f_reason The reason of the ban.
*
* @return A JSON document for the ban.
*/
QJsonDocument constructBanJson(const QString& f_ipid, const QString& f_moderator, const QString& f_duration, const QString& f_reason, const int& f_banID);
/**
* @brief Constructs a new QHttpMultiPart document for log files.
*
@ -91,6 +103,16 @@ public slots:
*/
void onModcallWebhookRequested(const QString& f_name, const QString& f_area, const QString& f_reason, const QQueue<QString>& f_buffer);
/**
* @brief Handles a ban webhook request.
*
* @param f_ipid The IPID of the client.
* @param f_moderator The name of the moderator banning.
* @param f_duration The date the ban expires.
* @param f_reason The reason of the ban.
*/
void onBanWebhookRequested(const QString& f_ipid, const QString& f_moderator, const QString& f_duration, const QString& f_reason, const int& f_banID);
private:
/**
* @brief The QNetworkAccessManager for webhooks.

View File

@ -249,6 +249,9 @@ class Server : public QObject {
*/
void modcallWebhookRequest(const QString& f_name, const QString& f_area, const QString& f_reason, const QQueue<QString>& f_buffer);
void banWebhookRequest(const QString& f_ipid, const QString& f_moderator, const QString& f_duration, const QString& f_reason, const int& f_banID);
private:
/**
* @brief The proxy used for WebSocket connections.

View File

@ -72,9 +72,13 @@ void AOClient::cmdBan(int argc, QStringList argv)
else {
ban_duration = "The heat death of the universe.";
}
client->sendPacket("KB", {ban.reason + "\nID: " + QString::number(server->db_manager->getBanID(ban.ip)) + "\nUntil: " + ban_duration});
int ban_id = server->db_manager->getBanID(ban.ip);
client->sendPacket("KB", {ban.reason + "\nID: " + QString::number(ban_id) + "\nUntil: " + ban_duration});
client->socket->close();
kick_counter++;
if (ConfigManager::discordBanWebhookEnabled())
emit server->banWebhookRequest(ban.ipid, ban.moderator, ban_duration, ban.reason, ban_id);
}
if (kick_counter > 1)

View File

@ -285,6 +285,11 @@ bool ConfigManager::discordWebhookSendFile()
return m_settings->value("Discord/webhook_sendfile", false).toBool();
}
bool ConfigManager::discordBanWebhookEnabled()
{
return m_settings->value("Discord/webhook_ban_enabled", false).toBool();
}
bool ConfigManager::passwordRequirements()
{
return m_settings->value("Password/password_requirements", true).toBool();

View File

@ -39,6 +39,12 @@ void Discord::onModcallWebhookRequested(const QString &f_name, const QString &f_
}
}
void Discord::onBanWebhookRequested(const QString &f_ipid, const QString &f_moderator, const QString &f_duration, const QString &f_reason, const int &f_banID)
{
QJsonDocument l_json = constructBanJson(f_ipid,f_moderator, f_duration, f_reason, f_banID);
postJsonWebhook(l_json);
}
QJsonDocument Discord::constructModcallJson(const QString &f_name, const QString &f_area, const QString &f_reason) const
{
QJsonObject l_json;
@ -56,6 +62,21 @@ QJsonDocument Discord::constructModcallJson(const QString &f_name, const QString
return QJsonDocument(l_json);
}
QJsonDocument Discord::constructBanJson(const QString &f_ipid, const QString &f_moderator, const QString &f_duration, const QString &f_reason, const int &f_banID)
{
QJsonObject l_json;
QJsonArray l_array;
QJsonObject l_object {
{"color", "13312842"},
{"title", "Ban issued by " + f_moderator},
{"description", "Client IPID : " + f_ipid + "\nBan ID: " + QString::number(f_banID) + "\nBan reason : " + f_reason +"\nBanned until : " +f_duration}
};
l_array.append(l_object);
l_json["embeds"] = l_array;
return QJsonDocument(l_json);
}
QHttpMultiPart* Discord::constructLogMultipart(const QQueue<QString> &f_buffer) const
{
QHttpMultiPart* l_multipart = new QHttpMultiPart();

View File

@ -56,6 +56,8 @@ void Server::start()
discord = new Discord(this);
connect(this, &Server::modcallWebhookRequest,
discord, &Discord::onModcallWebhookRequested);
connect(this, &Server::banWebhookRequest,
discord, &Discord::onBanWebhookRequested);
}
if (ConfigManager::advertiseHTTPServer()) {