aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorForesterDev <11771800+ForesterDev@users.noreply.github.com>2019-04-15 17:25:08 +0400
committerShauren <shauren.trinity@gmail.com>2021-11-30 20:58:49 +0100
commitedd911b14d64369158db888fa4dc8d80a4f36f61 (patch)
tree11af6728f58df575f1c1f8f8da4a327d23eef351 /src
parent9b9452af7522adc2f6d753adc6a0abbd56d6ca4b (diff)
Core/Social: Separated checks for friend and ignored limits (#23181)
(cherry picked from commit 2a6eef76e24bcc266050237df0bf296e4cce4bae)
Diffstat (limited to 'src')
-rw-r--r--src/server/game/Entities/Player/SocialMgr.cpp22
1 files changed, 16 insertions, 6 deletions
diff --git a/src/server/game/Entities/Player/SocialMgr.cpp b/src/server/game/Entities/Player/SocialMgr.cpp
index fee87cd6898..dbdefe080a7 100644
--- a/src/server/game/Entities/Player/SocialMgr.cpp
+++ b/src/server/game/Entities/Player/SocialMgr.cpp
@@ -142,21 +142,31 @@ void PlayerSocial::SendSocialList(Player* player, uint32 flags)
{
ASSERT(player);
+ uint32 friendsCount = 0;
+ uint32 ignoredCount = 0;
+
WorldPackets::Social::ContactList contactList;
- contactList.Flags = flags;
+ contactList.Flags = flags; // 0x1 = Friendlist update. 0x2 = Ignorelist update. 0x4 = Mutelist update.
for (PlayerSocialMap::value_type& v : _playerSocialMap)
{
- if (!(v.second.Flags & flags))
+ uint8 contactFlags = v.second.Flags;
+ if (!(contactFlags & flags))
continue;
+ // Check client limit for friends list
+ if (contactFlags & SOCIAL_FLAG_FRIEND)
+ if (++friendsCount > SOCIALMGR_FRIEND_LIMIT)
+ continue;
+
+ // Check client limit for ignore list
+ if (contactFlags & SOCIAL_FLAG_IGNORED)
+ if (++ignoredCount > SOCIALMGR_IGNORE_LIMIT)
+ continue;
+
sSocialMgr->GetFriendInfo(player, v.first, v.second);
contactList.Contacts.emplace_back(v.first, v.second);
-
- // client's friends list and ignore list limit
- if (contactList.Contacts.size() >= (((flags & SOCIAL_FLAG_FRIEND) != 0) ? SOCIALMGR_FRIEND_LIMIT : SOCIALMGR_IGNORE_LIMIT))
- break;
}
player->SendDirectMessage(contactList.Write());