mirror of
https://github.com/mod-playerbots/azerothcore-wotlk.git
synced 2026-01-13 09:17:18 +00:00
feat(Command): Remove spy command from AC and make it a module (#1401)
This commit is contained in:
committed by
Francesco Borzì
parent
d4ab165888
commit
f0913b7da8
@@ -0,0 +1,4 @@
|
||||
INSERT INTO `version_db_world` (`sql_rev`) VALUES ('1549462763029736000');
|
||||
|
||||
DELETE FROM `trinity_string` WHERE `entry` BETWEEN 5062 AND 5071;
|
||||
DELETE FROM `command` WHERE `name` IN ('spy follow', 'spy unfollow', 'spy groupfollow', 'spy groupunfollow', 'spy clear', 'spy status');
|
||||
@@ -1146,19 +1146,7 @@ enum TrinityStrings
|
||||
LANG_COMMAND_MUTEHISTORY_EMPTY = 5060,
|
||||
LANG_COMMAND_MUTEHISTORY_OUTPUT = 5061,
|
||||
|
||||
// Spy command
|
||||
LANG_COMMAND_SPY_FOLLOWING = 5062,
|
||||
LANG_COMMAND_SPY_UNFOLLOW = 5063,
|
||||
LANG_COMMAND_SPY_ALREADY_FOLLOWED_BY = 5064,
|
||||
LANG_COMMAND_SPY_FOLLOWING_GROUP = 5065,
|
||||
LANG_COMMAND_SPY_UNFOLLOW_GROUP = 5066,
|
||||
LANG_COMMAND_SPY_NOT_FOLLOWING_GROUP = 5067,
|
||||
LANG_COMMAND_SPY_CLEARED = 5068,
|
||||
LANG_COMMAND_SPY_LIST = 5069,
|
||||
LANG_COMMAND_SPY_WHISPERS_PLAYER = 5070,
|
||||
LANG_COMMAND_SPY_TELLS_GROUP = 5071,
|
||||
|
||||
// Room for more Trinity strings 5072-9999
|
||||
// Room for more Trinity strings 5062-9999
|
||||
|
||||
// Level requirement notifications
|
||||
LANG_SAY_REQ = 6604,
|
||||
|
||||
@@ -37,7 +37,6 @@ set(scripts_STAT_SRCS
|
||||
Commands/cs_quest.cpp
|
||||
Commands/cs_reload.cpp
|
||||
Commands/cs_reset.cpp
|
||||
Commands/cs_spy.cpp
|
||||
Commands/cs_server.cpp
|
||||
Commands/cs_tele.cpp
|
||||
Commands/cs_ticket.cpp
|
||||
|
||||
@@ -1,281 +0,0 @@
|
||||
#include "Player.h"
|
||||
#include "ScriptMgr.h"
|
||||
#include "Chat.h"
|
||||
#include "Channel.h"
|
||||
#include "Language.h"
|
||||
#include "Group.h"
|
||||
|
||||
// Maps to store followed players
|
||||
std::map<uint32,uint32> gmListening;
|
||||
std::map<uint32,uint32> gmListeningGroup;
|
||||
|
||||
class chat_spy_playerscript : public PlayerScript
|
||||
{
|
||||
public:
|
||||
chat_spy_playerscript() : PlayerScript("chat_spy_playerscript") { }
|
||||
|
||||
void OnChat(Player *sender, uint32 /*type*/, uint32 lang, std::string& msg, Player *receiver)
|
||||
{
|
||||
if (gmListening.size() > 0 && lang != LANG_ADDON)
|
||||
{
|
||||
// if the sender or the receiver is being followed
|
||||
Player* gm = GetGmFromList(sender);
|
||||
if (!gm)
|
||||
gm = GetGmFromList(receiver);
|
||||
|
||||
if (gm)
|
||||
{
|
||||
ChatHandler(gm->GetSession()).PSendSysMessage(LANG_COMMAND_SPY_WHISPERS_PLAYER,
|
||||
sender->GetName().c_str(), receiver ? receiver->GetName().c_str() : "<unknown>", msg.c_str());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void OnChat(Player* sender, uint32 /*type*/, uint32 lang, std::string& msg, Group* group)
|
||||
{
|
||||
if(gmListeningGroup.size() > 0 && lang != LANG_ADDON)
|
||||
if(Player* gm = GetGmFromGroupList(group))
|
||||
ChatHandler(gm->GetSession()).PSendSysMessage(LANG_COMMAND_SPY_TELLS_GROUP,
|
||||
sender->GetName().c_str(), msg.c_str());
|
||||
}
|
||||
|
||||
Player* GetGmFromList(Player* from)
|
||||
{
|
||||
std::map<uint32,uint32>::const_iterator itr = gmListening.find(from->GetGUIDLow());
|
||||
return itr != gmListening.end() ? sObjectMgr->GetPlayerByLowGUID(itr->second) : NULL;
|
||||
}
|
||||
|
||||
Player* GetGmFromGroupList(Group* group)
|
||||
{
|
||||
std::map<uint32,uint32>::const_iterator itr = gmListeningGroup.find(group->GetLowGUID());
|
||||
return itr != gmListeningGroup.end() ? sObjectMgr->GetPlayerByLowGUID(itr->second) : NULL;
|
||||
}
|
||||
};
|
||||
|
||||
class chat_spy_commandscript : public CommandScript
|
||||
{
|
||||
public:
|
||||
chat_spy_commandscript() : CommandScript("chat_spy_commandscript") { }
|
||||
|
||||
std::vector<ChatCommand> GetCommands() const override
|
||||
{
|
||||
static std::vector<ChatCommand> spyCommandTable =
|
||||
{
|
||||
{ "follow", SEC_GAMEMASTER, false, &HandleSpyFollowCommand, ""},
|
||||
{ "groupfollow", SEC_ADMINISTRATOR, false, &HandleSpyFollowGroupCommand, ""},
|
||||
{ "unfollow", SEC_GAMEMASTER, false, &HandleSpyUnFollowCommand, ""},
|
||||
{ "groupunfollow", SEC_ADMINISTRATOR, false, &HandleSpyUnFollowGroupCommand, ""},
|
||||
{ "clear", SEC_GAMEMASTER, false, &HandleSpyClearCommand, ""},
|
||||
{ "status", SEC_GAMEMASTER, false, &HandleSpyStatusCommand, ""}
|
||||
};
|
||||
|
||||
static std::vector<ChatCommand> commandTable =
|
||||
{
|
||||
{ "spy", SEC_GAMEMASTER, false, NULL, "", spyCommandTable}
|
||||
};
|
||||
|
||||
return commandTable;
|
||||
}
|
||||
|
||||
static bool HandleSpyFollowCommand(ChatHandler* handler, const char* args)
|
||||
{
|
||||
if(!*args)
|
||||
return false;
|
||||
|
||||
char *cName = strtok ((char*)args, " ");
|
||||
if(!cName)
|
||||
return false;
|
||||
|
||||
std::string pTarget = args;
|
||||
if(!normalizePlayerName(pTarget))
|
||||
{
|
||||
handler->SendSysMessage(LANG_PLAYER_NOT_FOUND);
|
||||
return true;
|
||||
}
|
||||
|
||||
if(Player* target = ObjectAccessor::FindPlayer(sObjectMgr->GetPlayerGUIDByName(pTarget.c_str())))
|
||||
{
|
||||
std::map<uint32,uint32>::const_iterator itr = gmListening.find(target->GetGUIDLow());
|
||||
if(itr != gmListening.end())
|
||||
{
|
||||
if(Player* gm = sObjectMgr->GetPlayerByLowGUID(itr->second))
|
||||
{
|
||||
handler->PSendSysMessage(LANG_COMMAND_SPY_ALREADY_FOLLOWED_BY, target->GetName().c_str(), gm->GetName().c_str());
|
||||
return true;
|
||||
}
|
||||
|
||||
gmListening[target->GetGUIDLow()] = handler->GetSession()->GetPlayer()->GetGUIDLow();
|
||||
handler->PSendSysMessage(LANG_COMMAND_SPY_FOLLOWING, target->GetName().c_str());
|
||||
}
|
||||
}
|
||||
else
|
||||
handler->SendSysMessage(LANG_PLAYER_NOT_FOUND);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
static bool HandleSpyFollowGroupCommand(ChatHandler* handler, const char* args)
|
||||
{
|
||||
if(!*args)
|
||||
return false;
|
||||
|
||||
char *cName = strtok ((char*)args," ");
|
||||
if(!cName)
|
||||
return false;
|
||||
|
||||
std::string pTarget = args;
|
||||
if(!normalizePlayerName(pTarget))
|
||||
{
|
||||
handler->SendSysMessage(LANG_PLAYER_NOT_FOUND);
|
||||
return true;
|
||||
}
|
||||
|
||||
if(Player* target = ObjectAccessor::FindPlayer(sObjectMgr->GetPlayerGUIDByName(pTarget.c_str())))
|
||||
{
|
||||
if(Group* group = target->GetGroup())
|
||||
{
|
||||
std::map<uint32,uint32>::const_iterator itr = gmListeningGroup.find(group->GetLowGUID());
|
||||
if(itr != gmListeningGroup.end())
|
||||
{
|
||||
if(Player* gm = sObjectMgr->GetPlayerByLowGUID(itr->second))
|
||||
{
|
||||
handler->PSendSysMessage(LANG_COMMAND_SPY_ALREADY_FOLLOWED_BY, target->GetName().c_str(), gm->GetName().c_str());
|
||||
return true;
|
||||
}
|
||||
|
||||
gmListeningGroup[group->GetLowGUID()] = handler->GetSession()->GetPlayer()->GetGUIDLow();
|
||||
handler->PSendSysMessage(LANG_COMMAND_SPY_FOLLOWING_GROUP, target->GetName().c_str());
|
||||
}
|
||||
}
|
||||
else
|
||||
handler->PSendSysMessage(LANG_NOT_IN_GROUP, target->GetName().c_str());
|
||||
}
|
||||
else
|
||||
handler->SendSysMessage(LANG_PLAYER_NOT_FOUND);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
static bool HandleSpyUnFollowCommand(ChatHandler* handler, const char* args)
|
||||
{
|
||||
if(!*args)
|
||||
return false;
|
||||
|
||||
char *cName = strtok ((char*)args," ");
|
||||
if(!cName)
|
||||
return false;
|
||||
|
||||
std::string pTarget = args;
|
||||
if(!normalizePlayerName(pTarget))
|
||||
{
|
||||
handler->SendSysMessage(LANG_PLAYER_NOT_FOUND);
|
||||
return true;
|
||||
}
|
||||
|
||||
if(Player* target = ObjectAccessor::FindPlayer(sObjectMgr->GetPlayerGUIDByName(pTarget.c_str())))
|
||||
{
|
||||
handler->PSendSysMessage(LANG_COMMAND_SPY_UNFOLLOW, cName);
|
||||
if(gmListening.find(target->GetGUIDLow()) != gmListening.end())
|
||||
gmListening.erase(target->GetGUIDLow());
|
||||
}
|
||||
else
|
||||
handler->SendSysMessage(LANG_PLAYER_NOT_FOUND);
|
||||
return true;
|
||||
}
|
||||
|
||||
static bool HandleSpyUnFollowGroupCommand(ChatHandler* handler, const char* args)
|
||||
{
|
||||
if(!*args)
|
||||
return false;
|
||||
|
||||
char *cName = strtok ((char*)args," ");
|
||||
if(!cName)
|
||||
return false;
|
||||
|
||||
std::string pTarget = args;
|
||||
if(!normalizePlayerName(pTarget))
|
||||
{
|
||||
handler->SendSysMessage(LANG_PLAYER_NOT_FOUND);
|
||||
return true;
|
||||
}
|
||||
|
||||
if(Player* target = ObjectAccessor::FindPlayer(sObjectMgr->GetPlayerGUIDByName(pTarget.c_str())))
|
||||
{
|
||||
if(Group* group = target->GetGroup())
|
||||
{
|
||||
if(gmListeningGroup.find(group->GetLowGUID()) != gmListening.end())
|
||||
{
|
||||
gmListeningGroup.erase(group->GetLowGUID());
|
||||
handler->PSendSysMessage(LANG_COMMAND_SPY_UNFOLLOW_GROUP, cName);
|
||||
}
|
||||
else
|
||||
handler->PSendSysMessage(LANG_COMMAND_SPY_NOT_FOLLOWING_GROUP, cName);
|
||||
}
|
||||
else
|
||||
handler->PSendSysMessage(LANG_NOT_IN_GROUP, target->GetName().c_str());
|
||||
}
|
||||
else
|
||||
handler->SendSysMessage(LANG_PLAYER_NOT_FOUND);
|
||||
return true;
|
||||
}
|
||||
|
||||
static bool HandleSpyClearCommand(ChatHandler* handler, const char* /*args*/)
|
||||
{
|
||||
gmListening.clear();
|
||||
handler->SendSysMessage(LANG_COMMAND_SPY_CLEARED);
|
||||
return true;
|
||||
}
|
||||
|
||||
static bool HandleSpyStatusCommand(ChatHandler* handler, const char* /*args*/)
|
||||
{
|
||||
uint32 guidlow = handler->GetSession()->GetPlayer()->GetGUIDLow();
|
||||
std::map<uint32,uint32>::iterator next;
|
||||
handler->SendSysMessage(LANG_COMMAND_SPY_LIST);
|
||||
|
||||
for(std::map<uint32,uint32>::iterator itr = gmListening.begin(); itr != gmListening.end(); itr = next)
|
||||
{
|
||||
// There's the possibility that itr is erased, so we save it
|
||||
next = itr;
|
||||
++next;
|
||||
if(itr->second == guidlow)
|
||||
{
|
||||
if(Player* target = ObjectAccessor::FindPlayer(itr->first))
|
||||
handler->PSendSysMessage("%s", target->GetName().c_str());
|
||||
else // clear offline players
|
||||
gmListening.erase(itr);
|
||||
}
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
class chat_spy_logout_cleaner : public PlayerScript
|
||||
{
|
||||
public:
|
||||
chat_spy_logout_cleaner() : PlayerScript("chat_spy_logout_cleaner") { }
|
||||
|
||||
void OnLogout(Player* player)
|
||||
{
|
||||
if(player && player->IsGameMaster())
|
||||
{
|
||||
uint32 guidlow = player->GetGUIDLow();
|
||||
std::map<uint32,uint32>::iterator next;
|
||||
for(std::map<uint32,uint32>::iterator itr = gmListening.begin(); itr != gmListening.end(); itr = next)
|
||||
{
|
||||
next = itr; // Save a reference to the next one
|
||||
++next;
|
||||
if(itr->second == guidlow)
|
||||
gmListening.erase(itr);
|
||||
}
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
void AddSC_spy_commandscript()
|
||||
{
|
||||
new chat_spy_playerscript();
|
||||
new chat_spy_commandscript();
|
||||
new chat_spy_logout_cleaner();
|
||||
}
|
||||
@@ -55,7 +55,6 @@ void AddSC_reload_commandscript();
|
||||
void AddSC_reset_commandscript();
|
||||
void AddSC_server_commandscript();
|
||||
void AddSC_spectator_commandscript();
|
||||
void AddSC_spy_commandscript();
|
||||
void AddSC_tele_commandscript();
|
||||
void AddSC_ticket_commandscript();
|
||||
void AddSC_titles_commandscript();
|
||||
@@ -632,7 +631,6 @@ void AddCommandScripts()
|
||||
AddSC_reload_commandscript();
|
||||
AddSC_reset_commandscript();
|
||||
AddSC_spectator_commandscript();
|
||||
AddSC_spy_commandscript();
|
||||
AddSC_tele_commandscript();
|
||||
AddSC_ticket_commandscript();
|
||||
AddSC_titles_commandscript();
|
||||
|
||||
Reference in New Issue
Block a user