From 8ce5712552df47c6eff45c596b95a8890826d8b4 Mon Sep 17 00:00:00 2001 From: xinef1 Date: Sat, 31 Dec 2016 20:50:56 +0100 Subject: Core/Pets: Fixed exploit where warlock can abandon its pet to generate new name (#18606) --- src/server/game/Handlers/PetHandler.cpp | 17 ++++++----------- 1 file changed, 6 insertions(+), 11 deletions(-) (limited to 'src') diff --git a/src/server/game/Handlers/PetHandler.cpp b/src/server/game/Handlers/PetHandler.cpp index 6be8389a485..348f6048064 100644 --- a/src/server/game/Handlers/PetHandler.cpp +++ b/src/server/game/Handlers/PetHandler.cpp @@ -676,20 +676,15 @@ void WorldSession::HandlePetAbandon(WorldPacket& recvData) // pet/charmed Creature* pet = ObjectAccessor::GetCreatureOrPetOrVehicle(*_player, guid); - if (pet) + if (pet && pet->ToPet() && pet->ToPet()->getPetType() == HUNTER_PET) { - if (pet->IsPet()) + if (pet->GetGUID() == _player->GetPetGUID()) { - if (pet->GetGUID() == _player->GetPetGUID()) - { - uint32 feelty = pet->GetPower(POWER_HAPPINESS); - pet->SetPower(POWER_HAPPINESS, feelty > 50000 ? (feelty-50000) : 0); - } - - _player->RemovePet((Pet*)pet, PET_SAVE_AS_DELETED); + uint32 feelty = pet->GetPower(POWER_HAPPINESS); + pet->SetPower(POWER_HAPPINESS, feelty > 50000 ? (feelty-50000) : 0); } - else if (pet->GetGUID() == _player->GetCharmGUID()) - _player->StopCastingCharm(); + + _player->RemovePet((Pet*)pet, PET_SAVE_AS_DELETED); } } -- cgit v1.2.3