AreaData acccess rework, from direct to through getters
Literal hell.
This commit is contained in:
parent
3aeff2d72d
commit
5a0c291825
@ -53,40 +53,6 @@ class AreaData : public QObject {
|
||||
QString image; //!< A path originating from `base/evidence/` that points to an image file.
|
||||
};
|
||||
|
||||
/**
|
||||
* @brief The list of timers available in the area.
|
||||
*/
|
||||
QList<QTimer*> timers;
|
||||
|
||||
/**
|
||||
* @brief The user-facing and internal name of the area.
|
||||
*/
|
||||
QString name;
|
||||
|
||||
/**
|
||||
* @brief The index of the area in the server's area list.
|
||||
*/
|
||||
int index;
|
||||
|
||||
/**
|
||||
* @brief A list of the character IDs of all characters taken.
|
||||
*/
|
||||
QList<int> characters_taken;
|
||||
|
||||
/**
|
||||
* @brief A list of Evidence currently available in the area's court record.
|
||||
*
|
||||
* @details This contains *all* evidence, not just the ones a given side can see.
|
||||
*
|
||||
* @see HIDDEN_CM
|
||||
*/
|
||||
QList<Evidence> evidence;
|
||||
|
||||
/**
|
||||
* @brief The amount of clients inside the area.
|
||||
*/
|
||||
int player_count;
|
||||
|
||||
/**
|
||||
* @brief The status of an area.
|
||||
*
|
||||
@ -105,25 +71,6 @@ class AreaData : public QObject {
|
||||
/// Exposes the metadata of the Status enum.
|
||||
Q_ENUM(Status);
|
||||
|
||||
/**
|
||||
* @brief The status of the area.
|
||||
*
|
||||
* @see Status
|
||||
*/
|
||||
Status status;
|
||||
|
||||
/**
|
||||
* @brief The IDs of all the owners (or Case Makers / CMs) of the area.
|
||||
*/
|
||||
QList<int> owners;
|
||||
|
||||
/**
|
||||
* @brief The list of clients invited to the area.
|
||||
*
|
||||
* @see LOCKED and SPECTATABLE for the benefits of being invited.
|
||||
*/
|
||||
QList<int> invited;
|
||||
|
||||
/**
|
||||
* @brief Determines who may traverse and communicate in the area.
|
||||
*/
|
||||
@ -157,86 +104,6 @@ class AreaData : public QObject {
|
||||
/// Exposes the metadata of the LockStatus enum.
|
||||
Q_ENUM(LockStatus);
|
||||
|
||||
/**
|
||||
* @brief The status of the area's accessibility to clients.
|
||||
*
|
||||
* @see LockStatus
|
||||
*/
|
||||
LockStatus locked;
|
||||
|
||||
/**
|
||||
* @brief The background of the area.
|
||||
*
|
||||
* @details Represents a directory's name in `base/background/` clientside.
|
||||
*/
|
||||
QString background;
|
||||
|
||||
/**
|
||||
* @brief If true, nobody may become the CM of this area.
|
||||
*/
|
||||
bool is_protected;
|
||||
|
||||
/**
|
||||
* @brief If true, clients are allowed to put on "shownames", custom names
|
||||
* in place of their character's normally displayed name.
|
||||
*/
|
||||
bool showname_allowed;
|
||||
|
||||
/**
|
||||
* @brief If true, clients are allowed to use the cursed art of iniswapping in the area.
|
||||
*/
|
||||
bool iniswap_allowed;
|
||||
|
||||
/**
|
||||
* @brief If true, clients are allowed to send empty IC messages
|
||||
*/
|
||||
bool blankposting_allowed;
|
||||
|
||||
/**
|
||||
* @brief If true, the background of the area cannot be changed except by a moderator.
|
||||
*/
|
||||
bool bg_locked;
|
||||
|
||||
/**
|
||||
* @brief The hyperlink to the document of the area.
|
||||
*
|
||||
* @details Documents are generally used for cases or roleplays, where they contain the related game's
|
||||
* rules. #document can also be something like "None" if there is no case or roleplay being run.
|
||||
*/
|
||||
QString document;
|
||||
|
||||
/**
|
||||
* @brief The Confidence Gauge's value for the Defence side.
|
||||
*
|
||||
* @details Unit is 10%, and the values range from 0 (= 0%) to 10 (= 100%).
|
||||
*/
|
||||
int def_hp;
|
||||
|
||||
/**
|
||||
* @brief The Confidence Gauge's value for the Prosecutor side.
|
||||
*
|
||||
* @copydetails #def_hp
|
||||
*/
|
||||
int pro_hp;
|
||||
|
||||
/**
|
||||
* @brief The title of the music currently being played in the area.
|
||||
*
|
||||
* @details Title is a path to the music file, with the starting point on
|
||||
* `base/sounds/music/` clientside, with file extension.
|
||||
*/
|
||||
QString current_music;
|
||||
|
||||
/**
|
||||
* @brief The name of the client (or client's character) that started the currently playing music.
|
||||
*/
|
||||
QString music_played_by;
|
||||
|
||||
/**
|
||||
* @brief A pointer to a Logger, used to send requests to log data.
|
||||
*/
|
||||
Logger* logger;
|
||||
|
||||
/**
|
||||
* @brief The level of "authorisation" needed to be able to modify, add, and remove evidence in the area.
|
||||
*/
|
||||
@ -270,14 +137,6 @@ class AreaData : public QObject {
|
||||
* where `XXX` is either a position, of a list of positions separated by `,`.
|
||||
*/
|
||||
|
||||
/**
|
||||
* @brief The evidence mod of the area.
|
||||
*
|
||||
* @see EvidenceMod
|
||||
*/
|
||||
EvidenceMod evi_mod;
|
||||
QMap<QString, QString> notecards;
|
||||
|
||||
/**
|
||||
* @brief The five "states" the testimony recording system can have in an area.
|
||||
*/
|
||||
@ -322,38 +181,215 @@ class AreaData : public QObject {
|
||||
|
||||
/// Exposes the metadata of the TestimonyRecording enum.
|
||||
Q_ENUM(TestimonyRecording);
|
||||
TestimonyRecording test_rec;
|
||||
|
||||
/**
|
||||
* @brief A client in the area has left the area.
|
||||
*
|
||||
* @details This function counts down the playercount and removes the character from the list of taken characters.
|
||||
*
|
||||
* @param f_charId The character ID of the area.
|
||||
*/
|
||||
void clientLeftArea(int f_charId);
|
||||
|
||||
QList<int> owners() const;
|
||||
|
||||
void addOwner(int f_clientId);
|
||||
|
||||
/**
|
||||
* @brief Removes the target client from the list of owners.
|
||||
*
|
||||
* @param f_clientId The ID of the client to remove from the owners.
|
||||
*
|
||||
* @return True if because of this removal, an ARUP message must be sent out about the locks.
|
||||
*
|
||||
* @note This function *does not* imply that the client also left the area, only that they are no longer its owner.
|
||||
* See clientLeftArea() for that.
|
||||
*/
|
||||
bool removeOwner(int f_clientId);
|
||||
|
||||
bool blankpostingAllowed() const;
|
||||
|
||||
bool isProtected() const;
|
||||
|
||||
LockStatus lockStatus() 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);
|
||||
|
||||
private:
|
||||
/**
|
||||
* @brief The list of timers available in the area.
|
||||
*/
|
||||
QList<QTimer*> m_timers;
|
||||
|
||||
/**
|
||||
* @brief The user-facing and internal name of the area.
|
||||
*/
|
||||
QString m_name;
|
||||
|
||||
/**
|
||||
* @brief The index of the area in the server's area list.
|
||||
*/
|
||||
int m_index;
|
||||
|
||||
/**
|
||||
* @brief A list of the character IDs of all characters taken.
|
||||
*/
|
||||
QList<int> m_charactersTaken;
|
||||
|
||||
/**
|
||||
* @brief A list of Evidence currently available in the area's court record.
|
||||
*
|
||||
* @details This contains *all* evidence, not just the ones a given side can see.
|
||||
*
|
||||
* @see HIDDEN_CM
|
||||
*/
|
||||
QList<Evidence> m_evidence;
|
||||
|
||||
/**
|
||||
* @brief The amount of clients inside the area.
|
||||
*/
|
||||
int m_playerCount;
|
||||
|
||||
/**
|
||||
* @brief The status of the area.
|
||||
*
|
||||
* @see Status
|
||||
*/
|
||||
Status m_status;
|
||||
|
||||
/**
|
||||
* @brief The IDs of all the owners (or Case Makers / CMs) of the area.
|
||||
*/
|
||||
QList<int> m_owners;
|
||||
|
||||
/**
|
||||
* @brief The list of clients invited to the area.
|
||||
*
|
||||
* @see LOCKED and SPECTATABLE for the benefits of being invited.
|
||||
*/
|
||||
QList<int> m_invited;
|
||||
|
||||
/**
|
||||
* @brief The status of the area's accessibility to clients.
|
||||
*
|
||||
* @see LockStatus
|
||||
*/
|
||||
LockStatus m_locked;
|
||||
|
||||
/**
|
||||
* @brief The background of the area.
|
||||
*
|
||||
* @details Represents a directory's name in `base/background/` clientside.
|
||||
*/
|
||||
QString m_background;
|
||||
|
||||
/**
|
||||
* @brief If true, nobody may become the CM of this area.
|
||||
*/
|
||||
bool m_isProtected;
|
||||
|
||||
/**
|
||||
* @brief If true, clients are allowed to put on "shownames", custom names
|
||||
* in place of their character's normally displayed name.
|
||||
*/
|
||||
bool m_shownameAllowed;
|
||||
|
||||
/**
|
||||
* @brief If true, clients are allowed to use the cursed art of iniswapping in the area.
|
||||
*/
|
||||
bool m_iniswapAllowed;
|
||||
|
||||
/**
|
||||
* @brief If true, clients are allowed to send empty IC messages
|
||||
*/
|
||||
bool m_blankpostingAllowed;
|
||||
|
||||
/**
|
||||
* @brief If true, the background of the area cannot be changed except by a moderator.
|
||||
*/
|
||||
bool m_bgLocked;
|
||||
|
||||
/**
|
||||
* @brief The hyperlink to the document of the area.
|
||||
*
|
||||
* @details Documents are generally used for cases or roleplays, where they contain the related game's
|
||||
* rules. #document can also be something like "None" if there is no case or roleplay being run.
|
||||
*/
|
||||
QString m_document;
|
||||
|
||||
/**
|
||||
* @brief The Confidence Gauge's value for the Defence side.
|
||||
*
|
||||
* @details Unit is 10%, and the values range from 0 (= 0%) to 10 (= 100%).
|
||||
*/
|
||||
int m_defHP;
|
||||
|
||||
/**
|
||||
* @brief The Confidence Gauge's value for the Prosecutor side.
|
||||
*
|
||||
* @copydetails #def_hp
|
||||
*/
|
||||
int m_proHP;
|
||||
|
||||
/**
|
||||
* @brief The title of the music currently being played in the area.
|
||||
*
|
||||
* @details Title is a path to the music file, with the starting point on
|
||||
* `base/sounds/music/` clientside, with file extension.
|
||||
*/
|
||||
QString m_currentMusic;
|
||||
|
||||
/**
|
||||
* @brief The name of the client (or client's character) that started the currently playing music.
|
||||
*/
|
||||
QString m_musicPlayerBy;
|
||||
|
||||
/**
|
||||
* @brief A pointer to a Logger, used to send requests to log data.
|
||||
*/
|
||||
Logger* m_logger;
|
||||
|
||||
/**
|
||||
* @brief The evidence mod of the area.
|
||||
*
|
||||
* @see EvidenceMod
|
||||
*/
|
||||
EvidenceMod m_eviMod;
|
||||
QMap<QString, QString> m_notecards;
|
||||
|
||||
TestimonyRecording m_testimonyRecording;
|
||||
|
||||
|
||||
QVector<QStringList> testimony; //!< Vector of all statements saved. Index 0 is always the title of the testimony.
|
||||
int statement; //!< Keeps track of the currently played statement.
|
||||
QVector<QStringList> m_testimony; //!< Vector of all statements saved. Index 0 is always the title of the testimony.
|
||||
int m_statement; //!< Keeps track of the currently played statement.
|
||||
|
||||
/**
|
||||
* @brief The judgelog of an area.
|
||||
*
|
||||
* @details This list contains up to 10 recorded packets of the most recent judge actions (WT/CE or penalty updates) in an area.
|
||||
*/
|
||||
QStringList judgelog;
|
||||
QStringList m_judgelog;
|
||||
|
||||
/**
|
||||
* @brief The last IC packet sent in an area.
|
||||
*/
|
||||
QStringList last_ic_message;
|
||||
QStringList m_lastICMessage;
|
||||
|
||||
/**
|
||||
* @brief The value of logger in config.ini.
|
||||
*/
|
||||
QString log_type;
|
||||
|
||||
/**
|
||||
* @brief Whether or not to force immediate text processing in this area.
|
||||
*/
|
||||
bool force_immediate;
|
||||
bool m_forceImmediate;
|
||||
|
||||
/**
|
||||
* @brief Whether or not music is allowed in this area. If false, only CMs can change the music.
|
||||
*/
|
||||
bool toggle_music;
|
||||
bool m_toggleMusic;
|
||||
};
|
||||
|
||||
#endif // AREA_DATA_H
|
||||
|
@ -18,19 +18,12 @@
|
||||
#ifndef LOGGER_H
|
||||
#define LOGGER_H
|
||||
|
||||
#include "include/aoclient.h"
|
||||
#include "include/aopacket.h"
|
||||
#include "include/area_data.h"
|
||||
|
||||
#include <QFile>
|
||||
#include <QDebug>
|
||||
#include <QString>
|
||||
#include <QQueue>
|
||||
#include <QDateTime>
|
||||
|
||||
class AOClient;
|
||||
class AreaData;
|
||||
|
||||
/**
|
||||
* @brief A class associated with an AreaData class to log various events happening inside the latter.
|
||||
*/
|
||||
@ -40,34 +33,40 @@ public:
|
||||
/**
|
||||
* @brief Constructs a Logger instance.
|
||||
*
|
||||
* @param p_max_length The maximum amount of entries the Logger can store at once.
|
||||
* @param p_area The area associated with the Logger from which it should log entries.
|
||||
* @param f_max_length The maximum amount of entries the Logger can store at once.
|
||||
*/
|
||||
Logger(int p_max_length, AreaData* p_area) : max_length(p_max_length), area(p_area) {};
|
||||
Logger(int f_max_length, const QString& f_logType_r) : m_maxLength(f_max_length), m_logType(f_logType_r) {};
|
||||
|
||||
public slots:
|
||||
/**
|
||||
* @brief Logs an IC message.
|
||||
*
|
||||
* @param client The client who sent the IC message.
|
||||
* @param packet The IC packet itself, used to grab the text of the IC message.
|
||||
* @param f_areaName_r The name of the area where the event happened.
|
||||
* @param f_charName_r The character name of the client who sent the IC message.
|
||||
* @param f_ipid_r The IPID of the aforementioned client.
|
||||
* @param f_message_r The text of the IC message.
|
||||
*/
|
||||
void logIC(AOClient* client, AOPacket* packet);
|
||||
void logIC(const QString& f_areaName_r, const QString& f_charName_r, const QString& f_ipid_r, const QString& f_message_r);
|
||||
|
||||
/**
|
||||
* @brief Logs an OOC message.
|
||||
*
|
||||
* @param client The client who sent the OOC message.
|
||||
* @param packet The OOC packet itself, used to grab the text of the OOC message.
|
||||
* @param f_areaName_r The name of the area where the event happened.
|
||||
* @param f_charName_r The character name of the client who sent the OOC message.
|
||||
* @param f_ipid_r The IPID of the aforementioned client.
|
||||
* @param f_message_r The text of the OOC message.
|
||||
*/
|
||||
void logOOC(AOClient* client, AOPacket* packet);
|
||||
void logOOC(const QString& f_areaName_r, const QString& f_charName_r, const QString& f_ipid_r, const QString& f_message_r);
|
||||
|
||||
/**
|
||||
* @brief Logs a mod call message.
|
||||
*
|
||||
* @param client The client who sent the mod call.
|
||||
* @param packet The ZZ packet itself, used to grab the reason field of the modcall.
|
||||
* @param f_areaName_r The name of the area where the event happened.
|
||||
* @param f_charName_r The character name of the client who sent the mod call.
|
||||
* @param f_ipid_r The IPID of the aforementioned client.
|
||||
* @param f_modcallReason_r The reason for the modcall.
|
||||
*/
|
||||
void logModcall(AOClient* client, AOPacket* packet);
|
||||
void logModcall(const QString& f_areaName_r, const QString& f_charName_r, const QString& f_ipid_r, const QString& f_modcallReason_r);
|
||||
|
||||
/**
|
||||
* @brief Logs a command called in OOC.
|
||||
@ -75,69 +74,67 @@ public:
|
||||
* @details If the command is not one of any of the 'special' ones, it defaults to logOOC().
|
||||
* The only thing that makes a command 'special' if it is handled differently in here.
|
||||
*
|
||||
* @param client The client who sent the command.
|
||||
* @param packet The OOC packet. Passed to logOOC() if the command is not 'special' (see details).
|
||||
* @param cmd The command called in the OOC -- this is the first word after the `/` character.
|
||||
* @param args The arguments interpreted for the command, every word separated by a whitespace.
|
||||
* @param f_areaName_r The name of the area where the event happened.
|
||||
* @param f_charName_r The character name of the client who sent the command.
|
||||
* @param f_ipid_r The IPID of the aforementioned client.
|
||||
* @param f_oocMessage_r The text of the OOC message. Passed to logOOC() if the command is not 'special' (see details).
|
||||
* @param f_cmd_r The command called in the OOC -- this is the first word after the `/` character.
|
||||
* @param f_cmdArgs_r The arguments interpreted for the command, every word separated by a whitespace.
|
||||
*/
|
||||
void logCmd(AOClient* client, AOPacket* packet, QString cmd, QStringList args);
|
||||
void logCmd(const QString& f_areaName_r, const QString& f_charName_r, const QString& f_ipid_r,
|
||||
const QString& f_oocMessage_r, const QString& f_cmd_r, const QStringList& f_cmdArgs_r);
|
||||
|
||||
/**
|
||||
* @brief Logs a login attempt.
|
||||
*
|
||||
* @param client The client that attempted to login.
|
||||
* @param f_areaName_r The name of the area where the event happened.
|
||||
* @param f_charName_r The character name of the client that attempted to login.
|
||||
* @param f_ipid_r The IPID of the aforementioned client.
|
||||
* @param success True if the client successfully authenticated as a mod.
|
||||
* @param modname If the client logged in with a modname, then this is it. Otherwise, it's `"moderator"`.
|
||||
*
|
||||
* @note Why does this exist? logCmd() already does this in part.
|
||||
* @param f_modname_r If the client logged in with a modname, then this is it. Otherwise, it's `"moderator"`.
|
||||
*/
|
||||
void logLogin(AOClient* client, bool success, QString modname);
|
||||
void logLogin(const QString& f_areaName_r, const QString& f_charName_r, const QString& f_ipid_r, bool success, const QString& f_modname_r);
|
||||
|
||||
/**
|
||||
* @brief Appends the contents of #buffer into `config/server.log`, emptying the former.
|
||||
*
|
||||
* @param f_areaName_r The name of the area where the event happened.
|
||||
*/
|
||||
void flush();
|
||||
void flush(const QString& f_areaName_r);
|
||||
|
||||
/**
|
||||
* @brief Contains entries that have not yet been flushed out into a log file.
|
||||
*/
|
||||
QQueue<QString> m_buffer;
|
||||
|
||||
private:
|
||||
/**
|
||||
* @brief Convenience function to format entries to the acceptable standard for logging.
|
||||
*
|
||||
* @param client The client who 'caused' the source event for the entry to happen.
|
||||
* @param type The type of entry that is being built, something that uniquely identifies entries of similar being.
|
||||
* @param message Any additional information related to the entry.
|
||||
*
|
||||
* @return A formatted string representation of the entry.
|
||||
*/
|
||||
QString buildEntry(AOClient* client, QString type, QString message);
|
||||
|
||||
/**
|
||||
* @brief Convenience function to add an entry to #buffer.
|
||||
*
|
||||
* @details If the buffer's size is equal to #max_length, the first entry in the queue is removed,
|
||||
* and the newest entry is added to the end.
|
||||
*
|
||||
* @param entry The string representation of the entry to add.
|
||||
*
|
||||
* @pre You would probably call buildEntry() to format the entry before adding it to the buffer.
|
||||
* @param f_areaName_r The name of the area where the loggable entry happened.
|
||||
* @param f_charName_r The character name of the client who 'caused' the source event for the entry to happen.
|
||||
* @param f_ipid_r The IPID of the aforementioned client.
|
||||
* @param f_type_r The type of entry that is being built, something that uniquely identifies entries of similar being.
|
||||
* @param f_message_r Any additional information related to the entry.
|
||||
*/
|
||||
void addEntry(QString entry);
|
||||
void addEntry(const QString& f_areaName_r, const QString& f_charName_r, const QString& f_ipid_r,
|
||||
const QString& f_type_r, const QString& f_message_r);
|
||||
|
||||
/**
|
||||
* @brief The max amount of entries that may be contained in #buffer.
|
||||
*/
|
||||
int max_length;
|
||||
int m_maxLength;
|
||||
|
||||
/**
|
||||
* @brief Contains entries that have not yet been flushed out into a log file.
|
||||
*/
|
||||
QQueue<QString> buffer;
|
||||
|
||||
/**
|
||||
* @brief A pointer to the area this logger is associated with.
|
||||
* @brief Determines what kind of logging happens, `"full"` or `"modcall"`.
|
||||
*
|
||||
* @details Used for logging in what area did a given packet event happen.
|
||||
* @details This largely influences the resulting log file's name, and in case of a `"full"` setup,
|
||||
* the in-memory buffer is auto-dumped to said file if full.
|
||||
*/
|
||||
AreaData* area;
|
||||
QString m_logType;
|
||||
};
|
||||
|
||||
#endif // LOGGER_H
|
||||
|
@ -49,23 +49,21 @@ void AOClient::clientDisconnected()
|
||||
#endif
|
||||
if (joined) {
|
||||
server->player_count--;
|
||||
server->areas[current_area]->player_count--;
|
||||
server->areas[current_area]->clientLeftArea(server->getCharID(current_char));
|
||||
arup(ARUPType::PLAYER_COUNT, true);
|
||||
}
|
||||
|
||||
if (current_char != "") {
|
||||
server->areas[current_area]->characters_taken.removeAll(server->getCharID(current_char));
|
||||
server->updateCharsTaken(server->areas[current_area]);
|
||||
}
|
||||
bool update_locks;
|
||||
|
||||
bool l_updateLocks = false;
|
||||
|
||||
for (AreaData* area : server->areas) {
|
||||
area->owners.removeAll(id);
|
||||
area->invited.removeAll(id);
|
||||
if (area->owners.isEmpty() && area->locked != AreaData::FREE) {
|
||||
area->locked = AreaData::FREE;
|
||||
update_locks = true;
|
||||
}
|
||||
l_updateLocks = l_updateLocks || area->removeOwner(id);
|
||||
}
|
||||
if (update_locks)
|
||||
|
||||
if (l_updateLocks)
|
||||
arup(ARUPType::LOCKED, true);
|
||||
arup(ARUPType::CM, true);
|
||||
}
|
||||
@ -109,34 +107,34 @@ void AOClient::changeArea(int new_area)
|
||||
sendServerMessage("You are already in area " + server->area_names[current_area]);
|
||||
return;
|
||||
}
|
||||
if (server->areas[new_area]->locked == AreaData::LockStatus::LOCKED && !server->areas[new_area]->invited.contains(id)) {
|
||||
if (server->areas[new_area]->m_locked == AreaData::LockStatus::LOCKED && !server->areas[new_area]->m_invited.contains(id)) {
|
||||
sendServerMessage("Area " + server->area_names[new_area] + " is locked.");
|
||||
return;
|
||||
}
|
||||
|
||||
if (current_char != "") {
|
||||
server->areas[current_area]->characters_taken.removeAll(server->getCharID(current_char));
|
||||
server->areas[current_area]->m_charactersTaken.removeAll(server->getCharID(current_char));
|
||||
server->updateCharsTaken(server->areas[current_area]);
|
||||
}
|
||||
server->areas[new_area]->player_count++;
|
||||
server->areas[current_area]->player_count--;
|
||||
server->areas[new_area]->m_playerCount++;
|
||||
server->areas[current_area]->m_playerCount--;
|
||||
current_area = new_area;
|
||||
arup(ARUPType::PLAYER_COUNT, true);
|
||||
sendEvidenceList(server->areas[new_area]);
|
||||
sendPacket("HP", {"1", QString::number(server->areas[new_area]->def_hp)});
|
||||
sendPacket("HP", {"2", QString::number(server->areas[new_area]->pro_hp)});
|
||||
sendPacket("BN", {server->areas[new_area]->background});
|
||||
if (server->areas[current_area]->characters_taken.contains(server->getCharID(current_char))) {
|
||||
sendPacket("HP", {"1", QString::number(server->areas[new_area]->m_defHP)});
|
||||
sendPacket("HP", {"2", QString::number(server->areas[new_area]->m_proHP)});
|
||||
sendPacket("BN", {server->areas[new_area]->m_background});
|
||||
if (server->areas[current_area]->m_charactersTaken.contains(server->getCharID(current_char))) {
|
||||
server->updateCharsTaken(server->areas[current_area]);
|
||||
current_char = "";
|
||||
sendPacket("DONE");
|
||||
}
|
||||
else {
|
||||
server->areas[current_area]->characters_taken.append(server->getCharID(current_char));
|
||||
server->areas[current_area]->m_charactersTaken.append(server->getCharID(current_char));
|
||||
server->updateCharsTaken(server->areas[current_area]);
|
||||
}
|
||||
for (QTimer* timer : server->areas[current_area]->timers) {
|
||||
int timer_id = server->areas[current_area]->timers.indexOf(timer) + 1;
|
||||
for (QTimer* timer : server->areas[current_area]->m_timer) {
|
||||
int timer_id = server->areas[current_area]->m_timer.indexOf(timer) + 1;
|
||||
if (timer->isActive()) {
|
||||
sendPacket("TI", {QString::number(timer_id), "2"});
|
||||
sendPacket("TI", {QString::number(timer_id), "0", QString::number(QTime(0,0).msecsTo(QTime(0,0).addMSecs(timer->remainingTime())))});
|
||||
@ -146,7 +144,7 @@ void AOClient::changeArea(int new_area)
|
||||
}
|
||||
}
|
||||
sendServerMessage("You moved to area " + server->area_names[current_area]);
|
||||
if (server->areas[current_area]->locked == AreaData::LockStatus::SPECTATABLE)
|
||||
if (server->areas[current_area]->m_locked == AreaData::LockStatus::SPECTATABLE)
|
||||
sendServerMessage("Area " + server->area_names[current_area] + " is spectate-only; to chat IC you will need to be invited by the CM.");
|
||||
}
|
||||
|
||||
@ -162,16 +160,16 @@ bool AOClient::changeCharacter(int char_id)
|
||||
}
|
||||
|
||||
if (current_char != "") {
|
||||
area->characters_taken.removeAll(server->getCharID(current_char));
|
||||
area->m_charactersTaken.removeAll(server->getCharID(current_char));
|
||||
}
|
||||
|
||||
if (char_id >= 0) {
|
||||
QString char_selected = server->characters[char_id];
|
||||
bool taken = area->characters_taken.contains(char_id);
|
||||
bool taken = area->m_charactersTaken.contains(char_id);
|
||||
if (taken || char_selected == "")
|
||||
return false;
|
||||
|
||||
area->characters_taken.append(char_id);
|
||||
area->m_charactersTaken.append(char_id);
|
||||
current_char = char_selected;
|
||||
}
|
||||
else {
|
||||
@ -216,20 +214,20 @@ void AOClient::arup(ARUPType type, bool broadcast)
|
||||
for (AreaData* area : server->areas) {
|
||||
switch(type) {
|
||||
case ARUPType::PLAYER_COUNT: {
|
||||
arup_data.append(QString::number(area->player_count));
|
||||
arup_data.append(QString::number(area->m_playerCount));
|
||||
break;
|
||||
}
|
||||
case ARUPType::STATUS: {
|
||||
QString area_status = QVariant::fromValue(area->status).toString().replace("_", "-"); // LOOKING_FOR_PLAYERS to LOOKING-FOR-PLAYERS
|
||||
QString area_status = QVariant::fromValue(area->m_status).toString().replace("_", "-"); // LOOKING_FOR_PLAYERS to LOOKING-FOR-PLAYERS
|
||||
arup_data.append(area_status);
|
||||
break;
|
||||
}
|
||||
case ARUPType::CM: {
|
||||
if (area->owners.isEmpty())
|
||||
if (area->m_owners.isEmpty())
|
||||
arup_data.append("FREE");
|
||||
else {
|
||||
QStringList area_owners;
|
||||
for (int owner_id : area->owners) {
|
||||
for (int owner_id : area->m_owners) {
|
||||
AOClient* owner = server->getClientByID(owner_id);
|
||||
area_owners.append("[" + QString::number(owner->id) + "] " + owner->current_char);
|
||||
}
|
||||
@ -238,7 +236,7 @@ void AOClient::arup(ARUPType type, bool broadcast)
|
||||
break;
|
||||
}
|
||||
case ARUPType::LOCKED: {
|
||||
QString lock_status = QVariant::fromValue(area->locked).toString();
|
||||
QString lock_status = QVariant::fromValue(area->m_locked).toString();
|
||||
arup_data.append(lock_status);
|
||||
break;
|
||||
}
|
||||
@ -314,7 +312,7 @@ bool AOClient::checkAuth(unsigned long long acl_mask)
|
||||
if (acl_mask != ACLFlags.value("NONE")) {
|
||||
if (acl_mask == ACLFlags.value("CM")) {
|
||||
AreaData* area = server->areas[current_area];
|
||||
if (area->owners.contains(id))
|
||||
if (area->m_owners.contains(id))
|
||||
return true;
|
||||
}
|
||||
else if (!authenticated) {
|
||||
|
@ -18,56 +18,123 @@
|
||||
#include "include/area_data.h"
|
||||
|
||||
AreaData::AreaData(QString p_name, int p_index) :
|
||||
index(p_index),
|
||||
player_count(0),
|
||||
status(IDLE),
|
||||
locked(FREE),
|
||||
document("No document."),
|
||||
def_hp(10),
|
||||
pro_hp(10),
|
||||
judgelog(),
|
||||
last_ic_message()
|
||||
m_index(p_index),
|
||||
m_playerCount(0),
|
||||
m_status(IDLE),
|
||||
m_locked(FREE),
|
||||
m_document("No document."),
|
||||
m_defHP(10),
|
||||
m_proHP(10),
|
||||
m_judgelog(),
|
||||
m_lastICMessage()
|
||||
{
|
||||
QStringList name_split = p_name.split(":");
|
||||
name_split.removeFirst();
|
||||
name = name_split.join(":");
|
||||
m_name = name_split.join(":");
|
||||
QSettings areas_ini("config/areas.ini", QSettings::IniFormat);
|
||||
areas_ini.setIniCodec("UTF-8");
|
||||
areas_ini.beginGroup(p_name);
|
||||
background = areas_ini.value("background", "gs4").toString();
|
||||
is_protected = areas_ini.value("protected_area", "false").toBool();
|
||||
iniswap_allowed = areas_ini.value("iniswap_allowed", "true").toBool();
|
||||
bg_locked = areas_ini.value("bg_locked", "false").toBool();
|
||||
m_background = areas_ini.value("background", "gs4").toString();
|
||||
m_isProtected = areas_ini.value("protected_area", "false").toBool();
|
||||
m_iniswapAllowed = areas_ini.value("iniswap_allowed", "true").toBool();
|
||||
m_bgLocked = areas_ini.value("bg_locked", "false").toBool();
|
||||
QString configured_evi_mod = areas_ini.value("evidence_mod", "FFA").toString().toLower();
|
||||
blankposting_allowed = areas_ini.value("blankposting_allowed","true").toBool();
|
||||
force_immediate = areas_ini.value("force_immediate", "false").toBool();
|
||||
toggle_music = areas_ini.value("toggle_music", "true").toBool();
|
||||
showname_allowed = areas_ini.value("shownames_allowed", "true").toBool();
|
||||
m_blankpostingAllowed = areas_ini.value("blankposting_allowed","true").toBool();
|
||||
m_forceImmediate = areas_ini.value("force_immediate", "false").toBool();
|
||||
m_toggleMusic = areas_ini.value("toggle_music", "true").toBool();
|
||||
m_shownameAllowed = areas_ini.value("shownames_allowed", "true").toBool();
|
||||
areas_ini.endGroup();
|
||||
QSettings config_ini("config/config.ini", QSettings::IniFormat);
|
||||
config_ini.setIniCodec("UTF-8");
|
||||
config_ini.beginGroup("Options");
|
||||
int log_size = config_ini.value("logbuffer", 50).toInt();
|
||||
log_type = config_ini.value("logger","modcall").toString();
|
||||
QString l_logType = config_ini.value("logger","modcall").toString();
|
||||
config_ini.endGroup();
|
||||
if (log_size == 0)
|
||||
log_size = 500;
|
||||
logger = new Logger(log_size, this);
|
||||
m_logger = new Logger(log_size, l_logType);
|
||||
QTimer* timer1 = new QTimer();
|
||||
timers.append(timer1);
|
||||
m_timers.append(timer1);
|
||||
QTimer* timer2 = new QTimer();
|
||||
timers.append(timer2);
|
||||
m_timers.append(timer2);
|
||||
QTimer* timer3 = new QTimer();
|
||||
timers.append(timer3);
|
||||
m_timers.append(timer3);
|
||||
QTimer* timer4 = new QTimer();
|
||||
timers.append(timer4);
|
||||
m_timers.append(timer4);
|
||||
|
||||
if (configured_evi_mod == "cm")
|
||||
evi_mod = EvidenceMod::CM;
|
||||
m_eviMod = EvidenceMod::CM;
|
||||
else if (configured_evi_mod == "mod")
|
||||
evi_mod = EvidenceMod::MOD;
|
||||
m_eviMod = EvidenceMod::MOD;
|
||||
else if (configured_evi_mod == "hiddencm")
|
||||
evi_mod = EvidenceMod::HIDDEN_CM;
|
||||
m_eviMod = EvidenceMod::HIDDEN_CM;
|
||||
else
|
||||
evi_mod = EvidenceMod::FFA;
|
||||
m_eviMod = EvidenceMod::FFA;
|
||||
}
|
||||
|
||||
void AreaData::clientLeftArea(int f_charId)
|
||||
{
|
||||
--m_playerCount;
|
||||
m_charactersTaken.removeAll(f_charId);
|
||||
}
|
||||
|
||||
QList<int> AreaData::owners() const
|
||||
{
|
||||
QString l_test;
|
||||
const auto& l_buffer = m_logger->m_buffer;
|
||||
for (const auto& l_item : l_buffer)
|
||||
{
|
||||
l_test.append(l_item + "\n");
|
||||
}
|
||||
|
||||
return m_owners;
|
||||
}
|
||||
|
||||
void AreaData::addOwner(int f_clientId)
|
||||
{
|
||||
m_owners.append(f_clientId);
|
||||
m_invited.append(f_clientId);
|
||||
}
|
||||
|
||||
bool AreaData::removeOwner(int f_clientId)
|
||||
{
|
||||
m_owners.removeAll(f_clientId);
|
||||
m_invited.removeAll(f_clientId);
|
||||
|
||||
if (m_owners.isEmpty() && m_locked != AreaData::FREE) {
|
||||
m_locked = AreaData::FREE;
|
||||
return true;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
bool AreaData::blankpostingAllowed() const
|
||||
{
|
||||
return m_blankpostingAllowed;
|
||||
}
|
||||
|
||||
bool AreaData::isProtected() const
|
||||
{
|
||||
return m_isProtected;
|
||||
}
|
||||
|
||||
AreaData::LockStatus AreaData::lockStatus() const
|
||||
{
|
||||
return m_locked;
|
||||
}
|
||||
|
||||
bool AreaData::invite(int f_clientId)
|
||||
{
|
||||
if (m_invited.contains(f_clientId)) {
|
||||
return false;
|
||||
}
|
||||
|
||||
m_invited.append(f_clientId);
|
||||
return true;
|
||||
}
|
||||
|
||||
int AreaData::playerCount() const
|
||||
{
|
||||
return m_playerCount;
|
||||
}
|
||||
|
@ -25,17 +25,16 @@ void AOClient::cmdCM(int argc, QStringList argv)
|
||||
{
|
||||
QString sender_name = ooc_name;
|
||||
AreaData* area = server->areas[current_area];
|
||||
if (area->is_protected) {
|
||||
if (area->isProtected()) {
|
||||
sendServerMessage("This area is protected, you may not become CM.");
|
||||
return;
|
||||
}
|
||||
else if (area->owners.isEmpty()) { // no one owns this area, and it's not protected
|
||||
area->owners.append(id);
|
||||
area->invited.append(id);
|
||||
else if (area->owners().isEmpty()) { // no one owns this area, and it's not protected
|
||||
area->addOwner(id);
|
||||
sendServerMessageArea(sender_name + " is now CM in this area.");
|
||||
arup(ARUPType::CM, true);
|
||||
}
|
||||
else if (!area->owners.contains(id)) { // there is already a CM, and it isn't us
|
||||
else if (!area->owners().contains(id)) { // there is already a CM, and it isn't us
|
||||
sendServerMessage("You cannot become a CM in this area.");
|
||||
}
|
||||
else if (argc == 1) { // we are CM, and we want to make ID argv[0] also CM
|
||||
@ -49,7 +48,7 @@ void AOClient::cmdCM(int argc, QStringList argv)
|
||||
sendServerMessage("Unable to find client with ID " + argv[0] + ".");
|
||||
return;
|
||||
}
|
||||
area->owners.append(owner_candidate->id);
|
||||
area->addOwner(owner_candidate->id);
|
||||
sendServerMessageArea(owner_candidate->ooc_name + " is now CM in this area.");
|
||||
arup(ARUPType::CM, true);
|
||||
}
|
||||
@ -63,7 +62,7 @@ void AOClient::cmdUnCM(int argc, QStringList argv)
|
||||
AreaData* area = server->areas[current_area];
|
||||
int uid;
|
||||
|
||||
if (area->owners.isEmpty()) {
|
||||
if (area->owners().isEmpty()) {
|
||||
sendServerMessage("There are no CMs in this area.");
|
||||
return;
|
||||
}
|
||||
@ -78,7 +77,7 @@ void AOClient::cmdUnCM(int argc, QStringList argv)
|
||||
sendServerMessage("Invalid user ID.");
|
||||
return;
|
||||
}
|
||||
if (!area->owners.contains(uid)) {
|
||||
if (!area->owners().contains(uid)) {
|
||||
sendServerMessage("That user is not CMed.");
|
||||
return;
|
||||
}
|
||||
@ -89,16 +88,12 @@ void AOClient::cmdUnCM(int argc, QStringList argv)
|
||||
sendServerMessage("Invalid command.");
|
||||
return;
|
||||
}
|
||||
area->owners.removeAll(uid);
|
||||
area->invited.removeAll(uid);
|
||||
arup(ARUPType::CM, true);
|
||||
if (area->owners.isEmpty()) {
|
||||
area->invited.clear();
|
||||
if (area->locked != AreaData::FREE) {
|
||||
area->locked = AreaData::FREE;
|
||||
arup(ARUPType::LOCKED, true);
|
||||
}
|
||||
|
||||
if (area->removeOwner(uid)) {
|
||||
arup(ARUPType::LOCKED, true);
|
||||
}
|
||||
|
||||
arup(ARUPType::CM, true);
|
||||
}
|
||||
|
||||
void AOClient::cmdInvite(int argc, QStringList argv)
|
||||
@ -114,11 +109,10 @@ void AOClient::cmdInvite(int argc, QStringList argv)
|
||||
sendServerMessage("No client with that ID found.");
|
||||
return;
|
||||
}
|
||||
else if (area->invited.contains(invited_id)) {
|
||||
else if (!area->invite(invited_id)) {
|
||||
sendServerMessage("That ID is already on the invite list.");
|
||||
return;
|
||||
}
|
||||
area->invited.append(invited_id);
|
||||
sendServerMessage("You invited ID " + argv[0]);
|
||||
}
|
||||
|
||||
@ -135,30 +129,30 @@ void AOClient::cmdUnInvite(int argc, QStringList argv)
|
||||
sendServerMessage("No client with that ID found.");
|
||||
return;
|
||||
}
|
||||
else if (area->owners.contains(uninvited_id)) {
|
||||
else if (area->owners().contains(uninvited_id)) {
|
||||
sendServerMessage("You cannot uninvite a CM!");
|
||||
return;
|
||||
}
|
||||
else if (!area->invited.contains(uninvited_id)) {
|
||||
else if (!area->m_invited.contains(uninvited_id)) {
|
||||
sendServerMessage("That ID is not on the invite list.");
|
||||
return;
|
||||
}
|
||||
area->invited.removeAll(uninvited_id);
|
||||
area->m_invited.removeAll(uninvited_id);
|
||||
sendServerMessage("You uninvited ID " + argv[0]);
|
||||
}
|
||||
|
||||
void AOClient::cmdLock(int argc, QStringList argv)
|
||||
{
|
||||
AreaData* area = server->areas[current_area];
|
||||
if (area->locked == AreaData::LockStatus::LOCKED) {
|
||||
if (area->lockStatus() == AreaData::LockStatus::LOCKED) {
|
||||
sendServerMessage("This area is already locked.");
|
||||
return;
|
||||
}
|
||||
sendServerMessageArea("This area is now locked.");
|
||||
area->locked = AreaData::LockStatus::LOCKED;
|
||||
area->m_locked = AreaData::LockStatus::LOCKED;
|
||||
for (AOClient* client : server->clients) {
|
||||
if (client->current_area == current_area && client->joined) {
|
||||
area->invited.append(client->id);
|
||||
area->m_invited.append(client->id);
|
||||
}
|
||||
}
|
||||
arup(ARUPType::LOCKED, true);
|
||||
@ -167,15 +161,15 @@ void AOClient::cmdLock(int argc, QStringList argv)
|
||||
void AOClient::cmdSpectatable(int argc, QStringList argv)
|
||||
{
|
||||
AreaData* area = server->areas[current_area];
|
||||
if (area->locked == AreaData::LockStatus::SPECTATABLE) {
|
||||
if (area->lockStatus() == AreaData::LockStatus::SPECTATABLE) {
|
||||
sendServerMessage("This area is already in spectate mode.");
|
||||
return;
|
||||
}
|
||||
sendServerMessageArea("This area is now spectatable.");
|
||||
area->locked = AreaData::LockStatus::SPECTATABLE;
|
||||
area->m_locked = AreaData::LockStatus::SPECTATABLE;
|
||||
for (AOClient* client : server->clients) {
|
||||
if (client->current_area == current_area && client->joined) {
|
||||
area->invited.append(client->id);
|
||||
area->m_invited.append(client->id);
|
||||
}
|
||||
}
|
||||
arup(ARUPType::LOCKED, true);
|
||||
@ -184,12 +178,12 @@ void AOClient::cmdSpectatable(int argc, QStringList argv)
|
||||
void AOClient::cmdUnLock(int argc, QStringList argv)
|
||||
{
|
||||
AreaData* area = server->areas[current_area];
|
||||
if (area->locked == AreaData::LockStatus::FREE) {
|
||||
if (area->m_locked == AreaData::LockStatus::FREE) {
|
||||
sendServerMessage("This area is not locked.");
|
||||
return;
|
||||
}
|
||||
sendServerMessageArea("This area is now unlocked.");
|
||||
area->locked = AreaData::LockStatus::FREE;
|
||||
area->m_locked = AreaData::LockStatus::FREE;
|
||||
arup(ARUPType::LOCKED, true);
|
||||
}
|
||||
|
||||
@ -241,9 +235,9 @@ void AOClient::cmdAreaKick(int argc, QStringList argv)
|
||||
void AOClient::cmdSetBackground(int argc, QStringList argv)
|
||||
{
|
||||
AreaData* area = server->areas[current_area];
|
||||
if (authenticated || !area->bg_locked) {
|
||||
if (authenticated || !area->m_bgLocked) {
|
||||
if (server->backgrounds.contains(argv[0])) {
|
||||
area->background = argv[0];
|
||||
area->m_background = argv[0];
|
||||
server->broadcast(AOPacket("BN", {argv[0]}), current_area);
|
||||
sendServerMessageArea(current_char + " changed the background to " + argv[0]);
|
||||
}
|
||||
@ -259,14 +253,14 @@ void AOClient::cmdSetBackground(int argc, QStringList argv)
|
||||
void AOClient::cmdBgLock(int argc, QStringList argv)
|
||||
{
|
||||
AreaData* area = server->areas[current_area];
|
||||
area->bg_locked = true;
|
||||
area->m_bgLocked = true;
|
||||
server->broadcast(AOPacket("CT", {"Server", current_char + " locked the background.", "1"}), current_area);
|
||||
}
|
||||
|
||||
void AOClient::cmdBgUnlock(int argc, QStringList argv)
|
||||
{
|
||||
AreaData* area = server->areas[current_area];
|
||||
area->bg_locked = false;
|
||||
area->m_bgLocked = false;
|
||||
server->broadcast(AOPacket("CT", {"Server", current_char + " unlocked the background.", "1"}), current_area);
|
||||
}
|
||||
|
||||
@ -275,17 +269,17 @@ void AOClient::cmdStatus(int argc, QStringList argv)
|
||||
AreaData* area = server->areas[current_area];
|
||||
QString arg = argv[0].toLower();
|
||||
if (arg == "idle")
|
||||
area->status = AreaData::IDLE;
|
||||
area->m_status = AreaData::IDLE;
|
||||
else if (arg == "rp")
|
||||
area->status = AreaData::RP;
|
||||
area->m_status = AreaData::RP;
|
||||
else if (arg == "casing")
|
||||
area->status = AreaData::CASING;
|
||||
area->m_status = AreaData::CASING;
|
||||
else if (arg == "looking-for-players" || arg == "lfp")
|
||||
area->status = AreaData::LOOKING_FOR_PLAYERS;
|
||||
area->m_status = AreaData::LOOKING_FOR_PLAYERS;
|
||||
else if (arg == "recess")
|
||||
area->status = AreaData::RECESS;
|
||||
area->m_status = AreaData::RECESS;
|
||||
else if (arg == "gaming")
|
||||
area->status = AreaData::GAMING;
|
||||
area->m_status = AreaData::GAMING;
|
||||
else {
|
||||
sendServerMessage("That does not look like a valid status. Valid statuses are idle, rp, casing, lfp, recess, gaming");
|
||||
return;
|
||||
@ -297,11 +291,11 @@ void AOClient::cmdStatus(int argc, QStringList argv)
|
||||
void AOClient::cmdJudgeLog(int argc, QStringList argv)
|
||||
{
|
||||
AreaData* area = server->areas[current_area];
|
||||
if (area->judgelog.isEmpty()) {
|
||||
if (area->m_judgelog.isEmpty()) {
|
||||
sendServerMessage("There have been no judge actions in this area.");
|
||||
return;
|
||||
}
|
||||
QString message = area->judgelog.join("\n");
|
||||
QString message = area->m_judgelog.join("\n");
|
||||
//Judgelog contains an IPID, so we shouldn't send that unless the caller has appropriate permissions
|
||||
if (checkAuth(ACLFlags.value("KICK")) == 1 || checkAuth(ACLFlags.value("BAN")) == 1) {
|
||||
sendServerMessage(message);
|
||||
|
@ -40,7 +40,7 @@ void AOClient::cmdLogin(int argc, QStringList argv)
|
||||
sendPacket("AUTH", {"0"}); // Client: "Login unsuccessful."
|
||||
sendServerMessage("Incorrect password.");
|
||||
}
|
||||
server->areas.value(current_area)->logger->logLogin(this, authenticated, "moderator");
|
||||
server->areas.value(current_area)->m_logger->logLogin(this, authenticated, "moderator");
|
||||
}
|
||||
else if (server->auth_type == "advanced") {
|
||||
if (argc < 2) {
|
||||
@ -61,7 +61,7 @@ void AOClient::cmdLogin(int argc, QStringList argv)
|
||||
sendPacket("AUTH", {"0"}); // Client: "Login unsuccessful."
|
||||
sendServerMessage("Incorrect password.");
|
||||
}
|
||||
server->areas.value(current_area)->logger->logLogin(this, authenticated, username);
|
||||
server->areas.value(current_area)->m_logger->logLogin(this, authenticated, username);
|
||||
}
|
||||
else {
|
||||
qWarning() << "config.ini has an unrecognized auth_type!";
|
||||
|
@ -25,10 +25,10 @@ void AOClient::cmdDoc(int argc, QStringList argv)
|
||||
QString sender_name = ooc_name;
|
||||
AreaData* area = server->areas[current_area];
|
||||
if (argc == 0) {
|
||||
sendServerMessage("Document: " + area->document);
|
||||
sendServerMessage("Document: " + area->m_document);
|
||||
}
|
||||
else {
|
||||
area->document = argv.join(" ");
|
||||
area->m_document = argv.join(" ");
|
||||
sendServerMessageArea(sender_name + " changed the document.");
|
||||
}
|
||||
}
|
||||
@ -37,7 +37,7 @@ void AOClient::cmdClearDoc(int argc, QStringList argv)
|
||||
{
|
||||
QString sender_name = ooc_name;
|
||||
AreaData* area = server->areas[current_area];
|
||||
area->document = "No document.";
|
||||
area->m_document = "No document.";
|
||||
sendServerMessageArea(sender_name + " cleared the document.");
|
||||
}
|
||||
|
||||
@ -46,13 +46,13 @@ void AOClient::cmdEvidenceMod(int argc, QStringList argv)
|
||||
AreaData* area = server->areas[current_area];
|
||||
argv[0] = argv[0].toLower();
|
||||
if (argv[0] == "cm")
|
||||
area->evi_mod = AreaData::EvidenceMod::CM;
|
||||
area->m_eviMod = AreaData::EvidenceMod::CM;
|
||||
else if (argv[0] == "mod")
|
||||
area->evi_mod = AreaData::EvidenceMod::MOD;
|
||||
area->m_eviMod = AreaData::EvidenceMod::MOD;
|
||||
else if (argv[0] == "hiddencm")
|
||||
area->evi_mod = AreaData::EvidenceMod::HIDDEN_CM;
|
||||
area->m_eviMod = AreaData::EvidenceMod::HIDDEN_CM;
|
||||
else if (argv[0] == "ffa")
|
||||
area->evi_mod = AreaData::EvidenceMod::FFA;
|
||||
area->m_eviMod = AreaData::EvidenceMod::FFA;
|
||||
else {
|
||||
sendServerMessage("Invalid evidence mod.");
|
||||
return;
|
||||
@ -66,7 +66,7 @@ void AOClient::cmdEvidenceMod(int argc, QStringList argv)
|
||||
void AOClient::cmdEvidence_Swap(int argc, QStringList argv)
|
||||
{
|
||||
AreaData* area = server->areas[current_area];
|
||||
int ev_size = area->evidence.size() -1;
|
||||
int ev_size = area->m_evidence.size() -1;
|
||||
|
||||
if (ev_size < 0) {
|
||||
sendServerMessage("No evidence in area.");
|
||||
@ -89,7 +89,7 @@ void AOClient::cmdEvidence_Swap(int argc, QStringList argv)
|
||||
//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);
|
||||
area->m_evidence.swapItemsAt(ev_id1, ev_id2);
|
||||
#endif
|
||||
sendEvidenceList(area);
|
||||
sendServerMessage("The evidence " + QString::number(ev_id1) + " and " + QString::number(ev_id2) + " have been swapped.");
|
||||
@ -102,12 +102,12 @@ void AOClient::cmdEvidence_Swap(int argc, QStringList argv)
|
||||
void AOClient::cmdTestify(int argc, QStringList argv)
|
||||
{
|
||||
AreaData* area = server->areas[current_area];
|
||||
if (area->test_rec == AreaData::TestimonyRecording::RECORDING) {
|
||||
if (area->m_testimonyRecording == AreaData::TestimonyRecording::RECORDING) {
|
||||
sendServerMessage("Testimony recording is already in progress. Please stop it before starting a new one.");
|
||||
}
|
||||
else {
|
||||
clearTestimony();
|
||||
area->test_rec = AreaData::TestimonyRecording::RECORDING;
|
||||
area->m_testimonyRecording = AreaData::TestimonyRecording::RECORDING;
|
||||
sendServerMessage("Started testimony recording.");
|
||||
}
|
||||
}
|
||||
@ -115,15 +115,15 @@ void AOClient::cmdTestify(int argc, QStringList argv)
|
||||
void AOClient::cmdExamine(int argc, QStringList argv)
|
||||
{
|
||||
AreaData* area = server->areas[current_area];
|
||||
if (area->testimony.size() -1 > 0)
|
||||
if (area->m_testimony.size() -1 > 0)
|
||||
{
|
||||
area->test_rec = AreaData::TestimonyRecording::PLAYBACK;
|
||||
area->m_testimonyRecording = AreaData::TestimonyRecording::PLAYBACK;
|
||||
server->broadcast(AOPacket("RT",{"testimony2"}), current_area);
|
||||
server->broadcast(AOPacket("MS", {area->testimony[0]}), current_area);
|
||||
area->statement = 0;
|
||||
server->broadcast(AOPacket("MS", {area->m_testimony[0]}), current_area);
|
||||
area->m_statement = 0;
|
||||
return;
|
||||
}
|
||||
if (area->test_rec == AreaData::TestimonyRecording::PLAYBACK)
|
||||
if (area->m_testimonyRecording == AreaData::TestimonyRecording::PLAYBACK)
|
||||
sendServerMessage("Unable to examine while another examination is running");
|
||||
else
|
||||
sendServerMessage("Unable to start replay without prior examination.");
|
||||
@ -132,15 +132,15 @@ void AOClient::cmdExamine(int argc, QStringList argv)
|
||||
void AOClient::cmdTestimony(int argc, QStringList argv)
|
||||
{
|
||||
AreaData* area = server->areas[current_area];
|
||||
if (area->testimony.size() -1 < 1) {
|
||||
if (area->m_testimony.size() -1 < 1) {
|
||||
sendServerMessage("Unable to display empty testimony.");
|
||||
return;
|
||||
}
|
||||
|
||||
QString ooc_message;
|
||||
for (int i = 1; i <= area->testimony.size() -1; i++)
|
||||
for (int i = 1; i <= area->m_testimony.size() -1; i++)
|
||||
{
|
||||
QStringList packet = area->testimony.at(i);
|
||||
QStringList packet = area->m_testimony.at(i);
|
||||
QString ic_message = packet[4];
|
||||
ooc_message.append( "[" + QString::number(i) + "]" + ic_message + "\n");
|
||||
}
|
||||
@ -150,35 +150,35 @@ void AOClient::cmdTestimony(int argc, QStringList argv)
|
||||
void AOClient::cmdDeleteStatement(int argc, QStringList argv)
|
||||
{
|
||||
AreaData* area = server->areas[current_area];
|
||||
int c_statement = area->statement;
|
||||
if (area->testimony.size() - 1 == 0) {
|
||||
int c_statement = area->m_statement;
|
||||
if (area->m_testimony.size() - 1 == 0) {
|
||||
sendServerMessage("Unable to delete statement. No statements saved in this area.");
|
||||
}
|
||||
if (c_statement > 0 && area->testimony.size() > 2) {
|
||||
area->testimony.remove(c_statement);
|
||||
area->statement = c_statement - 1;
|
||||
if (c_statement > 0 && area->m_testimony.size() > 2) {
|
||||
area->m_testimony.remove(c_statement);
|
||||
area->m_statement = c_statement - 1;
|
||||
sendServerMessage("The statement with id " + QString::number(c_statement) + " has been deleted from the testimony.");
|
||||
}
|
||||
}
|
||||
|
||||
void AOClient::cmdUpdateStatement(int argc, QStringList argv)
|
||||
{
|
||||
server->areas[current_area]->test_rec = AreaData::TestimonyRecording::UPDATE;
|
||||
server->areas[current_area]->m_testimonyRecording = AreaData::TestimonyRecording::UPDATE;
|
||||
sendServerMessage("The next IC-Message will replace the last displayed replay message.");
|
||||
}
|
||||
|
||||
void AOClient::cmdPauseTestimony(int argc, QStringList argv)
|
||||
{
|
||||
AreaData* area = server->areas[current_area];
|
||||
area->test_rec = AreaData::TestimonyRecording::STOPPED;
|
||||
area->m_testimonyRecording = AreaData::TestimonyRecording::STOPPED;
|
||||
server->broadcast(AOPacket("RT",{"testimony1#1"}), current_area);
|
||||
sendServerMessage("Testimony has been stopped.");
|
||||
}
|
||||
|
||||
void AOClient::cmdAddStatement(int argc, QStringList argv)
|
||||
{
|
||||
if (server->areas[current_area]->statement < server->maximum_statements) {
|
||||
server->areas[current_area]->test_rec = AreaData::TestimonyRecording::ADD;
|
||||
if (server->areas[current_area]->m_statement < server->maximum_statements) {
|
||||
server->areas[current_area]->m_testimonyRecording = AreaData::TestimonyRecording::ADD;
|
||||
sendServerMessage("The next IC-Message will be inserted into the testimony.");
|
||||
}
|
||||
else
|
||||
@ -196,7 +196,7 @@ void AOClient::cmdSaveTestimony(int argc, QStringList argv)
|
||||
|
||||
if (permission_found) {
|
||||
AreaData* area = server->areas[current_area];
|
||||
if (area->testimony.size() -1 <= 0) {
|
||||
if (area->m_testimony.size() -1 <= 0) {
|
||||
sendServerMessage("Can't save an empty testimony.");
|
||||
return;
|
||||
}
|
||||
@ -216,9 +216,9 @@ void AOClient::cmdSaveTestimony(int argc, QStringList argv)
|
||||
QTextStream out(&file);
|
||||
out.setCodec("UTF-8");
|
||||
if(file.open(QIODevice::WriteOnly | QIODevice::Append | QIODevice::Text)) {
|
||||
for (int i = 0; i <= area->testimony.size() -1; i++)
|
||||
for (int i = 0; i <= area->m_testimony.size() -1; i++)
|
||||
{
|
||||
out << area->testimony.at(i).join("#") << "\n";
|
||||
out << area->m_testimony.at(i).join("#") << "\n";
|
||||
}
|
||||
sendServerMessage("Testimony saved. To load it use /loadtestimony " + testimony_name);
|
||||
testimony_saving = false;
|
||||
@ -258,7 +258,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->m_testimony.append(packet);
|
||||
testimony_lines = testimony_lines + 1;
|
||||
}
|
||||
else {
|
||||
|
@ -32,7 +32,7 @@ QStringList AOClient::buildAreaList(int area_idx)
|
||||
QString area_name = server->area_names[area_idx];
|
||||
AreaData* area = server->areas[area_idx];
|
||||
entries.append("=== " + area_name + " ===");
|
||||
switch (area->locked) {
|
||||
switch (area->locked()) {
|
||||
case AreaData::LockStatus::LOCKED:
|
||||
entries.append("[LOCKED]");
|
||||
break;
|
||||
@ -43,13 +43,13 @@ QStringList AOClient::buildAreaList(int area_idx)
|
||||
default:
|
||||
break;
|
||||
}
|
||||
entries.append("[" + QString::number(area->player_count) + " users][" + QVariant::fromValue(area->status).toString().replace("_", "-") + "]");
|
||||
entries.append("[" + QString::number(area->m_playerCount) + " users][" + QVariant::fromValue(area->m_status).toString().replace("_", "-") + "]");
|
||||
for (AOClient* client : server->clients) {
|
||||
if (client->current_area == area_idx && client->joined) {
|
||||
QString char_entry = "[" + QString::number(client->id) + "] " + client->current_char;
|
||||
if (client->current_char == "")
|
||||
char_entry += "Spectator";
|
||||
if (area->owners.contains(client->id))
|
||||
if (area->m_owners.contains(client->id))
|
||||
char_entry.insert(0, "[CM] ");
|
||||
if (authenticated)
|
||||
char_entry += " (" + client->getIpid() + "): " + client->ooc_name;
|
||||
@ -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->m_timer[timer_idx - 1];
|
||||
else
|
||||
return "Invalid timer ID.";
|
||||
|
||||
|
@ -106,7 +106,7 @@ void AOClient::cmdRandomChar(int argc, QStringList argv)
|
||||
bool taken = true;
|
||||
while (taken) {
|
||||
selected_char_id = genRand(0, server->characters.size() - 1);
|
||||
if (!area->characters_taken.contains(selected_char_id)) {
|
||||
if (!area->m_charactersTaken.contains(selected_char_id)) {
|
||||
taken = false;
|
||||
}
|
||||
}
|
||||
@ -423,7 +423,7 @@ void AOClient::cmdA(int argc, QStringList argv)
|
||||
}
|
||||
|
||||
AreaData* area = server->areas[area_id];
|
||||
if (!area->owners.contains(id)) {
|
||||
if (!area->m_owners.contains(id)) {
|
||||
sendServerMessage("You are not CM in that area.");
|
||||
return;
|
||||
}
|
||||
@ -441,7 +441,7 @@ void AOClient::cmdS(int argc, QStringList argv)
|
||||
QString ooc_message = argv.join(" ");
|
||||
|
||||
for (int i = 0; i <= all_areas; i++) {
|
||||
if (server->areas[i]->owners.contains(id))
|
||||
if (server->areas[i]->m_owners.contains(id))
|
||||
server->broadcast(AOPacket("CT", {"[CM]" + sender_name, ooc_message}), i);
|
||||
}
|
||||
}
|
||||
|
@ -333,8 +333,8 @@ void AOClient::cmdAllowBlankposting(int argc, QStringList argv)
|
||||
{
|
||||
QString sender_name = ooc_name;
|
||||
AreaData* area = server->areas[current_area];
|
||||
area->blankposting_allowed = !area->blankposting_allowed;
|
||||
if (area->blankposting_allowed == false) {
|
||||
area->m_blankpostingAllowed = !area->m_blankpostingAllowed;
|
||||
if (area->blankpostingAllowed() == false) {
|
||||
sendServerMessageArea(sender_name + " has set blankposting in the area to forbidden.");
|
||||
}
|
||||
else {
|
||||
@ -391,16 +391,16 @@ void AOClient::cmdReload(int argc, QStringList argv)
|
||||
void AOClient::cmdForceImmediate(int argc, QStringList argv)
|
||||
{
|
||||
AreaData* area = server->areas[current_area];
|
||||
area->force_immediate = !area->force_immediate;
|
||||
QString state = area->force_immediate ? "on." : "off.";
|
||||
area->m_forceImmediate = !area->m_forceImmediate;
|
||||
QString state = area->m_forceImmediate ? "on." : "off.";
|
||||
sendServerMessage("Forced immediate text processing in this area is now " + state);
|
||||
}
|
||||
|
||||
void AOClient::cmdAllowIniswap(int argc, QStringList argv)
|
||||
{
|
||||
AreaData* area = server->areas[current_area];
|
||||
area->iniswap_allowed = !area->iniswap_allowed;
|
||||
QString state = area->iniswap_allowed ? "allowed." : "disallowed.";
|
||||
area->m_iniswapAllowed = !area->m_iniswapAllowed;
|
||||
QString state = area->m_iniswapAllowed ? "allowed." : "disallowed.";
|
||||
sendServerMessage("Iniswapping in this area is now " + state);
|
||||
}
|
||||
|
||||
|
@ -28,8 +28,8 @@ void AOClient::cmdPlay(int argc, QStringList argv)
|
||||
}
|
||||
AreaData* area = server->areas[current_area];
|
||||
QString song = argv.join(" ");
|
||||
area->current_music = song;
|
||||
area->music_played_by = showname;
|
||||
area->m_currentMusic = song;
|
||||
area->m_musicPlayerBy = showname;
|
||||
AOPacket music_change("MC", {song, QString::number(server->getCharID(current_char)), showname, "1", "0"});
|
||||
server->broadcast(music_change, current_area);
|
||||
}
|
||||
@ -37,8 +37,8 @@ void AOClient::cmdPlay(int argc, QStringList argv)
|
||||
void AOClient::cmdCurrentMusic(int argc, QStringList argv)
|
||||
{
|
||||
AreaData* area = server->areas[current_area];
|
||||
if (area->current_music != "" && area->current_music != "~stop.mp3") // dummy track for stopping music
|
||||
sendServerMessage("The current song is " + area->current_music + " played by " + area->music_played_by);
|
||||
if (area->m_currentMusic != "" && area->m_currentMusic != "~stop.mp3") // dummy track for stopping music
|
||||
sendServerMessage("The current song is " + area->m_currentMusic + " played by " + area->m_musicPlayerBy);
|
||||
else
|
||||
sendServerMessage("There is no music playing.");
|
||||
}
|
||||
@ -86,7 +86,7 @@ void AOClient::cmdUnBlockDj(int argc, QStringList argv)
|
||||
void AOClient::cmdToggleMusic(int argc, QStringList argv)
|
||||
{
|
||||
AreaData* area = server->areas[current_area];
|
||||
area->toggle_music = !area->toggle_music;
|
||||
QString state = area->toggle_music ? "allowed." : "disallowed.";
|
||||
area->m_toggleMusic = !area->m_toggleMusic;
|
||||
QString state = area->m_toggleMusic ? "allowed." : "disallowed.";
|
||||
sendServerMessage("Music in this area is now " + state);
|
||||
}
|
||||
|
@ -48,7 +48,7 @@ void AOClient::cmdTimer(int argc, QStringList argv)
|
||||
QStringList timers;
|
||||
timers.append("Currently active timers:");
|
||||
for (int i = 0; i <= 4; i++) {
|
||||
timers.append(getAreaTimer(area->index, i));
|
||||
timers.append(getAreaTimer(area->m_index, i));
|
||||
}
|
||||
sendServerMessage(timers.join("\n"));
|
||||
return;
|
||||
@ -65,7 +65,7 @@ void AOClient::cmdTimer(int argc, QStringList argv)
|
||||
// Called with one argument
|
||||
// Shows the status of one timer
|
||||
if (argc == 1) {
|
||||
sendServerMessage(getAreaTimer(area->index, timer_id));
|
||||
sendServerMessage(getAreaTimer(area->m_index, timer_id));
|
||||
return;
|
||||
}
|
||||
|
||||
@ -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->m_timers[timer_id - 1];
|
||||
|
||||
AOPacket show_timer("TI", {QString::number(timer_id), "2"});
|
||||
AOPacket hide_timer("TI", {QString::number(timer_id), "3"});
|
||||
@ -130,18 +130,18 @@ 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);
|
||||
if (area->m_notecards.keys().contains(current_char))
|
||||
area->m_notecards.remove(current_char);
|
||||
QString notecard = argv.join(" ");
|
||||
area->notecards[current_char] = notecard;
|
||||
area->m_notecards[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->m_notecards.keys().contains(current_char)) {
|
||||
area->m_notecards.remove(current_char);
|
||||
sendServerMessageArea(current_char + " erased their note card.");
|
||||
}
|
||||
else
|
||||
@ -151,17 +151,17 @@ void AOClient::cmdNoteCardClear(int argc, QStringList argv)
|
||||
void AOClient::cmdNoteCardReveal(int argc, QStringList argv)
|
||||
{
|
||||
AreaData* area = server->areas[current_area];
|
||||
if (area->notecards.isEmpty()) {
|
||||
if (area->m_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)
|
||||
for (i = area->m_notecards.begin(); i != area->m_notecards.end(); ++i)
|
||||
message << i.key() + ": " + i.value();
|
||||
sendServerMessageArea(message.join("\n"));
|
||||
area->notecards.clear();
|
||||
area->m_notecards.clear();
|
||||
}
|
||||
|
||||
void AOClient::cmd8Ball(int argc, QStringList argv)
|
||||
|
@ -1,6 +1,6 @@
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
// akashi - a server for Attorney Online 2 //
|
||||
// Copyright (C) 2020 scatterflower //
|
||||
// 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 //
|
||||
@ -15,101 +15,101 @@
|
||||
// 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 <QDir>
|
||||
|
||||
#include "include/logger.h"
|
||||
|
||||
void Logger::logIC(AOClient *client, AOPacket *packet)
|
||||
void Logger::logIC(const QString& f_areaName_r, const QString& f_charName_r, const QString& f_ipid_r, const QString& f_message_r)
|
||||
{
|
||||
QString message = packet->contents[4];
|
||||
addEntry(buildEntry(client, "IC", message));
|
||||
addEntry(f_areaName_r, f_charName_r, f_ipid_r, "IC", f_message_r);
|
||||
}
|
||||
|
||||
void Logger::logOOC(AOClient* client, AOPacket* packet)
|
||||
void Logger::logOOC(const QString& f_areaName_r, const QString& f_charName_r, const QString& f_ipid_r, const QString& f_message_r)
|
||||
{
|
||||
QString message = packet->contents[1];
|
||||
addEntry(buildEntry(client, "OOC", message));
|
||||
addEntry(f_areaName_r, f_charName_r, f_ipid_r, "OOC", f_message_r);
|
||||
}
|
||||
|
||||
void Logger::logModcall(AOClient* client, AOPacket* packet)
|
||||
void Logger::logModcall(const QString& f_areaName_r, const QString& f_charName_r, const QString& f_ipid_r, const QString& f_modcallReason_r)
|
||||
{
|
||||
QString message = packet->contents[0];
|
||||
addEntry(buildEntry(client, "MODCALL", message));
|
||||
addEntry(f_areaName_r, f_charName_r, f_ipid_r, "MODCALL", f_modcallReason_r);
|
||||
}
|
||||
|
||||
void Logger::logCmd(AOClient *client, AOPacket *packet, QString cmd, QStringList args)
|
||||
void Logger::logCmd(const QString& f_areaName_r, const QString& f_charName_r, const QString& f_ipid_r,
|
||||
const QString& f_oocMessage_r, const QString& f_cmd_r, const QStringList& f_cmdArgs_r)
|
||||
{
|
||||
// Some commands contain sensitive data, like passwords
|
||||
// These must be filtered out
|
||||
if (cmd == "login") {
|
||||
addEntry(buildEntry(client, "LOGIN", "Attempted login"));
|
||||
if (f_cmd_r == "login") {
|
||||
addEntry(f_areaName_r, f_charName_r, f_ipid_r, "LOGIN", "Attempted login");
|
||||
}
|
||||
else if (cmd == "rootpass") {
|
||||
addEntry(buildEntry(client, "USERS", "Root password created"));
|
||||
else if (f_cmd_r == "rootpass") {
|
||||
addEntry(f_areaName_r, f_charName_r, f_ipid_r, "USERS", "Root password created");
|
||||
}
|
||||
else if (cmd == "adduser" && !args.isEmpty()) {
|
||||
addEntry(buildEntry(client, "USERS", "Added user " + args[0]));
|
||||
else if (f_cmd_r == "adduser" && !f_cmdArgs_r.isEmpty()) {
|
||||
addEntry(f_areaName_r, f_charName_r, f_ipid_r, "USERS", "Added user " + f_cmdArgs_r[0]);
|
||||
}
|
||||
else {
|
||||
logOOC(f_areaName_r, f_charName_r, f_ipid_r, f_oocMessage_r);
|
||||
}
|
||||
else
|
||||
logOOC(client, packet);
|
||||
}
|
||||
|
||||
void Logger::logLogin(AOClient *client, bool success, QString modname)
|
||||
void Logger::logLogin(const QString& f_areaName_r, const QString& f_charName_r, const QString& f_ipid_r, bool success, const QString& f_modname_r)
|
||||
{
|
||||
QString message = success ? "Logged in as " + modname : "Failed to log in as " + modname;
|
||||
addEntry(buildEntry(client, "LOGIN", message));
|
||||
QString l_message = success ? "Logged in as " + f_modname_r : "Failed to log in as " + f_modname_r;
|
||||
addEntry(f_areaName_r, f_charName_r, f_ipid_r, "LOGIN", l_message);
|
||||
}
|
||||
|
||||
QString Logger::buildEntry(AOClient *client, QString type, QString message)
|
||||
void Logger::addEntry(
|
||||
const QString& f_areaName_r,
|
||||
const QString& f_charName_r,
|
||||
const QString& f_ipid_r,
|
||||
const QString& f_type_r,
|
||||
const QString& f_message_r)
|
||||
{
|
||||
QString time = QDateTime::currentDateTime().toString("ddd MMMM d yyyy | hh:mm:ss");
|
||||
QString area_name = area->name;
|
||||
QString char_name = client->current_char;
|
||||
QString ipid = client->getIpid();
|
||||
QString l_time = QDateTime::currentDateTime().toString("ddd MMMM d yyyy | hh:mm:ss");
|
||||
|
||||
QString log_entry = QStringLiteral("[%1][%2][%6] %3(%4): %5\n")
|
||||
.arg(time)
|
||||
.arg(area_name)
|
||||
.arg(char_name)
|
||||
.arg(ipid)
|
||||
.arg(message)
|
||||
.arg(type);
|
||||
return log_entry;
|
||||
}
|
||||
QString l_logEntry = QStringLiteral("[%1][%2][%6] %3(%4): %5\n")
|
||||
.arg(l_time, f_areaName_r, f_charName_r, f_ipid_r, f_message_r, f_type_r);
|
||||
|
||||
void Logger::addEntry(QString entry)
|
||||
{
|
||||
if (buffer.length() < max_length) {
|
||||
buffer.enqueue(entry);
|
||||
if (area->log_type == "full") {
|
||||
flush();
|
||||
if (m_buffer.length() < m_maxLength) {
|
||||
m_buffer.enqueue(l_logEntry);
|
||||
|
||||
if (m_logType == "full") {
|
||||
flush(f_areaName_r);
|
||||
}
|
||||
}
|
||||
else {
|
||||
buffer.dequeue();
|
||||
buffer.enqueue(entry);
|
||||
m_buffer.dequeue();
|
||||
m_buffer.enqueue(l_logEntry);
|
||||
}
|
||||
}
|
||||
|
||||
void Logger::flush()
|
||||
void Logger::flush(const QString& f_areaName_r)
|
||||
{
|
||||
QDir dir("logs/");
|
||||
if (!dir.exists()) {
|
||||
dir.mkpath(".");
|
||||
QDir l_dir("logs/");
|
||||
if (!l_dir.exists()) {
|
||||
l_dir.mkpath(".");
|
||||
}
|
||||
|
||||
QFile logfile;
|
||||
if (area->log_type == "modcall") {
|
||||
logfile.setFileName(QString("logs/report_%1_%2.log").arg((area->name), (QDateTime::currentDateTime().toString("yyyy-MM-dd_hhmmss"))));
|
||||
QFile l_logfile;
|
||||
|
||||
if (m_logType == "modcall") {
|
||||
l_logfile.setFileName(QString("logs/report_%1_%2.log").arg(f_areaName_r, (QDateTime::currentDateTime().toString("yyyy-MM-dd_hhmmss"))));
|
||||
}
|
||||
else if (area->log_type == "full") {
|
||||
logfile.setFileName(QString("logs/%1.log").arg(QDate::currentDate().toString("yyyy-MM-dd")));
|
||||
else if (m_logType == "full") {
|
||||
l_logfile.setFileName(QString("logs/%1.log").arg(QDate::currentDate().toString("yyyy-MM-dd")));
|
||||
}
|
||||
else {
|
||||
qCritical("Invalid logger set!");
|
||||
}
|
||||
if (logfile.open(QIODevice::WriteOnly | QIODevice::Append)) {
|
||||
QTextStream file_stream(&logfile);
|
||||
while (!buffer.isEmpty())
|
||||
file_stream << buffer.dequeue();
|
||||
}
|
||||
logfile.close();
|
||||
|
||||
if (l_logfile.open(QIODevice::WriteOnly | QIODevice::Append)) {
|
||||
QTextStream file_stream(&l_logfile);
|
||||
|
||||
while (!m_buffer.isEmpty())
|
||||
file_stream << m_buffer.dequeue();
|
||||
}
|
||||
|
||||
l_logfile.close();
|
||||
}
|
||||
|
@ -96,19 +96,19 @@ void AOClient::pktLoadingDone(AreaData* area, int argc, QStringList argv, AOPack
|
||||
}
|
||||
|
||||
server->player_count++;
|
||||
area->player_count++;
|
||||
area->m_playerCount++;
|
||||
joined = true;
|
||||
server->updateCharsTaken(area);
|
||||
|
||||
arup(ARUPType::PLAYER_COUNT, true); // Tell everyone there is a new player
|
||||
sendEvidenceList(area);
|
||||
|
||||
sendPacket("HP", {"1", QString::number(area->def_hp)});
|
||||
sendPacket("HP", {"2", QString::number(area->pro_hp)});
|
||||
sendPacket("HP", {"1", QString::number(area->m_defHP)});
|
||||
sendPacket("HP", {"2", QString::number(area->m_proHP)});
|
||||
sendPacket("FA", server->area_names);
|
||||
sendPacket("OPPASS", {"DEADBEEF"});
|
||||
sendPacket("DONE");
|
||||
sendPacket("BN", {area->background});
|
||||
sendPacket("BN", {area->m_background});
|
||||
|
||||
sendServerMessage("=== MOTD ===\r\n" + server->MOTD + "\r\n=============");
|
||||
|
||||
@ -120,8 +120,8 @@ void AOClient::pktLoadingDone(AreaData* area, int argc, QStringList argv, AOPack
|
||||
else {
|
||||
sendPacket("TI", {"0", "3"});
|
||||
}
|
||||
for (QTimer* timer : area->timers) {
|
||||
int timer_id = area->timers.indexOf(timer) + 1;
|
||||
for (QTimer* timer : area->m_timer) {
|
||||
int timer_id = area->m_timer.indexOf(timer) + 1;
|
||||
if (timer->isActive()) {
|
||||
sendPacket("TI", {QString::number(timer_id), "2"});
|
||||
sendPacket("TI", {QString::number(timer_id), "0", QString::number(QTime(0,0).msecsTo(QTime(0,0).addMSecs(timer->remainingTime())))});
|
||||
@ -164,10 +164,10 @@ void AOClient::pktIcChat(AreaData* area, int argc, QStringList argv, AOPacket pa
|
||||
if (pos != "")
|
||||
validated_packet.contents[5] = pos;
|
||||
|
||||
area->logger->logIC(this, &validated_packet);
|
||||
area->m_logger->logIC(this, &validated_packet);
|
||||
server->broadcast(validated_packet, current_area);
|
||||
area->last_ic_message.clear();
|
||||
area->last_ic_message.append(validated_packet.contents);
|
||||
area->m_lastICMessage.clear();
|
||||
area->m_lastICMessage.append(validated_packet.contents);
|
||||
}
|
||||
|
||||
void AOClient::pktOocChat(AreaData* area, int argc, QStringList argv, AOPacket packet)
|
||||
@ -196,12 +196,12 @@ void AOClient::pktOocChat(AreaData* area, int argc, QStringList argv, AOPacket p
|
||||
command = command.right(command.length() - 1);
|
||||
cmd_argv.removeFirst();
|
||||
int cmd_argc = cmd_argv.length();
|
||||
area->logger->logCmd(this, &final_packet, command, cmd_argv);
|
||||
area->m_logger->logCmd(this, &final_packet, command, cmd_argv);
|
||||
handleCommand(command, cmd_argc, cmd_argv);
|
||||
}
|
||||
else {
|
||||
server->broadcast(final_packet, current_area);
|
||||
area->logger->logOOC(this, &final_packet);
|
||||
area->m_logger->logOOC(this, &final_packet);
|
||||
}
|
||||
}
|
||||
|
||||
@ -230,7 +230,7 @@ void AOClient::pktChangeMusic(AreaData* area, int argc, QStringList argv, AOPack
|
||||
sendServerMessage("You are blocked from changing the music.");
|
||||
return;
|
||||
}
|
||||
if (!area->toggle_music && !checkAuth(ACLFlags.value("CM"))) {
|
||||
if (!area->m_toggleMusic && !checkAuth(ACLFlags.value("CM"))) {
|
||||
sendServerMessage("Music is disabled in this area.");
|
||||
return;
|
||||
}
|
||||
@ -245,8 +245,8 @@ void AOClient::pktChangeMusic(AreaData* area, int argc, QStringList argv, AOPack
|
||||
else
|
||||
final_song = argument;
|
||||
AOPacket music_change("MC", {final_song, argv[1], showname, "1", "0", effects});
|
||||
area->current_music = final_song;
|
||||
area->music_played_by = showname;
|
||||
area->m_currentMusic = final_song;
|
||||
area->m_musicPlayerBy = showname;
|
||||
server->broadcast(music_change, current_area);
|
||||
return;
|
||||
}
|
||||
@ -281,13 +281,13 @@ void AOClient::pktHpBar(AreaData* area, int argc, QStringList argv, AOPacket pac
|
||||
return;
|
||||
}
|
||||
if (argv[0] == "1") {
|
||||
area->def_hp = std::min(std::max(0, argv[1].toInt()), 10);
|
||||
area->m_defHP = std::min(std::max(0, argv[1].toInt()), 10);
|
||||
}
|
||||
else if (argv[0] == "2") {
|
||||
area->pro_hp = std::min(std::max(0, argv[1].toInt()), 10);
|
||||
area->m_proHP = std::min(std::max(0, argv[1].toInt()), 10);
|
||||
}
|
||||
server->broadcast(AOPacket("HP", {"1", QString::number(area->def_hp)}), area->index);
|
||||
server->broadcast(AOPacket("HP", {"2", QString::number(area->pro_hp)}), area->index);
|
||||
server->broadcast(AOPacket("HP", {"1", QString::number(area->m_defHP)}), area->m_index);
|
||||
server->broadcast(AOPacket("HP", {"2", QString::number(area->m_proHP)}), area->m_index);
|
||||
updateJudgeLog(area, this, "updated the penalties");
|
||||
}
|
||||
|
||||
@ -326,8 +326,8 @@ void AOClient::pktModCall(AreaData* area, int argc, QStringList argv, AOPacket p
|
||||
if (client->authenticated)
|
||||
client->sendPacket(packet);
|
||||
}
|
||||
area->logger->logModcall(this, &packet);
|
||||
area->logger->flush();
|
||||
area->m_logger->logModcall(this, &packet);
|
||||
area->m_logger->flush();
|
||||
}
|
||||
|
||||
void AOClient::pktAddEvidence(AreaData* area, int argc, QStringList argv, AOPacket packet)
|
||||
@ -335,7 +335,7 @@ void AOClient::pktAddEvidence(AreaData* area, int argc, QStringList argv, AOPack
|
||||
if (!checkEvidenceAccess(area))
|
||||
return;
|
||||
AreaData::Evidence evi = {argv[0], argv[1], argv[2]};
|
||||
area->evidence.append(evi);
|
||||
area->m_evidence.append(evi);
|
||||
sendEvidenceList(area);
|
||||
}
|
||||
|
||||
@ -345,8 +345,8 @@ void AOClient::pktRemoveEvidence(AreaData* area, int argc, QStringList argv, AOP
|
||||
return;
|
||||
bool is_int = false;
|
||||
int idx = argv[0].toInt(&is_int);
|
||||
if (is_int && idx <= area->evidence.size() && idx >= 0) {
|
||||
area->evidence.removeAt(idx);
|
||||
if (is_int && idx <= area->m_evidence.size() && idx >= 0) {
|
||||
area->m_evidence.removeAt(idx);
|
||||
}
|
||||
sendEvidenceList(area);
|
||||
}
|
||||
@ -358,8 +358,8 @@ void AOClient::pktEditEvidence(AreaData* area, int argc, QStringList argv, AOPac
|
||||
bool is_int = false;
|
||||
int idx = argv[0].toInt(&is_int);
|
||||
AreaData::Evidence evi = {argv[1], argv[2], argv[3]};
|
||||
if (is_int && idx <= area->evidence.size() && idx >= 0) {
|
||||
area->evidence.replace(idx, evi);
|
||||
if (is_int && idx <= area->m_evidence.size() && idx >= 0) {
|
||||
area->m_evidence.replace(idx, evi);
|
||||
}
|
||||
sendEvidenceList(area);
|
||||
}
|
||||
@ -430,8 +430,8 @@ void AOClient::updateEvidenceList(AreaData* area)
|
||||
QStringList evidence_list;
|
||||
QString evidence_format("%1&%2&%3");
|
||||
|
||||
for (AreaData::Evidence evidence : area->evidence) {
|
||||
if (!checkAuth(ACLFlags.value("CM")) && area->evi_mod == AreaData::EvidenceMod::HIDDEN_CM) {
|
||||
for (AreaData::Evidence evidence : area->m_evidence) {
|
||||
if (!checkAuth(ACLFlags.value("CM")) && area->m_eviMod == AreaData::EvidenceMod::HIDDEN_CM) {
|
||||
QRegularExpression regex("<owner=(.*?)>");
|
||||
QRegularExpressionMatch match = regex.match(evidence.description);
|
||||
if (match.hasMatch()) {
|
||||
@ -466,7 +466,7 @@ AOPacket AOClient::validateIcPacket(AOPacket packet)
|
||||
// Spectators cannot use IC
|
||||
return invalid;
|
||||
AreaData* area = server->areas[current_area];
|
||||
if (area->locked == AreaData::LockStatus::SPECTATABLE && !area->invited.contains(id))
|
||||
if (area->m_locked == AreaData::LockStatus::SPECTATABLE && !area->m_invited.contains(id))
|
||||
// Non-invited players cannot speak in spectatable areas
|
||||
return invalid;
|
||||
|
||||
@ -491,7 +491,7 @@ AOPacket AOClient::validateIcPacket(AOPacket packet)
|
||||
if (current_char != incoming_args[2].toString()) {
|
||||
// Selected char is different from supplied folder name
|
||||
// This means the user is INI-swapped
|
||||
if (!area->iniswap_allowed) {
|
||||
if (!area->m_iniswapAllowed) {
|
||||
if (!server->characters.contains(incoming_args[2].toString()))
|
||||
return invalid;
|
||||
}
|
||||
@ -509,12 +509,12 @@ AOPacket AOClient::validateIcPacket(AOPacket packet)
|
||||
return invalid;
|
||||
|
||||
QString incoming_msg = dezalgo(incoming_args[4].toString().trimmed());
|
||||
if (!area->last_ic_message.isEmpty()
|
||||
&& incoming_msg == area->last_ic_message[4]
|
||||
if (!area->m_lastICMessage.isEmpty()
|
||||
&& incoming_msg == area->m_lastICMessage[4]
|
||||
&& incoming_msg != "")
|
||||
return invalid;
|
||||
|
||||
if (incoming_msg == "" && area->blankposting_allowed == false) {
|
||||
if (incoming_msg == "" && area->m_blankpostingAllowed == false) {
|
||||
sendServerMessage("Blankposting has been forbidden in this area.");
|
||||
return invalid;
|
||||
}
|
||||
@ -587,7 +587,7 @@ AOPacket AOClient::validateIcPacket(AOPacket packet)
|
||||
|
||||
// evidence
|
||||
int evi_idx = incoming_args[11].toInt();
|
||||
if (evi_idx > area->evidence.length())
|
||||
if (evi_idx > area->m_evidence.length())
|
||||
return invalid;
|
||||
args.append(QString::number(evi_idx));
|
||||
|
||||
@ -614,7 +614,7 @@ AOPacket AOClient::validateIcPacket(AOPacket packet)
|
||||
if (incoming_args.length() > 15) {
|
||||
// showname
|
||||
QString incoming_showname = dezalgo(incoming_args[15].toString().trimmed());
|
||||
if (!(incoming_showname == current_char || incoming_showname.isEmpty()) && !area->showname_allowed) {
|
||||
if (!(incoming_showname == current_char || incoming_showname.isEmpty()) && !area->m_shownameAllowed) {
|
||||
sendServerMessage("Shownames are not allowed in this area!");
|
||||
return invalid;
|
||||
}
|
||||
@ -680,7 +680,7 @@ AOPacket AOClient::validateIcPacket(AOPacket packet)
|
||||
|
||||
// immediate text processing
|
||||
int immediate = incoming_args[18].toInt();
|
||||
if (area->force_immediate)
|
||||
if (area->m_forceImmediate)
|
||||
immediate = 1;
|
||||
if (immediate != 1 && immediate != 0)
|
||||
return invalid;
|
||||
@ -714,10 +714,10 @@ AOPacket AOClient::validateIcPacket(AOPacket packet)
|
||||
int additive = incoming_args[24].toInt();
|
||||
if (additive != 0 && additive != 1)
|
||||
return invalid;
|
||||
else if (area->last_ic_message.isEmpty()){
|
||||
else if (area->m_lastICMessage.isEmpty()){
|
||||
additive = 0;
|
||||
}
|
||||
else if (!(char_id == area->last_ic_message[8].toInt())) {
|
||||
else if (!(char_id == area->m_lastICMessage[8].toInt())) {
|
||||
additive = 0;
|
||||
}
|
||||
else if (additive == 1) {
|
||||
@ -730,29 +730,29 @@ AOPacket AOClient::validateIcPacket(AOPacket packet)
|
||||
}
|
||||
|
||||
//Testimony playback
|
||||
if (area->test_rec == AreaData::TestimonyRecording::RECORDING || area->test_rec == AreaData::TestimonyRecording::ADD) {
|
||||
if (area->m_testimonyRecording == AreaData::TestimonyRecording::RECORDING || area->m_testimonyRecording == AreaData::TestimonyRecording::ADD) {
|
||||
if (args[5] != "wit")
|
||||
return AOPacket("MS", args);
|
||||
|
||||
if (area->statement == -1) {
|
||||
if (area->m_statement == -1) {
|
||||
args[4] = "~~\\n-- " + args[4] + " --";
|
||||
args[14] = "3";
|
||||
server->broadcast(AOPacket("RT",{"testimony1"}), current_area);
|
||||
}
|
||||
addStatement(args);
|
||||
}
|
||||
else if (area->test_rec == AreaData::TestimonyRecording::UPDATE) {
|
||||
else if (area->m_testimonyRecording == AreaData::TestimonyRecording::UPDATE) {
|
||||
args = updateStatement(args);
|
||||
}
|
||||
else if (area->test_rec == AreaData::TestimonyRecording::PLAYBACK) {
|
||||
else if (area->m_testimonyRecording == AreaData::TestimonyRecording::PLAYBACK) {
|
||||
if (args[4] == ">") {
|
||||
pos = "wit";
|
||||
area->statement = area->statement + 1;
|
||||
area->m_statement = area->m_statement + 1;
|
||||
args = playTestimony();
|
||||
}
|
||||
if (args[4] == "<") {
|
||||
pos = "wit";
|
||||
area->statement = area->statement - 1;
|
||||
area->m_statement = area->m_statement - 1;
|
||||
args = playTestimony();
|
||||
}
|
||||
QString decoded_message = decodeMessage(args[4]); //Get rid of that pesky encoding first.
|
||||
@ -760,7 +760,7 @@ AOPacket AOClient::validateIcPacket(AOPacket packet)
|
||||
QRegularExpressionMatch match = jump.match(decoded_message);
|
||||
if (match.hasMatch()) {
|
||||
pos = "wit";
|
||||
area->statement = match.captured("int").toInt();
|
||||
area->m_statement = match.captured("int").toInt();
|
||||
args= playTestimony();
|
||||
}
|
||||
}
|
||||
@ -777,7 +777,7 @@ QString AOClient::dezalgo(QString p_text)
|
||||
|
||||
bool AOClient::checkEvidenceAccess(AreaData *area)
|
||||
{
|
||||
switch(area->evi_mod) {
|
||||
switch(area->m_eviMod) {
|
||||
case AreaData::EvidenceMod::FFA:
|
||||
return true;
|
||||
case AreaData::EvidenceMod::CM:
|
||||
@ -798,12 +798,12 @@ void AOClient::updateJudgeLog(AreaData* area, AOClient* client, QString action)
|
||||
QString ipid = client->getIpid();
|
||||
QString message = action;
|
||||
QString logmessage = QString("[%1]: [%2] %3 (%4) %5").arg(timestamp, uid, char_name, ipid, message);
|
||||
int size = area->judgelog.size();
|
||||
int size = area->m_judgelog.size();
|
||||
if (size == 10) {
|
||||
area->judgelog.removeFirst();
|
||||
area->judgelog.append(logmessage);
|
||||
area->m_judgelog.removeFirst();
|
||||
area->m_judgelog.append(logmessage);
|
||||
}
|
||||
else area->judgelog.append(logmessage);
|
||||
else area->m_judgelog.append(logmessage);
|
||||
}
|
||||
|
||||
QString AOClient::decodeMessage(QString incoming_message)
|
||||
|
@ -160,7 +160,7 @@ void Server::updateCharsTaken(AreaData* area)
|
||||
{
|
||||
QStringList chars_taken;
|
||||
for (QString cur_char : characters) {
|
||||
chars_taken.append(area->characters_taken.contains(getCharID(cur_char))
|
||||
chars_taken.append(area->m_charactersTaken.contains(getCharID(cur_char))
|
||||
? QStringLiteral("-1")
|
||||
: QStringLiteral("0"));
|
||||
}
|
||||
@ -168,7 +168,7 @@ void Server::updateCharsTaken(AreaData* area)
|
||||
AOPacket response_cc("CharsCheck", chars_taken);
|
||||
|
||||
for (AOClient* client : clients) {
|
||||
if (client->current_area == area->index){
|
||||
if (client->current_area == area->m_index){
|
||||
if (!client->is_charcursed)
|
||||
client->sendPacket(response_cc);
|
||||
else {
|
||||
|
@ -22,30 +22,30 @@
|
||||
void AOClient::addStatement(QStringList packet)
|
||||
{
|
||||
AreaData* area = server->areas[current_area];
|
||||
int c_statement = area->statement;
|
||||
int c_statement = area->m_statement;
|
||||
if (c_statement >= -1) {
|
||||
if (area->test_rec == AreaData::TestimonyRecording::RECORDING) {
|
||||
if (area->m_testimonyRecording == AreaData::TestimonyRecording::RECORDING) {
|
||||
if (c_statement <= server->maximum_statements) {
|
||||
if (c_statement == -1)
|
||||
packet[14] = "3";
|
||||
else
|
||||
packet[14] = "1";
|
||||
area->statement = c_statement + 1;
|
||||
area->testimony.append(packet);
|
||||
area->m_statement = c_statement + 1;
|
||||
area->m_testimony.append(packet);
|
||||
return;
|
||||
}
|
||||
else {
|
||||
sendServerMessage("Unable to add more statements. The maximum amount of statements has been reached.");
|
||||
}
|
||||
}
|
||||
else if (area->test_rec == AreaData::TestimonyRecording::ADD) {
|
||||
else if (area->m_testimonyRecording == AreaData::TestimonyRecording::ADD) {
|
||||
packet[14] = "1";
|
||||
area->testimony.insert(c_statement,packet);
|
||||
area->test_rec = AreaData::TestimonyRecording::PLAYBACK;
|
||||
area->m_testimony.insert(c_statement,packet);
|
||||
area->m_testimonyRecording = AreaData::TestimonyRecording::PLAYBACK;
|
||||
}
|
||||
else {
|
||||
sendServerMessage("Unable to add more statements. The maximum amount of statements has been reached.");
|
||||
area->test_rec = AreaData::TestimonyRecording::PLAYBACK;
|
||||
area->m_testimonyRecording = AreaData::TestimonyRecording::PLAYBACK;
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -53,15 +53,15 @@ void AOClient::addStatement(QStringList packet)
|
||||
QStringList AOClient::updateStatement(QStringList packet)
|
||||
{
|
||||
AreaData* area = server->areas[current_area];
|
||||
int c_statement = area->statement;
|
||||
area->test_rec = AreaData::TestimonyRecording::PLAYBACK;
|
||||
if (c_statement <= 0 || area->testimony[c_statement].empty())
|
||||
int c_statement = area->m_statement;
|
||||
area->m_testimonyRecording = AreaData::TestimonyRecording::PLAYBACK;
|
||||
if (c_statement <= 0 || area->m_testimony[c_statement].empty())
|
||||
sendServerMessage("Unable to update an empty statement. Please use /addtestimony.");
|
||||
else {
|
||||
packet[14] = "1";
|
||||
area->testimony.replace(c_statement, packet);
|
||||
area->m_testimony.replace(c_statement, packet);
|
||||
sendServerMessage("Updated current statement.");
|
||||
return area->testimony[c_statement];
|
||||
return area->m_testimony[c_statement];
|
||||
}
|
||||
return packet;
|
||||
}
|
||||
@ -69,28 +69,28 @@ QStringList AOClient::updateStatement(QStringList packet)
|
||||
void AOClient::clearTestimony()
|
||||
{
|
||||
AreaData* area = server->areas[current_area];
|
||||
area->test_rec = AreaData::TestimonyRecording::STOPPED;
|
||||
area->statement = -1;
|
||||
area->testimony.clear(); //!< Empty out the QVector
|
||||
area->testimony.squeeze(); //!< Release memory. Good idea? God knows, I do not.
|
||||
area->m_testimonyRecording = AreaData::TestimonyRecording::STOPPED;
|
||||
area->m_statement = -1;
|
||||
area->m_testimony.clear(); //!< Empty out the QVector
|
||||
area->m_testimony.squeeze(); //!< Release memory. Good idea? God knows, I do not.
|
||||
}
|
||||
|
||||
QStringList AOClient::playTestimony()
|
||||
{
|
||||
AreaData* area = server->areas[current_area];
|
||||
int c_statement = area->statement;
|
||||
if (c_statement > area->testimony.size() - 1) {
|
||||
int c_statement = area->m_statement;
|
||||
if (c_statement > area->m_testimony.size() - 1) {
|
||||
sendServerMessageArea("Last statement reached. Looping to first statement.");
|
||||
area->statement = 1;
|
||||
return area->testimony[area->statement];
|
||||
area->m_statement = 1;
|
||||
return area->m_testimony[area->m_statement];
|
||||
}
|
||||
if (c_statement <= 0) {
|
||||
sendServerMessage("First statement reached.");
|
||||
area->statement = 1;
|
||||
return area->testimony[area->statement = 1];
|
||||
area->m_statement = 1;
|
||||
return area->m_testimony[area->m_statement = 1];
|
||||
}
|
||||
else {
|
||||
return area->testimony[c_statement];
|
||||
return area->m_testimony[c_statement];
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user