1
Fork 0
mirror of https://github.com/SapphireServer/Sapphire.git synced 2025-05-08 11:47:45 +00:00
sapphire/src/world/Task/MoveTerritoryTask.cpp

65 lines
1.8 KiB
C++
Raw Normal View History

2022-01-30 14:44:17 +01:00
#include "MoveTerritoryTask.h"
#include <Logging/Logger.h>
#include <Actor/Player.h>
#include <WorldServer.h>
#include <Service.h>
#include <Manager/TerritoryMgr.h>
using namespace Sapphire::World;
using namespace Sapphire::World::Manager;
MoveTerritoryTask::MoveTerritoryTask( Entity::Player& player, Common::WarpType warpType,
uint32_t targetTerritoryId, Common::FFXIVARR_POSITION3 targetPos, float targetRot, uint64_t delayTime ) : Task( delayTime )
{
m_playerId = player.getId();
m_warpInfo = { targetTerritoryId, warpType, targetPos, targetRot };
}
void MoveTerritoryTask::onQueue()
{
Logger::debug( { __FUNCTION__ } );
}
void MoveTerritoryTask::execute()
{
auto& server = Common::Service< WorldServer >::ref();
auto pPlayer = server.getPlayer( m_playerId );
if( !pPlayer )
return;
pPlayer->setPos( m_warpInfo.m_targetPos, false );
pPlayer->setRot( m_warpInfo.m_targetRot );
auto& teriMgr = Common::Service< TerritoryMgr >::ref();
pPlayer->setOnEnterEventDone( false );
TerritoryPtr pZone;
if( m_warpInfo.m_targetTerritoryId != 0 )
pZone = teriMgr.getTerritoryByGuId( m_warpInfo.m_targetTerritoryId );
2023-01-27 11:13:57 +01:00
if( !pZone )
{
Logger::error( "Territory typeId#{} not found!", m_warpInfo.m_targetTerritoryId );
return;
}
if( !teriMgr.movePlayer( *pZone, *pPlayer ) )
2022-01-30 14:44:17 +01:00
{
// todo: this will require proper handling, for now just return the player to their previous area
pPlayer->setPos( pPlayer->getPrevPos(), false );
auto pZone1 = teriMgr.getZoneByTerritoryTypeId( pPlayer->getPrevTerritoryTypeId() );
2023-01-27 11:13:57 +01:00
if( !teriMgr.movePlayer( *pZone1, *pPlayer ) )
2022-01-30 14:44:17 +01:00
return;
}
}
std::string MoveTerritoryTask::toString()
{
return fmt::format( "MoveTerritoryTask: Player#{}, TerritoryId#{}, ElapsedTimeMs: {}", m_playerId, m_warpInfo.m_targetTerritoryId, getDelayTimeMs() );
}