diff --git a/cheat-library/cheat-library.vcxproj b/cheat-library/cheat-library.vcxproj index f4dabce..627186e 100644 --- a/cheat-library/cheat-library.vcxproj +++ b/cheat-library/cheat-library.vcxproj @@ -931,7 +931,8 @@ - "$(OutDir)injector.exe" powershell -nop -c "& {sleep 15}" + "$(OutDir)injector.exe" +powershell -nop -c "& {sleep 20}" $(OutDir)_noexist.nope;%(Outputs) $(TargetPath);%(Inputs) diff --git a/cheat-library/src/appdata/il2cpp-types.h b/cheat-library/src/appdata/il2cpp-types.h index e21c02b..ca7e76a 100644 --- a/cheat-library/src/appdata/il2cpp-types.h +++ b/cheat-library/src/appdata/il2cpp-types.h @@ -11858,8 +11858,17 @@ namespace app { struct MoleMole_Config_ConfigAbilityModifier__Fields fields; }; + struct __declspec(align(8)) HKMHAGBLLMK__Fields { + struct MoleMole_BaseAbilityMixin__Array* JGLDNAPGGGC; + struct List_1_System_ValueTuple_2__1* JFLGBBBFBLF; + struct List_1_System_ValueTuple_2__2* EFOPNOEMFBI; + struct List_1_MoleMole_Config_ConfigAbilityAction__1* PGICFJEDMAE; + struct List_1_System_ValueTuple_3__1* CGBNAMBLDOE; + struct IList_1_MoleMole_BaseAbilityMixin_* LOGOJNMHLIF; + }; + struct MoleMole_ActorModifier__Fields { - void* _; + HKMHAGBLLMK__Fields _; struct MoleMole_ActorAbility* parentAbility; uint32_t parentAbilityInstanceID; struct MoleMole_Config_ConfigAbility* _parentAbilityConfig; diff --git a/cheat-library/src/user/cheat/player/GodMode.cpp b/cheat-library/src/user/cheat/player/GodMode.cpp index da3807b..bc1ae8d 100644 --- a/cheat-library/src/user/cheat/player/GodMode.cpp +++ b/cheat-library/src/user/cheat/player/GodMode.cpp @@ -6,19 +6,6 @@ namespace cheat::feature { - static bool Miscs_CheckTargetAttackable_Hook(app::BaseEntity* attacker, app::BaseEntity* target, MethodInfo* method); - static void VCHumanoidMove_NotifyLandVelocity_Hook(app::VCHumanoidMove* __this, app::Vector3 velocity, float reachMaxDownVelocityTime, MethodInfo* method); - static void LCBaseCombat_FireBeingHitEvent_Hook(app::LCBaseCombat* __this, uint32_t attackeeRuntimeID, app::AttackResult* attackResult, MethodInfo* method); - static bool MoleMole_ActorAbilityPlugin_HanlderModifierThinkTimerUp_Hook(app::ActorAbilityPlugin* __this, float delay, app::Object* arg, MethodInfo* method); - - std::vector v{ - "BlackMud", - "SERVER_ClimateAbility", - "ElectricWater", - "SeiraiThunder", - "UNIQUE_Monster_", - "Monster_Shougun"}; - GodMode::GodMode() : Feature(), NFEX(f_Enabled, "God mode", "m_GodMode", "Player", false, false), NF(f_AltGodMode, "Alternative God Mode", "Player", false) @@ -64,7 +51,7 @@ namespace cheat::feature } // Attack immunity (return false when target is avatar, that mean avatar entity isn't attackable) - static bool Miscs_CheckTargetAttackable_Hook(app::BaseEntity* attacker, app::BaseEntity* target, MethodInfo* method) + bool GodMode::Miscs_CheckTargetAttackable_Hook(app::BaseEntity* attacker, app::BaseEntity* target, MethodInfo* method) { auto& gm = GodMode::GetInstance(); auto& manager = game::EntityManager::instance(); @@ -78,7 +65,7 @@ namespace cheat::feature // Raised when avatar fall on ground. // Sending fall speed, and how many time pass from gain max fall speed (~30m/s). // To disable fall damage reset reachMaxDownVelocityTime and decrease fall velocity. - static void VCHumanoidMove_NotifyLandVelocity_Hook(app::VCHumanoidMove* __this, app::Vector3 velocity, float reachMaxDownVelocityTime, MethodInfo* method) + void GodMode::VCHumanoidMove_NotifyLandVelocity_Hook(app::VCHumanoidMove* __this, app::Vector3 velocity, float reachMaxDownVelocityTime, MethodInfo* method) { auto& gm = GodMode::GetInstance(); if ((gm.f_Enabled || gm.f_AltGodMode) && -velocity.y > 13) @@ -92,7 +79,7 @@ namespace cheat::feature } // Analog function for disable attack damage (Thanks to Taiga74164) - static void LCBaseCombat_FireBeingHitEvent_Hook(app::LCBaseCombat* __this, uint32_t attackeeRuntimeID, app::AttackResult* attackResult, MethodInfo* method) + void GodMode::LCBaseCombat_FireBeingHitEvent_Hook(app::LCBaseCombat* __this, uint32_t attackeeRuntimeID, app::AttackResult* attackResult, MethodInfo* method) { auto& gm = GodMode::GetInstance(); auto& manager = game::EntityManager::instance(); @@ -103,55 +90,61 @@ namespace cheat::feature } // Environmental damage immunity (Thanks to RELOADED#7236 / GitHub: @34736384) - static bool MoleMole_ActorAbilityPlugin_HanlderModifierThinkTimerUp_Hook(app::ActorAbilityPlugin* __this, float delay, app::Object* arg, MethodInfo* method) + bool GodMode::MoleMole_ActorAbilityPlugin_HanlderModifierThinkTimerUp_Hook(app::ActorAbilityPlugin* __this, float delay, app::Object* arg, MethodInfo* method) { - auto& gm = GodMode::GetInstance(); - auto actorModifer = reinterpret_cast(arg); - auto argStr = actorModifer->fields._config->fields._modifierName; - std::string name; - - if ((uintptr_t)actorModifer->klass == *(uintptr_t*)app::MoleMole_ActorModifier__TypeInfo) - { - uintptr_t MoleMole_ActorModifier = (uintptr_t)arg; - uintptr_t ConfigAbilityModifier = *(uintptr_t*)(MoleMole_ActorModifier + 0x68); - if (ConfigAbilityModifier) - { - //app::String* modifierName = actorModifer->fields._config->fields._modifierName; - app::String* modifierName = *(app::String**)(ConfigAbilityModifier + 0x28); - if (modifierName) - name = il2cppi_to_string(modifierName).c_str(); - } - } + if (GetInstance().NeedBlockHanlerModifierThinkTimeUp(arg)) + return false; - if (gm.f_AltGodMode) - for (auto& v : v) - if (name.find(v) != std::string::npos) - return false; - - //LOG_DEBUG("%s", name.c_str()); return CALL_ORIGIN(MoleMole_ActorAbilityPlugin_HanlderModifierThinkTimerUp_Hook, __this, delay, arg, method); } -} -// ____________________________________________________________________________________________________________ -// | Name | Description | -// |------------------------------------------------------------------------|-----------------------------------| -// | SERVER_ClimateAbility_Cold_Area | Sheer cold | -// | SERVER_ClimateAbility_Cold_Lv1 | Sheer cold | -// | SERVER_ClimateAbility_Cold_Lv2 | Sheer cold | -// | SERVER_ClimateAbility_TsurumiMist_Area | Electric debuff | -// | SERVER_ClimateAbility_TatariRegion_Area | Electric debuff | -// | SERVER_ClimateAbility_TatariRegion_Lv1 | Electric debuff | -// | SERVER_ClimateAbility_TatariRegion_Lv2 | Electric debuff | -// | SERVER_ClimateAbility_SeiraiStorm_Area | Serai Island | -// | SERVER_ClimateAbility_SeiraiStorm_Lv1 | Serai Island | -// | SERVER_ClimateAbility_SeiraiStorm_Lv2 | Serai Island | -// | SERVER_ClimateAbility_TsurumiMist_Area | Tsurumi Island | -// | ElectricWaterAreaModifier | All electric water in inazuma | -// | BlackMudAreaBuff_Avatar | | -// | BlackMudAreaBuff_Avatar02 | | -// | WaterAreaModifier | | -// | SeiraiThunder_Manager | | -// | UNIQUE_Monster_Shougun_Mitakenarukami_BurstAtk02_NotInShieldPredicated | | -// | Monster_Shougun_Mitakenarukami_BurstAtk02_NotInShieldAtk | | -// |------------------------------------------------------------------------|-----------------------------------| \ No newline at end of file + bool GodMode::NeedBlockHanlerModifierThinkTimeUp(app::Object* arg) + { + if (!f_AltGodMode) + return false; + + auto actorModifier = CastTo(arg, *app::MoleMole_ActorModifier__TypeInfo); + if (actorModifier == nullptr) + return false; + + static std::vector modifierBlacklist + { + "BlackMud", + "SERVER_ClimateAbility", + "ElectricWater", + "SeiraiThunder", + "UNIQUE_Monster_", + "Monster_Shougun" + }; + + std::string modifierName = il2cppi_to_string(actorModifier->fields._config->fields._modifierName); + for (auto& forbiddenModifierName : modifierBlacklist) + if (modifierName.find(forbiddenModifierName) != std::string::npos) + return true; + + return false; + } + + // ____________________________________________________________________________________________________________ + // | Name | Description | + // |------------------------------------------------------------------------|-----------------------------------| + // | SERVER_ClimateAbility_Cold_Area | Sheer cold | + // | SERVER_ClimateAbility_Cold_Lv1 | Sheer cold | + // | SERVER_ClimateAbility_Cold_Lv2 | Sheer cold | + // | SERVER_ClimateAbility_TsurumiMist_Area | Electric debuff | + // | SERVER_ClimateAbility_TatariRegion_Area | Electric debuff | + // | SERVER_ClimateAbility_TatariRegion_Lv1 | Electric debuff | + // | SERVER_ClimateAbility_TatariRegion_Lv2 | Electric debuff | + // | SERVER_ClimateAbility_SeiraiStorm_Area | Serai Island | + // | SERVER_ClimateAbility_SeiraiStorm_Lv1 | Serai Island | + // | SERVER_ClimateAbility_SeiraiStorm_Lv2 | Serai Island | + // | SERVER_ClimateAbility_TsurumiMist_Area | Tsurumi Island | + // | ElectricWaterAreaModifier | All electric water in inazuma | + // | BlackMudAreaBuff_Avatar | | + // | BlackMudAreaBuff_Avatar02 | | + // | WaterAreaModifier | | + // | SeiraiThunder_Manager | | + // | UNIQUE_Monster_Shougun_Mitakenarukami_BurstAtk02_NotInShieldPredicated | | + // | Monster_Shougun_Mitakenarukami_BurstAtk02_NotInShieldAtk | | + // |------------------------------------------------------------------------|-----------------------------------| +} \ No newline at end of file diff --git a/cheat-library/src/user/cheat/player/GodMode.h b/cheat-library/src/user/cheat/player/GodMode.h index 79baf5a..94ce8ed 100644 --- a/cheat-library/src/user/cheat/player/GodMode.h +++ b/cheat-library/src/user/cheat/player/GodMode.h @@ -16,10 +16,18 @@ namespace cheat::feature const FeatureGUIInfo& GetGUIInfo() const override; void DrawMain() override; - virtual bool NeedStatusDraw() const override; + bool NeedStatusDraw() const override; void DrawStatus() override; private: + + bool NeedBlockHanlerModifierThinkTimeUp(app::Object* arg); + static bool MoleMole_ActorAbilityPlugin_HanlderModifierThinkTimerUp_Hook(app::ActorAbilityPlugin* __this, float delay, app::Object* arg, MethodInfo* method); + + static void LCBaseCombat_FireBeingHitEvent_Hook(app::LCBaseCombat* __this, uint32_t attackeeRuntimeID, app::AttackResult* attackResult, MethodInfo* method); + static void VCHumanoidMove_NotifyLandVelocity_Hook(app::VCHumanoidMove* __this, app::Vector3 velocity, float reachMaxDownVelocityTime, MethodInfo* method); + static bool Miscs_CheckTargetAttackable_Hook(app::BaseEntity* attacker, app::BaseEntity* target, MethodInfo* method); + GodMode(); }; }