diff options
author | Shauren <shauren.trinity@gmail.com> | 2021-08-05 19:37:53 +0200 |
---|---|---|
committer | Shauren <shauren.trinity@gmail.com> | 2021-08-08 00:18:05 +0200 |
commit | cd5357dc185f95c6ef78089c5ab8bd2b885dd89f (patch) | |
tree | 0937cc060467205336311a3ba3bd04f5d334c34b /src/server/game/Chat/ChatLink.cpp | |
parent | 07f51437fc9ddba2810c090caa76ab294bcf777b (diff) |
Core/PacketIO: 9.1.0 opcodes and packet structures
Diffstat (limited to 'src/server/game/Chat/ChatLink.cpp')
-rw-r--r-- | src/server/game/Chat/ChatLink.cpp | 26 |
1 files changed, 25 insertions, 1 deletions
diff --git a/src/server/game/Chat/ChatLink.cpp b/src/server/game/Chat/ChatLink.cpp index d1cf52203a4..1641e216a95 100644 --- a/src/server/game/Chat/ChatLink.cpp +++ b/src/server/game/Chat/ChatLink.cpp @@ -106,7 +106,7 @@ bool ChatLink::ValidateName(char* buffer, char const* /*context*/) return true; } -// |color|Hitem:item_id:perm_ench_id:gem1:gem2:gem3:0:random_property:property_seed:reporter_level:reporter_spec:modifiers_mask:context:numBonusListIDs:bonusListIDs(%d):numModifiers:(modifierType(%d):modifierValue(%d)):gem1numBonusListIDs:gem1bonusListIDs(%d):gem2numBonusListIDs:gem2bonusListIDs(%d):gem3numBonusListIDs:gem3bonusListIDs(%d)|h[name]|h|r +// |color|Hitem:item_id:perm_ench_id:gem1:gem2:gem3:0:random_property:property_seed:reporter_level:reporter_spec:modifiers_mask:context:numBonusListIDs:bonusListIDs(%d):numModifiers:(modifierType(%d):modifierValue(%d)):gem1numBonusListIDs:gem1bonusListIDs(%d):gem2numBonusListIDs:gem2bonusListIDs(%d):gem3numBonusListIDs:gem3bonusListIDs(%d):creator:use_enchant_id|h[name]|h|r // |cffa335ee|Hitem:124382:0:0:0:0:0:0:0:0:0:0:0:4:42:562:565:567|h[Edict of Argus]|h|r"); bool ItemChatLink::Initialize(std::istringstream& iss) { @@ -365,6 +365,30 @@ bool ItemChatLink::Initialize(std::istringstream& iss) } } + if (!CheckDelimiter(iss, DELIMITER, "item")) + return false; + + // guid as string + if (HasValue(iss)) + { + std::array<char, 128> guidBuffer = { }; + if (!iss.getline(guidBuffer.data(), 128, DELIMITER)) + { + TC_LOG_TRACE("chat.system", "ChatHandler::isValidChatMessage('%s'): sequence finished unexpectedly while reading creator guid string", iss.str().c_str()); + return false; + } + iss.unget(); // put next : back into stream + } + + if (!CheckDelimiter(iss, DELIMITER, "item")) + return false; + + if (HasValue(iss) && !ReadInt32(iss, _useEnchantId)) + { + TC_LOG_TRACE("chat.system", "ChatHandler::isValidChatMessage('%s'): sequence finished unexpectedly while reading on use enchatment id", iss.str().c_str()); + return false; + } + return true; } |