Skip to content

Commit

Permalink
Merge branch 'master' of https://github.com/SapphireServer/Sapphire i…
Browse files Browse the repository at this point in the history
…nto actions-war
  • Loading branch information
arieshi255 committed Jun 20, 2024
2 parents cc63ac1 + 5189042 commit 390426a
Show file tree
Hide file tree
Showing 21 changed files with 323 additions and 27 deletions.
1 change: 1 addition & 0 deletions deps/datReader/bparse.h
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
#include <iomanip>
#include <sstream>
#include <vector>
#include <cstdint>

namespace xiv::utils::bparse
{
Expand Down
1 change: 1 addition & 0 deletions deps/datReaderPs3/bparse.h
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
#include <iomanip>
#include <sstream>
#include <vector>
#include <cstdint>

namespace xivps3::utils::bparse
{
Expand Down
1 change: 1 addition & 0 deletions deps/mysqlConnector/ResultSetBase.h
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
#include <list>
#include <map>
#include <iostream>
#include <cstdint>

namespace Mysql
{
Expand Down
1 change: 1 addition & 0 deletions deps/mysqlConnector/mysql_util.h
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ with this program; if not, write to the Free Software Foundation, Inc.,

#include <iostream>
#include <sstream>
#include <cstdint>
#include <mysql.h>

//using MYSQL_FIELD = st_mysql_field;
Expand Down
30 changes: 17 additions & 13 deletions src/api/main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -244,12 +244,14 @@ void createAccount( shared_ptr< HttpServer::Response > response, shared_ptr< Htt
std::string sId;
if( g_sapphireAPI.createAccount( user, pass, sId ) )
{
// todo: construct proper json object here
std::string json_string = "{\"sId\":\"" + sId +
"\", \"lobbyHost\":\"" +
m_config.global.network.lobbyHost +
"\", \"frontierHost\":\"" +
m_config.global.network.restHost + "\"}";
nlohmann::json response_json = {
{"sId", sId},
{"lobbyHost", m_config.global.network.lobbyHost},
{"frontierHost", m_config.global.network.restHost},
{"lobbyPort", m_config.global.network.lobbyPort}
};

std::string json_string = response_json.dump();
*response << buildHttpResponse( 200, json_string, JSON );
}
else
Expand Down Expand Up @@ -277,12 +279,15 @@ void login( shared_ptr< HttpServer::Response > response, shared_ptr< HttpServer:
// reloadConfig();
if( g_sapphireAPI.login( user, pass, sId ) )
{
// todo: build proper json object and stringify it
std::string json_string = "{\"sId\":\"" + sId +
"\", \"lobbyHost\":\"" +
m_config.global.network.lobbyHost +
"\", \"frontierHost\":\"" +
m_config.global.network.restHost + "\"}";
nlohmann::json response_json = {
{"sId", sId},
{"lobbyHost", m_config.global.network.lobbyHost},
{"frontierHost", m_config.global.network.restHost},
{"lobbyPort", m_config.global.network.lobbyPort}
};

std::string json_string = response_json.dump();

*response << buildHttpResponse( 200, json_string, JSON );
}
else
Expand All @@ -294,7 +299,6 @@ void login( shared_ptr< HttpServer::Response > response, shared_ptr< HttpServer:
*response << buildHttpResponse( 500 );
Logger::error( e.what() );
}

}

void deleteCharacter( shared_ptr< HttpServer::Response > response, shared_ptr< HttpServer::Request > request )
Expand Down
2 changes: 2 additions & 0 deletions src/common/Common.h
Original file line number Diff line number Diff line change
Expand Up @@ -1058,6 +1058,7 @@ namespace Sapphire::Common
ItemActionCompanion = 853,
ItemActionVFX2 = 944,
ItemActionMount = 1322,
ItemActionSong = 5845,
};

enum ActionEffectDisplayType : uint8_t
Expand Down Expand Up @@ -1824,6 +1825,7 @@ namespace Sapphire::Common
{
uint16_t targetAetheryte;
uint16_t cost;
bool useAetheryteTicket{ false };
};

enum EventSceneError : uint8_t
Expand Down
1 change: 1 addition & 0 deletions src/common/Crypt/base64.h
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
#pragma once

#include <string>
#include <cstdint>

namespace Sapphire::Common::Util
{
Expand Down
1 change: 1 addition & 0 deletions src/scripts/action/common/ActionTeleport5.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ class ActionTeleport5 : public Sapphire::ScriptAPI::ActionScript
auto teleportQuery = pPlayer->getTeleportQuery();

if( pPlayer->getCurrency( Common::CurrencyType::Gil ) < teleportQuery.cost ||
teleportQuery.useAetheryteTicket && !pPlayer->removeItem( 7569 ) ||
teleportQuery.targetAetheryte == 0 )
{
action.interrupt();
Expand Down
14 changes: 11 additions & 3 deletions src/scripts/common/aethernet/Aetheryte.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -62,10 +62,18 @@ class Aetheryte :
// eventParam4 (or params[1] if using EventPlay8, which is actually used on retail) anything bigger than 1 will show select instance menu item
eventMgr().playScene( player, eventId, 0, 1, { 1, 2 }, [ this ]( Entity::Player& player, const Event::SceneResult& result )
{
if( result.numOfResults == 1 ) // set homepoint
if( result.numOfResults == 1 )
{
player.setHomepoint( result.eventId & 0xFFFF );
eventMgr().sendEventNotice( player, result.eventId, 2, 0xEA, 0, 0 );
auto cmd = result.getResult( 0 );
if( cmd == 1 ) // set homepoint
{
player.setHomepoint( result.eventId & 0xFFFF );
eventMgr().sendEventNotice( player, result.eventId, 2, 0xEA, 0, 0 );
}
else if( cmd == 5 )
{
//TODO: Housing teleport selection
}
}
else if( result.numOfResults == 2 ) // aethernet access
{
Expand Down
105 changes: 105 additions & 0 deletions src/scripts/quest/classquest/CNJ/ClsCnj998.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,105 @@
// This is an automatically generated C++ script template
// Content needs to be added by hand to make it function
// In order for this script to be loaded, move it to the correct folder in <root>/scripts/

#include "Manager/EventMgr.h"
#include <Actor/Player.h>
#include <ScriptObject.h>
#include <Service.h>

// Quest Script: ClsCnj998_00133
// Quest Name: Way of the Conjurer
// Quest ID: 65669
// Start NPC: 1000323 (Madelle)
// End NPC: 1000692 (E-Sumi-Yan)

using namespace Sapphire;

class ClsCnj998 : public Sapphire::ScriptAPI::QuestScript
{
private:
// Basic quest information
// Quest vars / flags used
// UI8AL

/// Countable Num: 1 Seq: 255 Event: 1 Listener: 1000692
// Steps in this quest ( 0 is before accepting,
// 1 is first, 255 means ready for turning it in
enum Sequence : uint8_t
{
Seq0 = 0,
SeqFinish = 255,
};

// Entities found in the script data of the quest
static constexpr auto Actor0 = 1000323;// Madelle ( Pos: -234.028000 -4.000220 -11.062800 Teri: 133 )
static constexpr auto Actor1 = 1000692;// E-sumi-yan ( Pos: -258.808014 -5.773500 -27.237400 Teri: 133 )
static constexpr auto Classjob = 6;
static constexpr auto GearsetUnlock = 1905;
static constexpr auto LogmessageMonsterNotePageUnlock = 1009;
static constexpr auto UnlockImageClassCnj = 25;

public:
ClsCnj998() : Sapphire::ScriptAPI::QuestScript( 65669 ){};
~ClsCnj998() = default;

//////////////////////////////////////////////////////////////////////
// Event Handlers
void onTalk( World::Quest& quest, Entity::Player& player, uint64_t actorId ) override
{
switch( actorId )
{
case Actor0:
{
if( quest.getSeq() == Seq0 )
Scene00000( quest, player );
break;
}
case Actor1:
{
if( quest.getSeq() == SeqFinish )
Scene00001( quest, player );
break;
}
}
}


private:
//////////////////////////////////////////////////////////////////////
// Available Scenes in this quest, not necessarly all are used
//////////////////////////////////////////////////////////////////////

void Scene00000( World::Quest& quest, Entity::Player& player )
{
eventMgr().playQuestScene( player, getId(), 0, HIDE_HOTBAR, bindSceneReturn( &ClsCnj998::Scene00000Return ) );
}

void Scene00000Return( World::Quest& quest, Entity::Player& player, const Event::SceneResult& result )
{
if( result.getResult( 0 ) == 1 )// accept quest
{
quest.setSeq( SeqFinish );
}
}

//////////////////////////////////////////////////////////////////////

void Scene00001( World::Quest& quest, Entity::Player& player )
{
eventMgr().playQuestScene( player, getId(), 1, FADE_OUT | HIDE_UI, bindSceneReturn( &ClsCnj998::Scene00001Return ) );
}

void Scene00001Return( World::Quest& quest, Entity::Player& player, const Event::SceneResult& result )
{

if( result.getResult( 0 ) == 1 )
{
player.finishQuest( getId() );
player.setLevelForClass( 1, Sapphire::Common::ClassJob::Conjurer );
player.addGearSet();
}
}
};

EXPOSE_SCRIPT( ClsCnj998 );
72 changes: 72 additions & 0 deletions src/scripts/quest/classquest/CNJ/ClsCnj999.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,72 @@
// This is an automatically generated C++ script template
// Content needs to be added by hand to make it function
// In order for this script to be loaded, move it to the correct folder in <root>/scripts/

#include "Manager/EventMgr.h"
#include <Actor/Player.h>
#include <ScriptObject.h>
#include <Service.h>

// Quest Script: ClsCnj999_00182
// Quest Name: So You Want to Be a Conjurer
// Quest ID: 65718
// Start NPC: 1000323 (Madelle)
// End NPC: 1000323 (Madelle)

using namespace Sapphire;

class ClsCnj999 : public Sapphire::ScriptAPI::QuestScript
{
private:
// Basic quest information
// Quest vars / flags used

// Steps in this quest ( 0 is before accepting,
// 1 is first, 255 means ready for turning it in
enum Sequence : uint8_t
{
};
static constexpr auto Actor0 = 1000323;


// Entities found in the script data of the quest

public:
ClsCnj999() : Sapphire::ScriptAPI::QuestScript( 65718 ){};
~ClsCnj999() = default;

//////////////////////////////////////////////////////////////////////
// Event Handlers
void onTalk( World::Quest& quest, Entity::Player& player, uint64_t actorId ) override
{
switch( actorId )
{
case Actor0:
{
Scene00000( quest, player );
break;
}
}
}


private:
//////////////////////////////////////////////////////////////////////
// Available Scenes in this quest, not necessarly all are used
//////////////////////////////////////////////////////////////////////

void Scene00000( World::Quest& quest, Entity::Player& player )
{
eventMgr().playQuestScene( player, getId(), 0, HIDE_HOTBAR, bindSceneReturn( &ClsCnj999::Scene00000Return ) );
}

void Scene00000Return( World::Quest& quest, Entity::Player& player, const Event::SceneResult& result )
{
if( result.getResult( 0 ) == 1 )
{
player.finishQuest( getId(), 0 );
}
}
};

EXPOSE_SCRIPT( ClsCnj999 );
2 changes: 0 additions & 2 deletions src/scripts/quest/subquest/gridania/SubFst009.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -96,8 +96,6 @@ class SubFst009 : public Sapphire::ScriptAPI::QuestScript
{
if (result.getResult(0) == 1)
Scene00100(quest, player);
else
Scene00099(quest, player);
}

//////////////////////////////////////////////////////////////////////
Expand Down
7 changes: 5 additions & 2 deletions src/scripts/quest/subquest/gridania/SubFst011.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -67,8 +67,11 @@ class SubFst011 : public Sapphire::ScriptAPI::QuestScript
case Enemy0:
{
auto currentKC = quest.getUI8AL();
quest.setUI8AL( currentKC + 1 );
eventMgr().sendEventNotice( player, getId(), 0, 2, currentKC + 1, 6 );
if( currentKC < 6 )
{
quest.setUI8AL( currentKC + 1 );
eventMgr().sendEventNotice( player, getId(), 0, 2, currentKC + 1, 6 );
}

if( currentKC + 1 >= 6 )
quest.setSeq( SeqFinish );
Expand Down
15 changes: 15 additions & 0 deletions src/world/Action/ItemAction.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,13 @@ void ItemAction::execute()

break;
}

case Common::ItemActionType::ItemActionSong:
{
handleSongItem();

break;
}
}
}

Expand Down Expand Up @@ -102,4 +109,12 @@ void ItemAction::handleMountItem()

player->unlockMount( m_itemAction->data().Calcu0Arg[ 0 ] );
player->dropInventoryItem( static_cast< Common::InventoryType >( m_itemSourceContainer ), static_cast< uint8_t >( m_itemSourceSlot ) );
}

void ItemAction::handleSongItem()
{
auto player = getSourceChara()->getAsPlayer();

player->learnSong( m_itemAction->data().Calcu0Arg[ 0 ], m_id );
player->dropInventoryItem( static_cast< Common::InventoryType >( m_itemSourceContainer ), static_cast< uint8_t >( m_itemSourceSlot ) );
}
2 changes: 2 additions & 0 deletions src/world/Action/ItemAction.h
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,8 @@ namespace Sapphire::World::Action

void handleMountItem();

void handleSongItem();

private:
std::shared_ptr< Excel::ExcelStruct< Excel::ItemAction > > m_itemAction;

Expand Down
Loading

0 comments on commit 390426a

Please sign in to comment.