aboutsummaryrefslogtreecommitdiff
path: root/src/server/game/Handlers/ChatHandler.cpp
diff options
context:
space:
mode:
authorIntel <chemicstry@gmail.com>2014-11-17 20:41:16 +0200
committerIntel <chemicstry@gmail.com>2014-11-17 20:49:15 +0200
commitdbb102e6470dd51dbd277f4be9a3d20b977d7afe (patch)
tree48974dfcb012d64477bc0f97a1b41c2b95d2dfd1 /src/server/game/Handlers/ChatHandler.cpp
parentda37723b5f6739eb536b3c32676177b3b821c39d (diff)
Core/Packets: Added most of the chat packets
Diffstat (limited to 'src/server/game/Handlers/ChatHandler.cpp')
-rw-r--r--src/server/game/Handlers/ChatHandler.cpp704
1 files changed, 144 insertions, 560 deletions
diff --git a/src/server/game/Handlers/ChatHandler.cpp b/src/server/game/Handlers/ChatHandler.cpp
index ce1f0f8ea2d..c877a2a19b5 100644
--- a/src/server/game/Handlers/ChatHandler.cpp
+++ b/src/server/game/Handlers/ChatHandler.cpp
@@ -41,11 +41,9 @@
#include "AccountMgr.h"
#include "ChatPackets.h"
-void WorldSession::HandleMessagechatOpcode(WorldPackets::Chat::ChatMessage& packet)
+void WorldSession::HandleChatMessageOpcode(WorldPackets::Chat::ChatMessage& packet)
{
- uint32 type = 0;
- uint32 lang = packet.Language;
- std::string msg = packet.Text;
+ ChatMsg type;
switch (packet.GetOpcode())
{
@@ -75,9 +73,29 @@ void WorldSession::HandleMessagechatOpcode(WorldPackets::Chat::ChatMessage& pack
return;
}
+ HandleChatMessage(type, packet.Language, packet.Text);
+}
+
+void WorldSession::HandleChatMessageWhisperOpcode(WorldPackets::Chat::ChatMessageWhisper& packet)
+{
+ HandleChatMessage(CHAT_MSG_WHISPER, packet.Language, packet.Text, packet.Target);
+}
+
+void WorldSession::HandleChatMessageChannelOpcode(WorldPackets::Chat::ChatMessageChannel& packet)
+{
+ HandleChatMessage(CHAT_MSG_CHANNEL, packet.Language, packet.Text, packet.Target);
+}
+
+void WorldSession::HandleChatMessageEmoteOpcode(WorldPackets::Chat::ChatMessageEmote& packet)
+{
+ HandleChatMessage(CHAT_MSG_EMOTE, LANG_UNIVERSAL, packet.Text);
+}
+
+void WorldSession::HandleChatMessage(ChatMsg type, uint32 lang, std::string msg, std::string target /*= ""*/)
+{
Player* sender = GetPlayer();
- if (packet.Language == LANG_UNIVERSAL)
+ if (lang == LANG_UNIVERSAL && type != CHAT_MSG_EMOTE)
{
TC_LOG_ERROR("network", "CMSG_MESSAGECHAT: Possible hacking-attempt: %s tried to send a message in universal language", GetPlayerInfo().c_str());
SendNotification(LANG_UNKNOWN_LANGUAGE);
@@ -153,7 +171,7 @@ void WorldSession::HandleMessagechatOpcode(WorldPackets::Chat::ChatMessage& pack
return;
}
- if (sender->HasAura(1852) && type != CHAT_MSG_WHISPER)
+ if (sender->HasAura(GM_SILENCE_AURA) && type != CHAT_MSG_WHISPER)
{
SendNotification(GetTrinityString(LANG_GM_SILENCE), sender->GetName().c_str());
return;
@@ -183,373 +201,6 @@ void WorldSession::HandleMessagechatOpcode(WorldPackets::Chat::ChatMessage& pack
switch (type)
{
case CHAT_MSG_SAY:
- case CHAT_MSG_YELL:
- {
- // Prevent cheating
- if (!sender->IsAlive())
- return;
-
- if (sender->getLevel() < sWorld->getIntConfig(CONFIG_CHAT_SAY_LEVEL_REQ))
- {
- SendNotification(GetTrinityString(LANG_SAY_REQ), sWorld->getIntConfig(CONFIG_CHAT_SAY_LEVEL_REQ));
- return;
- }
-
- if (type == CHAT_MSG_SAY)
- sender->Say(msg, Language(lang));
- else if (type == CHAT_MSG_EMOTE)
- sender->TextEmote(msg);
- else if (type == CHAT_MSG_YELL)
- sender->Yell(msg, Language(lang));
- break;
- }
- case CHAT_MSG_PARTY:
- {
- // if player is in battleground, he cannot say to battleground members by /p
- Group* group = GetPlayer()->GetOriginalGroup();
- if (!group)
- {
- group = sender->GetGroup();
- if (!group || group->isBGGroup())
- return;
- }
-
- if (group->IsLeader(GetPlayer()->GetGUID()))
- type = CHAT_MSG_PARTY_LEADER;
-
- sScriptMgr->OnPlayerChat(GetPlayer(), type, lang, msg, group);
-
- WorldPackets::Chat::Chat packet;
- ChatHandler::BuildChatPacket(&packet, ChatMsg(type), Language(lang), sender, NULL, msg);
- group->BroadcastPacket(packet.Write(), false, group->GetMemberGroup(GetPlayer()->GetGUID()));
- break;
- }
- case CHAT_MSG_GUILD:
- {
- if (GetPlayer()->GetGuildId())
- {
- if (Guild* guild = sGuildMgr->GetGuildById(GetPlayer()->GetGuildId()))
- {
- sScriptMgr->OnPlayerChat(GetPlayer(), type, lang, msg, guild);
-
- guild->BroadcastToGuild(this, false, msg, lang == LANG_ADDON ? LANG_ADDON : LANG_UNIVERSAL);
- }
- }
- break;
- }
- case CHAT_MSG_OFFICER:
- {
- if (GetPlayer()->GetGuildId())
- {
- if (Guild* guild = sGuildMgr->GetGuildById(GetPlayer()->GetGuildId()))
- {
- sScriptMgr->OnPlayerChat(GetPlayer(), type, lang, msg, guild);
-
- guild->BroadcastToGuild(this, true, msg, lang == LANG_ADDON ? LANG_ADDON : LANG_UNIVERSAL);
- }
- }
- break;
- }
- case CHAT_MSG_RAID:
- {
- // if player is in battleground, he cannot say to battleground members by /ra
- Group* group = GetPlayer()->GetOriginalGroup();
- if (!group)
- {
- group = GetPlayer()->GetGroup();
- if (!group || group->isBGGroup() || !group->isRaidGroup())
- return;
- }
-
- if (group->IsLeader(GetPlayer()->GetGUID()))
- type = CHAT_MSG_RAID_LEADER;
-
- sScriptMgr->OnPlayerChat(GetPlayer(), type, lang, msg, group);
-
- WorldPackets::Chat::Chat packet;
- ChatHandler::BuildChatPacket(&packet, ChatMsg(type), Language(lang), sender, NULL, msg);
- group->BroadcastPacket(packet.Write(), false);
- break;
- }
- case CHAT_MSG_RAID_WARNING:
- {
- Group* group = GetPlayer()->GetGroup();
- if (!group || !group->isRaidGroup() || !(group->IsLeader(GetPlayer()->GetGUID()) || group->IsAssistant(GetPlayer()->GetGUID())) || group->isBGGroup())
- return;
-
- sScriptMgr->OnPlayerChat(GetPlayer(), type, lang, msg, group);
-
- WorldPackets::Chat::Chat packet;
- //in battleground, raid warning is sent only to players in battleground - code is ok
- ChatHandler::BuildChatPacket(&packet, CHAT_MSG_RAID_WARNING, Language(lang), sender, NULL, msg);
- group->BroadcastPacket(packet.Write(), false);
- break;
- }
- default:
- TC_LOG_ERROR("network", "CHAT: unknown message type %u, lang: %u", type, lang);
- break;
- }
-}
-
-
-/** Left in here until all chat messages are moved to new packets
-void WorldSession::HandleMessagechatOpcode(WorldPacket& recvData)
-{
- uint32 type = 0;
- uint32 lang;
-
- switch (recvData.GetOpcode())
- {
- case CMSG_MESSAGECHAT_SAY:
- type = CHAT_MSG_SAY;
- break;
- case CMSG_MESSAGECHAT_YELL:
- type = CHAT_MSG_YELL;
- break;
- case CMSG_MESSAGECHAT_CHANNEL:
- type = CHAT_MSG_CHANNEL;
- break;
- case CMSG_MESSAGECHAT_WHISPER:
- type = CHAT_MSG_WHISPER;
- break;
- case CMSG_MESSAGECHAT_GUILD:
- type = CHAT_MSG_GUILD;
- break;
- case CMSG_MESSAGECHAT_OFFICER:
- type = CHAT_MSG_OFFICER;
- break;
- case CMSG_MESSAGECHAT_AFK:
- type = CHAT_MSG_AFK;
- break;
- case CMSG_MESSAGECHAT_DND:
- type = CHAT_MSG_DND;
- break;
- case CMSG_MESSAGECHAT_EMOTE:
- type = CHAT_MSG_EMOTE;
- break;
- case CMSG_MESSAGECHAT_PARTY:
- type = CHAT_MSG_PARTY;
- break;
- case CMSG_MESSAGECHAT_RAID:
- type = CHAT_MSG_RAID;
- break;
- case CMSG_MESSAGECHAT_BATTLEGROUND:
- type = CHAT_MSG_BATTLEGROUND;
- break;
- case CMSG_MESSAGECHAT_RAID_WARNING:
- type = CHAT_MSG_RAID_WARNING;
- break;
- default:
- TC_LOG_ERROR("network", "HandleMessagechatOpcode : Unknown chat opcode (%u)", recvData.GetOpcode());
- recvData.hexlike();
- return;
- }
-
- if (type >= MAX_CHAT_MSG_TYPE)
- {
- TC_LOG_ERROR("network", "CHAT: Wrong message type received: %u", type);
- recvData.rfinish();
- return;
- }
-
- Player* sender = GetPlayer();
-
- //TC_LOG_DEBUG("misc", "CHAT: packet received. type %u, lang %u", type, lang);
-
- // no language sent with emote packet.
- if (type != CHAT_MSG_EMOTE && type != CHAT_MSG_AFK && type != CHAT_MSG_DND)
- {
- recvData >> lang;
-
- if (lang == LANG_UNIVERSAL)
- {
- TC_LOG_ERROR("network", "CMSG_MESSAGECHAT: Possible hacking-attempt: %s tried to send a message in universal language", GetPlayerInfo().c_str());
- SendNotification(LANG_UNKNOWN_LANGUAGE);
- recvData.rfinish();
- return;
- }
-
- // prevent talking at unknown language (cheating)
- LanguageDesc const* langDesc = GetLanguageDescByID(lang);
- if (!langDesc)
- {
- SendNotification(LANG_UNKNOWN_LANGUAGE);
- recvData.rfinish();
- return;
- }
-
- if (langDesc->skill_id != 0 && !sender->HasSkill(langDesc->skill_id))
- {
- // also check SPELL_AURA_COMPREHEND_LANGUAGE (client offers option to speak in that language)
- Unit::AuraEffectList const& langAuras = sender->GetAuraEffectsByType(SPELL_AURA_COMPREHEND_LANGUAGE);
- bool foundAura = false;
- for (Unit::AuraEffectList::const_iterator i = langAuras.begin(); i != langAuras.end(); ++i)
- {
- if ((*i)->GetMiscValue() == int32(lang))
- {
- foundAura = true;
- break;
- }
- }
- if (!foundAura)
- {
- SendNotification(LANG_NOT_LEARNED_LANGUAGE);
- recvData.rfinish();
- return;
- }
- }
-
- if (lang == LANG_ADDON)
- {
- // LANG_ADDON is only valid for the following message types
- switch (type)
- {
- case CHAT_MSG_PARTY:
- case CHAT_MSG_RAID:
- case CHAT_MSG_GUILD:
- case CHAT_MSG_BATTLEGROUND:
- case CHAT_MSG_WHISPER:
- // check if addon messages are disabled
- if (!sWorld->getBoolConfig(CONFIG_ADDON_CHANNEL))
- {
- recvData.rfinish();
- return;
- }
- break;
- default:
- TC_LOG_ERROR("network", "Player %s (%s) sent a chatmessage with an invalid language/message type combination",
- GetPlayer()->GetName().c_str(), GetPlayer()->GetGUID().ToString().c_str());
-
- recvData.rfinish();
- return;
- }
- }
- // LANG_ADDON should not be changed nor be affected by flood control
- else
- {
- // send in universal language if player in .gm on mode (ignore spell effects)
- if (sender->IsGameMaster())
- lang = LANG_UNIVERSAL;
- else
- {
- // send in universal language in two side iteration allowed mode
- if (HasPermission(rbac::RBAC_PERM_TWO_SIDE_INTERACTION_CHAT))
- lang = LANG_UNIVERSAL;
- else
- {
- switch (type)
- {
- case CHAT_MSG_PARTY:
- case CHAT_MSG_PARTY_LEADER:
- case CHAT_MSG_RAID:
- case CHAT_MSG_RAID_LEADER:
- case CHAT_MSG_RAID_WARNING:
- // allow two side chat at group channel if two side group allowed
- if (sWorld->getBoolConfig(CONFIG_ALLOW_TWO_SIDE_INTERACTION_GROUP))
- lang = LANG_UNIVERSAL;
- break;
- case CHAT_MSG_GUILD:
- case CHAT_MSG_OFFICER:
- // allow two side chat at guild channel if two side guild allowed
- if (sWorld->getBoolConfig(CONFIG_ALLOW_TWO_SIDE_INTERACTION_GUILD))
- lang = LANG_UNIVERSAL;
- break;
- }
- }
-
- // but overwrite it by SPELL_AURA_MOD_LANGUAGE auras (only single case used)
- Unit::AuraEffectList const& ModLangAuras = sender->GetAuraEffectsByType(SPELL_AURA_MOD_LANGUAGE);
- if (!ModLangAuras.empty())
- lang = ModLangAuras.front()->GetMiscValue();
- }
-
- if (!sender->CanSpeak())
- {
- std::string timeStr = secsToTimeString(m_muteTime - time(NULL));
- SendNotification(GetTrinityString(LANG_WAIT_BEFORE_SPEAKING), timeStr.c_str());
- recvData.rfinish(); // Prevent warnings
- return;
- }
- }
- }
- else
- lang = LANG_UNIVERSAL;
-
- if (sender->HasAura(1852) && type != CHAT_MSG_WHISPER)
- {
- SendNotification(GetTrinityString(LANG_GM_SILENCE), sender->GetName().c_str());
- recvData.rfinish();
- return;
- }
-
- uint32 textLength = 0;
- uint32 receiverLength = 0;
- std::string to, channel, msg;
- bool ignoreChecks = false;
- switch (type)
- {
- case CHAT_MSG_SAY:
- case CHAT_MSG_EMOTE:
- case CHAT_MSG_YELL:
- case CHAT_MSG_PARTY:
- case CHAT_MSG_GUILD:
- case CHAT_MSG_OFFICER:
- case CHAT_MSG_RAID:
- case CHAT_MSG_RAID_WARNING:
- case CHAT_MSG_BATTLEGROUND:
- textLength = recvData.ReadBits(9);
- msg = recvData.ReadString(textLength);
- break;
- case CHAT_MSG_WHISPER:
- receiverLength = recvData.ReadBits(10);
- textLength = recvData.ReadBits(9);
- to = recvData.ReadString(receiverLength);
- msg = recvData.ReadString(textLength);
- break;
- case CHAT_MSG_CHANNEL:
- receiverLength = recvData.ReadBits(10);
- textLength = recvData.ReadBits(9);
- msg = recvData.ReadString(textLength);
- channel = recvData.ReadString(receiverLength);
- break;
- case CHAT_MSG_AFK:
- case CHAT_MSG_DND:
- textLength = recvData.ReadBits(9);
- msg = recvData.ReadString(textLength);
- ignoreChecks = true;
- break;
- }
-
- if (!ignoreChecks)
- {
- if (msg.empty())
- return;
-
- if (ChatHandler(this).ParseCommands(msg.c_str()))
- return;
-
- if (lang != LANG_ADDON)
- {
- // Strip invisible characters for non-addon messages
- if (sWorld->getBoolConfig(CONFIG_CHAT_FAKE_MESSAGE_PREVENTING))
- stripLineInvisibleChars(msg);
-
- if (sWorld->getIntConfig(CONFIG_CHAT_STRICT_LINK_CHECKING_SEVERITY) && !ChatHandler(this).isValidChatMessage(msg.c_str()))
- {
- TC_LOG_ERROR("network", "Player %s (%s) sent a chatmessage with an invalid link: %s", GetPlayer()->GetName().c_str(),
- GetPlayer()->GetGUID().ToString().c_str(), msg.c_str());
-
- if (sWorld->getIntConfig(CONFIG_CHAT_STRICT_LINK_CHECKING_KICK))
- KickPlayer();
-
- return;
- }
- }
- }
-
- switch (type)
- {
- case CHAT_MSG_SAY:
case CHAT_MSG_EMOTE:
case CHAT_MSG_YELL:
{
@@ -573,16 +224,19 @@ void WorldSession::HandleMessagechatOpcode(WorldPacket& recvData)
}
case CHAT_MSG_WHISPER:
{
- if (!normalizePlayerName(to))
+ /// @todo implement cross realm whispers (someday)
+ ExtendedPlayerName extName = ExtractExtendedPlayerName(target);
+
+ if (!normalizePlayerName(extName.Name))
{
- SendPlayerNotFoundNotice(to);
+ SendPlayerNotFoundNotice(target);
break;
}
- Player* receiver = ObjectAccessor::FindConnectedPlayerByName(to);
+ Player* receiver = ObjectAccessor::FindConnectedPlayerByName(extName.Name);
if (!receiver || (lang != LANG_ADDON && !receiver->isAcceptWhispers() && receiver->GetSession()->HasPermission(rbac::RBAC_PERM_CAN_FILTER_WHISPERS) && !receiver->IsInWhisperWhiteList(sender->GetGUID())))
{
- SendPlayerNotFoundNotice(to);
+ SendPlayerNotFoundNotice(target);
return;
}
if (!sender->IsGameMaster() && sender->getLevel() < sWorld->getIntConfig(CONFIG_CHAT_WHISPER_LEVEL_REQ) && !receiver->IsInWhisperWhiteList(sender->GetGUID()))
@@ -613,7 +267,6 @@ void WorldSession::HandleMessagechatOpcode(WorldPacket& recvData)
break;
}
case CHAT_MSG_PARTY:
- case CHAT_MSG_PARTY_LEADER:
{
// if player is in battleground, he cannot say to battleground members by /p
Group* group = GetPlayer()->GetOriginalGroup();
@@ -629,9 +282,9 @@ void WorldSession::HandleMessagechatOpcode(WorldPacket& recvData)
sScriptMgr->OnPlayerChat(GetPlayer(), type, lang, msg, group);
- WorldPacket data;
- ChatHandler::BuildChatPacket(data, ChatMsg(type), Language(lang), sender, NULL, msg);
- group->BroadcastPacket(&data, false, group->GetMemberGroup(GetPlayer()->GetGUID()));
+ WorldPackets::Chat::Chat packet;
+ ChatHandler::BuildChatPacket(&packet, ChatMsg(type), Language(lang), sender, NULL, msg);
+ group->BroadcastPacket(packet.Write(), false, group->GetMemberGroup(GetPlayer()->GetGUID()));
break;
}
case CHAT_MSG_GUILD:
@@ -661,25 +314,19 @@ void WorldSession::HandleMessagechatOpcode(WorldPacket& recvData)
break;
}
case CHAT_MSG_RAID:
- case CHAT_MSG_RAID_LEADER:
{
- // if player is in battleground, he cannot say to battleground members by /ra
Group* group = GetPlayer()->GetOriginalGroup();
if (!group)
- {
- group = GetPlayer()->GetGroup();
- if (!group || group->isBGGroup() || !group->isRaidGroup())
- return;
- }
+ return;
if (group->IsLeader(GetPlayer()->GetGUID()))
type = CHAT_MSG_RAID_LEADER;
sScriptMgr->OnPlayerChat(GetPlayer(), type, lang, msg, group);
- WorldPacket data;
- ChatHandler::BuildChatPacket(data, ChatMsg(type), Language(lang), sender, NULL, msg);
- group->BroadcastPacket(&data, false);
+ WorldPackets::Chat::Chat packet;
+ ChatHandler::BuildChatPacket(&packet, ChatMsg(type), Language(lang), sender, NULL, msg);
+ group->BroadcastPacket(packet.Write(), false);
break;
}
case CHAT_MSG_RAID_WARNING:
@@ -690,28 +337,10 @@ void WorldSession::HandleMessagechatOpcode(WorldPacket& recvData)
sScriptMgr->OnPlayerChat(GetPlayer(), type, lang, msg, group);
- WorldPacket data;
+ WorldPackets::Chat::Chat packet;
//in battleground, raid warning is sent only to players in battleground - code is ok
- ChatHandler::BuildChatPacket(data, CHAT_MSG_RAID_WARNING, Language(lang), sender, NULL, msg);
- group->BroadcastPacket(&data, false);
- break;
- }
- case CHAT_MSG_BATTLEGROUND:
- case CHAT_MSG_BATTLEGROUND_LEADER:
- {
- // battleground raid is always in Player->GetGroup(), never in GetOriginalGroup()
- Group* group = GetPlayer()->GetGroup();
- if (!group || !group->isBGGroup())
- return;
-
- if (group->IsLeader(GetPlayer()->GetGUID()))
- type = CHAT_MSG_BATTLEGROUND_LEADER;
-
- sScriptMgr->OnPlayerChat(GetPlayer(), type, lang, msg, group);
-
- WorldPacket data;
- ChatHandler::BuildChatPacket(data, ChatMsg(type), Language(lang), sender, NULL, msg);
- group->BroadcastPacket(&data, false);
+ ChatHandler::BuildChatPacket(&packet, CHAT_MSG_RAID_WARNING, Language(lang), sender, NULL, msg);
+ group->BroadcastPacket(packet.Write(), false);
break;
}
case CHAT_MSG_CHANNEL:
@@ -727,7 +356,7 @@ void WorldSession::HandleMessagechatOpcode(WorldPacket& recvData)
if (ChannelMgr* cMgr = ChannelMgr::forTeam(sender->GetTeam()))
{
- if (Channel* chn = cMgr->GetChannel(channel, sender))
+ if (Channel* chn = cMgr->GetChannel(target, sender))
{
sScriptMgr->OnPlayerChat(sender, type, lang, msg, chn);
chn->Say(sender->GetGUID(), msg.c_str(), lang);
@@ -735,70 +364,18 @@ void WorldSession::HandleMessagechatOpcode(WorldPacket& recvData)
}
break;
}
- case CHAT_MSG_AFK:
- {
- if (!sender->IsInCombat())
- {
- if (sender ->isAFK()) // Already AFK
- {
- if (msg.empty())
- sender->ToggleAFK(); // Remove AFK
- else
- sender->autoReplyMsg = msg; // Update message
- }
- else // New AFK mode
- {
- sender->autoReplyMsg = msg.empty() ? GetTrinityString(LANG_PLAYER_AFK_DEFAULT) : msg;
-
- if (sender->isDND())
- sender->ToggleDND();
-
- sender->ToggleAFK();
- }
-
- sScriptMgr->OnPlayerChat(sender, type, lang, msg);
- }
- break;
- }
- case CHAT_MSG_DND:
- {
- if (sender->isDND()) // Already DND
- {
- if (msg.empty())
- sender->ToggleDND(); // Remove DND
- else
- sender->autoReplyMsg = msg; // Update message
- }
- else // New DND mode
- {
- sender->autoReplyMsg = msg.empty() ? GetTrinityString(LANG_PLAYER_DND_DEFAULT) : msg;
-
- if (sender->isAFK())
- sender->ToggleAFK();
-
- sender->ToggleDND();
- }
-
- sScriptMgr->OnPlayerChat(sender, type, lang, msg);
- break;
- }
default:
TC_LOG_ERROR("network", "CHAT: unknown message type %u, lang: %u", type, lang);
break;
}
-}*/
+}
-void WorldSession::HandleAddonMessagechatOpcode(WorldPacket& recvData)
+void WorldSession::HandleChatAddonMessageOpcode(WorldPackets::Chat::ChatAddonMessage& packet)
{
- Player* sender = GetPlayer();
ChatMsg type;
- switch (recvData.GetOpcode())
+ switch (packet.GetOpcode())
{
- /*
- case CMSG_MESSAGECHAT_ADDON_BATTLEGROUND:
- type = CHAT_MSG_BATTLEGROUND;
- break;
case CMSG_MESSAGECHAT_ADDON_GUILD:
type = CHAT_MSG_GUILD;
break;
@@ -811,95 +388,50 @@ void WorldSession::HandleAddonMessagechatOpcode(WorldPacket& recvData)
case CMSG_MESSAGECHAT_ADDON_RAID:
type = CHAT_MSG_RAID;
break;
- case CMSG_MESSAGECHAT_ADDON_WHISPER:
- type = CHAT_MSG_WHISPER;
- break;
- */
default:
- TC_LOG_ERROR("network", "HandleAddonMessagechatOpcode: Unknown addon chat opcode (%u)", recvData.GetOpcode());
- recvData.hexlike();
+ TC_LOG_ERROR("network", "HandleChatAddonMessageOpcode: Unknown addon chat opcode (%u)", packet.GetOpcode());
return;
}
- std::string message;
- std::string prefix;
- std::string targetName;
+ HandleChatAddonMessage(type, packet.Prefix, packet.Text);
+}
- switch (type)
- {
- case CHAT_MSG_WHISPER:
- {
- uint32 msgLen = recvData.ReadBits(9);
- uint32 prefixLen = recvData.ReadBits(5);
- uint32 targetLen = recvData.ReadBits(10);
- message = recvData.ReadString(msgLen);
- prefix = recvData.ReadString(prefixLen);
- targetName = recvData.ReadString(targetLen);
- break;
- }
- case CHAT_MSG_PARTY:
- case CHAT_MSG_RAID:
- case CHAT_MSG_OFFICER:
- {
- uint32 prefixLen = recvData.ReadBits(5);
- uint32 msgLen = recvData.ReadBits(9);
- prefix = recvData.ReadString(prefixLen);
- message = recvData.ReadString(msgLen);
- break;
- }
- case CHAT_MSG_GUILD:
- case CHAT_MSG_BATTLEGROUND:
- {
- uint32 msgLen = recvData.ReadBits(9);
- uint32 prefixLen = recvData.ReadBits(5);
- message = recvData.ReadString(msgLen);
- prefix = recvData.ReadString(prefixLen);
- break;
- }
- default:
- break;
- }
+void WorldSession::HandleChatAddonMessageWhisperOpcode(WorldPackets::Chat::ChatAddonMessageWhisper& packet)
+{
+ HandleChatAddonMessage(CHAT_MSG_WHISPER, packet.Prefix, packet.Text, packet.Target);
+}
+
+void WorldSession::HandleChatAddonMessage(ChatMsg type, std::string prefix, std::string text, std::string target /*= ""*/)
+{
+ Player* sender = GetPlayer();
if (prefix.empty() || prefix.length() > 16)
return;
// Disabled addon channel?
if (!sWorld->getBoolConfig(CONFIG_ADDON_CHANNEL))
- {
- recvData.rfinish();
return;
- }
switch (type)
{
- case CHAT_MSG_BATTLEGROUND:
- {
- Group* group = sender->GetGroup();
- if (!group || !group->isBGGroup())
- return;
-
- WorldPackets::Chat::Chat packet;
- ChatHandler::BuildChatPacket(&packet, type, LANG_ADDON, sender, NULL, message, 0U, "", DEFAULT_LOCALE, prefix);
- group->BroadcastAddonMessagePacket(packet.Write(), prefix, false);
- break;
- }
case CHAT_MSG_GUILD:
case CHAT_MSG_OFFICER:
{
if (sender->GetGuildId())
if (Guild* guild = sGuildMgr->GetGuildById(sender->GetGuildId()))
- guild->BroadcastAddonToGuild(this, type == CHAT_MSG_OFFICER, message, prefix);
+ guild->BroadcastAddonToGuild(this, type == CHAT_MSG_OFFICER, text, prefix);
break;
}
case CHAT_MSG_WHISPER:
{
- if (!normalizePlayerName(targetName))
+ if (!normalizePlayerName(target))
break;
- Player* receiver = sObjectAccessor->FindPlayerByName(targetName);
+
+ Player* receiver = sObjectAccessor->FindPlayerByName(target);
if (!receiver)
break;
- sender->WhisperAddon(message, prefix, receiver);
+ sender->WhisperAddon(text, prefix, receiver);
break;
}
// Messages sent to "RAID" while in a party will get delivered to "PARTY"
@@ -908,11 +440,11 @@ void WorldSession::HandleAddonMessagechatOpcode(WorldPacket& recvData)
{
Group* group = sender->GetGroup();
- if (!group || group->isBGGroup())
+ if (!group)
break;
WorldPackets::Chat::Chat packet;
- ChatHandler::BuildChatPacket(&packet, type, LANG_ADDON, sender, NULL, message, 0U, "", DEFAULT_LOCALE, prefix);
+ ChatHandler::BuildChatPacket(&packet, type, LANG_ADDON, sender, NULL, text, 0U, "", DEFAULT_LOCALE, prefix);
group->BroadcastAddonMessagePacket(packet.Write(), prefix, true, -1, sender->GetGUID());
break;
}
@@ -924,6 +456,72 @@ void WorldSession::HandleAddonMessagechatOpcode(WorldPacket& recvData)
}
}
+void WorldSession::HandleChatMessageAFKOpcode(WorldPackets::Chat::ChatMessageAFK& packet)
+{
+ Player* sender = GetPlayer();
+
+ if (sender->IsInCombat())
+ return;
+
+ if (sender->HasAura(GM_SILENCE_AURA))
+ {
+ SendNotification(GetTrinityString(LANG_GM_SILENCE), sender->GetName().c_str());
+ return;
+ }
+
+ if (sender->isAFK()) // Already AFK
+ {
+ if (packet.Text.empty())
+ sender->ToggleAFK(); // Remove AFK
+ else
+ sender->autoReplyMsg = packet.Text; // Update message
+ }
+ else // New AFK mode
+ {
+ sender->autoReplyMsg = packet.Text.empty() ? GetTrinityString(LANG_PLAYER_AFK_DEFAULT) : packet.Text;
+
+ if (sender->isDND())
+ sender->ToggleDND();
+
+ sender->ToggleAFK();
+ }
+
+ sScriptMgr->OnPlayerChat(sender, CHAT_MSG_AFK, LANG_UNIVERSAL, packet.Text);
+}
+
+void WorldSession::HandleChatMessageDNDOpcode(WorldPackets::Chat::ChatMessageDND& packet)
+{
+ Player* sender = GetPlayer();
+
+ if (sender->IsInCombat())
+ return;
+
+ if (sender->HasAura(GM_SILENCE_AURA))
+ {
+ SendNotification(GetTrinityString(LANG_GM_SILENCE), sender->GetName().c_str());
+ return;
+ }
+
+ if (sender->isDND()) // Already DND
+ {
+ if (packet.Text.empty())
+ sender->ToggleDND(); // Remove DND
+ else
+ sender->autoReplyMsg = packet.Text; // Update message
+ }
+ else // New DND mode
+ {
+ sender->autoReplyMsg = packet.Text.empty() ? GetTrinityString(LANG_PLAYER_DND_DEFAULT) : packet.Text;
+
+ if (sender->isAFK())
+ sender->ToggleAFK();
+
+ sender->ToggleDND();
+ }
+
+ sScriptMgr->OnPlayerChat(sender, CHAT_MSG_DND, LANG_UNIVERSAL, packet.Text);
+}
+
void WorldSession::HandleEmoteOpcode(WorldPacket& recvData)
{
if (!GetPlayer()->IsAlive() || GetPlayer()->HasUnitState(UNIT_STATE_DIED))
@@ -945,18 +543,13 @@ namespace Trinity
void operator()(WorldPacket& data, LocaleConstant loc_idx)
{
- std::string const name(i_target ? i_target->GetNameForLocaleIdx(loc_idx) : "");
- uint32 namlen = name.size();
-
- data.Initialize(SMSG_TEXT_EMOTE, 20 + namlen);
- data << i_player.GetGUID();
- data << uint32(i_text_emote);
- data << uint32(i_emote_num);
- data << uint32(namlen);
- if (namlen > 1)
- data << name;
- else
- data << uint8(0x00);
+ WorldPackets::Chat::STextEmote packet;
+ packet.SourceGUID = i_player.GetGUID();
+ packet.SourceAccountGUID = i_player.GetSession()->GetAccountGUID();
+ packet.TargetGUID = i_target->GetGUID();
+ packet.EmoteID = i_emote_num;
+ packet.SoundIndex = i_text_emote;
+ data = *packet.Write();
}
private:
@@ -965,11 +558,10 @@ namespace Trinity
uint32 i_emote_num;
Unit const* i_target;
};
-} // namespace Trinity
+}
-void WorldSession::HandleTextEmoteOpcode(WorldPacket& recvData)
+void WorldSession::HandleTextEmoteOpcode(WorldPackets::Chat::CTextEmote& packet)
{
- /*
if (!GetPlayer()->IsAlive())
return;
@@ -980,16 +572,9 @@ void WorldSession::HandleTextEmoteOpcode(WorldPacket& recvData)
return;
}
- uint32 text_emote, emoteNum;
- ObjectGuid guid;
-
- recvData >> text_emote;
- recvData >> emoteNum;
- recvData >> guid;
-
- sScriptMgr->OnPlayerTextEmote(GetPlayer(), text_emote, emoteNum, guid);
+ sScriptMgr->OnPlayerTextEmote(GetPlayer(), packet.SoundIndex, packet.EmoteID, packet.Target);
- EmotesTextEntry const* em = sEmotesTextStore.LookupEntry(text_emote);
+ EmotesTextEntry const* em = sEmotesTextStore.LookupEntry(packet.SoundIndex);
if (!em)
return;
@@ -1014,25 +599,24 @@ void WorldSession::HandleTextEmoteOpcode(WorldPacket& recvData)
break;
}
- Unit* unit = ObjectAccessor::GetUnit(*_player, guid);
+ Unit* unit = ObjectAccessor::GetUnit(*_player, packet.Target);
CellCoord p = Trinity::ComputeCellCoord(GetPlayer()->GetPositionX(), GetPlayer()->GetPositionY());
Cell cell(p);
cell.SetNoCreate();
- Trinity::EmoteChatBuilder emote_builder(*GetPlayer(), text_emote, emoteNum, unit);
+ Trinity::EmoteChatBuilder emote_builder(*GetPlayer(), packet.SoundIndex, packet.EmoteID, unit);
Trinity::LocalizedPacketDo<Trinity::EmoteChatBuilder > emote_do(emote_builder);
Trinity::PlayerDistWorker<Trinity::LocalizedPacketDo<Trinity::EmoteChatBuilder > > emote_worker(GetPlayer(), sWorld->getFloatConfig(CONFIG_LISTEN_RANGE_TEXTEMOTE), emote_do);
TypeContainerVisitor<Trinity::PlayerDistWorker<Trinity::LocalizedPacketDo<Trinity::EmoteChatBuilder> >, WorldTypeMapContainer> message(emote_worker);
cell.Visit(p, message, *GetPlayer()->GetMap(), *GetPlayer(), sWorld->getFloatConfig(CONFIG_LISTEN_RANGE_TEXTEMOTE));
- GetPlayer()->UpdateAchievementCriteria(ACHIEVEMENT_CRITERIA_TYPE_DO_EMOTE, text_emote, 0, 0, unit);
+ GetPlayer()->UpdateAchievementCriteria(ACHIEVEMENT_CRITERIA_TYPE_DO_EMOTE, packet.SoundIndex, 0, 0, unit);
//Send scripted event call
if (unit && unit->GetTypeId() == TYPEID_UNIT && ((Creature*)unit)->AI())
- ((Creature*)unit)->AI()->ReceiveEmote(GetPlayer(), text_emote);
- */
+ ((Creature*)unit)->AI()->ReceiveEmote(GetPlayer(), packet.SoundIndex);
}
void WorldSession::HandleChatIgnoredOpcode(WorldPacket& recvData)