mirror of
https://github.com/Mr-X-GTA/YimMenu.git
synced 2025-01-03 16:13:36 +08:00
feat(lua): expose io.open (limited to scripts_config folder) (#2495)
This commit is contained in:
parent
542fe17b91
commit
22e2c36249
@ -4,8 +4,9 @@
|
|||||||
|
|
||||||
namespace big
|
namespace big
|
||||||
{
|
{
|
||||||
lua_manager::lua_manager(folder scripts_folder) :
|
lua_manager::lua_manager(folder scripts_folder, folder scripts_config_folder) :
|
||||||
m_scripts_folder(scripts_folder)
|
m_scripts_folder(scripts_folder),
|
||||||
|
m_scripts_config_folder(scripts_config_folder)
|
||||||
{
|
{
|
||||||
m_wake_time_changed_scripts_check = std::chrono::high_resolution_clock::now() + m_delay_between_changed_scripts_check;
|
m_wake_time_changed_scripts_check = std::chrono::high_resolution_clock::now() + m_delay_between_changed_scripts_check;
|
||||||
|
|
||||||
|
@ -14,9 +14,10 @@ namespace big
|
|||||||
std::chrono::high_resolution_clock::time_point m_wake_time_changed_scripts_check;
|
std::chrono::high_resolution_clock::time_point m_wake_time_changed_scripts_check;
|
||||||
|
|
||||||
folder m_scripts_folder;
|
folder m_scripts_folder;
|
||||||
|
folder m_scripts_config_folder;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
lua_manager(folder scripts_folder);
|
lua_manager(folder scripts_folder, folder scripts_config_folder);
|
||||||
~lua_manager();
|
~lua_manager();
|
||||||
|
|
||||||
void load_all_modules();
|
void load_all_modules();
|
||||||
@ -32,6 +33,11 @@ namespace big
|
|||||||
return m_scripts_folder;
|
return m_scripts_folder;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
inline const folder& get_scripts_config_folder() const
|
||||||
|
{
|
||||||
|
return m_scripts_config_folder;
|
||||||
|
}
|
||||||
|
|
||||||
std::weak_ptr<lua_module> get_module(rage::joaat_t module_id);
|
std::weak_ptr<lua_module> get_module(rage::joaat_t module_id);
|
||||||
|
|
||||||
bool has_gui_to_draw(rage::joaat_t tab_hash);
|
bool has_gui_to_draw(rage::joaat_t tab_hash);
|
||||||
|
@ -16,8 +16,8 @@
|
|||||||
#include "bindings/stats.hpp"
|
#include "bindings/stats.hpp"
|
||||||
#include "bindings/tunables.hpp"
|
#include "bindings/tunables.hpp"
|
||||||
#include "bindings/vector.hpp"
|
#include "bindings/vector.hpp"
|
||||||
#include "bindings/weapons.hpp"
|
|
||||||
#include "bindings/vehicles.hpp"
|
#include "bindings/vehicles.hpp"
|
||||||
|
#include "bindings/weapons.hpp"
|
||||||
#include "file_manager.hpp"
|
#include "file_manager.hpp"
|
||||||
#include "script_mgr.hpp"
|
#include "script_mgr.hpp"
|
||||||
|
|
||||||
@ -96,6 +96,7 @@ namespace big
|
|||||||
sol::lib::math,
|
sol::lib::math,
|
||||||
sol::lib::table,
|
sol::lib::table,
|
||||||
sol::lib::bit32,
|
sol::lib::bit32,
|
||||||
|
sol::lib::io,
|
||||||
sol::lib::utf8
|
sol::lib::utf8
|
||||||
);
|
);
|
||||||
// clang-format on
|
// clang-format on
|
||||||
@ -179,6 +180,45 @@ namespace big
|
|||||||
m_state["os"] = sandbox_os;
|
m_state["os"] = sandbox_os;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void lua_module::sandbox_lua_io_library()
|
||||||
|
{
|
||||||
|
auto io = m_state["io"];
|
||||||
|
sol::table sandbox_io(m_state, sol::create);
|
||||||
|
|
||||||
|
m_io_open = io["open"];
|
||||||
|
sandbox_io["open"] = [this](const std::string& filename, const std::string& mode) {
|
||||||
|
constexpr auto make_absolute = [](const std::filesystem::path& root, const std::filesystem::path& user_path) -> std::optional<std::filesystem::path> {
|
||||||
|
auto final_path = std::filesystem::weakly_canonical(root / user_path);
|
||||||
|
|
||||||
|
auto [root_end, nothing] = std::mismatch(root.begin(), root.end(), final_path.begin());
|
||||||
|
|
||||||
|
if (root_end != root.end())
|
||||||
|
return std::nullopt;
|
||||||
|
|
||||||
|
return final_path;
|
||||||
|
};
|
||||||
|
|
||||||
|
const auto scripts_config_sub_path = make_absolute(g_lua_manager->get_scripts_config_folder().get_path(), filename);
|
||||||
|
if (!scripts_config_sub_path)
|
||||||
|
{
|
||||||
|
LOG(WARNING) << "io.open is restricted to the scripts_config folder, and the filename provided (" << filename << ") is outside of it.";
|
||||||
|
|
||||||
|
return sol::reference(sol::lua_nil);
|
||||||
|
}
|
||||||
|
|
||||||
|
const auto res = m_io_open(scripts_config_sub_path.value().u8string().c_str(), mode).get<sol::reference>();
|
||||||
|
|
||||||
|
if (res.get_type() == sol::type::lua_nil)
|
||||||
|
{
|
||||||
|
LOG(WARNING) << "Couldn't io.open a file called " << filename << " mode (" << mode << "). Note that io.open is restricted to the scripts_config folder.";
|
||||||
|
}
|
||||||
|
|
||||||
|
return res;
|
||||||
|
};
|
||||||
|
|
||||||
|
m_state["io"] = sandbox_io;
|
||||||
|
}
|
||||||
|
|
||||||
template<size_t N>
|
template<size_t N>
|
||||||
static constexpr auto not_supported_lua_function(const char (&function_name)[N])
|
static constexpr auto not_supported_lua_function(const char (&function_name)[N])
|
||||||
{
|
{
|
||||||
@ -216,6 +256,7 @@ namespace big
|
|||||||
// https://blog.rubenwardy.com/2020/07/26/sol3-script-sandbox/
|
// https://blog.rubenwardy.com/2020/07/26/sol3-script-sandbox/
|
||||||
// https://www.lua.org/manual/5.4/manual.html#pdf-require
|
// https://www.lua.org/manual/5.4/manual.html#pdf-require
|
||||||
sandbox_lua_os_library();
|
sandbox_lua_os_library();
|
||||||
|
sandbox_lua_io_library();
|
||||||
sandbox_lua_loads(scripts_folder);
|
sandbox_lua_loads(scripts_folder);
|
||||||
|
|
||||||
lua::log::bind(m_state);
|
lua::log::bind(m_state);
|
||||||
|
@ -1,9 +1,10 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
#include "../script.hpp"
|
||||||
#include "bindings/gui/gui_element.hpp"
|
#include "bindings/gui/gui_element.hpp"
|
||||||
#include "core/data/menu_event.hpp"
|
#include "core/data/menu_event.hpp"
|
||||||
#include "lua_patch.hpp"
|
#include "lua_patch.hpp"
|
||||||
#include "sol.hpp"
|
#include "sol.hpp"
|
||||||
#include "../script.hpp"
|
|
||||||
#include <services/gui/gui_service.hpp>
|
#include <services/gui/gui_service.hpp>
|
||||||
|
|
||||||
namespace big
|
namespace big
|
||||||
@ -12,6 +13,8 @@ namespace big
|
|||||||
{
|
{
|
||||||
sol::state m_state;
|
sol::state m_state;
|
||||||
|
|
||||||
|
sol::protected_function m_io_open;
|
||||||
|
|
||||||
std::filesystem::path m_module_path;
|
std::filesystem::path m_module_path;
|
||||||
|
|
||||||
std::string m_module_name;
|
std::string m_module_name;
|
||||||
@ -47,6 +50,7 @@ namespace big
|
|||||||
void set_folder_for_lua_require(folder& scripts_folder);
|
void set_folder_for_lua_require(folder& scripts_folder);
|
||||||
|
|
||||||
void sandbox_lua_os_library();
|
void sandbox_lua_os_library();
|
||||||
|
void sandbox_lua_io_library();
|
||||||
void sandbox_lua_loads(folder& scripts_folder);
|
void sandbox_lua_loads(folder& scripts_folder);
|
||||||
|
|
||||||
void init_lua_api(folder& scripts_folder);
|
void init_lua_api(folder& scripts_folder);
|
||||||
|
13
src/main.cpp
13
src/main.cpp
@ -113,11 +113,11 @@ BOOL APIENTRY DllMain(HMODULE hmod, DWORD reason, PVOID)
|
|||||||
auto pointers_instance = std::make_unique<pointers>();
|
auto pointers_instance = std::make_unique<pointers>();
|
||||||
LOG(INFO) << "Pointers initialized.";
|
LOG(INFO) << "Pointers initialized.";
|
||||||
|
|
||||||
while(!disable_anticheat_skeleton())
|
while (!disable_anticheat_skeleton())
|
||||||
{
|
{
|
||||||
LOG(WARNING) << "Failed patching anticheat gameskeleton (injected too early?). Waiting 100ms and trying again";
|
LOG(WARNING) << "Failed patching anticheat gameskeleton (injected too early?). Waiting 100ms and trying again";
|
||||||
std::this_thread::sleep_for(100ms);
|
std::this_thread::sleep_for(100ms);
|
||||||
}
|
}
|
||||||
LOG(INFO) << "Disabled anticheat gameskeleton.";
|
LOG(INFO) << "Disabled anticheat gameskeleton.";
|
||||||
|
|
||||||
auto byte_patch_manager_instance = std::make_unique<byte_patch_manager>();
|
auto byte_patch_manager_instance = std::make_unique<byte_patch_manager>();
|
||||||
@ -187,7 +187,8 @@ BOOL APIENTRY DllMain(HMODULE hmod, DWORD reason, PVOID)
|
|||||||
auto native_hooks_instance = std::make_unique<native_hooks>();
|
auto native_hooks_instance = std::make_unique<native_hooks>();
|
||||||
LOG(INFO) << "Dynamic native hooker initialized.";
|
LOG(INFO) << "Dynamic native hooker initialized.";
|
||||||
|
|
||||||
auto lua_manager_instance = std::make_unique<lua_manager>(g_file_manager.get_project_folder("scripts"));
|
auto lua_manager_instance =
|
||||||
|
std::make_unique<lua_manager>(g_file_manager.get_project_folder("scripts"), g_file_manager.get_project_folder("scripts_config"));
|
||||||
LOG(INFO) << "Lua manager initialized.";
|
LOG(INFO) << "Lua manager initialized.";
|
||||||
|
|
||||||
g_running = true;
|
g_running = true;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user