diff options
author | ForesterDev <11771800+ForesterDev@users.noreply.github.com> | 2019-04-15 17:25:08 +0400 |
---|---|---|
committer | Shauren <shauren.trinity@gmail.com> | 2021-11-30 20:58:49 +0100 |
commit | edd911b14d64369158db888fa4dc8d80a4f36f61 (patch) | |
tree | 11af6728f58df575f1c1f8f8da4a327d23eef351 /src | |
parent | 9b9452af7522adc2f6d753adc6a0abbd56d6ca4b (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.cpp | 22 |
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()); |