The "NoMercy" project is "the gold standard" open source Windows kernel/user mode anti cheat written with C/C++.
- The project is still under development
- Currently just developed and tested on Windows 10 x64 RS4(1804) as x64 process
- Build 3rd party dependencies or download released pre-compiled bundle and extract .zip content to "NoMercy\Extern\CompiledLibs"
- Windows Vista or greater
- DLL inject detection
- Thread inject detection
- Harmful thread detection
- Virtual memory code inject detection
- Virtual memory code modification detection
- Virtual memory module integrity protection
- Virtual memory hook & breakpoint & dump protection
- Ingame harmful window detection
- Mouse & Keyboard automation detection
- Ingame keyboard hijack detection
- Software & hardware macro detection
- Multi client detection
- Game client modification detection
- Detect/Reject/Analysis game process memory access
- Detect/Reject/Analysis game process handle access
- Detect/Reject Kernel and User mode debugging
- Detection execute on virtual machine, emulation and generic sandboxes
- Hardware information based ban system
- Heuristic detection
- Common checks; File, Driver, Handle, Heap, Module, System object, Process, Virtual memory section, Thread, Window
- Self integrity protection
- Splash UI
- Game specific protection methods
- Special ring3 access protection
- to be added later
- to be added later
- Node JS API server, TLS encrypted communication
- Plugin based heartbeat system
- Crash handler integration
- Self updater
- Global hook engine
- Protected network wrapper API for game <> client communication
- Web interface
- Remote Administration tool for manage master server connections
- Sequence
- Serializer
- Server daemon
- Dynamic key re-genereation on every 60sec for every peer
- P2P pool for master server
- Driver to Service Logger instance
- Integrity check for self OB callbacks
- Monitor section activity with minifilter (IRP_MJ_ACQUIRE_FOR_SECTION_SYNCHRONIZATION)
- Enumerate kernel memory for find manually mapped and hidden(unlinked), deleted(file), non-signed drivers, hijacked objects, non device created drivers
- Anti hook (Inline, IAT, EAT, SSDT, SSSDT, IDT)
- APC monitor for block injection
- Anti speed hack based time modification detection/manipulation
- Ring3 protection(PPL) for self protected apps
- Anti debug/sandbox/hypervisor/virtualization
- Scan/Analyse non paged allocations
- Physical memory based SBD scan (MmGetPhysicalMemoryRanges)
- Child process create monitor for our protected apps
- Protect from inherit'd handles
- Scan/Analyse VAD entries and hidden VAD entries
- g_CiOptions integrity check
- ExpLookupHandleTableEntry integrity check
- KPP integrity check
- SMEP integrity check
- PPL manipulation check
- PspNotifyEnableMask integrity check
- Physical memory user mode access check
- Block game hwnd access from window APIs(NtUserQueryWindow/NtUserBuildHwndList/NtUserFindWindowEx/NtUserGetForegroundWindow/NtUserSetWindowLong/NtUserWindowFromPoint)
- Block suspend access to our kernel threads from System(4) process
- Split handle owner system apps(csrss, lsass, pcasvc) accesses
- Scan unloaded drivers(MmUnloadedDriver-MmLastUnloadedDriver) Also manipulation check just like list is it null, list is filled with fake modules(time ranges)
- Manually iterate all drivers inside memory an check their integritys
- Hook & Analyse IRP_MJ_CREATE calls
- Real time detection status
- Game statistics data as Daily/weekly/monthly/quarterly/yearly
- Accessed counts
- Executed counts
- Hacking tool detection counts
- Unknown hardware devise frequency of use
- Nationally executed/access frequency of use
- Game play frequency of use
- Operate system frequency use
- National VPN detour frequency use
- List of nationality hacking tool detection/user
- Provide daily/weekly/monthly user statistic data
- Rank of hacking tool used IP
- Rank of hacking tool used system
- Rank of hacking tool used account
- Provide daily/weekly data
- Accessed account/system mapping information
- Hacking tool detection log information
- amy - License
- asyncplusplus - License
- boost - License
- ClanLib - License
- cryptopp - License
- Deviare-InProc - License
- lazy_importer - License
- MySQL - License
- rtti-obfuscator - License
- spdlog - License
- tinyxml2 - License
- xorstr - License
- xxHash - License
- rewolf-wow64ext - License
- ReflectiveDLLRefresher - License
NoMercy is licensed under the GPLv3 License. Dependencies are under their respective licenses.
- Fork it(https://github.com/mq1n/NoMercy/fork)
- Create your feature branch: "git checkout -b my-new-feature".
- Commit your changes: "git commit -am 'Add some feature'".
- Push to the branch: "git push origin my-new-feature".
- Submit a pull request.
If you did like to buy me a coffee, I won't complain. x)
1P6GqjR9TcoDkVNz4TJqQaH5SyTgnsyirB
0xdA847F888f2dfB1c491f0bf4cEc1D3A718e56695
qz9jn9yjkyxvp7tfjffjc2wjf4yxvgey3sekl3yrqu