diff options
author | iThorgrim <125808072+iThorgrim@users.noreply.github.com> | 2025-02-17 03:26:05 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2025-02-17 03:26:05 +0100 |
commit | e28384b059f8b266ebea1da771df56f5ff36a277 (patch) | |
tree | 236857a295f34946a6950369a25698c6759534f3 /src | |
parent | 0c099a75ec709f30308b4b2a07c9befd450e9134 (diff) |
feat(Core/Scripting): Add new hooks for Ticket (#21238)
Diffstat (limited to 'src')
-rw-r--r-- | src/server/game/Handlers/TicketHandler.cpp | 2 | ||||
-rw-r--r-- | src/server/game/Scripting/ScriptDefines/AllScriptsObjects.h | 1 | ||||
-rw-r--r-- | src/server/game/Scripting/ScriptDefines/TicketScript.cpp | 58 | ||||
-rw-r--r-- | src/server/game/Scripting/ScriptDefines/TicketScript.h | 50 | ||||
-rw-r--r-- | src/server/game/Scripting/ScriptMgr.cpp | 5 | ||||
-rw-r--r-- | src/server/game/Scripting/ScriptMgr.h | 8 | ||||
-rw-r--r-- | src/server/game/Scripting/ScriptObjectFwd.h | 1 | ||||
-rw-r--r-- | src/server/game/Tickets/TicketMgr.cpp | 11 | ||||
-rw-r--r-- | src/server/game/Tickets/TicketMgr.h | 2 | ||||
-rw-r--r-- | src/server/scripts/Commands/cs_ticket.cpp | 18 |
10 files changed, 143 insertions, 13 deletions
diff --git a/src/server/game/Handlers/TicketHandler.cpp b/src/server/game/Handlers/TicketHandler.cpp index 6d53bf95b7..eb6243b215 100644 --- a/src/server/game/Handlers/TicketHandler.cpp +++ b/src/server/game/Handlers/TicketHandler.cpp @@ -116,7 +116,7 @@ void WorldSession::HandleGMTicketCreateOpcode(WorldPacket& recvData) ticket->SetChatLog(times, chatLog); sTicketMgr->AddTicket(ticket); - sTicketMgr->UpdateLastChange(); + sTicketMgr->UpdateLastChange(ticket); ChatHandler(nullptr).SendGMText(LANG_COMMAND_TICKETNEW, GetPlayer()->GetName(), ticket->GetId()); diff --git a/src/server/game/Scripting/ScriptDefines/AllScriptsObjects.h b/src/server/game/Scripting/ScriptDefines/AllScriptsObjects.h index aad81c0700..9196c32845 100644 --- a/src/server/game/Scripting/ScriptDefines/AllScriptsObjects.h +++ b/src/server/game/Scripting/ScriptDefines/AllScriptsObjects.h @@ -58,6 +58,7 @@ #include "PlayerScript.h" #include "ServerScript.h" #include "SpellScriptLoader.h" +#include "TicketScript.h" #include "TransportScript.h" #include "UnitScript.h" #include "VehicleScript.h" diff --git a/src/server/game/Scripting/ScriptDefines/TicketScript.cpp b/src/server/game/Scripting/ScriptDefines/TicketScript.cpp new file mode 100644 index 0000000000..a7e72076fd --- /dev/null +++ b/src/server/game/Scripting/ScriptDefines/TicketScript.cpp @@ -0,0 +1,58 @@ +/* + * This file is part of the AzerothCore Project. See AUTHORS file for Copyright information + * + * This program is free software; you can redistribute it and/or modify it + * under the terms of the GNU Affero General Public License as published by the + * Free Software Foundation; either version 3 of the License, or (at your + * option) any later version. + * + * This program is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for + * more details. + * + * You should have received a copy of the GNU General Public License along + * with this program. If not, see <http://www.gnu.org/licenses/>. + */ + +#include "TicketScript.h" +#include "ScriptMgr.h" +#include "ScriptMgrMacros.h" + +void ScriptMgr::OnTicketCreate(GmTicket* ticket) +{ + CALL_ENABLED_HOOKS(TicketScript, TICKETHOOK_ON_TICKET_CREATE, script->OnTicketCreate(ticket)); +} + +void ScriptMgr::OnTicketUpdateLastChange(GmTicket* ticket) +{ + CALL_ENABLED_HOOKS(TicketScript, TICKETHOOK_ON_TICKET_UPDATE_LAST_CHANGE, script->OnTicketUpdateLastChange(ticket)); +} + +void ScriptMgr::OnTicketClose(GmTicket* ticket) +{ + CALL_ENABLED_HOOKS(TicketScript, TICKETHOOK_ON_TICKET_CLOSE, script->OnTicketClose(ticket)); +} + +void ScriptMgr::OnTicketStatusUpdate(GmTicket* ticket) +{ + CALL_ENABLED_HOOKS(TicketScript, TICKETHOOK_ON_TICKET_STATUS_UPDATE, script->OnTicketStatusUpdate(ticket)); +} + +void ScriptMgr::OnTicketResolve(GmTicket* ticket) +{ + CALL_ENABLED_HOOKS(TicketScript, TICKETHOOK_ON_TICKET_RESOLVE, script->OnTicketResolve(ticket)); +} + +TicketScript::TicketScript(char const* name, std::vector<uint16> enabledHooks) +: ScriptObject(name, TICKETHOOK_END) +{ + // If empty - enable all available hooks. + if (enabledHooks.empty()) + for (uint16 i = 0; i < TICKETHOOK_END; ++i) + enabledHooks.emplace_back(i); + + ScriptRegistry<TicketScript>::AddScript(this, std::move(enabledHooks)); +} + +template class AC_GAME_API ScriptRegistry<TicketScript>; diff --git a/src/server/game/Scripting/ScriptDefines/TicketScript.h b/src/server/game/Scripting/ScriptDefines/TicketScript.h new file mode 100644 index 0000000000..43bf616aed --- /dev/null +++ b/src/server/game/Scripting/ScriptDefines/TicketScript.h @@ -0,0 +1,50 @@ +/* + * This file is part of the AzerothCore Project. See AUTHORS file for Copyright information + * + * This program is free software; you can redistribute it and/or modify it + * under the terms of the GNU Affero General Public License as published by the + * Free Software Foundation; either version 3 of the License, or (at your + * option) any later version. + * + * This program is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for + * more details. + * + * You should have received a copy of the GNU General Public License along + * with this program. If not, see <http://www.gnu.org/licenses/>. + */ + +#ifndef SCRIPT_OBJECT_TICKET_SCRIPT_H_ +#define SCRIPT_OBJECT_TICKET_SCRIPT_H_ + +#include "ScriptObject.h" +#include "TicketMgr.h" +#include <vector> + +enum TicketHook +{ + TICKETHOOK_ON_TICKET_CREATE, + TICKETHOOK_ON_TICKET_UPDATE_LAST_CHANGE, + TICKETHOOK_ON_TICKET_CLOSE, + TICKETHOOK_ON_TICKET_STATUS_UPDATE, + TICKETHOOK_ON_TICKET_RESOLVE, + TICKETHOOK_END +}; + +class TicketScript : public ScriptObject +{ +protected: + TicketScript(char const* name, std::vector<uint16> enabledHooks = std::vector<uint16>()); + +public: + [[nodiscard]] bool IsDatabaseBound() const override { return false; } + + virtual void OnTicketCreate(GmTicket* /*ticket*/) { } + virtual void OnTicketUpdateLastChange(GmTicket* /*ticket*/) { } + virtual void OnTicketClose(GmTicket* /*ticket*/) { } + virtual void OnTicketStatusUpdate(GmTicket* /*ticket*/) { } + virtual void OnTicketResolve(GmTicket* /*ticket*/) { } +}; + +#endif diff --git a/src/server/game/Scripting/ScriptMgr.cpp b/src/server/game/Scripting/ScriptMgr.cpp index 83af4d8512..3a78145cab 100644 --- a/src/server/game/Scripting/ScriptMgr.cpp +++ b/src/server/game/Scripting/ScriptMgr.cpp @@ -98,6 +98,7 @@ void ScriptMgr::Initialize() ScriptRegistry<PlayerScript>::InitEnabledHooksIfNeeded(PLAYERHOOK_END); ScriptRegistry<ServerScript>::InitEnabledHooksIfNeeded(SERVERHOOK_END); ScriptRegistry<SpellSC>::InitEnabledHooksIfNeeded(ALLSPELLHOOK_END); + ScriptRegistry<TicketScript>::InitEnabledHooksIfNeeded(TICKETHOOK_END); ScriptRegistry<UnitScript>::InitEnabledHooksIfNeeded(UNITHOOK_END); ScriptRegistry<WorldObjectScript>::InitEnabledHooksIfNeeded(WORLDOBJECTHOOK_END); ScriptRegistry<WorldScript>::InitEnabledHooksIfNeeded(WORLDHOOK_END); @@ -145,6 +146,7 @@ void ScriptMgr::Unload() SCR_CLEAR<ServerScript>(); SCR_CLEAR<SpellSC>(); SCR_CLEAR<SpellScriptLoader>(); + SCR_CLEAR<TicketScript>(); SCR_CLEAR<TransportScript>(); SCR_CLEAR<UnitScript>(); SCR_CLEAR<VehicleScript>(); @@ -224,7 +226,8 @@ void ScriptMgr::CheckIfScriptsInDatabaseExist() !ScriptRegistry<CommandSC>::GetScriptById(sid) && !ScriptRegistry<ArenaScript>::GetScriptById(sid) && !ScriptRegistry<GroupScript>::GetScriptById(sid) && - !ScriptRegistry<DatabaseScript>::GetScriptById(sid)) + !ScriptRegistry<DatabaseScript>::GetScriptById(sid) && + !ScriptRegistry<TicketScript>::GetScriptById(sid)) { LOG_ERROR("sql.sql", "Script named '{}' is assigned in the database, but has no code!", scriptName); } diff --git a/src/server/game/Scripting/ScriptMgr.h b/src/server/game/Scripting/ScriptMgr.h index a0db4d2ea7..0d7091e48d 100644 --- a/src/server/game/Scripting/ScriptMgr.h +++ b/src/server/game/Scripting/ScriptMgr.h @@ -704,6 +704,14 @@ public: /* LootScript */ void OnLootMoney(Player* player, uint32 gold); +public: /* TicketScript */ + + void OnTicketCreate(GmTicket* ticket); + void OnTicketUpdateLastChange(GmTicket* ticket); + void OnTicketClose(GmTicket* ticket); + void OnTicketStatusUpdate(GmTicket* ticket); + void OnTicketResolve(GmTicket* ticket); + private: uint32 _scriptCount; diff --git a/src/server/game/Scripting/ScriptObjectFwd.h b/src/server/game/Scripting/ScriptObjectFwd.h index 35f425eae5..03494cbb81 100644 --- a/src/server/game/Scripting/ScriptObjectFwd.h +++ b/src/server/game/Scripting/ScriptObjectFwd.h @@ -67,6 +67,7 @@ class SpellCastTargets; class SpellInfo; class SpellScript; class TempSummon; +class TicketMgr; class Transport; class Unit; class Vehicle; diff --git a/src/server/game/Tickets/TicketMgr.cpp b/src/server/game/Tickets/TicketMgr.cpp index e4d2d94df3..f339be0e1e 100644 --- a/src/server/game/Tickets/TicketMgr.cpp +++ b/src/server/game/Tickets/TicketMgr.cpp @@ -25,6 +25,7 @@ #include "Log.h" #include "Opcodes.h" #include "Player.h" +#include "ScriptMgr.h" #include "World.h" #include "WorldPacket.h" #include "WorldSession.h" @@ -364,6 +365,8 @@ void TicketMgr::AddTicket(GmTicket* ticket) ++_openTicketCount; CharacterDatabaseTransaction trans = CharacterDatabaseTransaction(nullptr); ticket->SaveToDB(trans); + + sScriptMgr->OnTicketCreate(ticket); } void TicketMgr::CloseTicket(uint32 ticketId, ObjectGuid source) @@ -375,6 +378,8 @@ void TicketMgr::CloseTicket(uint32 ticketId, ObjectGuid source) if (source) --_openTicketCount; ticket->SaveToDB(trans); + + sScriptMgr->OnTicketClose(ticket); } } @@ -398,6 +403,8 @@ void TicketMgr::ResolveAndCloseTicket(uint32 ticketId, ObjectGuid source) if (source) --_openTicketCount; ticket->SaveToDB(trans); + + sScriptMgr->OnTicketResolve(ticket); } } @@ -438,7 +445,9 @@ void TicketMgr::SendTicket(WorldSession* session, GmTicket* ticket) const session->SendPacket(&data); } -void TicketMgr::UpdateLastChange() +void TicketMgr::UpdateLastChange(GmTicket* ticket) { _lastChange = GameTime::GetGameTime().count(); + + sScriptMgr->OnTicketUpdateLastChange(ticket); } diff --git a/src/server/game/Tickets/TicketMgr.h b/src/server/game/Tickets/TicketMgr.h index aa2369bd78..d345567166 100644 --- a/src/server/game/Tickets/TicketMgr.h +++ b/src/server/game/Tickets/TicketMgr.h @@ -230,7 +230,7 @@ public: void SetStatus(bool status) { _status = status; } uint64 GetLastChange() const { return _lastChange; } - void UpdateLastChange(); + void UpdateLastChange(GmTicket* ticket); uint32 GenerateTicketId() { return ++_lastTicketId; } uint32 GetOpenTicketCount() const { return _openTicketCount; } diff --git a/src/server/scripts/Commands/cs_ticket.cpp b/src/server/scripts/Commands/cs_ticket.cpp index bef6f6f13a..166b0fa446 100644 --- a/src/server/scripts/Commands/cs_ticket.cpp +++ b/src/server/scripts/Commands/cs_ticket.cpp @@ -117,7 +117,7 @@ public: CharacterDatabaseTransaction trans = CharacterDatabaseTransaction(nullptr); ticket->SetAssignedTo(targetGuid, AccountMgr::IsAdminAccount(targetGmLevel)); ticket->SaveToDB(trans); - sTicketMgr->UpdateLastChange(); + sTicketMgr->UpdateLastChange(ticket); std::string msg = ticket->FormatMessageString(*handler, nullptr, target.c_str(), nullptr, nullptr); handler->SendGlobalGMSysMessage(msg.c_str()); @@ -143,7 +143,7 @@ public: } sTicketMgr->ResolveAndCloseTicket(ticket->GetId(), player ? player->GetGUID() : ObjectGuid::Empty); - sTicketMgr->UpdateLastChange(); + sTicketMgr->UpdateLastChange(ticket); std::string msg = ticket->FormatMessageString(*handler, player ? player->GetName().c_str() : "Console", nullptr, nullptr, nullptr); handler->SendGlobalGMSysMessage(msg.c_str()); @@ -182,7 +182,7 @@ public: CharacterDatabaseTransaction trans = CharacterDatabaseTransaction(nullptr); ticket->SetComment(comment.data()); ticket->SaveToDB(trans); - sTicketMgr->UpdateLastChange(); + sTicketMgr->UpdateLastChange(ticket); std::string const assignedName = ticket->GetAssignedToName(); std::string msg = ticket->FormatMessageString(*handler, assignedName.empty() ? nullptr : assignedName.c_str(), nullptr, nullptr, nullptr); @@ -237,7 +237,7 @@ public: std::string msg = ticket->FormatMessageString(*handler, nullptr, nullptr, nullptr, nullptr); msg += handler->PGetParseString(LANG_COMMAND_TICKETCOMPLETED, gm ? gm->GetName().c_str() : "Console"); handler->SendGlobalGMSysMessage(msg.c_str()); - sTicketMgr->UpdateLastChange(); + sTicketMgr->UpdateLastChange(ticket); return true; } @@ -260,7 +260,7 @@ public: handler->SendGlobalGMSysMessage(msg.c_str()); sTicketMgr->RemoveTicket(ticket->GetId()); - sTicketMgr->UpdateLastChange(); + sTicketMgr->UpdateLastChange(ticket); if (Player* player = ticket->GetPlayer()) { @@ -287,7 +287,7 @@ public: if (Player* player = ticket->GetPlayer()) sTicketMgr->SendTicket(player->GetSession(), ticket); - sTicketMgr->UpdateLastChange(); + sTicketMgr->UpdateLastChange(ticket); return true; } @@ -373,7 +373,7 @@ public: CharacterDatabaseTransaction trans = CharacterDatabaseTransaction(nullptr); ticket->SetUnassigned(); ticket->SaveToDB(trans); - sTicketMgr->UpdateLastChange(); + sTicketMgr->UpdateLastChange(ticket); std::string msg = ticket->FormatMessageString(*handler, nullptr, assignedTo.c_str(), handler->GetSession() ? handler->GetSession()->GetPlayer()->GetName().c_str() : "Console", nullptr); @@ -464,7 +464,7 @@ public: ticket->AppendResponse("\n"); ticket->AppendResponse(response); ticket->SaveToDB(trans); - sTicketMgr->UpdateLastChange(); + sTicketMgr->UpdateLastChange(ticket); std::string msg = ticket->FormatMessageString(*handler, nullptr, nullptr, nullptr, nullptr); msg += handler->PGetParseString(LANG_COMMAND_TICKETRESPONSEAPPENDED, response); @@ -505,7 +505,7 @@ public: CharacterDatabaseTransaction trans = CharacterDatabaseTransaction(nullptr); ticket->DeleteResponse(); ticket->SaveToDB(trans); - sTicketMgr->UpdateLastChange(); + sTicketMgr->UpdateLastChange(ticket); std::string msg = ticket->FormatMessageString(*handler, nullptr, nullptr, nullptr, nullptr); msg += handler->PGetParseString(LANG_COMMAND_TICKETRESPONSEDELETED, player ? player->GetName() : "Console"); |