#include "hooks.h" #include "plugin/PluginContainer.h" #include "utils/StorageUtilsDeprecated.h" #include "utils/logger.h" #include "utils/storage/StorageUtils.h" #include static const char **hook_names = (const char *[]){ "WUPS_LOADER_HOOK_INIT_WUT_MALLOC", "WUPS_LOADER_HOOK_FINI_WUT_MALLOC", "WUPS_LOADER_HOOK_INIT_WUT_NEWLIB", "WUPS_LOADER_HOOK_FINI_WUT_NEWLIB", "WUPS_LOADER_HOOK_INIT_WUT_STDCPP", "WUPS_LOADER_HOOK_FINI_WUT_STDCPP", "WUPS_LOADER_HOOK_INIT_WUT_DEVOPTAB", "WUPS_LOADER_HOOK_FINI_WUT_DEVOPTAB", "WUPS_LOADER_HOOK_INIT_WUT_SOCKETS", "WUPS_LOADER_HOOK_FINI_WUT_SOCKETS", "WUPS_LOADER_HOOK_INIT_WRAPPER", "WUPS_LOADER_HOOK_FINI_WRAPPER", "WUPS_LOADER_HOOK_GET_CONFIG", "WUPS_LOADER_HOOK_CONFIG_CLOSED", "WUPS_LOADER_HOOK_INIT_STORAGE_DEPRECATED", "WUPS_LOADER_HOOK_INIT_PLUGIN", "WUPS_LOADER_HOOK_DEINIT_PLUGIN", "WUPS_LOADER_HOOK_APPLICATION_STARTS", "WUPS_LOADER_HOOK_RELEASE_FOREGROUND", "WUPS_LOADER_HOOK_ACQUIRED_FOREGROUND", "WUPS_LOADER_HOOK_APPLICATION_REQUESTS_EXIT", "WUPS_LOADER_HOOK_APPLICATION_ENDS", "WUPS_LOADER_HOOK_INIT_STORAGE"}; void CallHook(const std::vector> &plugins, wups_loader_hook_type_t hook_type) { DEBUG_FUNCTION_LINE_VERBOSE("Calling hook of type %s [%d]", hook_names[hook_type], hook_type); for (const auto &plugin : plugins) { CallHook(*plugin, hook_type); } } void CallHook(const PluginContainer &plugin, wups_loader_hook_type_t hook_type) { for (const auto &hook : plugin.getPluginInformation().getHookDataList()) { if (hook->getType() == hook_type) { DEBUG_FUNCTION_LINE_VERBOSE("Calling hook of type %s for plugin %s [%d]", hook_names[hook->getType()], plugin.getMetaInformation().getName().c_str(), hook_type); void *func_ptr = hook->getFunctionPointer(); if (func_ptr != nullptr) { switch (hook_type) { case WUPS_LOADER_HOOK_INIT_WUT_MALLOC: case WUPS_LOADER_HOOK_FINI_WUT_MALLOC: case WUPS_LOADER_HOOK_INIT_WUT_NEWLIB: case WUPS_LOADER_HOOK_FINI_WUT_NEWLIB: case WUPS_LOADER_HOOK_INIT_WUT_STDCPP: case WUPS_LOADER_HOOK_FINI_WUT_STDCPP: case WUPS_LOADER_HOOK_INIT_WUT_DEVOPTAB: case WUPS_LOADER_HOOK_FINI_WUT_DEVOPTAB: case WUPS_LOADER_HOOK_INIT_WUT_SOCKETS: case WUPS_LOADER_HOOK_FINI_WUT_SOCKETS: case WUPS_LOADER_HOOK_INIT_WRAPPER: case WUPS_LOADER_HOOK_FINI_WRAPPER: case WUPS_LOADER_HOOK_GET_CONFIG: case WUPS_LOADER_HOOK_CONFIG_CLOSED: case WUPS_LOADER_HOOK_INIT_PLUGIN: case WUPS_LOADER_HOOK_DEINIT_PLUGIN: case WUPS_LOADER_HOOK_APPLICATION_STARTS: case WUPS_LOADER_HOOK_RELEASE_FOREGROUND: case WUPS_LOADER_HOOK_ACQUIRED_FOREGROUND: case WUPS_LOADER_HOOK_APPLICATION_REQUESTS_EXIT: case WUPS_LOADER_HOOK_APPLICATION_ENDS: // clang-format off ((void(*)())((uint32_t *) func_ptr))(); // clang-format on break; case WUPS_LOADER_HOOK_INIT_STORAGE: case WUPS_LOADER_HOOK_INIT_STORAGE_DEPRECATED: { if (plugin.getMetaInformation().getWUPSVersion() < WUPSVersion(0, 7, 2)) { WUPSStorageDeprecated::wups_loader_init_storage_args_t_ args{}; args.open_storage_ptr = &WUPSStorageDeprecated::StorageUtils::OpenStorage; args.close_storage_ptr = &WUPSStorageDeprecated::StorageUtils::CloseStorage; args.plugin_id = plugin.getMetaInformation().getStorageId().c_str(); // clang-format off ((void(*)(WUPSStorageDeprecated::wups_loader_init_storage_args_t_))((uint32_t *) func_ptr))(args); // clang-format on break; } wups_loader_init_storage_args_t_ args{}; args.version = WUPS_STORAGE_CUR_API_VERSION; args.open_storage_ptr = &StorageUtils::API::OpenStorage; args.close_storage_ptr = &StorageUtils::API::CloseStorage; args.delete_item_function_ptr = &StorageUtils::API::DeleteItem; args.create_sub_item_function_ptr = &StorageUtils::API::CreateSubItem; args.get_sub_item_function_ptr = &StorageUtils::API::GetSubItem; args.store_item_function_ptr = &StorageUtils::API::StoreItem; args.get_item_function_ptr = &StorageUtils::API::GetItem; args.get_item_size_function_ptr = &StorageUtils::API::GetItemSize; args.plugin_id = plugin.getMetaInformation().getStorageId().c_str(); // clang-format off auto res = ((WUPSStorageError(*)(wups_loader_init_storage_args_t_))((uint32_t *) func_ptr))(args); // clang-format on if (res == WUPS_STORAGE_ERROR_INVALID_VERSION) { // TODO: More error handling? Notification? DEBUG_FUNCTION_LINE_ERR("WUPS_LOADER_HOOK_INIT_STORAGE failed for plugin %s: WUPS_STORAGE_ERROR_INVALID_VERSION", plugin.getMetaInformation().getName().c_str()); } break; } default: { DEBUG_FUNCTION_LINE_ERR("######################################"); DEBUG_FUNCTION_LINE_ERR("Hook is not implemented %s [%d]", hook_names[hook_type], hook_type); DEBUG_FUNCTION_LINE_ERR("######################################"); } } } else { DEBUG_FUNCTION_LINE_ERR("Failed to call hook. It was not defined"); } break; } } }