diff options
author | Carbenium <carbenium@outlook.com> | 2020-08-20 00:20:41 +0200 |
---|---|---|
committer | Shauren <shauren.trinity@gmail.com> | 2022-03-13 00:15:35 +0100 |
commit | 9bee960880c669d3c2ff42935f4666cfd32103f0 (patch) | |
tree | 2e45056a77b4d38f9ce52d9bd1af8ad0f2c01fc4 | |
parent | 92a89ab6f3446d77f896ad585b3b2c8c235b7228 (diff) |
Scripts/Commands: Convert argument parsing of instance commands to new system
(cherry picked from commit b90a4f1798bb948ce8203bd70d9367e6936b866a)
-rw-r--r-- | src/server/game/Accounts/RBAC.h | 2 | ||||
-rw-r--r-- | src/server/scripts/Commands/cs_instance.cpp | 155 |
2 files changed, 48 insertions, 109 deletions
diff --git a/src/server/game/Accounts/RBAC.h b/src/server/game/Accounts/RBAC.h index 9c1e2d1b0c6..eeccc323446 100644 --- a/src/server/game/Accounts/RBAC.h +++ b/src/server/game/Accounts/RBAC.h @@ -281,7 +281,7 @@ enum RBACPermissions RBAC_PERM_COMMAND_HONOR_ADD = 409, RBAC_PERM_COMMAND_HONOR_ADD_KILL = 410, RBAC_PERM_COMMAND_HONOR_UPDATE = 411, - RBAC_PERM_COMMAND_INSTANCE = 412, + // 412 previously used, do not reuse RBAC_PERM_COMMAND_INSTANCE_LISTBINDS = 413, RBAC_PERM_COMMAND_INSTANCE_UNBIND = 414, RBAC_PERM_COMMAND_INSTANCE_STATS = 415, diff --git a/src/server/scripts/Commands/cs_instance.cpp b/src/server/scripts/Commands/cs_instance.cpp index e31043c36e5..eb5173b1daf 100644 --- a/src/server/scripts/Commands/cs_instance.cpp +++ b/src/server/scripts/Commands/cs_instance.cpp @@ -32,55 +32,39 @@ EndScriptData */ #include "InstanceScript.h" #include "Language.h" #include "MapManager.h" -#include "ObjectAccessor.h" -#include "ObjectMgr.h" #include "Player.h" #include "RBAC.h" #include "WorldSession.h" #include <sstream> -#if TRINITY_COMPILER == TRINITY_COMPILER_GNU -#pragma GCC diagnostic ignored "-Wdeprecated-declarations" -#endif +using namespace Trinity::ChatCommands; class instance_commandscript : public CommandScript { public: instance_commandscript() : CommandScript("instance_commandscript") { } - std::vector<ChatCommand> GetCommands() const override + ChatCommandTable GetCommands() const override { - static std::vector<ChatCommand> instanceCommandTable = + static ChatCommandTable instanceCommandTable = { - { "listbinds", rbac::RBAC_PERM_COMMAND_INSTANCE_LISTBINDS, false, &HandleInstanceListBindsCommand, "" }, - { "unbind", rbac::RBAC_PERM_COMMAND_INSTANCE_UNBIND, false, &HandleInstanceUnbindCommand, "" }, - { "stats", rbac::RBAC_PERM_COMMAND_INSTANCE_STATS, true, &HandleInstanceStatsCommand, "" }, - { "savedata", rbac::RBAC_PERM_COMMAND_INSTANCE_SAVEDATA, false, &HandleInstanceSaveDataCommand, "" }, - { "setbossstate", rbac::RBAC_PERM_COMMAND_INSTANCE_SET_BOSS_STATE, true, &HandleInstanceSetBossStateCommand, "" }, - { "getbossstate", rbac::RBAC_PERM_COMMAND_INSTANCE_GET_BOSS_STATE, true, &HandleInstanceGetBossStateCommand, "" }, + { "listbinds", HandleInstanceListBindsCommand, rbac::RBAC_PERM_COMMAND_INSTANCE_LISTBINDS, Console::No }, + { "unbind", HandleInstanceUnbindCommand, rbac::RBAC_PERM_COMMAND_INSTANCE_UNBIND, Console::No }, + { "stats", HandleInstanceStatsCommand, rbac::RBAC_PERM_COMMAND_INSTANCE_STATS, Console::Yes }, + { "savedata", HandleInstanceSaveDataCommand, rbac::RBAC_PERM_COMMAND_INSTANCE_SAVEDATA, Console::No }, + { "setbossstate", HandleInstanceSetBossStateCommand, rbac::RBAC_PERM_COMMAND_INSTANCE_SET_BOSS_STATE, Console::Yes }, + { "getbossstate", HandleInstanceGetBossStateCommand, rbac::RBAC_PERM_COMMAND_INSTANCE_GET_BOSS_STATE, Console::Yes }, }; - static std::vector<ChatCommand> commandTable = + static ChatCommandTable commandTable = { - { "instance", rbac::RBAC_PERM_COMMAND_INSTANCE, true, nullptr, "", instanceCommandTable }, + { "instance", instanceCommandTable }, }; return commandTable; } - static std::string GetTimeString(uint64 time) - { - uint64 days = time / DAY, hours = (time % DAY) / HOUR, minute = (time % HOUR) / MINUTE; - std::ostringstream ss; - if (days) - ss << days << "d "; - if (hours) - ss << hours << "h "; - ss << minute << 'm'; - return ss.str(); - } - - static bool HandleInstanceListBindsCommand(ChatHandler* handler, char const* /*args*/) + static bool HandleInstanceListBindsCommand(ChatHandler* handler) { Player* player = handler->getSelectedPlayer(); if (!player) @@ -92,11 +76,11 @@ public: auto binds = player->GetBoundInstances(Difficulty(difficulty->ID)); if (binds != player->m_boundInstances.end()) { - for (auto itr = binds->second.begin(); itr != binds->second.end(); ++itr) + for (auto const& [mapId, bind] : binds->second) { - InstanceSave* save = itr->second.save; - std::string timeleft = GetTimeString(save->GetResetTime() - GameTime::GetGameTime()); - handler->PSendSysMessage(LANG_COMMAND_LIST_BIND_INFO, itr->first, save->GetInstanceId(), itr->second.perm ? "yes" : "no", itr->second.extendState == EXTEND_STATE_EXPIRED ? "expired" : itr->second.extendState == EXTEND_STATE_EXTENDED ? "yes" : "no", save->GetDifficultyID(), save->CanReset() ? "yes" : "no", timeleft.c_str()); + InstanceSave* save = bind.save; + std::string timeleft = secsToTimeString(save->GetResetTime() - GameTime::GetGameTime(), TimeFormat::ShortText); + handler->PSendSysMessage(LANG_COMMAND_LIST_BIND_INFO, mapId, save->GetInstanceId(), bind.perm ? "yes" : "no", bind.extendState == EXTEND_STATE_EXPIRED ? "expired" : bind.extendState == EXTEND_STATE_EXTENDED ? "yes" : "no", save->GetDifficultyID(), save->CanReset() ? "yes" : "no", timeleft.c_str()); counter++; } } @@ -111,11 +95,11 @@ public: auto binds = group->GetBoundInstances(Difficulty(difficulty->ID)); if (binds != group->GetBoundInstanceEnd()) { - for (auto itr = binds->second.begin(); itr != binds->second.end(); ++itr) + for (auto const& [mapId, bind] : binds->second) { - InstanceSave* save = itr->second.save; - std::string timeleft = GetTimeString(save->GetResetTime() - GameTime::GetGameTime()); - handler->PSendSysMessage(LANG_COMMAND_LIST_BIND_INFO, itr->first, save->GetInstanceId(), itr->second.perm ? "yes" : "no", "-", save->GetDifficultyID(), save->CanReset() ? "yes" : "no", timeleft.c_str()); + InstanceSave* save = bind.save; + std::string timeleft = secsToTimeString(save->GetResetTime() - GameTime::GetGameTime(), TimeFormat::ShortText); + handler->PSendSysMessage(LANG_COMMAND_LIST_BIND_INFO, mapId, save->GetInstanceId(), bind.perm ? "yes" : "no", "-", save->GetDifficultyID(), save->CanReset() ? "yes" : "no", timeleft.c_str()); counter++; } } @@ -126,27 +110,19 @@ public: return true; } - static bool HandleInstanceUnbindCommand(ChatHandler* handler, char const* args) + static bool HandleInstanceUnbindCommand(ChatHandler* handler, Variant<uint32, EXACT_SEQUENCE("all")> mapArg, Optional<uint8> difficultyArg) { - if (!*args) - return false; - Player* player = handler->getSelectedPlayer(); if (!player) player = handler->GetSession()->GetPlayer(); - char* map = strtok((char*)args, " "); - char* pDiff = strtok(nullptr, " "); - int8 diff = -1; - if (pDiff) - diff = atoi(pDiff); uint16 counter = 0; - uint16 MapId = 0; + uint32 mapId = 0; - if (strcmp(map, "all") != 0) + if (mapArg.holds_alternative<uint32>()) { - MapId = uint16(atoi(map)); - if (!MapId) + mapId = mapArg.get<uint32>(); + if (!mapId) return false; } @@ -157,10 +133,10 @@ public: { for (auto itr = binds->second.begin(); itr != binds->second.end();) { - InstanceSave* save = itr->second.save; - if (itr->first != player->GetMapId() && (!MapId || MapId == itr->first) && (diff == -1 || diff == save->GetDifficultyID())) + InstanceSave const* save = itr->second.save; + if (itr->first != player->GetMapId() && (!mapId || mapId == itr->first) && (!difficultyArg || difficultyArg == save->GetDifficultyID())) { - std::string timeleft = GetTimeString(save->GetResetTime() - GameTime::GetGameTime()); + std::string timeleft = secsToTimeString(save->GetResetTime() - GameTime::GetGameTime(), TimeFormat::ShortText); handler->PSendSysMessage(LANG_COMMAND_INST_UNBIND_UNBINDING, itr->first, save->GetInstanceId(), itr->second.perm ? "yes" : "no", save->GetDifficultyID(), save->CanReset() ? "yes" : "no", timeleft.c_str()); player->UnbindInstance(itr, binds); counter++; @@ -175,7 +151,7 @@ public: return true; } - static bool HandleInstanceStatsCommand(ChatHandler* handler, char const* /*args*/) + static bool HandleInstanceStatsCommand(ChatHandler* handler) { handler->PSendSysMessage(LANG_COMMAND_INST_STAT_LOADED_INST, sMapMgr->GetNumInstances()); handler->PSendSysMessage(LANG_COMMAND_INST_STAT_PLAYERS_IN, sMapMgr->GetNumPlayersInInstances()); @@ -186,7 +162,7 @@ public: return true; } - static bool HandleInstanceSaveDataCommand(ChatHandler* handler, char const* /*args*/) + static bool HandleInstanceSaveDataCommand(ChatHandler* handler) { Player* player = handler->GetSession()->GetPlayer(); InstanceMap* map = player->GetMap()->ToInstanceMap(); @@ -209,44 +185,27 @@ public: return true; } - static bool HandleInstanceSetBossStateCommand(ChatHandler* handler, char const* args) + static bool HandleInstanceSetBossStateCommand(ChatHandler* handler, uint32 encounterId, EncounterState state, Optional<PlayerIdentifier> player) { - if (!*args) - return false; - - char* param1 = strtok((char*)args, " "); - char* param2 = strtok(nullptr, " "); - char* param3 = strtok(nullptr, " "); - uint32 encounterId = 0; - int32 state = 0; - Player* player = nullptr; - std::string playerName; - // Character name must be provided when using this from console. - if (!param2 || (!param3 && !handler->GetSession())) + if (!player && !handler->GetSession()) { handler->PSendSysMessage(LANG_CMD_SYNTAX); handler->SetSentErrorMessage(true); return false; } - if (!param3) - player = handler->GetSession()->GetPlayer(); - else - { - playerName = param3; - if (normalizePlayerName(playerName)) - player = ObjectAccessor::FindPlayerByName(playerName); - } - if (!player) + player = PlayerIdentifier::FromSelf(handler); + + if (!player->IsConnected()) { handler->PSendSysMessage(LANG_PLAYER_NOT_FOUND); handler->SetSentErrorMessage(true); return false; } - InstanceMap* map = player->GetMap()->ToInstanceMap(); + InstanceMap* map = player->GetConnectedPlayer()->GetMap()->ToInstanceMap(); if (!map) { handler->PSendSysMessage(LANG_NOT_DUNGEON); @@ -261,58 +220,40 @@ public: return false; } - encounterId = atoul(param1); - state = atoi(param2); - // Reject improper values. - if (state > TO_BE_DECIDED || encounterId > map->GetInstanceScript()->GetEncounterCount()) + if (encounterId > map->GetInstanceScript()->GetEncounterCount()) { handler->PSendSysMessage(LANG_BAD_VALUE); handler->SetSentErrorMessage(true); return false; } - map->GetInstanceScript()->SetBossState(encounterId, EncounterState(state)); - handler->PSendSysMessage(LANG_COMMAND_INST_SET_BOSS_STATE, encounterId, state, InstanceScript::GetBossStateName(state)); + map->GetInstanceScript()->SetBossState(encounterId, state); + handler->PSendSysMessage(LANG_COMMAND_INST_SET_BOSS_STATE, encounterId, state, EnumUtils::ToConstant(state)); return true; } - static bool HandleInstanceGetBossStateCommand(ChatHandler* handler, char const* args) + static bool HandleInstanceGetBossStateCommand(ChatHandler* handler, uint32 encounterId, Optional<PlayerIdentifier> player) { - if (!*args) - return false; - - char* param1 = strtok((char*)args, " "); - char* param2 = strtok(nullptr, " "); - uint32 encounterId = 0; - Player* player = nullptr; - std::string playerName; - // Character name must be provided when using this from console. - if (!param1 || (!param2 && !handler->GetSession())) + if (!player && !handler->GetSession()) { handler->PSendSysMessage(LANG_CMD_SYNTAX); handler->SetSentErrorMessage(true); return false; } - if (!param2) - player = handler->GetSession()->GetPlayer(); - else - { - playerName = param2; - if (normalizePlayerName(playerName)) - player = ObjectAccessor::FindPlayerByName(playerName); - } - if (!player) + player = PlayerIdentifier::FromSelf(handler); + + if (!player->IsConnected()) { handler->PSendSysMessage(LANG_PLAYER_NOT_FOUND); handler->SetSentErrorMessage(true); return false; } - InstanceMap* map = player->GetMap()->ToInstanceMap(); + InstanceMap* map = player->GetConnectedPlayer()->GetMap()->ToInstanceMap(); if (!map) { handler->PSendSysMessage(LANG_NOT_DUNGEON); @@ -327,8 +268,6 @@ public: return false; } - encounterId = atoul(param1); - if (encounterId > map->GetInstanceScript()->GetEncounterCount()) { handler->PSendSysMessage(LANG_BAD_VALUE); @@ -336,8 +275,8 @@ public: return false; } - int32 state = map->GetInstanceScript()->GetBossState(encounterId); - handler->PSendSysMessage(LANG_COMMAND_INST_GET_BOSS_STATE, encounterId, state, InstanceScript::GetBossStateName(state)); + EncounterState state = map->GetInstanceScript()->GetBossState(encounterId); + handler->PSendSysMessage(LANG_COMMAND_INST_GET_BOSS_STATE, encounterId, state, EnumUtils::ToConstant(state)); return true; } }; |