2017-12-08 15:38:25 +01:00
|
|
|
#include <Server_Common/Common.h>
|
|
|
|
#include <Server_Common/Network/CommonNetwork.h>
|
|
|
|
#include <Server_Common/Network/GamePacketNew.h>
|
|
|
|
#include <Server_Common/Network/PacketContainer.h>
|
|
|
|
#include <Server_Common/Network/PacketDef/Zone/ServerZoneDef.h>
|
2017-08-08 13:53:47 +02:00
|
|
|
|
|
|
|
#include <boost/format.hpp>
|
|
|
|
|
2017-12-08 15:38:25 +01:00
|
|
|
#include "Network/GameConnection.h"
|
|
|
|
#include "Session.h"
|
|
|
|
#include "Network/PacketWrappers/ServerNoticePacket.h"
|
|
|
|
#include "Network/PacketWrappers/ActorControlPacket142.h"
|
|
|
|
#include "Network/PacketWrappers/ActorControlPacket143.h"
|
|
|
|
#include "Network/PacketWrappers/ActorControlPacket144.h"
|
|
|
|
#include "Network/PacketWrappers/EventStartPacket.h"
|
|
|
|
#include "Network/PacketWrappers/EventFinishPacket.h"
|
|
|
|
#include "Network/PacketWrappers/PlayerStateFlagsPacket.h"
|
|
|
|
#include "Script/ScriptManager.h"
|
|
|
|
#include "Actor/Player.h"
|
|
|
|
#include "Forwards.h"
|
|
|
|
#include "Event/EventHelper.h"
|
2017-08-08 13:53:47 +02:00
|
|
|
|
2017-08-17 17:36:40 +02:00
|
|
|
extern Core::Scripting::ScriptManager g_scriptMgr;
|
2017-08-08 13:53:47 +02:00
|
|
|
|
|
|
|
using namespace Core::Common;
|
|
|
|
using namespace Core::Network::Packets;
|
|
|
|
using namespace Core::Network::Packets::Server;
|
|
|
|
|
2017-08-17 17:45:45 +02:00
|
|
|
void Core::Network::GameConnection::eventHandler( const Packets::GamePacket& inPacket,
|
2017-12-08 11:46:47 +01:00
|
|
|
Entity::Player& player )
|
2017-08-08 13:53:47 +02:00
|
|
|
{
|
2017-08-17 17:30:00 +02:00
|
|
|
uint16_t eventHandlerId = inPacket.getValAt< uint16_t >( 0x12 );
|
2017-08-08 13:53:47 +02:00
|
|
|
|
|
|
|
// we need to abort the event in case it has not been scripted so the player wont be locked up
|
2017-12-08 11:46:47 +01:00
|
|
|
auto abortEventFunc = []( Core::Entity::Player& player, uint64_t actorId, uint32_t eventId )
|
2017-08-08 13:53:47 +02:00
|
|
|
{
|
2017-12-08 11:46:47 +01:00
|
|
|
player.queuePacket( EventStartPacket( player.getId(), actorId, eventId, 1, 0, 0 ) );
|
|
|
|
player.queuePacket( EventFinishPacket( player.getId(), eventId, 1, 0 ) );
|
2017-08-08 13:53:47 +02:00
|
|
|
// this isn't ideal as it will also reset any other status that might be active
|
2017-12-08 11:46:47 +01:00
|
|
|
player.queuePacket( PlayerStateFlagsPacket( player, PlayerStateFlagList{} ) );
|
2017-08-08 13:53:47 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
std::string eventIdStr = boost::str( boost::format( "%|04X|" ) % static_cast< uint32_t >( eventHandlerId & 0xFFFF ) );
|
2017-12-08 11:46:47 +01:00
|
|
|
player.sendDebug( "---------------------------------------" );
|
|
|
|
player.sendDebug( "EventHandler ( " + eventIdStr + " )" );
|
2017-08-08 13:53:47 +02:00
|
|
|
|
|
|
|
switch( eventHandlerId )
|
|
|
|
{
|
|
|
|
|
2017-08-20 22:31:23 +02:00
|
|
|
case ClientZoneIpcType::TalkEventHandler: // Talk event
|
2017-08-08 13:53:47 +02:00
|
|
|
{
|
2017-08-17 17:30:00 +02:00
|
|
|
uint64_t actorId = inPacket.getValAt< uint64_t >( 0x20 );
|
|
|
|
uint32_t eventId = inPacket.getValAt< uint32_t >( 0x28 );
|
2017-08-08 13:53:47 +02:00
|
|
|
|
2017-12-08 11:46:47 +01:00
|
|
|
if( !g_scriptMgr.onTalk( player, actorId, eventId ) )
|
|
|
|
abortEventFunc( player, actorId, eventId );
|
2017-08-08 13:53:47 +02:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2017-08-20 22:31:23 +02:00
|
|
|
case ClientZoneIpcType::EmoteEventHandler: // Emote event
|
2017-08-08 13:53:47 +02:00
|
|
|
{
|
2017-08-17 17:30:00 +02:00
|
|
|
uint64_t actorId = inPacket.getValAt< uint64_t >( 0x20 );
|
|
|
|
uint32_t eventId = inPacket.getValAt< uint32_t >( 0x28 );
|
|
|
|
uint16_t emoteId = inPacket.getValAt< uint16_t >( 0x2C );
|
2017-08-08 13:53:47 +02:00
|
|
|
|
|
|
|
std::string eventName = Event::getEventName( eventId );
|
|
|
|
|
2017-12-08 11:46:47 +01:00
|
|
|
if( !g_scriptMgr.onEmote( player, actorId, eventId, static_cast< uint8_t >( emoteId ) ) )
|
|
|
|
abortEventFunc( player, actorId, eventId );
|
2017-08-08 13:53:47 +02:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-08-20 22:31:23 +02:00
|
|
|
case ClientZoneIpcType::WithinRangeEventHandler:
|
2017-08-08 13:53:47 +02:00
|
|
|
{
|
2017-08-17 17:30:00 +02:00
|
|
|
uint32_t eventId = inPacket.getValAt< uint32_t >( 0x24 );
|
|
|
|
uint32_t eventParam1 = inPacket.getValAt< uint32_t >( 0x20 );
|
|
|
|
float x = inPacket.getValAt< float >( 0x28 );
|
|
|
|
float y = inPacket.getValAt< float >( 0x2C );
|
|
|
|
float z = inPacket.getValAt< float >( 0x30 );
|
2017-08-08 13:53:47 +02:00
|
|
|
|
|
|
|
std::string eventName = Event::getEventName( eventId );
|
|
|
|
|
2017-12-08 11:46:47 +01:00
|
|
|
if( !g_scriptMgr.onWithinRange( player, eventId, eventParam1, x, y, z ) )
|
|
|
|
abortEventFunc( player, 0, eventId );
|
2017-08-08 13:53:47 +02:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2017-08-20 22:31:23 +02:00
|
|
|
case ClientZoneIpcType::OutOfRangeEventHandler:
|
2017-08-08 13:53:47 +02:00
|
|
|
{
|
2017-08-17 17:30:00 +02:00
|
|
|
uint32_t eventId = inPacket.getValAt< uint32_t >( 0x24 );
|
|
|
|
uint32_t eventParam1 = inPacket.getValAt< uint32_t >( 0x20 );
|
|
|
|
float x = inPacket.getValAt< float >( 0x28 );
|
|
|
|
float y = inPacket.getValAt< float >( 0x2C );
|
|
|
|
float z = inPacket.getValAt< float >( 0x30 );
|
2017-08-08 13:53:47 +02:00
|
|
|
|
|
|
|
std::string eventName = Event::getEventName( eventId );
|
|
|
|
|
2017-12-08 11:46:47 +01:00
|
|
|
if( !g_scriptMgr.onOutsideRange( player, eventId, eventParam1, x, y, z ) )
|
|
|
|
abortEventFunc( player, 0, eventId );
|
2017-08-08 13:53:47 +02:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2017-08-20 22:31:23 +02:00
|
|
|
case ClientZoneIpcType::EnterTeriEventHandler:
|
2017-08-08 13:53:47 +02:00
|
|
|
{
|
2017-08-17 17:30:00 +02:00
|
|
|
uint32_t eventId = inPacket.getValAt< uint32_t >( 0x20 );
|
|
|
|
uint16_t eventParam1 = inPacket.getValAt< uint16_t >( 0x24 );
|
|
|
|
uint16_t eventParam2 = inPacket.getValAt< uint16_t >( 0x26 );
|
2017-08-08 13:53:47 +02:00
|
|
|
|
|
|
|
std::string eventName = Event::getEventName( eventId );
|
|
|
|
|
2017-12-08 11:46:47 +01:00
|
|
|
if( !g_scriptMgr.onEnterTerritory( player, eventId, eventParam1, eventParam2 ) )
|
|
|
|
abortEventFunc( player, 0, eventId );
|
2017-08-08 13:53:47 +02:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2017-08-20 22:31:23 +02:00
|
|
|
case ClientZoneIpcType::ReturnEventHandler:
|
|
|
|
case ClientZoneIpcType::TradeReturnEventHandler:
|
2017-08-08 13:53:47 +02:00
|
|
|
{
|
2017-08-17 17:30:00 +02:00
|
|
|
uint32_t eventId = inPacket.getValAt< uint32_t >( 0x20 );
|
|
|
|
uint16_t subEvent = inPacket.getValAt< uint16_t >( 0x24 );
|
|
|
|
uint16_t param1 = inPacket.getValAt< uint16_t >( 0x26 );
|
|
|
|
uint16_t param2 = inPacket.getValAt< uint16_t >( 0x28 );
|
|
|
|
uint16_t param3 = inPacket.getValAt< uint16_t >( 0x2C );
|
2017-08-08 13:53:47 +02:00
|
|
|
|
|
|
|
std::string eventName = Event::getEventName( eventId );
|
|
|
|
|
2017-12-08 11:46:47 +01:00
|
|
|
if( !g_scriptMgr.onEventHandlerReturn( player, eventId, subEvent, param1, param2, param3 ) )
|
|
|
|
abortEventFunc( player, 0, eventId );
|
2017-08-08 13:53:47 +02:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2017-08-23 23:58:14 +02:00
|
|
|
case ClientZoneIpcType::LinkshellEventHandler:
|
2017-08-27 02:03:27 +02:00
|
|
|
case ClientZoneIpcType::LinkshellEventHandler1:
|
2017-08-23 23:58:14 +02:00
|
|
|
{
|
|
|
|
uint32_t eventId = inPacket.getValAt< uint32_t >( 0x20 );
|
|
|
|
uint16_t subEvent = inPacket.getValAt< uint16_t >( 0x24 );
|
|
|
|
std::string lsName = inPacket.getStringAt( 0x27 );
|
|
|
|
|
2017-12-08 11:46:47 +01:00
|
|
|
ZoneChannelPacket< FFXIVIpcEventLinkshell > linkshellEvent( player.getId() );
|
2017-08-27 02:03:27 +02:00
|
|
|
linkshellEvent.data().eventId = eventId;
|
2017-12-08 11:46:47 +01:00
|
|
|
linkshellEvent.data().scene = static_cast< uint8_t >( subEvent );
|
2017-08-27 02:03:27 +02:00
|
|
|
linkshellEvent.data().param3 = 1;
|
|
|
|
linkshellEvent.data().unknown1 = 0x15a;
|
2017-12-08 11:46:47 +01:00
|
|
|
player.queuePacket( linkshellEvent );
|
2017-08-27 02:03:27 +02:00
|
|
|
|
|
|
|
// abortEventFunc( pPlayer, 0, eventId );
|
2017-08-23 23:58:14 +02:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2017-08-08 13:53:47 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|