Merge pull request #177 from AttorneyOnline/pay-attention
Add /notice, for moderators to be heard above the noise
This commit is contained in:
commit
d7d5984631
@ -231,6 +231,7 @@ class AOClient : public QObject {
|
|||||||
{"FORCE_CHARSELECT",1ULL << 13},
|
{"FORCE_CHARSELECT",1ULL << 13},
|
||||||
{"BYPASS_LOCKS", 1ULL << 14},
|
{"BYPASS_LOCKS", 1ULL << 14},
|
||||||
{"IGNORE_BGLIST", 1ULL << 15},
|
{"IGNORE_BGLIST", 1ULL << 15},
|
||||||
|
{"SEND_NOTICE", 1ULL << 16},
|
||||||
{"SUPER", ~0ULL }
|
{"SUPER", ~0ULL }
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -1223,6 +1224,30 @@ class AOClient : public QObject {
|
|||||||
*/
|
*/
|
||||||
void cmdUpdateBan(int argc, QStringList argv);
|
void cmdUpdateBan(int argc, QStringList argv);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Pops up a notice for all clients in the targeted area with a given message.
|
||||||
|
*
|
||||||
|
* @details The only argument is the message to send. This command only works on clients with support for the BB#%
|
||||||
|
*
|
||||||
|
* generic message box packet (i.e. Attorney Online versions 2.9 and up). To support earlier versions (as well as to make the message
|
||||||
|
*
|
||||||
|
* re-readable if a user clicks out of it too fast) the message will also be sent in OOC to all affected clients.
|
||||||
|
*
|
||||||
|
* @iscommand
|
||||||
|
*/
|
||||||
|
void cmdNotice(int argc, QStringList argv);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Pops up a notice for all clients in the server with a given message.
|
||||||
|
*
|
||||||
|
* @details Unlike cmdNotice, this command will send its notice to every client connected to the server.
|
||||||
|
*
|
||||||
|
* @see #cmdNotice
|
||||||
|
*
|
||||||
|
* @iscommand
|
||||||
|
*/
|
||||||
|
void cmdNoticeGlobal(int argc, QStringList argv);
|
||||||
|
|
||||||
///@}
|
///@}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -1904,6 +1929,16 @@ class AOClient : public QObject {
|
|||||||
* @return True if the password meets the requirements, otherwise false.
|
* @return True if the password meets the requirements, otherwise false.
|
||||||
*/
|
*/
|
||||||
bool checkPasswordRequirements(QString username, QString password);
|
bool checkPasswordRequirements(QString username, QString password);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Sends a server notice.
|
||||||
|
*
|
||||||
|
* @param notice The notice to send out.
|
||||||
|
*
|
||||||
|
* @param global Whether or not the notice should be server-wide.
|
||||||
|
*/
|
||||||
|
void sendNotice(QString notice, bool global = false);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Checks if a testimony contains '<' or '>'.
|
* @brief Checks if a testimony contains '<' or '>'.
|
||||||
@ -2074,7 +2109,9 @@ class AOClient : public QObject {
|
|||||||
{"update_ban", {ACLFlags.value("BAN"), 3, &AOClient::cmdUpdateBan}},
|
{"update_ban", {ACLFlags.value("BAN"), 3, &AOClient::cmdUpdateBan}},
|
||||||
{"changepass", {ACLFlags.value("NONE"), 1, &AOClient::cmdChangePassword}},
|
{"changepass", {ACLFlags.value("NONE"), 1, &AOClient::cmdChangePassword}},
|
||||||
{"ignorebglist", {ACLFlags.value("IGNORE_BGLIST"),0, &AOClient::cmdIgnoreBgList}},
|
{"ignorebglist", {ACLFlags.value("IGNORE_BGLIST"),0, &AOClient::cmdIgnoreBgList}},
|
||||||
{"ignore_bglist", {ACLFlags.value("IGNORE_BGLIST"),0, &AOClient::cmdIgnoreBgList}}
|
{"ignore_bglist", {ACLFlags.value("IGNORE_BGLIST"),0, &AOClient::cmdIgnoreBgList}},
|
||||||
|
{"notice", {ACLFlags.value("SEND_NOTICE"), 1, &AOClient::cmdNotice}},
|
||||||
|
{"noticeg", {ACLFlags.value("SEND_NOTICE"), 1, &AOClient::cmdNoticeGlobal}},
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -208,3 +208,17 @@ bool AOClient::checkPasswordRequirements(QString username, QString password)
|
|||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void AOClient::sendNotice(QString notice, bool global)
|
||||||
|
{
|
||||||
|
QString message = "A moderator sent this ";
|
||||||
|
if (global)
|
||||||
|
message += "server-wide ";
|
||||||
|
message += "notice:\n\n" + notice;
|
||||||
|
sendServerMessageArea(message);
|
||||||
|
AOPacket packet("BB", {message});
|
||||||
|
if (global)
|
||||||
|
server->broadcast(packet);
|
||||||
|
else
|
||||||
|
server->broadcast(packet, current_area);
|
||||||
|
}
|
||||||
|
@ -514,3 +514,12 @@ void AOClient::cmdUpdateBan(int argc, QStringList argv)
|
|||||||
}
|
}
|
||||||
sendServerMessage("Ban updated.");
|
sendServerMessage("Ban updated.");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void AOClient::cmdNotice(int argc, QStringList argv)
|
||||||
|
{
|
||||||
|
sendNotice(argv.join(" "));
|
||||||
|
}
|
||||||
|
void AOClient::cmdNoticeGlobal(int argc, QStringList argv)
|
||||||
|
{
|
||||||
|
sendNotice(argv.join(" "), true);
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user