2023-03-01 21:27:15 +00:00
|
|
|
#include "backend/backend.hpp"
|
2023-04-14 18:54:07 +02:00
|
|
|
#include "byte_patch_manager.hpp"
|
2022-06-27 20:12:45 +02:00
|
|
|
#include "common.hpp"
|
2019-03-21 20:18:31 +01:00
|
|
|
#include "fiber_pool.hpp"
|
|
|
|
#include "gui.hpp"
|
|
|
|
#include "hooking.hpp"
|
2023-03-01 21:27:15 +00:00
|
|
|
#include "logger/exception_handler.hpp"
|
2023-06-06 07:40:40 +00:00
|
|
|
#include "lua/lua_manager.hpp"
|
2023-03-01 21:27:15 +00:00
|
|
|
#include "native_hooks/native_hooks.hpp"
|
2019-03-21 20:18:31 +01:00
|
|
|
#include "pointers.hpp"
|
|
|
|
#include "renderer.hpp"
|
|
|
|
#include "script_mgr.hpp"
|
2023-03-01 21:27:15 +00:00
|
|
|
#include "services/api/api_service.hpp"
|
2022-06-30 00:11:54 +02:00
|
|
|
#include "services/context_menu/context_menu_service.hpp"
|
2022-07-29 14:32:02 +02:00
|
|
|
#include "services/custom_text/custom_text_service.hpp"
|
2022-06-30 00:11:54 +02:00
|
|
|
#include "services/globals/globals_service.hpp"
|
2022-07-19 18:19:19 +08:00
|
|
|
#include "services/gta_data/gta_data_service.hpp"
|
2023-03-01 21:27:15 +00:00
|
|
|
#include "services/gui/gui_service.hpp"
|
|
|
|
#include "services/hotkey/hotkey_service.hpp"
|
|
|
|
#include "services/matchmaking/matchmaking_service.hpp"
|
2022-06-30 00:11:54 +02:00
|
|
|
#include "services/mobile/mobile_service.hpp"
|
2023-03-01 21:27:15 +00:00
|
|
|
#include "services/model_preview/model_preview_service.hpp"
|
|
|
|
#include "services/notifications/notification_service.hpp"
|
2023-04-02 00:37:26 +08:00
|
|
|
#include "services/orbital_drone/orbital_drone.hpp"
|
2022-07-03 00:03:07 +02:00
|
|
|
#include "services/pickups/pickup_service.hpp"
|
2023-03-01 21:27:15 +00:00
|
|
|
#include "services/player_database/player_database_service.hpp"
|
2022-06-30 00:11:54 +02:00
|
|
|
#include "services/players/player_service.hpp"
|
2023-06-23 06:43:44 +00:00
|
|
|
#include "services/script_connection/script_connection_service.hpp"
|
2022-11-12 21:02:50 +00:00
|
|
|
#include "services/script_patcher/script_patcher_service.hpp"
|
2023-04-23 17:23:00 +02:00
|
|
|
#include "services/squad_spawner/squad_spawner.hpp"
|
2023-06-06 07:40:40 +00:00
|
|
|
#include "services/tunables/tunables_service.hpp"
|
2023-03-01 21:27:15 +00:00
|
|
|
#include "services/vehicle/handling_service.hpp"
|
2023-04-14 18:54:07 +02:00
|
|
|
#include "services/vehicle/vehicle_control_service.hpp"
|
2023-07-07 11:11:54 +02:00
|
|
|
#include "services/vehicle/xml_vehicles_service.hpp"
|
2023-03-01 21:27:15 +00:00
|
|
|
#include "thread_pool.hpp"
|
2023-07-02 00:52:36 +02:00
|
|
|
#include "util/migrate.hpp"
|
2023-03-01 21:27:15 +00:00
|
|
|
#include "version.hpp"
|
2023-02-08 23:36:55 +01:00
|
|
|
|
2019-03-21 20:18:31 +01:00
|
|
|
BOOL APIENTRY DllMain(HMODULE hmod, DWORD reason, PVOID)
|
|
|
|
{
|
|
|
|
using namespace big;
|
|
|
|
if (reason == DLL_PROCESS_ATTACH)
|
|
|
|
{
|
|
|
|
DisableThreadLibraryCalls(hmod);
|
2023-03-01 21:27:15 +00:00
|
|
|
g_hmodule = hmod;
|
|
|
|
g_main_thread = CreateThread(
|
|
|
|
nullptr,
|
|
|
|
0,
|
|
|
|
[](PVOID) -> DWORD {
|
|
|
|
auto handler = exception_handler();
|
|
|
|
|
|
|
|
while (!FindWindow("grcWindow", nullptr))
|
|
|
|
std::this_thread::sleep_for(100ms);
|
|
|
|
|
|
|
|
std::filesystem::path base_dir = std::getenv("appdata");
|
2023-07-02 00:52:36 +02:00
|
|
|
base_dir /= "YimMenu";
|
|
|
|
do_migration(base_dir);
|
2023-07-08 17:54:59 +02:00
|
|
|
g_file_manager.init(base_dir);
|
2023-03-01 21:27:15 +00:00
|
|
|
|
2023-07-08 17:54:59 +02:00
|
|
|
auto logger_instance = std::make_unique<logger>("YimMenu", g_file_manager.get_project_file("./cout.log"));
|
2023-03-01 21:27:15 +00:00
|
|
|
|
|
|
|
EnableMenuItem(GetSystemMenu(GetConsoleWindow(), 0), SC_CLOSE, MF_BYCOMMAND | MF_DISABLED | MF_GRAYED);
|
|
|
|
|
2023-03-20 20:23:43 +08:00
|
|
|
std::srand(std::chrono::system_clock::now().time_since_epoch().count());
|
|
|
|
|
2023-07-02 00:52:36 +02:00
|
|
|
LOG(INFO) << "Yim's Menu Initializing";
|
|
|
|
LOGF(INFO, "Git Info\n\tBranch:\t{}\n\tHash:\t{}\n\tDate:\t{}", version::GIT_BRANCH, version::GIT_SHA1, version::GIT_DATE);
|
|
|
|
|
|
|
|
auto thread_pool_instance = std::make_unique<thread_pool>();
|
|
|
|
LOG(INFO) << "Thread pool initialized.";
|
|
|
|
|
2023-07-08 17:54:59 +02:00
|
|
|
g.init(g_file_manager.get_project_file("./settings.json"));
|
2023-07-02 00:52:36 +02:00
|
|
|
LOG(INFO) << "Settings Loaded.";
|
|
|
|
|
|
|
|
auto pointers_instance = std::make_unique<pointers>();
|
|
|
|
LOG(INFO) << "Pointers initialized.";
|
|
|
|
|
|
|
|
auto byte_patch_manager_instance = std::make_unique<byte_patch_manager>();
|
|
|
|
LOG(INFO) << "Byte Patch Manager initialized.";
|
|
|
|
|
|
|
|
auto renderer_instance = std::make_unique<renderer>();
|
|
|
|
LOG(INFO) << "Renderer initialized.";
|
|
|
|
auto gui_instance = std::make_unique<gui>();
|
|
|
|
|
|
|
|
auto fiber_pool_instance = std::make_unique<fiber_pool>(11);
|
|
|
|
LOG(INFO) << "Fiber pool initialized.";
|
|
|
|
|
|
|
|
g_translation_service.init();
|
|
|
|
LOG(INFO) << "Translation Service initialized.";
|
|
|
|
|
|
|
|
auto hooking_instance = std::make_unique<hooking>();
|
|
|
|
LOG(INFO) << "Hooking initialized.";
|
|
|
|
|
|
|
|
auto context_menu_service_instance = std::make_unique<context_menu_service>();
|
|
|
|
auto custom_text_service_instance = std::make_unique<custom_text_service>();
|
|
|
|
auto globals_service_instace = std::make_unique<globals_service>();
|
|
|
|
auto mobile_service_instance = std::make_unique<mobile_service>();
|
|
|
|
auto notification_service_instance = std::make_unique<notification_service>();
|
|
|
|
auto pickup_service_instance = std::make_unique<pickup_service>();
|
|
|
|
auto player_service_instance = std::make_unique<player_service>();
|
|
|
|
auto gta_data_service_instance = std::make_unique<gta_data_service>();
|
|
|
|
auto model_preview_service_instance = std::make_unique<model_preview_service>();
|
|
|
|
auto handling_service_instance = std::make_unique<handling_service>();
|
|
|
|
auto gui_service_instance = std::make_unique<gui_service>();
|
|
|
|
auto script_patcher_service_instance = std::make_unique<script_patcher_service>();
|
|
|
|
auto player_database_service_instance = std::make_unique<player_database_service>();
|
|
|
|
auto hotkey_service_instance = std::make_unique<hotkey_service>();
|
|
|
|
auto matchmaking_service_instance = std::make_unique<matchmaking_service>();
|
|
|
|
auto api_service_instance = std::make_unique<api_service>();
|
|
|
|
auto tunables_service_instance = std::make_unique<tunables_service>();
|
|
|
|
auto script_connection_service_instance = std::make_unique<script_connection_service>();
|
2023-07-07 11:11:54 +02:00
|
|
|
auto xml_vehicles_service_instance = std::make_unique<xml_vehicles_service>();
|
2023-07-02 00:52:36 +02:00
|
|
|
LOG(INFO) << "Registered service instances...";
|
|
|
|
|
|
|
|
g_script_mgr.add_script(std::make_unique<script>(&gui::script_func, "GUI", false));
|
|
|
|
|
|
|
|
g_script_mgr.add_script(std::make_unique<script>(&backend::loop, "Backend Loop", false));
|
|
|
|
g_script_mgr.add_script(std::make_unique<script>(&backend::self_loop, "Self"));
|
|
|
|
g_script_mgr.add_script(std::make_unique<script>(&backend::weapons_loop, "Weapon"));
|
|
|
|
g_script_mgr.add_script(std::make_unique<script>(&backend::vehicles_loop, "Vehicle"));
|
|
|
|
g_script_mgr.add_script(std::make_unique<script>(&backend::misc_loop, "Miscellaneous"));
|
|
|
|
g_script_mgr.add_script(std::make_unique<script>(&backend::remote_loop, "Remote"));
|
|
|
|
g_script_mgr.add_script(std::make_unique<script>(&backend::lscustoms_loop, "LS Customs"));
|
|
|
|
g_script_mgr.add_script(std::make_unique<script>(&backend::rainbowpaint_loop, "Rainbow Paint"));
|
|
|
|
g_script_mgr.add_script(std::make_unique<script>(&backend::disable_control_action_loop, "Disable Controls"));
|
|
|
|
g_script_mgr.add_script(std::make_unique<script>(&backend::world_loop, "World"));
|
|
|
|
g_script_mgr.add_script(std::make_unique<script>(&backend::orbital_drone, "Orbital Drone"));
|
|
|
|
g_script_mgr.add_script(std::make_unique<script>(&backend::vehicle_control, "Vehicle Control"));
|
|
|
|
g_script_mgr.add_script(std::make_unique<script>(&context_menu_service::context_menu, "Context Menu"));
|
|
|
|
g_script_mgr.add_script(std::make_unique<script>(&backend::tunables_script, "Tunables"));
|
|
|
|
g_script_mgr.add_script(std::make_unique<script>(&backend::squad_spawner, "Squad Spawner"));
|
|
|
|
|
|
|
|
LOG(INFO) << "Scripts registered.";
|
|
|
|
|
|
|
|
g_hooking->enable();
|
|
|
|
LOG(INFO) << "Hooking enabled.";
|
|
|
|
|
|
|
|
auto native_hooks_instance = std::make_unique<native_hooks>();
|
|
|
|
LOG(INFO) << "Dynamic native hooker initialized.";
|
|
|
|
|
2023-07-08 17:54:59 +02:00
|
|
|
auto lua_manager_instance = std::make_unique<lua_manager>(g_file_manager.get_project_folder("scripts"));
|
2023-07-02 00:52:36 +02:00
|
|
|
LOG(INFO) << "Lua manager initialized.";
|
|
|
|
|
|
|
|
g_running = true;
|
|
|
|
|
|
|
|
// start update loop after setting g_running to true to prevent it from exiting instantly
|
|
|
|
g_player_database_service->start_update_loop();
|
|
|
|
|
|
|
|
while (g_running)
|
|
|
|
std::this_thread::sleep_for(500ms);
|
|
|
|
|
|
|
|
lua_manager_instance.reset();
|
|
|
|
LOG(INFO) << "Lua manager uninitialized.";
|
|
|
|
|
|
|
|
g_hooking->disable();
|
|
|
|
LOG(INFO) << "Hooking disabled.";
|
|
|
|
|
|
|
|
native_hooks_instance.reset();
|
|
|
|
LOG(INFO) << "Dynamic native hooker uninitialized.";
|
|
|
|
|
|
|
|
g_script_mgr.remove_all_scripts();
|
|
|
|
LOG(INFO) << "Scripts unregistered.";
|
|
|
|
|
|
|
|
// cleans up the thread responsible for saving settings
|
|
|
|
g.destroy();
|
|
|
|
|
|
|
|
// Make sure that all threads created don't have any blocking loops
|
|
|
|
// otherwise make sure that they have stopped executing
|
|
|
|
thread_pool_instance->destroy();
|
|
|
|
LOG(INFO) << "Destroyed thread pool.";
|
|
|
|
|
|
|
|
script_connection_service_instance.reset();
|
|
|
|
LOG(INFO) << "Script Connection Service reset.";
|
|
|
|
tunables_service_instance.reset();
|
|
|
|
LOG(INFO) << "Tunables Service reset.";
|
|
|
|
hotkey_service_instance.reset();
|
|
|
|
LOG(INFO) << "Hotkey Service reset.";
|
|
|
|
matchmaking_service_instance.reset();
|
|
|
|
LOG(INFO) << "Matchmaking Service reset.";
|
|
|
|
player_database_service_instance.reset();
|
|
|
|
LOG(INFO) << "Player Database Service reset.";
|
|
|
|
api_service_instance.reset();
|
|
|
|
LOG(INFO) << "API Service reset.";
|
|
|
|
script_patcher_service_instance.reset();
|
|
|
|
LOG(INFO) << "Script Patcher Service reset.";
|
|
|
|
gui_service_instance.reset();
|
|
|
|
LOG(INFO) << "Gui Service reset.";
|
|
|
|
gta_data_service_instance.reset();
|
|
|
|
LOG(INFO) << "GTA Data Service reset.";
|
|
|
|
handling_service_instance.reset();
|
|
|
|
LOG(INFO) << "Vehicle Service reset.";
|
|
|
|
model_preview_service_instance.reset();
|
|
|
|
LOG(INFO) << "Model Preview Service reset.";
|
|
|
|
mobile_service_instance.reset();
|
|
|
|
LOG(INFO) << "Mobile Service reset.";
|
|
|
|
player_service_instance.reset();
|
|
|
|
LOG(INFO) << "Player Service reset.";
|
|
|
|
pickup_service_instance.reset();
|
|
|
|
LOG(INFO) << "Pickup Service reset.";
|
|
|
|
globals_service_instace.reset();
|
|
|
|
LOG(INFO) << "Globals Service reset.";
|
|
|
|
custom_text_service_instance.reset();
|
|
|
|
LOG(INFO) << "Custom Text Service reset.";
|
|
|
|
context_menu_service_instance.reset();
|
|
|
|
LOG(INFO) << "Context Service reset.";
|
2023-07-07 11:11:54 +02:00
|
|
|
xml_vehicles_service_instance.reset();
|
|
|
|
LOG(INFO) << "Xml Vehicles Service reset.";
|
2023-07-02 00:52:36 +02:00
|
|
|
LOG(INFO) << "Services uninitialized.";
|
|
|
|
|
|
|
|
hooking_instance.reset();
|
|
|
|
LOG(INFO) << "Hooking uninitialized.";
|
|
|
|
|
|
|
|
fiber_pool_instance.reset();
|
|
|
|
LOG(INFO) << "Fiber pool uninitialized.";
|
|
|
|
|
|
|
|
renderer_instance.reset();
|
|
|
|
LOG(INFO) << "Renderer uninitialized.";
|
|
|
|
|
|
|
|
byte_patch_manager_instance.reset();
|
|
|
|
LOG(INFO) << "Byte Patch Manager uninitialized.";
|
|
|
|
|
|
|
|
pointers_instance.reset();
|
|
|
|
LOG(INFO) << "Pointers uninitialized.";
|
|
|
|
|
|
|
|
thread_pool_instance.reset();
|
|
|
|
LOG(INFO) << "Thread pool uninitialized.";
|
2023-03-01 21:27:15 +00:00
|
|
|
|
|
|
|
LOG(INFO) << "Farewell!";
|
|
|
|
logger_instance->destroy();
|
|
|
|
logger_instance.reset();
|
|
|
|
|
|
|
|
CloseHandle(g_main_thread);
|
|
|
|
FreeLibraryAndExitThread(g_hmodule, 0);
|
|
|
|
},
|
|
|
|
nullptr,
|
|
|
|
0,
|
|
|
|
&g_main_thread_id);
|
2019-03-21 20:18:31 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
2023-07-05 07:30:06 +00:00
|
|
|
}
|