Skip to content

Latest commit

 

History

History
289 lines (221 loc) · 14 KB

README.md

File metadata and controls

289 lines (221 loc) · 14 KB

RedEdr

Display events from Windows to see the detection surface of your malware.

Same data as an EDR sees.

  • Find the telemetry your malware generates
  • Verify your anti-EDR techniques work
  • Debug and analyze malware

RedEdr will observe one process, and identify malicious patterns. A normal EDR will observe all processes, and identify malicious processes.

It generates JSON files collecting the telemetry of your RedTeaming tools.

Try it online at rededr.r00ted.ch

Screenshots

The following shellcode execution:

	PVOID shellcodeAddr = VirtualAlloc(NULL, payloadSize, MEM_COMMIT | MEM_RESERVE, PAGE_READWRITE);
	memcpy(shellcodeAddr, payload, payloadSize);
	VirtualProtect(shellcodeAddr, payloadSize, PAGE_EXECUTE_READWRITE, &dwOldProtection));
	HANDLE hThread = CreateThread(NULL, 0, shellcodeAddr, shellcodeAddr, 0, &threadId);

Can be detected in the RedEdr events by looking at the RW->RWX VirtualProtect and following CreateThread invocation.

With ntdll.dll hooking: RedEdr Screenshot ntdll.dll hooking

ETW events: RedEdr Screenshot ETW

Implemented Telemetry Consumers

  • ETW

    • Microsoft-Windows-Kernel-Process
    • Microsoft-Windows-Kernel-Audit-API-Calls
    • Microsoft-Windows-Security-Auditing
      • needs SYSTEM
      • restrictions apply, configure group policy
    • And defender
      • Microsoft-Antimalware-Engine
      • Microsoft-Antimalware-RTP
      • Microsoft-Antimalware-AMFilter
      • Microsoft-Antimalware-Scan-Interface
      • Microsoft-Antimalware-Protection
  • ETW-TI (Threat Intelligence) with a PPL service via ELAM driver

  • Kernel Callbacks

    • PsSetCreateProcessNotifyRoutine
    • PsSetCreateThreadNotifyRoutine
    • PsSetLoadImageNotifyRoutine
    • (ObRegisterCallbacks, not used atm)
  • AMSI-style ntdll.dll hooking

    • from kernelspace (KAPC from LoadImage callback)
    • from userspace (ETW based, unreliable)
  • Callstacks

    • On ntdll.dll hook invocation
    • On several ETW events
  • process query:

    • PEB
    • Loaded DLL's (and their regions)

Installation

Use a dedicated VM for RedEdr. Tested on unlicensed (no Defender) Win10 Pro. Install VS2022 as we need it's debug libraries.

Change Windows boot options to enable self-signed kernel drivers and reboot. As admin cmd:

bcdedit /set testsigning on
bcdedit -debug on

If you use Hyper-V, uncheck "Security -> Enable Secure Boot".

Extract release.zip into C:\RedEdr. No other directories are supported.

Start terminal as local admin.

Change into C:\RedEdr and run .\RedEdr.exe:

PS C:\rededr> .\RedEdr.exe
Maldev event recorder
Usage:
  RedEdr [OPTION...]
  -t, --trace arg     Process name to trace
  -e, --etw           Input: Consume ETW Events
  -g, --etwti         Input: Consume ETW-TI Events
  -m, --mplog         Input: Consume Defender mplog file
  -k, --kernel        Input: Consume kernel callback events
  -i, --inject        Input: Consume DLL injection
  -w, --web           Output: Web server
...

Try: .\RedEdr.exe --all --trace otepad, and then start notepad (will be notepad.exe on Windows 10, Notepad.exe on Windows 11). The log should be printed as stdout.

Standard Usage

RedEdr will trace all processes containing by process image name (exe path).

Enable all consumers, and provide as web on http://localhost:8080, and disable output logging for performance:

PS > .\RedEdr.exe --all --web --hide --trace notepad.exe

Be aware ETW-TI (and possibly other ETW) will record the DLL hooking events if used together like this. Better use one of the following.

ntdll.dll hooking

KAPC DLL injection for ntdll.dll hooking. Thats what many EDR's depend on:

PS > .\RedEdr.exe --kernel --inject --trace notepad.exe

This requires self-signed kernel modules to load.

ETW & ETW-TI

ETW is mostly useful for MDE and Elastic.

ETW-TI requires an ELAM driver to start RedEdrPplService, and therefore requires self signed kernel driver option. Make a snapshot of your VM before doing this. Currently its not possible to remove the PPL service ever again.

PS > .\RedEdr.exe --etw --etwti --trace notepad.exe

If you want ETW Microsoft-Windows-Security-Auditing, start as SYSTEM (psexec -i -s cmd.exe). See gpedit.msc -> Computer Configuration -> Windows Settings -> Security Settings -> Advanced Audit Policy Configuration -> System Audit Policies - Local Group Policy object for settings to log.

Detections

  • RWX allocation
  • RW->RX protection change
  • Callstack from non-image

Example Output

See Data/ directory:

Hacking

Arch:

      ┌─────┐  ┌────────┐ ┌─────────┐  ┌──────┐                            
      │ ETW │  │ ETW-TI │ │ Kernel  │  │ DLL  │                            
      └──┬──┘  └───┬────┘ └────┬────┘  └──┬───┘                            
         │         │           │          │                                
         └─────────┴─────────┬─┴──────────┘                                
                             │                                             
                             │                                             
                             ▼                                             
                     ┌────────────────┐                                    
                     │                │                                    
Event as JSON string │  Event         │                                    
                     │  Aggregator    │                                    
                     │                │               ┌──────────┐         
                     └───────┬────────┘               │ Process  │         
                             │                        └──────────┘         
                             │                             ▲               
                             ▼                             │query          
                     ┌────────────────┐                    │               
                     │                │         ┌──────────┴────┐          
Event as JSON in C++ │  Event         ├────────►│ Process Query │          
                     │  Processor     │         └─────────────┬─┘          
                     │                │                       │add         
                     └┬───────────────┘                       ▼            
                      │                                    ┌──────────────┐
                      │ ┌────────────────────────┐query    │              │
                      ├─┤Event Augment           ├────────►┤  Mem Static  │
                      │ └────────────────────────┘         │              │
                      │ ┌────────────────────────┐add      └──────────────┘
                      ├─┤Event Mem Tracker       ├──────┐                  
                      │ └────────────────────────┘      │  ┌──────────────┐
                      │ ┌────────────────────────┐query └─►│              │
                      ├─┤Event Detection         ├───┐     │ Mem Dynamic  │
                      │ └────────────────────────┘   └────►│              │
                      ▼ ┌────────────────────────┐         └──────────────┘
                      └─┤Event Storage & Output  │                         
                        └────────────────────────┘                         

IPC:

  RedEdr.exe                                                                                       
┌────────────┐                    ┌─────────────────┐                                             
│            │   KERNEL_PIPE      │                 │    KERNEL_PIPE: Events (wchar)              
│            │◄───────────────────┤   Kernel Module │                                             
│ Pipe Server│                    │                 │    IOCTL: Config (MY_DRIVER_DATA):          
│            ├───────────────────►│                 │             filename                        
│            │   IOCTL            └─────────────────┘             enable                          
│            │                                                                                    
│            │                                                                                    
│            │                                                                                    
│            │                                                                                    
│            │                    ┌─────────────────┐                                             
│            │   DLL_PIPE         │                 │  DLL_PIPE: 1: Config (wchar)   RedEdr -> DLL
│ Pipe Server│◄───────────────────┤  Injected DLL   │                 "callstack:1;"              
│            │                    │                 │                                             
│            │                    │                 │           >1: Events (wchar)   RedEdr <- DLL
│            │                    └─────────────────┘                                             
│            │                                                                                    
│            │                                                                                    
│            │                                                                                    
│            │                    ┌─────────────────┐                                             
│            │   PPL_PIPE         │                 │  DLL_PIPE: Events (wchar)                   
│ Pipe Server│◄───────────────────┤  ETW-TI Service │                                             
│            │                    │  PPL            │                                             
│            │   SERVICE_PIPE     │                 │  SERVICE_PIPE: Config (wchar)               
│ Pipe Client├───────────────────►│                 │                  "start:<process name>"     
│            │                    └─────────────────┘                                             
│            │                                                                                    
│            │                    ┌─────────────────┐                                             
│            │◄───────────────────┤                 │                                             
│            │                    │  ETW            │                                             
│            │                    │                 │                                             
│            │                    │                 │                                             
│            │                    └─────────────────┘                                             
│            │                                                                                    
│            │                                                                                    
└────────────┘                                                                                    

Compiling

Good luck.

Use VS2022. Compile as DEBUG.

To compile the kernel driver:

It should deploy everything into C:\RedEdr\.

Based on

Based on MyDumbEdr

With KAPC injection from:

To run as PPL:

Libraries used