mirror of
https://github.com/YimMenu/RDR-Classes.git
synced 2024-12-22 14:37:30 +08:00
Session Events (#32)
This commit is contained in:
parent
8358e73c43
commit
ec19493aed
@ -1,6 +1,6 @@
|
|||||||
cmake_minimum_required(VERSION 3.11)
|
cmake_minimum_required(VERSION 3.11)
|
||||||
|
|
||||||
project(RDR-Classes)
|
project(RDR-Classes LANGUAGES CXX VERSION 0.0.1 DESCRIPTION "Reversed structures for Red Dead Redemption 2 PC")
|
||||||
|
|
||||||
include(CheckIncludeFileCXX)
|
include(CheckIncludeFileCXX)
|
||||||
|
|
||||||
@ -15,8 +15,8 @@ set(OK TRUE)
|
|||||||
file(GLOB_RECURSE HEADERS "**.hpp")
|
file(GLOB_RECURSE HEADERS "**.hpp")
|
||||||
file(GLOB_RECURSE SRC_MAIN "**.cpp")
|
file(GLOB_RECURSE SRC_MAIN "**.cpp")
|
||||||
source_group(FILES "${SRC_MAIN}")
|
source_group(FILES "${SRC_MAIN}")
|
||||||
add_library(RDR-Classes MODULE "${SRC_MAIN}")
|
add_library(RDR-Classes STATIC "${SRC_MAIN}" "${HEADERS}")
|
||||||
|
set_property(TARGET ${PROJECT_NAME} PROPERTY CXX_STANDARD 20)
|
||||||
add_compile_definitions(_CRT_SECURE_NO_WARNINGS)
|
add_compile_definitions(_CRT_SECURE_NO_WARNINGS)
|
||||||
|
|
||||||
message(STATUS "")
|
message(STATUS "")
|
||||||
|
@ -27,6 +27,7 @@
|
|||||||
#include "network/rlGamerInfoBase.hpp"
|
#include "network/rlGamerInfoBase.hpp"
|
||||||
#include "network/rlScPeerConnection.hpp"
|
#include "network/rlScPeerConnection.hpp"
|
||||||
#include "network/rlScSession.hpp"
|
#include "network/rlScSession.hpp"
|
||||||
|
#include "network/rlScSessionEvent.hpp"
|
||||||
#include "network/rlScSessionManagerImpl.hpp"
|
#include "network/rlScSessionManagerImpl.hpp"
|
||||||
#include "network/rlScSessionMultiplayer.hpp"
|
#include "network/rlScSessionMultiplayer.hpp"
|
||||||
#include "network/rlScSessionPeer.hpp"
|
#include "network/rlScSessionPeer.hpp"
|
||||||
|
@ -16,6 +16,7 @@ namespace rage
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
static_assert(sizeof(rlScSessionId) == 0x10);
|
static_assert(sizeof(rlScSessionId) == 0x10);
|
||||||
|
using rlScSessionRequestId = rlScSessionId; // for now
|
||||||
|
|
||||||
class rlScSessionPeerPoolEntry
|
class rlScSessionPeerPoolEntry
|
||||||
{
|
{
|
||||||
|
126
network/rlScSessionEvent.hpp
Normal file
126
network/rlScSessionEvent.hpp
Normal file
@ -0,0 +1,126 @@
|
|||||||
|
#pragma once
|
||||||
|
#include "rlGamerHandle.hpp"
|
||||||
|
#include "rlGamerInfoBase.hpp"
|
||||||
|
#include "rlScSession.hpp"
|
||||||
|
#include "rage/atUri.hpp"
|
||||||
|
|
||||||
|
#pragma pack(push, 8)
|
||||||
|
namespace rage
|
||||||
|
{
|
||||||
|
enum class SessionEvent : std::uint32_t
|
||||||
|
{
|
||||||
|
LEAVE_SESSION = 6,
|
||||||
|
ADD_PLAYER = 7,
|
||||||
|
REMOVE_PLAYER = 8,
|
||||||
|
HOST_CHANGED = 9,
|
||||||
|
QUEUE_ERROR = 17,
|
||||||
|
LOCALIZED_MESSAGE = 19,
|
||||||
|
CONFIG_PARAM = 20,
|
||||||
|
COMPLAINT_RECEIVED = 31,
|
||||||
|
QUEUE_ENTERED = 32,
|
||||||
|
ADMIN_SECURITY_INVITE = 38
|
||||||
|
};
|
||||||
|
|
||||||
|
class rlScSessionEvent
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
virtual ~rlScSessionEvent() = default;
|
||||||
|
|
||||||
|
SessionEvent m_EventType;
|
||||||
|
|
||||||
|
template<typename T>
|
||||||
|
inline T* As()
|
||||||
|
{
|
||||||
|
return T*(this);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
static_assert(sizeof(rage::rlScSessionEvent) == 0x10);
|
||||||
|
|
||||||
|
class rlScLeaveSessionEvent : public rlScSessionEvent
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
rage::rlScSessionId m_SessionId;
|
||||||
|
int m_Reason;
|
||||||
|
int m_Reason2;
|
||||||
|
int m_PlayerCount;
|
||||||
|
};
|
||||||
|
static_assert(sizeof(rage::rlScLeaveSessionEvent) == 0x30);
|
||||||
|
|
||||||
|
class rlScAddPlayerEvent : public rlScSessionEvent
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
rage::rlScSessionId m_SessionId;
|
||||||
|
rage::rlScSessionPeerIdentifier m_Identifier;
|
||||||
|
rage::rlGamerInfoBase m_PeerAddress;
|
||||||
|
};
|
||||||
|
static_assert(sizeof(rage::rlScAddPlayerEvent) == 0xD0);
|
||||||
|
|
||||||
|
class rlScRemovePlayerEvent : public rlScSessionEvent
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
rage::rlScSessionId m_SessionId;
|
||||||
|
rage::rlScSessionPeerIdentifier m_Identifier;
|
||||||
|
};
|
||||||
|
static_assert(sizeof(rage::rlScRemovePlayerEvent) == 0x38);
|
||||||
|
|
||||||
|
class rlScHostChangedEvent : public rlScSessionEvent
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
rage::rlScSessionId m_SessionId;
|
||||||
|
int m_OldIndex;
|
||||||
|
int m_NewIndex;
|
||||||
|
};
|
||||||
|
static_assert(sizeof(rage::rlScHostChangedEvent) == 0x28);
|
||||||
|
|
||||||
|
class rlScComplaintReceivedEvent : public rlScSessionEvent
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
rage::rlGamerHandle m_Complainer;
|
||||||
|
};
|
||||||
|
static_assert(sizeof(rage::rlScComplaintReceivedEvent) == 0x20);
|
||||||
|
|
||||||
|
class rlScQueueEnteredEvent : public rlScSessionEvent
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
rage::rlScSessionRequestId m_RequestId;
|
||||||
|
int m_QueueGroup;
|
||||||
|
int m_OptionFlags;
|
||||||
|
};
|
||||||
|
static_assert(sizeof(rage::rlScQueueEnteredEvent) == 0x28);
|
||||||
|
|
||||||
|
class rlScQueueErrorEvent : public rlScSessionEvent
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
rage::rlScSessionRequestId m_RequestId;
|
||||||
|
int m_Reason;
|
||||||
|
};
|
||||||
|
static_assert(sizeof(rage::rlScQueueErrorEvent) == 0x28);
|
||||||
|
|
||||||
|
// not rlScLocalizedMessageEvent
|
||||||
|
class rlScLocalizedMessage : public rlScSessionEvent
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
char m_Key[128];
|
||||||
|
};
|
||||||
|
static_assert(sizeof(rage::rlScLocalizedMessage) == 0x90);
|
||||||
|
|
||||||
|
class rlScConfigParamEvent : public rlScSessionEvent
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
int m_NameHash; // TODO: reverse this
|
||||||
|
char m_Value[32];
|
||||||
|
};
|
||||||
|
static_assert(sizeof(rage::rlScConfigParamEvent) == 0x38);
|
||||||
|
|
||||||
|
class rlScAdminSecurityInviteEvent : public rlScSessionEvent
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
rage::rlGamerHandle m_Handle;
|
||||||
|
int m_InviteId;
|
||||||
|
int m_Flags;
|
||||||
|
rage::atUri m_ServerUri;
|
||||||
|
int m_SessionType;
|
||||||
|
};
|
||||||
|
static_assert(sizeof(rage::rlScAdminSecurityInviteEvent) == 0x4B8);
|
||||||
|
}
|
||||||
|
#pragma pack(pop)
|
@ -1,6 +1,7 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
#include <cstdint>
|
#include <cstdint>
|
||||||
|
|
||||||
|
#pragma pack(push, 8)
|
||||||
namespace rage
|
namespace rage
|
||||||
{
|
{
|
||||||
class atUri
|
class atUri
|
||||||
@ -22,3 +23,4 @@ namespace rage
|
|||||||
};
|
};
|
||||||
static_assert(sizeof(atUri) == 0x488);
|
static_assert(sizeof(atUri) == 0x488);
|
||||||
}
|
}
|
||||||
|
#pragma pack(pop)
|
@ -1,6 +1,7 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
#include "script/types.hpp"
|
#include "script/types.hpp"
|
||||||
#include "rage/joaat.hpp"
|
#include "rage/joaat.hpp"
|
||||||
|
#include <unordered_map> // TODO: remove!
|
||||||
|
|
||||||
enum class CampState
|
enum class CampState
|
||||||
{
|
{
|
||||||
@ -10,7 +11,7 @@ enum class CampState
|
|||||||
CLEANUP
|
CLEANUP
|
||||||
};
|
};
|
||||||
|
|
||||||
inline std::map<CampState, std::string> g_CampStateMap = {
|
inline std::unordered_map<CampState, std::string> g_CampStateMap = {
|
||||||
{CampState::INVALID, "Invalid"},
|
{CampState::INVALID, "Invalid"},
|
||||||
{CampState::WAITING, "Waiting"},
|
{CampState::WAITING, "Waiting"},
|
||||||
{CampState::RUNNING, "Running"},
|
{CampState::RUNNING, "Running"},
|
||||||
@ -19,22 +20,22 @@ inline std::map<CampState, std::string> g_CampStateMap = {
|
|||||||
|
|
||||||
enum class CampLocationIndex : std::uint32_t
|
enum class CampLocationIndex : std::uint32_t
|
||||||
{
|
{
|
||||||
GRIZZLIES_CAMP = rage::joaat("GRIZZLIES_CAMP"),
|
GRIZZLIES_CAMP = rage::Joaat("GRIZZLIES_CAMP"),
|
||||||
BAYOU_NAWAS_CAMP = rage::joaat("BAYOU_NAWAS_CAMP"),
|
BAYOU_NAWAS_CAMP = rage::Joaat("BAYOU_NAWAS_CAMP"),
|
||||||
BIG_VALLEY_CAMP = rage::joaat("BIG_VALLEY_CAMP"),
|
BIG_VALLEY_CAMP = rage::Joaat("BIG_VALLEY_CAMP"),
|
||||||
CHOLLA_SPRINGS_CAMP = rage::joaat("CHOLLA_SPRINGS_CAMP"),
|
CHOLLA_SPRINGS_CAMP = rage::Joaat("CHOLLA_SPRINGS_CAMP"),
|
||||||
CUMBERLAND_FOREST_CAMP = rage::joaat("CUMBERLAND_FOREST_CAMP"),
|
CUMBERLAND_FOREST_CAMP = rage::Joaat("CUMBERLAND_FOREST_CAMP"),
|
||||||
GAPTOOTH_RIDGE_CAMP = rage::joaat("GAPTOOTH_RIDGE_CAMP"),
|
GAPTOOTH_RIDGE_CAMP = rage::Joaat("GAPTOOTH_RIDGE_CAMP"),
|
||||||
GREAT_PLAINS_CAMP = rage::joaat("GREAT_PLAINS_CAMP"),
|
GREAT_PLAINS_CAMP = rage::Joaat("GREAT_PLAINS_CAMP"),
|
||||||
HEARTLAND_CAMP = rage::joaat("HEARTLAND_CAMP"),
|
HEARTLAND_CAMP = rage::Joaat("HEARTLAND_CAMP"),
|
||||||
HENNIGANS_STEAD_CAMP = rage::joaat("HENNIGANS_STEAD_CAMP"),
|
HENNIGANS_STEAD_CAMP = rage::Joaat("HENNIGANS_STEAD_CAMP"),
|
||||||
RIO_BRAVO_CAMP = rage::joaat("RIO_BRAVO_CAMP"),
|
RIO_BRAVO_CAMP = rage::Joaat("RIO_BRAVO_CAMP"),
|
||||||
ROANOKE_RIDGE_CAMP = rage::joaat("ROANOKE_RIDGE_CAMP"),
|
ROANOKE_RIDGE_CAMP = rage::Joaat("ROANOKE_RIDGE_CAMP"),
|
||||||
SCARLETT_MEADOWS_CAMP = rage::joaat("SCARLETT_MEADOWS_CAMP"),
|
SCARLETT_MEADOWS_CAMP = rage::Joaat("SCARLETT_MEADOWS_CAMP"),
|
||||||
TALL_TREES_CAMP = rage::joaat("TALL_TREES_CAMP"),
|
TALL_TREES_CAMP = rage::Joaat("TALL_TREES_CAMP"),
|
||||||
};
|
};
|
||||||
|
|
||||||
inline std::map<CampLocationIndex, std::string> g_CampLocationMap = {
|
inline std::unordered_map<CampLocationIndex, std::string> g_CampLocationMap = {
|
||||||
{CampLocationIndex::GRIZZLIES_CAMP, "Grizzlies"},
|
{CampLocationIndex::GRIZZLIES_CAMP, "Grizzlies"},
|
||||||
{CampLocationIndex::BAYOU_NAWAS_CAMP, "Bayou Nawas"},
|
{CampLocationIndex::BAYOU_NAWAS_CAMP, "Bayou Nawas"},
|
||||||
{CampLocationIndex::BIG_VALLEY_CAMP, "Big Valley"},
|
{CampLocationIndex::BIG_VALLEY_CAMP, "Big Valley"},
|
||||||
@ -67,7 +68,7 @@ enum class CampBit
|
|||||||
WHITE_FLAG_LOCKED_FOR_CONTENT
|
WHITE_FLAG_LOCKED_FOR_CONTENT
|
||||||
};
|
};
|
||||||
|
|
||||||
inline std::map<CampBit, std::string> g_CampBitMap = {
|
inline std::unordered_map<CampBit, std::string> g_CampBitMap = {
|
||||||
{CampBit::IS_LAUNCHED, "Is Launched"},
|
{CampBit::IS_LAUNCHED, "Is Launched"},
|
||||||
{CampBit::IS_ATTACKING, "Is Attacking"},
|
{CampBit::IS_ATTACKING, "Is Attacking"},
|
||||||
{CampBit::IS_ACTIVE, "Is Active"},
|
{CampBit::IS_ACTIVE, "Is Active"},
|
||||||
@ -92,7 +93,7 @@ enum class CampContentType
|
|||||||
CAMP_RAID
|
CAMP_RAID
|
||||||
};
|
};
|
||||||
|
|
||||||
inline std::map<CampContentType, std::string> g_CampContentTypeMap = {
|
inline std::unordered_map<CampContentType, std::string> g_CampContentTypeMap = {
|
||||||
{CampContentType::NONE, "None"},
|
{CampContentType::NONE, "None"},
|
||||||
{CampContentType::NET_BEAT, "Net Beat"},
|
{CampContentType::NET_BEAT, "Net Beat"},
|
||||||
{CampContentType::DYNAMIC_MISSION, "Dynamic Mission"},
|
{CampContentType::DYNAMIC_MISSION, "Dynamic Mission"},
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
#include "script/types.hpp"
|
#include "script/types.hpp"
|
||||||
|
#include "unordered_map"
|
||||||
|
|
||||||
enum class PlayerStatus
|
enum class PlayerStatus
|
||||||
{
|
{
|
||||||
@ -355,7 +356,7 @@ enum class Region
|
|||||||
MAX
|
MAX
|
||||||
};
|
};
|
||||||
|
|
||||||
inline std::map<Region, std::string> g_RegionMap = {
|
inline std::unordered_map<Region, std::string> g_RegionMap = {
|
||||||
{ Region::INVALID, "Invalid" },
|
{ Region::INVALID, "Invalid" },
|
||||||
{ Region::BAY_CRAWDADWILLIES, "Crawdad Willies" },
|
{ Region::BAY_CRAWDADWILLIES, "Crawdad Willies" },
|
||||||
{ Region::BAY_MACOMBS_END, "Macomb's End" },
|
{ Region::BAY_MACOMBS_END, "Macomb's End" },
|
||||||
@ -522,7 +523,7 @@ enum class District
|
|||||||
HENNIGANS_STEAD
|
HENNIGANS_STEAD
|
||||||
};
|
};
|
||||||
|
|
||||||
inline std::map<District, std::string> g_DistrictMap = {
|
inline std::unordered_map<District, std::string> g_DistrictMap = {
|
||||||
{ District::INVALID, "Invalid" },
|
{ District::INVALID, "Invalid" },
|
||||||
{ District::BAYOU_NWA, "Bayou Nwa" },
|
{ District::BAYOU_NWA, "Bayou Nwa" },
|
||||||
{ District::BIG_VALLEY, "Big Valley" },
|
{ District::BIG_VALLEY, "Big Valley" },
|
||||||
@ -562,7 +563,7 @@ enum class Language
|
|||||||
CHINESE_SIMP
|
CHINESE_SIMP
|
||||||
};
|
};
|
||||||
|
|
||||||
inline std::map<Language, std::string> g_LanguageMap = {
|
inline std::unordered_map<Language, std::string> g_LanguageMap = {
|
||||||
{ Language::UNDEFINED, "Undefined" },
|
{ Language::UNDEFINED, "Undefined" },
|
||||||
{ Language::ENGLISH, "English" },
|
{ Language::ENGLISH, "English" },
|
||||||
{ Language::FRENCH, "French" },
|
{ Language::FRENCH, "French" },
|
||||||
@ -588,7 +589,7 @@ enum class PassiveState
|
|||||||
FORCED_FROM_PASSIVE
|
FORCED_FROM_PASSIVE
|
||||||
};
|
};
|
||||||
|
|
||||||
inline std::map<PassiveState, std::string> g_PassiveStateMap = {
|
inline std::unordered_map<PassiveState, std::string> g_PassiveStateMap = {
|
||||||
{PassiveState::NOT_PASSIVE, "Not Passive"},
|
{PassiveState::NOT_PASSIVE, "Not Passive"},
|
||||||
{PassiveState::WAITING_FOR_PASSIVE, "Waiting for Passive"},
|
{PassiveState::WAITING_FOR_PASSIVE, "Waiting for Passive"},
|
||||||
{PassiveState::PASSIVE, "Passive"},
|
{PassiveState::PASSIVE, "Passive"},
|
||||||
|
Loading…
Reference in New Issue
Block a user