Code Monkey home page Code Monkey logo

oro-bypass's Introduction

Oro / bypass

This is a very simple GameGuard bypass for RumbleFighter, an action fighting MMO. It was written in C++ using C++ 11 conventions and the win32 api.

About

The bypass works as follows:

  • Patches the GameGuard security subroutine. I've patched the subroutine rather than it's invocations, because this subroutine is used in multiple tricky contexts ie; loops inside of external threads.

  • Kill communication between both the client and the daemon. The client talks with the GameGuard daemon to ensure it's health. If communication is impossible, the client will kill itself or the daemon will terminate the process.

  • Kill the GameGuard daemon -> GameMon.des/GameMon64.des. If these daemons are left running after the changes above, they will terminate the client automatically because they cannot establish any communication.

It is not a complete bypass, in the sense that it will disarm GameGuard specific security checking routines, but does not include heartbeat emulation.

Because a heartbeat is not active, your client will inevitably disconnect after prolonged usage.

This bypass takes care of the following detections,

  • GameGuard has been falsified (GG not properly handling errors)
  • Hack detected (hacking tools, static memory modification)
  • GameGuard initialization failed (GG daemon did not respond)
  • Speed Hack (query tick performance counter modifications)
  • Unhandeled Exception (cannot determine security status)

Pattern scanning has been included, so the bypass should be able to persist over client versions.

Use

Simply build the project and inject the library into the RumbleFighter client. When the client window is created, the bypass will initialize itself.

Warning: In the event Oro cannot terminate the GG daemon using the win32 TerminateProcess method, the host machine must have PSTools installed. PSTools was levereged to avoid writing a custom driver, for the sake of saving time. @ https://docs.microsoft.com/en-us/sysinternals/downloads/pskill

Disclaimer

This project was created for eductional purposes only. I have not, and will not monetize this code for any personal gains.


Copyright (c) 2019 John Nolette Licensed under the MIT license.

oro-bypass's People

Contributors

neetjn avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

oro-bypass's Issues

create jmp based off of end sub address

oro-bypass/Oro/oro.cpp

Lines 68 to 73 in b186ec0

// TODO: create jmp based off of end sub address
// possibly try inline assembly?
memapi::write(this->gg_falsified, "EB 24"); // # route to no errors detected
memapi::write(this->gg_hack_detected, "EB 2B"); // # route to no errors detected
memapi::write(this->gg_init, "E9 94 00 00 00 90 90"); // # route to no errors detected
memapi::write(this->gg_speed_hack, "EB 63 90 90 90");


This issue was generated by todo based on a TODO comment in b186ec0. It's been assigned to @neetjn because they committed the code.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.