mirror of
https://github.com/mod-playerbots/azerothcore-wotlk.git
synced 2026-01-17 02:50:29 +00:00
71 lines
2.2 KiB
C++
71 lines
2.2 KiB
C++
/*
|
|
* Copyright (C) 2016+ AzerothCore <www.azerothcore.org>, released under GNU GPL v2 license, you may redistribute it and/or modify it under version 2 of the License, or (at your option), any later version.
|
|
* Copyright (C) 2008-2016 TrinityCore <http://www.trinitycore.org/>
|
|
* Copyright (C) 2005-2009 MaNGOS <http://getmangos.com/>
|
|
*/
|
|
|
|
#include "Common.h"
|
|
#include "Log.h"
|
|
#include "Opcodes.h"
|
|
#include "Player.h"
|
|
#include "UpdateData.h"
|
|
#include "WorldPacket.h"
|
|
#include "WorldSession.h"
|
|
|
|
void WorldSession::HandleDuelAcceptedOpcode(WorldPacket& recvPacket)
|
|
{
|
|
ObjectGuid guid;
|
|
Player* player;
|
|
Player* plTarget;
|
|
|
|
recvPacket >> guid;
|
|
|
|
if (!GetPlayer()->duel) // ignore accept from duel-sender
|
|
return;
|
|
|
|
player = GetPlayer();
|
|
plTarget = player->duel->opponent;
|
|
|
|
if (player == player->duel->initiator || !plTarget || player == plTarget || player->duel->startTime != 0 || plTarget->duel->startTime != 0)
|
|
return;
|
|
|
|
#if defined(ENABLE_EXTRAS) && defined(ENABLE_EXTRA_LOGS)
|
|
LOG_DEBUG("server", "Player 1 is: %s (%s)", player->GetGUID().ToString().c_str(), player->GetName().c_str());
|
|
LOG_DEBUG("server", "Player 2 is: %s (%s)", plTarget->GetGUID().ToString().c_str(), plTarget->GetName().c_str());
|
|
#endif
|
|
|
|
time_t now = time(nullptr);
|
|
player->duel->startTimer = now;
|
|
plTarget->duel->startTimer = now;
|
|
|
|
player->SendDuelCountdown(3000);
|
|
plTarget->SendDuelCountdown(3000);
|
|
}
|
|
|
|
void WorldSession::HandleDuelCancelledOpcode(WorldPacket& recvPacket)
|
|
{
|
|
#if defined(ENABLE_EXTRAS) && defined(ENABLE_EXTRA_LOGS)
|
|
LOG_DEBUG("network", "WORLD: Received CMSG_DUEL_CANCELLED");
|
|
#endif
|
|
ObjectGuid guid;
|
|
recvPacket >> guid;
|
|
|
|
// no duel requested
|
|
if (!GetPlayer()->duel)
|
|
return;
|
|
|
|
// player surrendered in a duel using /forfeit
|
|
if (GetPlayer()->duel->startTime != 0)
|
|
{
|
|
GetPlayer()->CombatStopWithPets(true);
|
|
if (GetPlayer()->duel->opponent)
|
|
GetPlayer()->duel->opponent->CombatStopWithPets(true);
|
|
|
|
GetPlayer()->CastSpell(GetPlayer(), 7267, true); // beg
|
|
GetPlayer()->DuelComplete(DUEL_WON);
|
|
return;
|
|
}
|
|
|
|
GetPlayer()->DuelComplete(DUEL_INTERRUPTED);
|
|
}
|