2018-03-06 22:22:19 +01:00
|
|
|
#include <Common.h>
|
2018-11-22 00:04:26 +01:00
|
|
|
#include <Logging/Logger.h>
|
2018-03-06 22:22:19 +01:00
|
|
|
#include <Exd/ExdDataGenerated.h>
|
|
|
|
#include <Network/CommonNetwork.h>
|
|
|
|
#include <Network/GamePacketNew.h>
|
|
|
|
#include <Network/PacketContainer.h>
|
|
|
|
#include <Network/PacketDef/Zone/ServerZoneDef.h>
|
2018-07-06 23:36:50 +10:00
|
|
|
#include <Network/PacketDef/Zone/ClientZoneDef.h>
|
2017-08-08 13:53:47 +02:00
|
|
|
|
2017-12-08 15:38:25 +01:00
|
|
|
#include "Network/GameConnection.h"
|
|
|
|
#include "Network/PacketWrappers/ServerNoticePacket.h"
|
|
|
|
#include "Network/PacketWrappers/EventStartPacket.h"
|
|
|
|
#include "Network/PacketWrappers/EventFinishPacket.h"
|
|
|
|
#include "Network/PacketWrappers/PlayerStateFlagsPacket.h"
|
2018-03-02 07:22:25 -03:00
|
|
|
|
|
|
|
#include "Script/ScriptMgr.h"
|
|
|
|
|
2018-10-26 08:25:20 +02:00
|
|
|
#include <Util/Util.h>
|
|
|
|
|
2018-09-20 23:31:38 +02:00
|
|
|
#include "Event/EventHandler.h"
|
2017-12-08 15:38:25 +01:00
|
|
|
#include "Event/EventHelper.h"
|
2018-03-06 00:10:36 +01:00
|
|
|
|
2018-02-25 17:23:52 +11:00
|
|
|
#include "Zone/InstanceContent.h"
|
2017-08-08 13:53:47 +02:00
|
|
|
|
2018-03-02 07:22:25 -03:00
|
|
|
#include "Session.h"
|
2018-06-02 15:52:35 +02:00
|
|
|
|
2018-03-02 07:22:25 -03:00
|
|
|
#include "Framework.h"
|
2017-08-08 13:53:47 +02:00
|
|
|
|
2018-03-09 00:06:44 +01:00
|
|
|
extern Core::Framework g_fw;
|
2017-08-08 13:53:47 +02:00
|
|
|
|
|
|
|
using namespace Core::Common;
|
|
|
|
using namespace Core::Network::Packets;
|
|
|
|
using namespace Core::Network::Packets::Server;
|
|
|
|
|
2018-06-18 23:03:39 +02:00
|
|
|
void Core::Network::GameConnection::eventHandlerTalk( const Packets::FFXIVARR_PACKET_RAW& inPacket,
|
|
|
|
Entity::Player& player )
|
2018-01-14 23:54:26 +01:00
|
|
|
{
|
2018-08-29 21:40:59 +02:00
|
|
|
auto pScriptMgr = g_fw.get< Scripting::ScriptMgr >();
|
|
|
|
auto pExdData = g_fw.get< Data::ExdDataGenerated >();
|
2018-06-18 23:03:39 +02:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
const auto packet = ZoneChannelPacket< Client::FFXIVIpcEventHandlerTalk >( inPacket );
|
2018-07-06 23:36:50 +10:00
|
|
|
|
2018-10-14 23:31:52 +11:00
|
|
|
const auto actorId = packet.data().actorId;
|
|
|
|
const auto eventId = packet.data().eventId;
|
2018-07-06 23:36:50 +10:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
auto eventType = static_cast< uint16_t >( eventId >> 16 );
|
2018-01-14 23:54:26 +01:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
std::string eventName = "onTalk";
|
|
|
|
std::string objName = Event::getEventName( eventId );
|
2018-01-14 23:54:26 +01:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
player.sendDebug( "Chara: " +
|
|
|
|
std::to_string( actorId ) + " -> " +
|
|
|
|
std::to_string( Event::mapEventActorToRealActor( static_cast< uint32_t >( actorId ) ) ) +
|
|
|
|
" \neventId: " +
|
|
|
|
std::to_string( eventId ) +
|
2018-10-26 08:25:20 +02:00
|
|
|
" (0x" + Util::intToHexString( static_cast< uint64_t >( eventId & 0xFFFFFFF ), 8 ) + ")" );
|
2018-01-14 23:54:26 +01:00
|
|
|
|
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
player.sendDebug( "Calling: " + objName + "." + eventName );
|
|
|
|
player.eventStart( actorId, eventId, Event::EventHandler::Talk, 0, 0 );
|
2018-01-14 23:54:26 +01:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
if( auto instance = player.getCurrentInstance() )
|
|
|
|
{
|
|
|
|
instance->onTalk( player, eventId, actorId );
|
|
|
|
}
|
|
|
|
else if( !pScriptMgr->onTalk( player, actorId, eventId ) &&
|
|
|
|
eventType == Event::EventHandler::EventHandlerType::Quest )
|
|
|
|
{
|
|
|
|
auto questInfo = pExdData->get< Core::Data::Quest >( eventId );
|
|
|
|
if( questInfo )
|
|
|
|
player.sendUrgent( "Quest not implemented: " + questInfo->name + " (" + questInfo->id + ")" );
|
|
|
|
}
|
2018-01-14 23:54:26 +01:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
player.checkEvent( eventId );
|
2018-01-14 23:54:26 +01:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2018-06-18 23:03:39 +02:00
|
|
|
void Core::Network::GameConnection::eventHandlerEmote( const Packets::FFXIVARR_PACKET_RAW& inPacket,
|
|
|
|
Entity::Player& player )
|
2018-01-16 02:16:48 +01:00
|
|
|
{
|
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
auto pScriptMgr = g_fw.get< Scripting::ScriptMgr >();
|
|
|
|
auto pExdData = g_fw.get< Data::ExdDataGenerated >();
|
2018-06-18 23:03:39 +02:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
const auto packet = ZoneChannelPacket< Client::FFXIVIpcEventHandlerEmote >( inPacket );
|
2018-07-06 23:36:50 +10:00
|
|
|
|
2018-10-14 23:31:52 +11:00
|
|
|
const auto actorId = packet.data().actorId;
|
|
|
|
const auto eventId = packet.data().eventId;
|
|
|
|
const auto emoteId = packet.data().emoteId;
|
2018-08-29 21:40:59 +02:00
|
|
|
const auto eventType = static_cast< uint16_t >( eventId >> 16 );
|
2017-08-08 13:53:47 +02:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
std::string eventName = "onEmote";
|
|
|
|
std::string objName = Event::getEventName( eventId );
|
2018-01-16 02:16:48 +01:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
player.sendDebug( "Chara: " +
|
|
|
|
std::to_string( actorId ) + " -> " +
|
|
|
|
std::to_string( Event::mapEventActorToRealActor( static_cast< uint32_t >( actorId ) ) ) +
|
|
|
|
" \neventId: " +
|
|
|
|
std::to_string( eventId ) +
|
2018-10-26 08:25:20 +02:00
|
|
|
" (0x" + Util::intToHexString( static_cast< uint64_t >( eventId & 0xFFFFFFF ), 8 ) + ")" );
|
2018-01-16 02:16:48 +01:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
player.sendDebug( "Calling: " + objName + "." + eventName );
|
2018-01-16 02:16:48 +01:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
player.eventStart( actorId, eventId, Event::EventHandler::Emote, 0, emoteId );
|
2018-01-16 02:16:48 +01:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
if( !pScriptMgr->onEmote( player, actorId, eventId, static_cast< uint8_t >( emoteId ) ) &&
|
|
|
|
eventType == Event::EventHandler::EventHandlerType::Quest )
|
|
|
|
{
|
|
|
|
auto questInfo = pExdData->get< Core::Data::Quest >( eventId );
|
|
|
|
if( questInfo )
|
|
|
|
player.sendUrgent( "Quest not implemented: " + questInfo->name );
|
|
|
|
}
|
2018-01-16 02:16:48 +01:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
player.checkEvent( eventId );
|
2018-01-16 02:16:48 +01:00
|
|
|
}
|
|
|
|
|
2018-06-18 23:03:39 +02:00
|
|
|
void Core::Network::GameConnection::eventHandlerWithinRange( const Packets::FFXIVARR_PACKET_RAW& inPacket,
|
2018-01-16 02:16:48 +01:00
|
|
|
Entity::Player& player )
|
|
|
|
{
|
2018-08-29 21:40:59 +02:00
|
|
|
auto pScriptMgr = g_fw.get< Scripting::ScriptMgr >();
|
2018-06-18 23:03:39 +02:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
const auto packet = ZoneChannelPacket< Client::FFXIVIpcEventHandlerWithinRange >( inPacket );
|
2018-06-18 23:03:39 +02:00
|
|
|
|
2018-10-14 23:31:52 +11:00
|
|
|
const auto eventId = packet.data().eventId;
|
|
|
|
const auto param1 = packet.data().param1;
|
2018-08-29 21:40:59 +02:00
|
|
|
const auto& pos = packet.data().position;
|
2018-01-16 02:16:48 +01:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
std::string eventName = "onWithinRange";
|
|
|
|
std::string objName = Event::getEventName( eventId );
|
|
|
|
player.sendDebug( "Calling: " + objName + "." + eventName + " - " + std::to_string( eventId ) +
|
|
|
|
" p1: " + std::to_string( param1 ) );
|
2018-01-16 02:16:48 +01:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
player.eventStart( player.getId(), eventId, Event::EventHandler::WithinRange, 1, param1 );
|
2018-01-16 02:16:48 +01:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
pScriptMgr->onWithinRange( player, eventId, param1, pos.x, pos.y, pos.z );
|
2018-01-16 02:16:48 +01:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
player.checkEvent( eventId );
|
2018-01-16 02:16:48 +01:00
|
|
|
}
|
|
|
|
|
2018-06-18 23:03:39 +02:00
|
|
|
void Core::Network::GameConnection::eventHandlerOutsideRange( const Packets::FFXIVARR_PACKET_RAW& inPacket,
|
2018-01-16 02:16:48 +01:00
|
|
|
Entity::Player& player )
|
|
|
|
{
|
2018-08-29 21:40:59 +02:00
|
|
|
auto pScriptMgr = g_fw.get< Scripting::ScriptMgr >();
|
2018-06-18 23:03:39 +02:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
const auto packet = ZoneChannelPacket< Client::FFXIVIpcEventHandlerOutsideRange >( inPacket );
|
2018-10-14 23:31:52 +11:00
|
|
|
const auto eventId = packet.data().eventId;
|
|
|
|
const auto param1 = packet.data().param1;
|
2018-08-29 21:40:59 +02:00
|
|
|
const auto& pos = packet.data().position;
|
2018-01-16 02:16:48 +01:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
std::string eventName = "onOutsideRange";
|
|
|
|
std::string objName = Event::getEventName( eventId );
|
|
|
|
player.sendDebug( "Calling: " + objName + "." + eventName + " - " + std::to_string( eventId ) +
|
|
|
|
" p1: " + std::to_string( param1 ) );
|
2018-01-16 02:16:48 +01:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
player.eventStart( player.getId(), eventId, Event::EventHandler::WithinRange, 1, param1 );
|
2018-01-16 02:16:48 +01:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
pScriptMgr->onOutsideRange( player, eventId, param1, pos.x, pos.y, pos.z );
|
2018-01-16 02:16:48 +01:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
player.checkEvent( eventId );
|
2018-01-16 02:16:48 +01:00
|
|
|
}
|
|
|
|
|
2018-06-18 23:03:39 +02:00
|
|
|
void Core::Network::GameConnection::eventHandlerEnterTerritory( const Packets::FFXIVARR_PACKET_RAW& inPacket,
|
|
|
|
Entity::Player& player )
|
2018-01-16 02:16:48 +01:00
|
|
|
{
|
2018-08-29 21:40:59 +02:00
|
|
|
auto pScriptMgr = g_fw.get< Scripting::ScriptMgr >();
|
2018-06-18 23:03:39 +02:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
const auto packet = ZoneChannelPacket< Client::FFXIVIpcEnterTerritoryHandler >( inPacket );
|
2018-07-06 23:36:50 +10:00
|
|
|
|
2018-10-14 23:31:52 +11:00
|
|
|
const auto eventId = packet.data().eventId;
|
|
|
|
const auto param1 = packet.data().param1;
|
|
|
|
const auto param2 = packet.data().param2;
|
2018-01-16 02:16:48 +01:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
std::string eventName = "onEnterTerritory";
|
2018-01-16 02:16:48 +01:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
std::string objName = Event::getEventName( eventId );
|
2018-01-16 02:16:48 +01:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
player.sendDebug( "Calling: " + objName + "." + eventName + " - " + std::to_string( eventId ) );
|
2018-01-16 02:16:48 +01:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
if( auto instance = player.getCurrentInstance() )
|
|
|
|
{
|
|
|
|
player.eventStart( player.getId(), eventId, Event::EventHandler::EnterTerritory, 1, player.getZoneId() );
|
|
|
|
instance->onEnterTerritory( player, eventId, param1, param2 );
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
player.eventStart( player.getId(), eventId, Event::EventHandler::EnterTerritory, 0, player.getZoneId() );
|
|
|
|
pScriptMgr->onEnterTerritory( player, eventId, param1, param2 );
|
|
|
|
}
|
2018-01-16 02:16:48 +01:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
player.checkEvent( eventId );
|
2018-01-16 02:16:48 +01:00
|
|
|
}
|
2017-08-08 13:53:47 +02:00
|
|
|
|
2018-06-18 23:03:39 +02:00
|
|
|
void Core::Network::GameConnection::eventHandlerReturn( const Packets::FFXIVARR_PACKET_RAW& inPacket,
|
|
|
|
Entity::Player& player )
|
2018-01-18 21:49:12 +01:00
|
|
|
{
|
2018-08-29 21:40:59 +02:00
|
|
|
const auto packet = ZoneChannelPacket< Client::FFXIVIpcEventHandlerReturn >( inPacket );
|
2018-10-14 23:31:52 +11:00
|
|
|
const auto eventId = packet.data().eventId;
|
|
|
|
const auto scene = packet.data().scene;
|
|
|
|
const auto param1 = packet.data().param1;
|
|
|
|
const auto param2 = packet.data().param2;
|
|
|
|
const auto param3 = packet.data().param3;
|
|
|
|
const auto param4 = packet.data().param4;
|
2018-08-29 21:40:59 +02:00
|
|
|
|
|
|
|
std::string eventName = Event::getEventName( eventId );
|
|
|
|
|
|
|
|
player.sendDebug( "eventId: " +
|
|
|
|
std::to_string( eventId ) +
|
2018-10-26 08:25:20 +02:00
|
|
|
" ( 0x" + Util::intToHexString( static_cast< uint64_t >( eventId & 0xFFFFFFF ), 8 ) + " ) " +
|
2018-08-29 21:40:59 +02:00
|
|
|
" scene: " + std::to_string( scene ) +
|
|
|
|
" p1: " + std::to_string( param1 ) +
|
|
|
|
" p2: " + std::to_string( param2 ) +
|
|
|
|
" p3: " + std::to_string( param3 ) );
|
|
|
|
|
|
|
|
auto pEvent = player.getEvent( eventId );
|
|
|
|
if( pEvent )
|
|
|
|
{
|
|
|
|
pEvent->setPlayedScene( false );
|
|
|
|
// try to retrieve a stored callback
|
|
|
|
auto eventCallback = pEvent->getEventReturnCallback();
|
|
|
|
// if there is one, proceed to call it
|
|
|
|
if( eventCallback )
|
|
|
|
{
|
|
|
|
Event::SceneResult result;
|
2018-11-25 23:20:56 +11:00
|
|
|
result.actorId = pEvent->getActorId();
|
2018-08-29 21:40:59 +02:00
|
|
|
result.eventId = eventId;
|
|
|
|
result.param1 = param1;
|
|
|
|
result.param2 = param2;
|
|
|
|
result.param3 = param3;
|
|
|
|
result.param4 = param4;
|
|
|
|
eventCallback( player, result );
|
|
|
|
}
|
2018-03-20 22:08:25 +11:00
|
|
|
// we might have a scene chain callback instead so check for that too
|
2018-08-29 21:40:59 +02:00
|
|
|
else if( auto chainCallback = pEvent->getSceneChainCallback() )
|
|
|
|
chainCallback( player );
|
2018-03-20 00:05:54 +01:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
}
|
2018-01-18 21:49:12 +01:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
player.checkEvent( eventId );
|
2018-01-18 21:49:12 +01:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2018-06-18 23:03:39 +02:00
|
|
|
void Core::Network::GameConnection::eventHandlerLinkshell( const Packets::FFXIVARR_PACKET_RAW& inPacket,
|
|
|
|
Entity::Player& player )
|
2018-01-18 21:49:12 +01:00
|
|
|
{
|
2018-08-29 21:40:59 +02:00
|
|
|
const auto packet = ZoneChannelPacket< Client::FFXIVIpcLinkshellEventHandler >( inPacket );
|
|
|
|
|
|
|
|
auto linkshellEvent = makeZonePacket< Server::FFXIVIpcEventLinkshell >( player.getId() );
|
|
|
|
linkshellEvent->data().eventId = packet.data().eventId;
|
|
|
|
linkshellEvent->data().scene = static_cast< uint8_t >( packet.data().scene );
|
|
|
|
linkshellEvent->data().param3 = 1;
|
|
|
|
linkshellEvent->data().unknown1 = 0x15a;
|
|
|
|
player.queuePacket( linkshellEvent );
|
2018-01-18 21:49:12 +01:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2018-11-22 00:04:26 +01:00
|
|
|
void Core::Network::GameConnection::eventHandlerShop( const Packets::FFXIVARR_PACKET_RAW& inPacket,
|
|
|
|
Entity::Player& player )
|
|
|
|
{
|
|
|
|
const auto packet = ZoneChannelPacket< Client::FFXIVIpcShopEventHandler >( inPacket );
|
|
|
|
|
|
|
|
auto pLog = g_fw.get< Logger >();
|
|
|
|
auto pScriptMgr = g_fw.get< Scripting::ScriptMgr >();
|
|
|
|
auto pExdData = g_fw.get< Data::ExdDataGenerated >();
|
|
|
|
|
|
|
|
const auto eventId = packet.data().eventId;
|
|
|
|
|
|
|
|
auto eventType = static_cast< uint16_t >( eventId >> 16 );
|
|
|
|
|
2018-11-22 23:59:42 +01:00
|
|
|
std::string eventName = "onOpen";
|
2018-11-22 00:04:26 +01:00
|
|
|
std::string objName = Event::getEventName( eventId );
|
|
|
|
|
|
|
|
player.sendDebug( "EventId: " +
|
|
|
|
std::to_string( eventId ) +
|
|
|
|
" (0x" + Util::intToHexString( static_cast< uint64_t >( eventId & 0xFFFFFFF ), 8 ) + ")" );
|
|
|
|
|
|
|
|
player.sendDebug( "Calling: " + objName + "." + eventName );
|
2018-11-24 15:17:18 +11:00
|
|
|
player.eventStart( player.getId(), eventId, Event::EventHandler::UI, 0, packet.data().param );
|
|
|
|
|
|
|
|
pScriptMgr->onTalk( player, player.getId(), eventId );
|
2018-11-22 00:04:26 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-08-08 13:53:47 +02:00
|
|
|
|