commit
af353b942e
@ -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]>.
|
; Additional text to send with the webhook message. Usually for adding tags for role. Ensure the format is <@&[RoleID]>.
|
||||||
webhook_content=
|
webhook_content=
|
||||||
|
|
||||||
|
; Enables the ban webhook.
|
||||||
|
webhook_ban_enabled = false
|
||||||
|
|
||||||
[Password]
|
[Password]
|
||||||
; Whether or not to enforce password requirements. Only applicable under advanced authorization.
|
; Whether or not to enforce password requirements. Only applicable under advanced authorization.
|
||||||
password_requirements = true
|
password_requirements = true
|
||||||
|
@ -218,6 +218,13 @@ class ConfigManager {
|
|||||||
*/
|
*/
|
||||||
static bool discordWebhookSendFile();
|
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.
|
* @brief Returns true if password requirements should be enforced.
|
||||||
*
|
*
|
||||||
|
@ -71,6 +71,18 @@ public:
|
|||||||
*/
|
*/
|
||||||
QJsonDocument constructModcallJson(const QString& f_name, const QString& f_area, const QString& f_reason) const;
|
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.
|
* @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);
|
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:
|
private:
|
||||||
/**
|
/**
|
||||||
* @brief The QNetworkAccessManager for webhooks.
|
* @brief The QNetworkAccessManager for webhooks.
|
||||||
|
@ -260,6 +260,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 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:
|
private:
|
||||||
/**
|
/**
|
||||||
* @brief The proxy used for WebSocket connections.
|
* @brief The proxy used for WebSocket connections.
|
||||||
|
@ -72,9 +72,13 @@ void AOClient::cmdBan(int argc, QStringList argv)
|
|||||||
else {
|
else {
|
||||||
ban_duration = "The heat death of the universe.";
|
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();
|
client->socket->close();
|
||||||
kick_counter++;
|
kick_counter++;
|
||||||
|
|
||||||
|
if (ConfigManager::discordBanWebhookEnabled())
|
||||||
|
emit server->banWebhookRequest(ban.ipid, ban.moderator, ban_duration, ban.reason, ban_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (kick_counter > 1)
|
if (kick_counter > 1)
|
||||||
|
@ -285,6 +285,11 @@ bool ConfigManager::discordWebhookSendFile()
|
|||||||
return m_settings->value("Discord/webhook_sendfile", false).toBool();
|
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()
|
bool ConfigManager::passwordRequirements()
|
||||||
{
|
{
|
||||||
return m_settings->value("Password/password_requirements", true).toBool();
|
return m_settings->value("Password/password_requirements", true).toBool();
|
||||||
|
@ -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
|
QJsonDocument Discord::constructModcallJson(const QString &f_name, const QString &f_area, const QString &f_reason) const
|
||||||
{
|
{
|
||||||
QJsonObject l_json;
|
QJsonObject l_json;
|
||||||
@ -56,6 +62,21 @@ QJsonDocument Discord::constructModcallJson(const QString &f_name, const QString
|
|||||||
return QJsonDocument(l_json);
|
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* Discord::constructLogMultipart(const QQueue<QString> &f_buffer) const
|
||||||
{
|
{
|
||||||
QHttpMultiPart* l_multipart = new QHttpMultiPart();
|
QHttpMultiPart* l_multipart = new QHttpMultiPart();
|
||||||
|
@ -56,6 +56,8 @@ void Server::start()
|
|||||||
discord = new Discord(this);
|
discord = new Discord(this);
|
||||||
connect(this, &Server::modcallWebhookRequest,
|
connect(this, &Server::modcallWebhookRequest,
|
||||||
discord, &Discord::onModcallWebhookRequested);
|
discord, &Discord::onModcallWebhookRequested);
|
||||||
|
connect(this, &Server::banWebhookRequest,
|
||||||
|
discord, &Discord::onBanWebhookRequested);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ConfigManager::advertiseHTTPServer()) {
|
if (ConfigManager::advertiseHTTPServer()) {
|
||||||
|
Loading…
Reference in New Issue
Block a user