Document merged changes from master

This commit is contained in:
Cerapter 2021-03-24 21:50:47 +01:00
parent c13a2d06f9
commit 28b1fb3b3a
6 changed files with 234 additions and 21 deletions

Binary file not shown.

View File

@ -96,10 +96,7 @@ class Advertiser : public QObject {
QString ip; QString ip;
/** /**
* @copydoc ConfigManager::server_settings::port * @copydoc ConfigManager::server_settings::ms_port
*
* @bug Because of a typo in the code, this also replaces #local_port, thus clients will have to attempt
* to connect through the same port as the connection is established to the master server.
*/ */
int port; int port;
@ -109,7 +106,7 @@ class Advertiser : public QObject {
int ws_port; int ws_port;
/** /**
* @copydoc ConfigManager::server_settings::local_port * @copydoc ConfigManager::server_settings::port
* *
* @bug See #port. * @bug See #port.
*/ */

View File

@ -70,6 +70,10 @@ class AOClient : public QObject {
* @see #ipid * @see #ipid
*/ */
QString getIpid(); QString getIpid();
/**
* @brief Calculates the client's IPID based on a hashed version of its IP.
*/
void calculateIpid(); void calculateIpid();
/** /**
@ -146,6 +150,9 @@ class AOClient : public QObject {
*/ */
bool global_enabled = true; bool global_enabled = true;
/**
* @brief If true, the client may not use in-character chat.
*/
bool is_muted = false; bool is_muted = false;
/** /**
@ -189,8 +196,19 @@ class AOClient : public QObject {
{"SUPER", ~0ULL }, {"SUPER", ~0ULL },
}; };
/**
* @brief If true, the client's in-character messages will have their word order randomised.
*/
bool is_shaken; bool is_shaken;
/**
* @brief If true, the client's in-character messages will have their vowels (English alphabet only) removed.
*/
bool is_disemvoweled; bool is_disemvoweled;
/**
* @brief If true, the client's in-character messages will be overwritten by a randomly picked predetermined message.
*/
bool is_gimped; bool is_gimped;
public slots: public slots:
@ -602,7 +620,25 @@ class AOClient : public QObject {
* @iscommand * @iscommand
*/ */
void cmdHelp(int argc, QStringList argv); void cmdHelp(int argc, QStringList argv);
/**
* @brief Gets or sets the server's Message Of The Day.
*
* @details If called without arguments, gets the MOTD.
*
* If it has any number of arguments, it is set as the **MOTD**.
*
* @iscommand
*/
void cmdMOTD(int argc, QStringList argv); void cmdMOTD(int argc, QStringList argv);
/**
* @brief Gives a very brief description of Akashi.
*
* @details No arguments.
*
* @iscommand
*/
void cmdAbout(int argc, QStringList argv); void cmdAbout(int argc, QStringList argv);
/** /**
@ -649,6 +685,14 @@ class AOClient : public QObject {
* @iscommand * @iscommand
*/ */
void cmdAddUser(int argc, QStringList argv); void cmdAddUser(int argc, QStringList argv);
/**
* @brief Removes a user from the moderators in `"advanced"` authorisation type.
*
* @details Takes the **targer user's name** as the argument.
*
* @iscommand
*/
void cmdRemoveUser(int argc, QStringList argv); void cmdRemoveUser(int argc, QStringList argv);
/** /**
@ -887,8 +931,14 @@ class AOClient : public QObject {
* @brief Bans a client from the server, forcibly severing its connection to the server, * @brief Bans a client from the server, forcibly severing its connection to the server,
* and disallowing their return. * and disallowing their return.
* *
* @details The first argument is the **target's IPID**, while the remaining arguments are the **reason** * @details The first argument is the **target's IPID**, the second is the **reason** why the client
* the client was banned. Both arguments are mandatory. * was banned, the third is the **duration**.
*
* Both the reason and the duration must be in quotation marks.
*
* The duration can be `"perma"`, meaning a forever ban, otherwise, it must be given in the format of `"YYyWWwDDdHHhMMmSSs"` to
* mean a YY years, WW weeks, DD days, HH hours, MM minutes and SS seconds long ban. Any of these may be left out, for example,
* `"1h30m"` for a 1.5 hour long ban.
* *
* Besides banning, this command kicks all clients having the given IPID, * Besides banning, this command kicks all clients having the given IPID,
* thus a multiclienting user will have all their clients be kicked from the server. * thus a multiclienting user will have all their clients be kicked from the server.
@ -899,6 +949,14 @@ class AOClient : public QObject {
* @iscommand * @iscommand
*/ */
void cmdBan(int argc, QStringList argv); void cmdBan(int argc, QStringList argv);
/**
* @brief Removes a ban from the database.
*
* @details Takes a single argument, the **ID** of the ban.
*
* @iscommand
*/
void cmdUnBan(int argc, QStringList argv); void cmdUnBan(int argc, QStringList argv);
/** /**
@ -913,11 +971,67 @@ class AOClient : public QObject {
* @iscommand * @iscommand
*/ */
void cmdKick(int argc, QStringList argv); void cmdKick(int argc, QStringList argv);
/**
* @brief Sends out a decorated global message, for announcements.
*
* @details The arguments are **the message** that the client wants to send.
*
* @iscommand
*
* @see AOClient::cmdG()
*/
void cmdAnnounce(int argc, QStringList argv); void cmdAnnounce(int argc, QStringList argv);
/**
* @brief Sends a message in the server-wide, moderator only chat.
*
* @details The arguments are **the message** that the client wants to send.
*
* @iscommand
*/
void cmdM(int argc, QStringList argv); void cmdM(int argc, QStringList argv);
/**
* @brief Sends out a global message that is marked with an `[M]` to mean it is coming from a moderator.
*
* @details The arguments are **the message** that the client wants to send.
*
* @iscommand
*
* @see AOClient::cmdG()
*/
void cmdGM(int argc, QStringList argv); void cmdGM(int argc, QStringList argv);
/**
* @brief Mutes a client.
*
* @details The only argument is the **target client's user ID**.
*
* @iscommand
*
* @see #is_muted
*/
void cmdMute(int argc, QStringList argv); void cmdMute(int argc, QStringList argv);
/**
* @brief Removes the muted status a client.
*
* @details The only argument is the **target client's user ID**.
*
* @iscommand
*
* @see #is_muted
*/
void cmdUnmute(int argc, QStringList argv); void cmdUnmute(int argc, QStringList argv);
/**
* @brief Lists the last five bans made on the server.
*
* @details No arguments.
*
* @iscommand
*/
void cmdBans(int argc, QStringList argv); void cmdBans(int argc, QStringList argv);
///@} ///@}
@ -1031,6 +1145,14 @@ class AOClient : public QObject {
* @see AreaData::EvidenceMod * @see AreaData::EvidenceMod
*/ */
void cmdEvidenceMod(int argc, QStringList argv); void cmdEvidenceMod(int argc, QStringList argv);
/**
* @brief Changes the subtheme of the clients in the current area.
*
* @details The only argument is the **name of the subtheme**. Reloading is always forced.
*
* @iscommand
*/
void cmdSubTheme(int argc, QStringList argv); void cmdSubTheme(int argc, QStringList argv);
///@} ///@}
@ -1179,6 +1301,26 @@ class AOClient : public QObject {
* @param Type The type of the dice-rolling being done. * @param Type The type of the dice-rolling being done.
*/ */
void diceThrower(int argc, QStringList argv, RollType Type); void diceThrower(int argc, QStringList argv, RollType Type);
/**
* @brief Interprets an expression of time into amount of seconds.
*
* @param input A string in the format of `"XXyXXwXXdXXhXXmXXs"`, where every `XX` is some integer.
* There is no limit on the length of the integers, the `XX` text is just a placeholder, and is not intended to
* indicate a limit of two digits maximum.
*
* The string gets interpreted as follows:
* * `XXy` is parsed into `XX` amount of years,
* * `XXw` is parsed into `XX` amount of weeks,
* * `XXd` is parsed into `XX` amount of days,
* * `XXh` is parsed into `XX` amount of hours,
* * `XXm` is parsed into `XX` amount of minutes, and
* * `XXs` is parsed into `XX` amount of seconds.
*
* Any of these may be left out, but the order must be kept (i.e., `"10s5y"` is a malformed text).
*
* @return The parsed text, converted into their respective durations, summed up, then converted into seconds.
*/
long long parseTime(QString input); long long parseTime(QString input);
///@} ///@}

View File

@ -35,6 +35,13 @@ class Logger;
class AreaData : public QObject { class AreaData : public QObject {
Q_OBJECT Q_OBJECT
public: public:
/**
* @brief Constructor for the AreaData class.
*
* @param p_name The name of the area. This must be in the format of `"X:YYYYYY"`, where `X` is an integer,
* and `YYYYYY` is the actual name of the area.
* @param p_index The index of the area in the area list.
*/
AreaData(QString p_name, int p_index); AreaData(QString p_name, int p_index);
/** /**
@ -61,6 +68,9 @@ class AreaData : public QObject {
*/ */
int index; int index;
/**
* @brief A list of the character IDs of all characters taken.
*/
QList<int> characters_taken; QList<int> characters_taken;
/** /**

View File

@ -82,30 +82,73 @@ public:
QString getBanReason(QHostAddress ip); QString getBanReason(QHostAddress ip);
/** /**
* @brief Overloaded function for getBanReason(QHostAddress). Returns based on HDID instead of IP. * @overload
*
* @param hdid The hardware ID whose ban reason needs to be returned.
*
* @return The ban reason if the hardware ID is actually banned,
* or `"Ban reason not found."` if the hardware ID is not actually banned.
*/ */
QString getBanReason(QString hdid); QString getBanReason(QString hdid);
long long getBanDuration(QString hdid);
/**
* @brief Returns the reason the given IP address was banned with.
*
* @param ip The IP address whose ban duration to get.
*
* @return The ban duration if the IP address is actually banned,
* or `-1` if the IP address is not actually banned.
*/
long long getBanDuration(QHostAddress ip); long long getBanDuration(QHostAddress ip);
int getBanID(QString hdid);
/**
* @overload
*/
long long getBanDuration(QString hdid);
/**
* @brief Gets the ID number of a given ban.
*
* @param ip The IP address whose associated ban's ID we need.
*
* @return The ID of the ban if the IP address is actually banned,
* or `-1` if the IP address is not actually banned.
*/
int getBanID(QHostAddress ip); int getBanID(QHostAddress ip);
/**
* @overload
*/
int getBanID(QString hdid);
/**
* @brief Details about a ban.
*/
struct BanInfo { struct BanInfo {
QString ipid; QString ipid; //!< The banned user's IPID.
QHostAddress ip; QHostAddress ip; //!< The banned user's IP.
QString hdid; QString hdid; //!< The banned user's hardware ID.
unsigned long time; unsigned long time; //!< The time the ban was registered.
QString reason; QString reason; //!< The reason given for the ban by the moderator who registered it.
long long duration; long long duration; //!< The duration of the ban, in seconds.
}; };
/**
* @brief Gets the last five bans made on the server.
*
* @return See brief description.
*/
QList<BanInfo> getRecentBans(); QList<BanInfo> getRecentBans();
/**
* @brief Registers a ban into the database.
*
* @param ban The details of the ban.
*/
void addBan(BanInfo ban); void addBan(BanInfo ban);
/**
* @brief Sets the duration of a given ban to 0, effectively removing the ban the associated user.
*
* @param id The ID of the ban to invalidate.
*
* @return False if no such ban exists, true if the invalidation was successful.
*/
bool invalidateBan(int id); bool invalidateBan(int id);
/** /**
@ -122,6 +165,14 @@ public:
* @see AOClient::ACLFlags for the potential special permissions a user may have. * @see AOClient::ACLFlags for the potential special permissions a user may have.
*/ */
bool createUser(QString username, QString salt, QString password, unsigned long long acl); bool createUser(QString username, QString salt, QString password, unsigned long long acl);
/**
* @brief Deletes an authorised user from the database.
*
* @param username The username whose associated user to delete.
*
* @return False if the user didn't even exist, true if the user was successfully deleted.
*/
bool deleteUser(QString username); bool deleteUser(QString username);
/** /**

View File

@ -77,9 +77,18 @@ class Server : public QObject {
* @param ipid The IPID to look for. * @param ipid The IPID to look for.
* *
* @return A pointer to the client if found, a nullpointer if not. * @return A pointer to the client if found, a nullpointer if not.
*
* @see Server::getClientsByIpid() to get all clients ran by the same user.
*/ */
AOClient* getClient(QString ipid); AOClient* getClient(QString ipid);
/**
* @brief Gets a list of pointers to all clients with the given IPID.
*
* @param ipid The IPID to look for.
*
* @return A list of clients whose IPID match. List may be empty.
*/
QList<AOClient*> getClientsByIpid(QString ipid); QList<AOClient*> getClientsByIpid(QString ipid);
/** /**
@ -196,6 +205,10 @@ class Server : public QObject {
* @note Unused. getServerName() serves its purpose instead. * @note Unused. getServerName() serves its purpose instead.
*/ */
QString server_name; QString server_name;
/**
* @brief The Message Of The Day of the server, shown upon entry to the server and on request.
*/
QString MOTD; QString MOTD;
/** /**