2018-03-06 22:22:19 +01:00
|
|
|
#include <Logging/Logger.h>
|
|
|
|
#include <Exd/ExdDataGenerated.h>
|
|
|
|
|
2018-10-25 13:38:06 +11:00
|
|
|
#include <watchdog/Watchdog.h>
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2018-12-01 00:27:16 +11:00
|
|
|
#include "Territory/Zone.h"
|
|
|
|
#include "Territory/InstanceContent.h"
|
2017-12-08 15:38:25 +01:00
|
|
|
#include "Actor/Player.h"
|
2018-11-30 23:15:58 +11:00
|
|
|
#include "Actor/EventObject.h"
|
2018-11-20 21:32:13 +01:00
|
|
|
#include "ServerMgr.h"
|
2018-01-09 23:50:54 +01:00
|
|
|
#include "Event/EventHandler.h"
|
2019-02-10 23:28:15 +11:00
|
|
|
#include "Action/Action.h"
|
2018-12-23 03:53:08 +01:00
|
|
|
|
|
|
|
#include "Manager/EventMgr.h"
|
2018-03-02 07:22:25 -03:00
|
|
|
|
2017-12-08 15:38:25 +01:00
|
|
|
#include "StatusEffect/StatusEffect.h"
|
2018-03-02 07:22:25 -03:00
|
|
|
|
2017-12-08 15:38:25 +01:00
|
|
|
#include "Network/PacketWrappers/ServerNoticePacket.h"
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2018-03-02 07:22:25 -03:00
|
|
|
#include "Script/ScriptMgr.h"
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2018-03-02 07:22:25 -03:00
|
|
|
#include "NativeScriptMgr.h"
|
2018-11-20 21:32:13 +01:00
|
|
|
#include "ServerMgr.h"
|
2018-03-02 07:22:25 -03:00
|
|
|
#include "Framework.h"
|
2018-01-28 11:16:34 +01:00
|
|
|
|
|
|
|
// enable the ambiguity fix for every platform to avoid #define nonsense
|
|
|
|
#define WIN_AMBIGUITY_FIX
|
2017-12-14 22:30:06 +11:00
|
|
|
|
2018-10-25 13:38:06 +11:00
|
|
|
namespace fs = std::experimental::filesystem;
|
|
|
|
|
2018-12-23 03:53:08 +01:00
|
|
|
Sapphire::Scripting::ScriptMgr::ScriptMgr( FrameworkPtr pFw ) :
|
|
|
|
World::Manager::BaseManager( pFw ),
|
2018-08-29 21:40:59 +02:00
|
|
|
m_firstScriptChangeNotificiation( false )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-12-23 03:53:08 +01:00
|
|
|
m_nativeScriptMgr = createNativeScriptMgr( pFw );
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
Sapphire::Scripting::ScriptMgr::~ScriptMgr()
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-08-29 21:40:59 +02:00
|
|
|
Watchdog::unwatchAll();
|
2017-12-14 22:30:06 +11:00
|
|
|
}
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
void Sapphire::Scripting::ScriptMgr::update()
|
2017-12-14 22:30:06 +11:00
|
|
|
{
|
2018-08-29 21:40:59 +02:00
|
|
|
m_nativeScriptMgr->processLoadQueue();
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::init()
|
2017-12-10 23:51:06 +11:00
|
|
|
{
|
2018-08-29 21:40:59 +02:00
|
|
|
std::set< std::string > files;
|
2019-01-07 23:00:09 +11:00
|
|
|
auto pServerMgr = framework()->get< World::ServerMgr >();
|
2017-12-10 23:51:06 +11:00
|
|
|
|
2019-01-07 23:00:09 +11:00
|
|
|
auto status = loadDir( pServerMgr->getConfig().scripts.path, files, m_nativeScriptMgr->getModuleExtension() );
|
2017-12-10 23:51:06 +11:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
if( !status )
|
|
|
|
{
|
2019-01-25 22:43:04 +11:00
|
|
|
Logger::error( "ScriptMgr: failed to load modules, the server will not function correctly without scripts loaded." );
|
2018-08-29 21:40:59 +02:00
|
|
|
return false;
|
|
|
|
}
|
2018-04-04 11:25:07 +10:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
uint32_t scriptsFound = 0;
|
|
|
|
uint32_t scriptsLoaded = 0;
|
2017-12-14 22:30:06 +11:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
for( auto itr = files.begin(); itr != files.end(); ++itr )
|
|
|
|
{
|
|
|
|
auto& path = *itr;
|
2017-12-10 23:51:06 +11:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
scriptsFound++;
|
2017-12-14 22:30:06 +11:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
if( m_nativeScriptMgr->loadScript( path ) )
|
|
|
|
scriptsLoaded++;
|
|
|
|
}
|
2017-12-10 23:51:06 +11:00
|
|
|
|
2019-01-04 22:37:01 +11:00
|
|
|
Logger::info( "ScriptMgr: Loaded {0}/{1} modules", scriptsLoaded, scriptsFound );
|
2017-12-14 22:30:06 +11:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
watchDirectories();
|
2017-12-14 22:30:06 +11:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
return true;
|
2017-12-10 23:51:06 +11:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
void Sapphire::Scripting::ScriptMgr::watchDirectories()
|
2017-12-14 22:30:06 +11:00
|
|
|
{
|
2019-01-07 23:00:09 +11:00
|
|
|
auto pServerMgr = framework()->get< World::ServerMgr >();
|
|
|
|
auto shouldWatch = pServerMgr->getConfig().scripts.hotSwap;
|
2018-08-29 21:40:59 +02:00
|
|
|
if( !shouldWatch )
|
|
|
|
return;
|
|
|
|
|
2019-01-07 23:00:09 +11:00
|
|
|
Watchdog::watchMany( pServerMgr->getConfig().scripts.path + "*" +
|
2018-08-29 21:40:59 +02:00
|
|
|
m_nativeScriptMgr->getModuleExtension(),
|
|
|
|
[ this ]( const std::vector< ci::fs::path >& paths )
|
|
|
|
{
|
|
|
|
if( !m_firstScriptChangeNotificiation )
|
|
|
|
{
|
|
|
|
// for whatever reason, the first time this runs, it detects every file as changed
|
|
|
|
// so we're always going to ignore the first notification
|
|
|
|
m_firstScriptChangeNotificiation = true;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2018-12-23 03:53:08 +01:00
|
|
|
for( const auto& path : paths )
|
2018-08-29 21:40:59 +02:00
|
|
|
{
|
|
|
|
if( m_nativeScriptMgr->isModuleLoaded( path.stem().string() ) )
|
|
|
|
{
|
2019-01-04 22:37:01 +11:00
|
|
|
Logger::debug( "Reloading changed script: {0}", path.stem().string() );
|
2018-08-29 21:40:59 +02:00
|
|
|
|
|
|
|
m_nativeScriptMgr->queueScriptReload( path.stem().string() );
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2019-01-04 22:37:01 +11:00
|
|
|
Logger::debug( "Loading new script: {0}", path.stem().string() );
|
2018-08-29 21:40:59 +02:00
|
|
|
|
|
|
|
m_nativeScriptMgr->loadScript( path.string() );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} );
|
2017-12-14 22:30:06 +11:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::loadDir( const std::string& dirname, std::set< std::string >& files,
|
2018-12-02 02:01:41 +01:00
|
|
|
const std::string& ext )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2019-01-04 22:37:01 +11:00
|
|
|
Logger::info( "ScriptMgr: loading scripts from: {0}", dirname );
|
2018-08-29 21:40:59 +02:00
|
|
|
|
2018-10-25 13:38:06 +11:00
|
|
|
if( !fs::exists( dirname ) )
|
2018-08-29 21:40:59 +02:00
|
|
|
{
|
2018-12-23 03:53:08 +01:00
|
|
|
Logger::error( "ScriptMgr: scripts directory doesn't exist" );
|
2018-08-29 21:40:59 +02:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2018-10-25 13:38:06 +11:00
|
|
|
fs::path targetDir( dirname );
|
2018-08-29 21:40:59 +02:00
|
|
|
|
2018-10-25 13:38:06 +11:00
|
|
|
fs::directory_iterator iter( targetDir );
|
2018-08-29 21:40:59 +02:00
|
|
|
|
2018-10-25 15:15:27 +02:00
|
|
|
for( const auto& i : iter )
|
2018-09-26 08:47:22 -04:00
|
|
|
{
|
2018-10-25 15:15:27 +02:00
|
|
|
if( fs::is_regular_file( i ) && fs::path( i ).extension() == ext )
|
2018-09-26 08:47:22 -04:00
|
|
|
{
|
2018-10-26 14:11:02 +02:00
|
|
|
files.insert( fs::path( i ).string() );
|
2018-09-26 08:47:22 -04:00
|
|
|
}
|
|
|
|
}
|
2018-08-29 21:40:59 +02:00
|
|
|
|
2018-12-23 03:53:08 +01:00
|
|
|
if( !files.empty() )
|
2018-08-29 21:40:59 +02:00
|
|
|
return true;
|
|
|
|
else
|
|
|
|
{
|
2018-12-23 03:53:08 +01:00
|
|
|
Logger::error( "ScriptMgr: couldn't find any script modules" );
|
2018-08-29 21:40:59 +02:00
|
|
|
return false;
|
|
|
|
}
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
void Sapphire::Scripting::ScriptMgr::onPlayerFirstEnterWorld( Entity::Player& player )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2017-12-10 01:52:03 +11:00
|
|
|
// try
|
|
|
|
// {
|
|
|
|
// std::string test = m_onFirstEnterWorld( player );
|
|
|
|
// }
|
|
|
|
// catch( const std::exception &e )
|
|
|
|
// {
|
|
|
|
// std::string what = e.what();
|
|
|
|
// }
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onTalk( Entity::Player& player, uint64_t actorId, uint32_t eventId )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-11-30 23:15:58 +11:00
|
|
|
// check if the actor is an eobj and call its script if we have one
|
|
|
|
auto zone = player.getCurrentZone();
|
|
|
|
if( auto eobj = zone->getEObj( actorId ) )
|
|
|
|
{
|
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::EventObjectScript >( eobj->getObjectId() );
|
|
|
|
if( script )
|
|
|
|
{
|
|
|
|
script->onTalk( eventId, player, *eobj );
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// check for a direct eventid match first, otherwise default to base type
|
2018-11-22 13:12:21 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::EventScript >( eventId );
|
2018-11-20 22:52:57 +11:00
|
|
|
if( script )
|
2018-08-29 21:40:59 +02:00
|
|
|
{
|
2018-11-20 22:52:57 +11:00
|
|
|
script->onTalk( eventId, player, actorId );
|
|
|
|
return true;
|
2018-08-29 21:40:59 +02:00
|
|
|
}
|
2018-11-20 22:52:57 +11:00
|
|
|
else
|
2018-08-29 21:40:59 +02:00
|
|
|
{
|
2018-12-02 02:01:41 +01:00
|
|
|
script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::EventScript >( eventId & 0xFFFF0000 );
|
2018-11-20 22:52:57 +11:00
|
|
|
if( !script )
|
|
|
|
return false;
|
|
|
|
|
|
|
|
script->onTalk( eventId, player, actorId );
|
|
|
|
return true;
|
2018-08-29 21:40:59 +02:00
|
|
|
}
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onEnterTerritory( Entity::Player& player, uint32_t eventId,
|
2018-12-02 02:01:41 +01:00
|
|
|
uint16_t param1, uint16_t param2 )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::EventScript >( eventId );
|
2018-08-29 21:40:59 +02:00
|
|
|
if( !script )
|
|
|
|
return false;
|
|
|
|
script->onEnterTerritory( player, eventId, param1, param2 );
|
|
|
|
return true;
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onWithinRange( Entity::Player& player, uint32_t eventId, uint32_t param1,
|
2018-12-02 02:01:41 +01:00
|
|
|
float x, float y, float z )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::EventScript >( eventId );
|
2018-08-29 21:40:59 +02:00
|
|
|
if( !script )
|
|
|
|
return false;
|
|
|
|
script->onWithinRange( player, eventId, param1, x, y, z );
|
|
|
|
return true;
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onOutsideRange( Entity::Player& player, uint32_t eventId, uint32_t param1,
|
2018-12-02 02:01:41 +01:00
|
|
|
float x, float y, float z )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::EventScript >( eventId );
|
2018-08-29 21:40:59 +02:00
|
|
|
if( !script )
|
|
|
|
return false;
|
|
|
|
script->onOutsideRange( player, eventId, param1, x, y, z );
|
|
|
|
return true;
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onEmote( Entity::Player& player, uint64_t actorId,
|
2018-12-02 02:01:41 +01:00
|
|
|
uint32_t eventId, uint8_t emoteId )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::EventScript >( eventId );
|
2018-08-29 21:40:59 +02:00
|
|
|
if( !script )
|
|
|
|
return false;
|
|
|
|
script->onEmote( actorId, eventId, emoteId, player );
|
|
|
|
return true;
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onEventHandlerReturn( Entity::Player& player, uint32_t eventId,
|
2018-12-02 02:01:41 +01:00
|
|
|
uint16_t subEvent, uint16_t param1, uint16_t param2,
|
|
|
|
uint16_t param3 )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
return false;
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onEventHandlerTradeReturn( Entity::Player& player, uint32_t eventId,
|
2018-12-02 02:01:41 +01:00
|
|
|
uint16_t subEvent, uint16_t param, uint32_t catalogId )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::EventScript >( eventId );
|
2018-08-29 21:40:59 +02:00
|
|
|
if( script )
|
|
|
|
{
|
|
|
|
script->onEventHandlerTradeReturn( player, eventId, subEvent, param, catalogId );
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onEventItem( Entity::Player& player, uint32_t eventItemId,
|
2018-12-02 02:01:41 +01:00
|
|
|
uint32_t eventId, uint32_t castTime, uint64_t targetId )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-12-23 03:53:08 +01:00
|
|
|
auto pEventMgr = framework()->get< World::Manager::EventMgr >();
|
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
std::string eventName = "onEventItem";
|
2018-12-23 03:53:08 +01:00
|
|
|
std::string objName = pEventMgr->getEventName( eventId );
|
2019-01-05 12:32:10 +01:00
|
|
|
player.sendDebug( "Calling: {0}.{1} - {2}", objName, eventName, eventId );
|
2017-12-13 22:19:00 +11:00
|
|
|
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::EventScript >( eventId );
|
2018-08-29 21:40:59 +02:00
|
|
|
if( script )
|
|
|
|
{
|
|
|
|
player.eventStart( targetId, eventId, Event::EventHandler::Item, 0, 0 );
|
2017-12-13 22:19:00 +11:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
script->onEventItem( player, eventItemId, eventId, castTime, targetId );
|
|
|
|
return true;
|
|
|
|
}
|
2017-12-13 22:19:00 +11:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
return false;
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2019-02-02 23:32:36 +11:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onBNpcKill( Entity::Player& player, uint16_t nameId )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-12-23 03:53:08 +01:00
|
|
|
auto pEventMgr = framework()->get< World::Manager::EventMgr >();
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2019-02-02 23:32:36 +11:00
|
|
|
// loop through all active quests and try to call available onBNpcKill callbacks
|
2018-08-29 21:40:59 +02:00
|
|
|
for( size_t i = 0; i < 30; i++ )
|
|
|
|
{
|
|
|
|
auto activeQuests = player.getQuestActive( static_cast< uint16_t >( i ) );
|
|
|
|
if( !activeQuests )
|
|
|
|
continue;
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2019-02-02 23:32:36 +11:00
|
|
|
uint32_t questId = activeQuests->c.questId | Event::EventHandler::EventHandlerType::Quest << 16;
|
2017-12-10 01:52:03 +11:00
|
|
|
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::EventScript >( questId );
|
2018-08-29 21:40:59 +02:00
|
|
|
if( script )
|
|
|
|
{
|
2019-01-29 19:04:24 +11:00
|
|
|
std::string objName = pEventMgr->getEventName( questId );
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2019-02-03 18:37:58 +11:00
|
|
|
player.sendDebug( "Calling: {0}.onBnpcKill nameId#{1}", objName, nameId );
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2019-02-02 23:32:36 +11:00
|
|
|
script->onBNpcKill( nameId, player );
|
2018-08-29 21:40:59 +02:00
|
|
|
}
|
|
|
|
}
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
return true;
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2019-02-10 22:13:47 +11:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onEObjHit( Sapphire::Entity::Player& player, uint64_t actorId )
|
|
|
|
{
|
|
|
|
auto pEventMgr = framework()->get< World::Manager::EventMgr >();
|
2019-02-11 00:40:00 +11:00
|
|
|
bool didCallScript = false;
|
2019-02-10 22:13:47 +11:00
|
|
|
|
|
|
|
for( size_t i = 0; i < 30; i++ )
|
|
|
|
{
|
|
|
|
auto activeQuests = player.getQuestActive( static_cast< uint16_t >( i ) );
|
|
|
|
if( !activeQuests )
|
|
|
|
continue;
|
|
|
|
|
|
|
|
uint32_t questId = activeQuests->c.questId | Event::EventHandler::EventHandlerType::Quest << 16;
|
|
|
|
|
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::EventScript >( questId );
|
|
|
|
if( script )
|
|
|
|
{
|
2019-02-11 00:40:00 +11:00
|
|
|
didCallScript = true;
|
2019-02-10 22:13:47 +11:00
|
|
|
std::string objName = pEventMgr->getEventName( questId );
|
|
|
|
|
|
|
|
player.sendDebug( "Calling: {0}.onEObjHit actorId#{1}", objName, actorId );
|
|
|
|
|
|
|
|
script->onEObjHit( player, actorId );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-02-11 00:40:00 +11:00
|
|
|
return didCallScript;
|
2019-02-10 22:13:47 +11:00
|
|
|
}
|
|
|
|
|
2019-03-07 20:27:45 +11:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onExecute( Action::Action& currentAction )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2019-02-10 23:28:15 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::ActionScript >( currentAction.getId() );
|
2017-12-10 01:52:03 +11:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
if( script )
|
2019-02-11 00:40:00 +11:00
|
|
|
{
|
2019-03-07 20:27:45 +11:00
|
|
|
script->onFinish( currentAction );
|
2019-02-11 00:40:00 +11:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
2019-02-10 23:28:15 +11:00
|
|
|
}
|
|
|
|
|
2019-03-07 20:27:45 +11:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onInterrupt( Action::Action& currentAction )
|
2019-02-10 23:28:15 +11:00
|
|
|
{
|
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::ActionScript >( currentAction.getId() );
|
|
|
|
|
|
|
|
if( script )
|
2019-02-11 00:40:00 +11:00
|
|
|
{
|
2019-03-07 20:27:45 +11:00
|
|
|
script->onInterrupt( currentAction );
|
2019-02-11 00:40:00 +11:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
2019-02-10 23:28:15 +11:00
|
|
|
}
|
|
|
|
|
2019-03-07 20:27:45 +11:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onStart( Action::Action& currentAction )
|
2019-02-10 23:28:15 +11:00
|
|
|
{
|
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::ActionScript >( currentAction.getId() );
|
|
|
|
|
|
|
|
if( script )
|
2019-02-11 00:40:00 +11:00
|
|
|
{
|
2019-03-07 20:27:45 +11:00
|
|
|
script->onStart( currentAction );
|
2019-02-11 00:40:00 +11:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onStatusReceive( Entity::CharaPtr pActor, uint32_t effectId )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::StatusEffectScript >( effectId );
|
2018-01-04 16:14:14 +11:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
if( script )
|
|
|
|
{
|
|
|
|
if( pActor->isPlayer() )
|
2019-01-05 12:32:10 +01:00
|
|
|
pActor->getAsPlayer()->sendDebug( "Calling status receive for statusid#{0}", effectId );
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
script->onApply( *pActor );
|
|
|
|
return true;
|
|
|
|
}
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
return false;
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onStatusTick( Entity::CharaPtr pChara, Sapphire::StatusEffect::StatusEffect& effect )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::StatusEffectScript >( effect.getId() );
|
2018-08-29 21:40:59 +02:00
|
|
|
if( script )
|
|
|
|
{
|
|
|
|
if( pChara->isPlayer() )
|
2019-01-05 12:32:10 +01:00
|
|
|
pChara->getAsPlayer()->sendDebug( "Calling status tick for statusid#{0}", effect.getId() );
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
script->onTick( *pChara );
|
|
|
|
return true;
|
|
|
|
}
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
return false;
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onStatusTimeOut( Entity::CharaPtr pChara, uint32_t effectId )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::StatusEffectScript >( effectId );
|
2018-08-29 21:40:59 +02:00
|
|
|
if( script )
|
|
|
|
{
|
|
|
|
if( pChara->isPlayer() )
|
2019-01-05 12:32:10 +01:00
|
|
|
pChara->getAsPlayer()->sendDebug( "Calling status timeout for statusid#{0}", effectId );
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
script->onExpire( *pChara );
|
|
|
|
return true;
|
|
|
|
}
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
return false;
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onZoneInit( ZonePtr pZone )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::ZoneScript >( pZone->getTerritoryTypeId() );
|
2018-08-29 21:40:59 +02:00
|
|
|
if( script )
|
|
|
|
{
|
|
|
|
script->onZoneInit();
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
2017-12-12 01:45:24 +11:00
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onInstanceInit( InstanceContentPtr instance )
|
2018-02-09 02:34:43 +11:00
|
|
|
{
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::InstanceContentScript >( instance->getDirectorId() );
|
2018-08-29 21:40:59 +02:00
|
|
|
if( script )
|
|
|
|
{
|
2019-02-20 19:53:54 +11:00
|
|
|
script->onInit( *instance );
|
2018-08-29 21:40:59 +02:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
2018-02-09 02:34:43 +11:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onInstanceUpdate( InstanceContentPtr instance, uint32_t currTime )
|
2018-02-09 02:34:43 +11:00
|
|
|
{
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::InstanceContentScript >( instance->getDirectorId() );
|
2018-03-06 00:10:36 +01:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
if( script )
|
|
|
|
{
|
2019-02-20 19:53:54 +11:00
|
|
|
script->onUpdate( *instance, currTime );
|
2018-08-29 21:40:59 +02:00
|
|
|
return true;
|
|
|
|
}
|
2018-02-09 02:34:43 +11:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
return false;
|
2018-02-09 02:34:43 +11:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onInstanceEnterTerritory( InstanceContentPtr instance, Entity::Player& player,
|
2018-12-02 02:01:41 +01:00
|
|
|
uint32_t eventId, uint16_t param1, uint16_t param2 )
|
2018-03-05 22:10:14 +11:00
|
|
|
{
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::InstanceContentScript >( instance->getDirectorId() );
|
2018-08-29 21:40:59 +02:00
|
|
|
if( script )
|
|
|
|
{
|
2019-02-20 19:53:54 +11:00
|
|
|
script->onEnterTerritory( *instance, player, eventId, param1, param2 );
|
2018-08-29 21:40:59 +02:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
2018-03-05 22:10:14 +11:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
Sapphire::Scripting::NativeScriptMgr& Sapphire::Scripting::ScriptMgr::getNativeScriptHandler()
|
2017-12-12 01:45:24 +11:00
|
|
|
{
|
2018-08-29 21:40:59 +02:00
|
|
|
return *m_nativeScriptMgr;
|
2017-12-12 01:45:24 +11:00
|
|
|
}
|