Fix clazy-writing-to-temporary
issues
TODO still: - Evidence - Judgelog
This commit is contained in:
parent
68b4174a40
commit
a42281c2c7
@ -237,13 +237,6 @@ class AreaData : public QObject {
|
||||
|
||||
void spectatable();
|
||||
|
||||
/**
|
||||
* @brief invite
|
||||
* @param f_clientId
|
||||
* @return True if the client was successfully invited. False if they were already in the list of invited people.
|
||||
*/
|
||||
bool invite(int f_clientId);
|
||||
|
||||
int playerCount() const;
|
||||
|
||||
QList<QTimer *> timers() const;
|
||||
@ -254,14 +247,27 @@ class AreaData : public QObject {
|
||||
|
||||
QList<int> charactersTaken() const;
|
||||
|
||||
bool changeCharacter(int f_from = -1, int f_to = -1);
|
||||
|
||||
QList<Evidence> evidence() const;
|
||||
|
||||
void swapEvidence(int f_eviId1, int f_eviId2);
|
||||
|
||||
Status status() const;
|
||||
|
||||
bool changeStatus(const QString& f_newStatus_r);
|
||||
|
||||
QList<int> invited() const;
|
||||
|
||||
/**
|
||||
* @brief invite
|
||||
* @param f_clientId
|
||||
* @return True if the client was successfully invited. False if they were already in the list of invited people.
|
||||
*/
|
||||
bool invite(int f_clientId);
|
||||
|
||||
bool uninvite(int f_clientId);
|
||||
|
||||
QString background() const;
|
||||
|
||||
bool shownameAllowed() const;
|
||||
@ -288,7 +294,9 @@ class AreaData : public QObject {
|
||||
|
||||
EvidenceMod eviMod() const;
|
||||
|
||||
QMap<QString, QString> notecards() const;
|
||||
bool addNotecard(const QString& f_owner_r, const QString& f_notecard_r);
|
||||
|
||||
QStringList getNotecards();
|
||||
|
||||
TestimonyRecording testimonyRecording() const;
|
||||
|
||||
@ -298,7 +306,7 @@ class AreaData : public QObject {
|
||||
|
||||
void clearTestimony();
|
||||
|
||||
QVector<QStringList> testimony() const;
|
||||
const QVector<QStringList>& testimony() const;
|
||||
|
||||
int statement() const;
|
||||
|
||||
@ -306,6 +314,8 @@ class AreaData : public QObject {
|
||||
|
||||
void addStatement(int f_position, const QStringList& f_newStatement);
|
||||
|
||||
void replaceStatement(int f_position, const QStringList& f_newStatement);
|
||||
|
||||
void removeStatement(int f_statementNumber);
|
||||
|
||||
std::pair<QStringList, TestimonyProgress> advanceTestimony(bool f_forward = true);
|
||||
|
@ -159,22 +159,14 @@ bool AOClient::changeCharacter(int char_id)
|
||||
return false;
|
||||
}
|
||||
|
||||
if (current_char != "") {
|
||||
area->charactersTaken().removeAll(server->getCharID(current_char));
|
||||
}
|
||||
bool l_successfulChange = area->changeCharacter(server->getCharID(current_char), char_id);
|
||||
|
||||
if (char_id >= 0) {
|
||||
current_char = "";
|
||||
|
||||
if (l_successfulChange) {
|
||||
QString char_selected = server->characters[char_id];
|
||||
bool taken = area->charactersTaken().contains(char_id);
|
||||
if (taken || char_selected == "")
|
||||
return false;
|
||||
|
||||
area->charactersTaken().append(char_id);
|
||||
current_char = char_selected;
|
||||
}
|
||||
else {
|
||||
current_char = "";
|
||||
}
|
||||
|
||||
pos = "";
|
||||
|
||||
|
@ -172,6 +172,16 @@ bool AreaData::invite(int f_clientId)
|
||||
return true;
|
||||
}
|
||||
|
||||
bool AreaData::uninvite(int f_clientId)
|
||||
{
|
||||
if (m_invited.contains(f_clientId)) {
|
||||
return false;
|
||||
}
|
||||
|
||||
m_invited.removeAll(f_clientId);
|
||||
return true;
|
||||
}
|
||||
|
||||
int AreaData::playerCount() const
|
||||
{
|
||||
return m_playerCount;
|
||||
@ -197,11 +207,39 @@ QList<int> AreaData::charactersTaken() const
|
||||
return m_charactersTaken;
|
||||
}
|
||||
|
||||
bool AreaData::changeCharacter(int f_from, int f_to)
|
||||
{
|
||||
if (f_from != -1) {
|
||||
m_charactersTaken.removeAll(f_from);
|
||||
}
|
||||
|
||||
if (m_charactersTaken.contains(f_to)) {
|
||||
return false;
|
||||
}
|
||||
|
||||
if (f_to != -1) {
|
||||
m_charactersTaken.append(f_to);
|
||||
return true;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
QList<AreaData::Evidence> AreaData::evidence() const
|
||||
{
|
||||
return m_evidence;
|
||||
}
|
||||
|
||||
void AreaData::swapEvidence(int f_eviId1, int f_eviId2)
|
||||
{
|
||||
#if QT_VERSION < QT_VERSION_CHECK(5, 13, 0)
|
||||
//swapItemsAt does not exist in Qt older than 5.13
|
||||
m_evidence.swap(f_eviId1, f_eviId2);
|
||||
#else
|
||||
m_evidence.swapItemsAt(f_eviId1, f_eviId2);
|
||||
#endif
|
||||
}
|
||||
|
||||
AreaData::Status AreaData::status() const
|
||||
{
|
||||
return m_status;
|
||||
@ -324,6 +362,11 @@ void AreaData::addStatement(int f_position, const QStringList &f_newStatement)
|
||||
m_testimony.insert(f_position, f_newStatement);
|
||||
}
|
||||
|
||||
void AreaData::replaceStatement(int f_position, const QStringList &f_newStatement)
|
||||
{
|
||||
m_testimony.replace(f_position, f_newStatement);
|
||||
}
|
||||
|
||||
void AreaData::removeStatement(int f_statementNumber)
|
||||
{
|
||||
m_testimony.remove(f_statementNumber);
|
||||
@ -351,7 +394,7 @@ QStringList AreaData::jumpToStatement(int f_statementNr)
|
||||
return m_testimony.at(m_statement);
|
||||
}
|
||||
|
||||
QVector<QStringList> AreaData::testimony() const
|
||||
const QVector<QStringList>& AreaData::testimony() const
|
||||
{
|
||||
return m_testimony;
|
||||
}
|
||||
@ -361,16 +404,38 @@ AreaData::TestimonyRecording AreaData::testimonyRecording() const
|
||||
return m_testimonyRecording;
|
||||
}
|
||||
|
||||
QMap<QString, QString> AreaData::notecards() const
|
||||
{
|
||||
return m_notecards;
|
||||
}
|
||||
|
||||
AreaData::EvidenceMod AreaData::eviMod() const
|
||||
{
|
||||
return m_eviMod;
|
||||
}
|
||||
|
||||
bool AreaData::addNotecard(const QString &f_owner_r, const QString &f_notecard_r)
|
||||
{
|
||||
m_notecards[f_owner_r] = f_notecard_r;
|
||||
|
||||
if (f_notecard_r.isNull()) {
|
||||
m_notecards.remove(f_owner_r);
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
QStringList AreaData::getNotecards()
|
||||
{
|
||||
QMapIterator<QString, QString> l_noteIter(m_notecards);
|
||||
QStringList l_notecards;
|
||||
|
||||
while (l_noteIter.hasNext()) {
|
||||
l_noteIter.next();
|
||||
l_notecards << l_noteIter.key() << ": " << l_noteIter.value() << "\n";
|
||||
}
|
||||
|
||||
m_notecards.clear();
|
||||
|
||||
return l_notecards;
|
||||
}
|
||||
|
||||
QString AreaData::musicPlayerBy() const
|
||||
{
|
||||
return m_musicPlayerBy;
|
||||
|
@ -133,11 +133,10 @@ void AOClient::cmdUnInvite(int argc, QStringList argv)
|
||||
sendServerMessage("You cannot uninvite a CM!");
|
||||
return;
|
||||
}
|
||||
else if (!area->invited().contains(uninvited_id)) {
|
||||
else if (!area->uninvite(uninvited_id)) {
|
||||
sendServerMessage("That ID is not on the invite list.");
|
||||
return;
|
||||
}
|
||||
area->invited().removeAll(uninvited_id);
|
||||
sendServerMessage("You uninvited ID " + argv[0]);
|
||||
}
|
||||
|
||||
@ -152,7 +151,7 @@ void AOClient::cmdLock(int argc, QStringList argv)
|
||||
area->lock();
|
||||
for (AOClient* client : server->clients) {
|
||||
if (client->current_area == current_area && client->joined) {
|
||||
area->invited().append(client->id);
|
||||
area->invite(client->id);
|
||||
}
|
||||
}
|
||||
arup(ARUPType::LOCKED, true);
|
||||
@ -169,7 +168,7 @@ void AOClient::cmdSpectatable(int argc, QStringList argv)
|
||||
area->spectatable();
|
||||
for (AOClient* client : server->clients) {
|
||||
if (client->current_area == current_area && client->joined) {
|
||||
area->invited().append(client->id);
|
||||
area->invite(client->id);
|
||||
}
|
||||
}
|
||||
arup(ARUPType::LOCKED, true);
|
||||
|
@ -85,12 +85,7 @@ void AOClient::cmdEvidence_Swap(int argc, QStringList argv)
|
||||
return;
|
||||
}
|
||||
if ((ev_id2 <= ev_size) && (ev_id1 <= ev_size)) {
|
||||
#if QT_VERSION < QT_VERSION_CHECK(5, 13, 0)
|
||||
//swapItemsAt does not exist in Qt older than 5.13
|
||||
area->evidence.swap(ev_id1, ev_id2);
|
||||
#else
|
||||
area->evidence().swapItemsAt(ev_id1, ev_id2);
|
||||
#endif
|
||||
area->swapEvidence(ev_id1, ev_id2);
|
||||
sendEvidenceList(area);
|
||||
sendServerMessage("The evidence " + QString::number(ev_id1) + " and " + QString::number(ev_id2) + " have been swapped.");
|
||||
}
|
||||
@ -256,7 +251,7 @@ void AOClient::cmdLoadTestimony(int argc, QStringList argv)
|
||||
if (testimony_lines <= server->maximum_statements) {
|
||||
QString line = in.readLine();
|
||||
QStringList packet = line.split("#");
|
||||
area->testimony().append(packet);
|
||||
area->addStatement(area->testimony().size(), packet);
|
||||
testimony_lines = testimony_lines + 1;
|
||||
}
|
||||
else {
|
||||
|
@ -103,7 +103,7 @@ QString AOClient::getAreaTimer(int area_idx, int timer_idx)
|
||||
if (timer_idx == 0)
|
||||
timer = server->timer;
|
||||
else if (timer_idx > 0 && timer_idx <= 4)
|
||||
timer = area->timers()[timer_idx - 1];
|
||||
timer = area->timers().at(timer_idx - 1);
|
||||
else
|
||||
return "Invalid timer ID.";
|
||||
|
||||
|
@ -83,7 +83,7 @@ void AOClient::cmdTimer(int argc, QStringList argv)
|
||||
requested_timer = server->timer;
|
||||
}
|
||||
else
|
||||
requested_timer = area->timers()[timer_id - 1];
|
||||
requested_timer = area->timers().at(timer_id - 1);
|
||||
|
||||
AOPacket show_timer("TI", {QString::number(timer_id), "2"});
|
||||
AOPacket hide_timer("TI", {QString::number(timer_id), "3"});
|
||||
@ -130,38 +130,33 @@ void AOClient::cmdTimer(int argc, QStringList argv)
|
||||
void AOClient::cmdNoteCard(int argc, QStringList argv)
|
||||
{
|
||||
AreaData* area = server->areas[current_area];
|
||||
if (area->notecards().keys().contains(current_char))
|
||||
area->notecards().remove(current_char);
|
||||
QString notecard = argv.join(" ");
|
||||
area->notecards()[current_char] = notecard;
|
||||
area->addNotecard(current_char, notecard);
|
||||
sendServerMessageArea(current_char + " wrote a note card.");
|
||||
}
|
||||
|
||||
void AOClient::cmdNoteCardClear(int argc, QStringList argv)
|
||||
{
|
||||
AreaData* area = server->areas[current_area];
|
||||
if (area->notecards().keys().contains(current_char)) {
|
||||
area->notecards().remove(current_char);
|
||||
if (!area->addNotecard(current_char, QString())) {
|
||||
sendServerMessageArea(current_char + " erased their note card.");
|
||||
}
|
||||
else
|
||||
sendServerMessage("You do not have a note card.");
|
||||
}
|
||||
|
||||
void AOClient::cmdNoteCardReveal(int argc, QStringList argv)
|
||||
{
|
||||
AreaData* area = server->areas[current_area];
|
||||
if (area->notecards().isEmpty()) {
|
||||
const QStringList l_notecards = area->getNotecards();
|
||||
|
||||
if (l_notecards.isEmpty()) {
|
||||
sendServerMessage("There are no cards to reveal in this area.");
|
||||
return;
|
||||
}
|
||||
QStringList message;
|
||||
message << "Note cards have been revealed.";
|
||||
QMap<QString, QString>::iterator i;
|
||||
for (i = area->notecards().begin(); i != area->notecards().end(); ++i)
|
||||
message << i.key() + ": " + i.value();
|
||||
sendServerMessageArea(message.join("\n"));
|
||||
area->notecards().clear();
|
||||
|
||||
QString message("Note cards have been revealed.\n");
|
||||
message.append(l_notecards.join("\n") + "\n");
|
||||
|
||||
sendServerMessageArea(message);
|
||||
}
|
||||
|
||||
void AOClient::cmd8Ball(int argc, QStringList argv)
|
||||
|
@ -58,7 +58,7 @@ QStringList AOClient::updateStatement(QStringList packet)
|
||||
sendServerMessage("Unable to update an empty statement. Please use /addtestimony.");
|
||||
else {
|
||||
packet[14] = "1";
|
||||
area->testimony().replace(c_statement, packet);
|
||||
area->replaceStatement(c_statement, packet);
|
||||
sendServerMessage("Updated current statement.");
|
||||
return area->testimony()[c_statement];
|
||||
}
|
||||
|
@ -1,67 +0,0 @@
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
// akashi - a server for Attorney Online 2 //
|
||||
// Copyright (C) 2020 scatterflower //
|
||||
// //
|
||||
// This program is free software: you can redistribute it and/or modify //
|
||||
// it under the terms of the GNU Affero General Public License as //
|
||||
// published by the Free Software Foundation, either version 3 of the //
|
||||
// License, or (at your option) any later version. //
|
||||
// //
|
||||
// This program is distributed in the hope that it will be useful, //
|
||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of //
|
||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the //
|
||||
// GNU Affero General Public License for more details. //
|
||||
// //
|
||||
// You should have received a copy of the GNU Affero General Public License //
|
||||
// along with this program. If not, see <https://www.gnu.org/licenses/>. //
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
#ifndef DISCORD_H
|
||||
#define DISCORD_H
|
||||
|
||||
#include <QtNetwork>
|
||||
#include <QCoreApplication>
|
||||
#include "server.h"
|
||||
|
||||
class Server;
|
||||
|
||||
class Discord : public QObject {
|
||||
Q_OBJECT
|
||||
|
||||
public:
|
||||
/**
|
||||
* @brief Creates an instance of the Discord class.
|
||||
*
|
||||
* @param p_server A pointer to the Server instance Discord is constructed by.
|
||||
* @param parent Qt-based parent, passed along to inherited constructor from QObject.
|
||||
*/
|
||||
Discord(Server* p_server, QObject* parent = nullptr)
|
||||
: QObject(parent), server(p_server) {
|
||||
};
|
||||
|
||||
public slots:
|
||||
|
||||
/**
|
||||
* @brief Sends a modcall to a discord webhook.
|
||||
*
|
||||
* @param name The character or OOC name of the client who sent the modcall.
|
||||
* @param area The area name of the area the modcall was sent from.
|
||||
* @param reason The reason the client specified for the modcall.
|
||||
* @param current_area The index of the area the modcall is made.
|
||||
*/
|
||||
void postModcallWebhook(QString name, QString reason, int current_area);
|
||||
|
||||
/**
|
||||
* @brief Sends the reply to the POST request sent by Discord::postModcallWebhook.
|
||||
*/
|
||||
void onFinish(QNetworkReply *reply);
|
||||
|
||||
private:
|
||||
|
||||
/**
|
||||
* @brief A pointer to the Server.
|
||||
*/
|
||||
Server* server;
|
||||
|
||||
};
|
||||
|
||||
#endif // DISCORD_H
|
@ -1,73 +0,0 @@
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
// akashi - a server for Attorney Online 2 //
|
||||
// Copyright (C) 2020 scatterflower //
|
||||
// //
|
||||
// This program is free software: you can redistribute it and/or modify //
|
||||
// it under the terms of the GNU Affero General Public License as //
|
||||
// published by the Free Software Foundation, either version 3 of the //
|
||||
// License, or (at your option) any later version. //
|
||||
// //
|
||||
// This program is distributed in the hope that it will be useful, //
|
||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of //
|
||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the //
|
||||
// GNU Affero General Public License for more details. //
|
||||
// //
|
||||
// You should have received a copy of the GNU Affero General Public License //
|
||||
// along with this program. If not, see <https://www.gnu.org/licenses/>. //
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
#include "include/discord.h"
|
||||
|
||||
void Discord::postModcallWebhook(QString name, QString reason, int current_area)
|
||||
{
|
||||
if (!QUrl (server->webhook_url).isValid()) {
|
||||
qWarning() << "Invalid webhook url!";
|
||||
return;
|
||||
}
|
||||
|
||||
QNetworkRequest request(QUrl (server->webhook_url));
|
||||
QNetworkAccessManager* nam = new QNetworkAccessManager();
|
||||
connect(nam, &QNetworkAccessManager::finished,
|
||||
this, &Discord::onFinish);
|
||||
|
||||
// This is the kind of garbage Qt makes me write.
|
||||
// I am so tired. Qt has broken me.
|
||||
request.setHeader(QNetworkRequest::ContentTypeHeader, "application/json");
|
||||
|
||||
QJsonObject json;
|
||||
QJsonArray jsonArray;
|
||||
QJsonObject jsonObject {
|
||||
{"color", "13312842"},
|
||||
{"title", name + " filed a modcall in " + server->areas[current_area]->name},
|
||||
{"description", reason}
|
||||
};
|
||||
jsonArray.append(jsonObject);
|
||||
json["embeds"] = jsonArray;
|
||||
|
||||
nam->post(request, QJsonDocument(json).toJson());
|
||||
|
||||
if (server->webhook_sendfile) {
|
||||
QHttpMultiPart* construct = new QHttpMultiPart();
|
||||
request.setHeader(QNetworkRequest::ContentTypeHeader, "multipart/form-data; boundary=" + construct->boundary());
|
||||
|
||||
//This cost me two days of my life. Thanks Qt and Discord. You have broken me.
|
||||
QHttpPart file;
|
||||
file.setRawHeader(QByteArray("Content-Disposition"), QByteArray("form-data; name=\"file\"; filename=\"log.txt\""));
|
||||
file.setRawHeader(QByteArray("Content-Type"), QByteArray("plain/text"));
|
||||
QQueue<QString> buffer = server->areas[current_area]->logger->getBuffer(); // I feel no shame for doing this
|
||||
QString log;
|
||||
while (!buffer.isEmpty()) {
|
||||
log.append(buffer.dequeue() + "\n");
|
||||
}
|
||||
file.setBody(log.toUtf8());
|
||||
construct->append(file);
|
||||
|
||||
nam->post(request, construct);
|
||||
}
|
||||
}
|
||||
|
||||
void Discord::onFinish(QNetworkReply *reply)
|
||||
{
|
||||
QByteArray data = reply->readAll();
|
||||
QString str_reply = data;
|
||||
qDebug() << str_reply;
|
||||
}
|
Loading…
Reference in New Issue
Block a user