Fix lua explosion bypass (#2255)

* move explosion_anti_cheat_bypass to its own file

* fix(lua): make sure lua user don't get tapped by game ac when using ADD_OWNED_EXPLOSION
This commit is contained in:
Quentin 2023-10-12 23:34:46 +02:00 committed by GitHub
parent 547fa1e137
commit 7ad35bb3d7
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 42 additions and 13 deletions

View File

@ -4,8 +4,8 @@
#include "hooking.hpp" #include "hooking.hpp"
#include "memory/byte_patch.hpp" #include "memory/byte_patch.hpp"
#include "pointers.hpp" #include "pointers.hpp"
#include "util/explosion_anti_cheat_bypass.hpp"
#include "util/police.hpp" #include "util/police.hpp"
#include "util/toxic.hpp"
#include "util/vehicle.hpp" #include "util/vehicle.hpp"
extern "C" void sound_overload_detour(); extern "C" void sound_overload_detour();
@ -22,9 +22,9 @@ namespace big
memory::byte_patch::make(g_pointers->m_gta.m_max_wanted_level.add(14).rip().as<uint32_t*>(), 0).get(); memory::byte_patch::make(g_pointers->m_gta.m_max_wanted_level.add(14).rip().as<uint32_t*>(), 0).get();
// Patch blocked explosions // Patch blocked explosions
toxic::explosion_anti_cheat_bypass::m_can_blame_others = explosion_anti_cheat_bypass::m_can_blame_others =
memory::byte_patch::make(g_pointers->m_gta.m_blame_explode.as<uint16_t*>(), 0xE990).get(); memory::byte_patch::make(g_pointers->m_gta.m_blame_explode.as<uint16_t*>(), 0xE990).get();
toxic::explosion_anti_cheat_bypass::m_can_use_blocked_explosions = explosion_anti_cheat_bypass::m_can_use_blocked_explosions =
memory::byte_patch::make(g_pointers->m_gta.m_explosion_patch.sub(12).as<uint16_t*>(), 0x9090).get(); memory::byte_patch::make(g_pointers->m_gta.m_explosion_patch.sub(12).as<uint16_t*>(), 0x9090).get();
// Skip matchmaking session validity checks // Skip matchmaking session validity checks

View File

@ -1,5 +1,6 @@
#include "lua_native_binding.hpp" #include "lua_native_binding.hpp"
#include "natives.hpp" #include "natives.hpp"
#include "util/explosion_anti_cheat_bypass.hpp"
namespace lua::native namespace lua::native
{ {
@ -63,7 +64,11 @@ namespace lua::native
static void LUA_NATIVE_FIRE_ADD_OWNED_EXPLOSION(Ped ped, float x, float y, float z, int explosionType, float damageScale, bool isAudible, bool isInvisible, float cameraShake) static void LUA_NATIVE_FIRE_ADD_OWNED_EXPLOSION(Ped ped, float x, float y, float z, int explosionType, float damageScale, bool isAudible, bool isInvisible, float cameraShake)
{ {
big::explosion_anti_cheat_bypass::apply();
FIRE::ADD_OWNED_EXPLOSION(ped, x, y, z, explosionType, damageScale, isAudible, isInvisible, cameraShake); FIRE::ADD_OWNED_EXPLOSION(ped, x, y, z, explosionType, damageScale, isAudible, isInvisible, cameraShake);
big::explosion_anti_cheat_bypass::restore();
} }
static void LUA_NATIVE_FIRE_ADD_EXPLOSION_WITH_USER_VFX(float x, float y, float z, int explosionType, Hash explosionFx, float damageScale, bool isAudible, bool isInvisible, float cameraShake) static void LUA_NATIVE_FIRE_ADD_EXPLOSION_WITH_USER_VFX(float x, float y, float z, int explosionType, Hash explosionFx, float damageScale, bool isAudible, bool isInvisible, float cameraShake)

View File

@ -95,6 +95,9 @@ class NativeFunc:
s += "\n" s += "\n"
s += "\t{\n" s += "\t{\n"
if self.cpp_name == "ADD_OWNED_EXPLOSION":
s+= "\t\tbig::explosion_anti_cheat_bypass::apply();\n\n"
call_native = "\t\t" call_native = "\t\t"
if len(self.out_params) > 0: if len(self.out_params) > 0:
if returning_multiple_values: if returning_multiple_values:
@ -127,6 +130,9 @@ class NativeFunc:
s += call_native s += call_native
if self.cpp_name == "ADD_OWNED_EXPLOSION":
s+= "\n\n\t\tbig::explosion_anti_cheat_bypass::restore();"
if returning_multiple_values: if returning_multiple_values:
assign_return_values = "\n" assign_return_values = "\n"
if self.return_type != "void": if self.return_type != "void":
@ -262,6 +268,8 @@ def generate_native_binding_cpp_and_hpp_files(functions_per_namespaces):
file_buffer += '#include "lua_native_binding.hpp"\n' file_buffer += '#include "lua_native_binding.hpp"\n'
file_buffer += '#include "natives.hpp"\n' file_buffer += '#include "natives.hpp"\n'
if namespace_name == "FIRE":
file_buffer += '#include "util/explosion_anti_cheat_bypass.hpp"\n'
file_buffer += "\n" file_buffer += "\n"
file_buffer += "namespace lua::native\n" file_buffer += "namespace lua::native\n"
file_buffer += "{\n" file_buffer += "{\n"

View File

@ -0,0 +1,23 @@
#pragma once
#include "memory/byte_patch.hpp"
namespace big
{
struct explosion_anti_cheat_bypass
{
inline static memory::byte_patch* m_can_blame_others;
inline static memory::byte_patch* m_can_use_blocked_explosions;
inline static void apply()
{
explosion_anti_cheat_bypass::m_can_blame_others->apply();
explosion_anti_cheat_bypass::m_can_use_blocked_explosions->apply();
}
inline static void restore()
{
explosion_anti_cheat_bypass::m_can_use_blocked_explosions->restore();
explosion_anti_cheat_bypass::m_can_blame_others->restore();
}
};
}

View File

@ -5,6 +5,7 @@
#include "gta/pickup_rewards.hpp" #include "gta/pickup_rewards.hpp"
#include "pointers.hpp" #include "pointers.hpp"
#include "services/gta_data/gta_data_service.hpp" #include "services/gta_data/gta_data_service.hpp"
#include "util/explosion_anti_cheat_bypass.hpp"
#include "util/scripts.hpp" #include "util/scripts.hpp"
#include "util/session.hpp" #include "util/session.hpp"
#include "util/system.hpp" #include "util/system.hpp"
@ -18,16 +19,9 @@
namespace big::toxic namespace big::toxic
{ {
struct explosion_anti_cheat_bypass
{
inline static memory::byte_patch* m_can_blame_others;
inline static memory::byte_patch* m_can_use_blocked_explosions;
};
inline void blame_explode_coord(player_ptr to_blame, Vector3 pos, eExplosionTag explosion_type, float damage, bool is_audible, bool is_invisible, float camera_shake) inline void blame_explode_coord(player_ptr to_blame, Vector3 pos, eExplosionTag explosion_type, float damage, bool is_audible, bool is_invisible, float camera_shake)
{ {
explosion_anti_cheat_bypass::m_can_blame_others->apply(); explosion_anti_cheat_bypass::apply();
explosion_anti_cheat_bypass::m_can_use_blocked_explosions->apply();
FIRE::ADD_OWNED_EXPLOSION( FIRE::ADD_OWNED_EXPLOSION(
(*g_pointers->m_gta.m_is_session_started && to_blame) ? PLAYER::GET_PLAYER_PED_SCRIPT_INDEX(to_blame->id()) : 0, (*g_pointers->m_gta.m_is_session_started && to_blame) ? PLAYER::GET_PLAYER_PED_SCRIPT_INDEX(to_blame->id()) : 0,
@ -40,8 +34,7 @@ namespace big::toxic
is_invisible, is_invisible,
camera_shake); camera_shake);
explosion_anti_cheat_bypass::m_can_use_blocked_explosions->restore(); explosion_anti_cheat_bypass::restore();
explosion_anti_cheat_bypass::m_can_blame_others->restore();
} }
inline void blame_explode_player(player_ptr to_blame, player_ptr target, eExplosionTag explosion_type, float damage, bool is_audible, bool is_invisible, float camera_shake) inline void blame_explode_player(player_ptr to_blame, player_ptr target, eExplosionTag explosion_type, float damage, bool is_audible, bool is_invisible, float camera_shake)