Asi extracting-memory-artifacts-with-rekall
install
source · Clone the upstream repo
git clone https://github.com/plurigrid/asi
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/plurigrid/asi "$T" && mkdir -p ~/.claude/skills && cp -r "$T/plugins/asi/skills/extracting-memory-artifacts-with-rekall" ~/.claude/skills/plurigrid-asi-extracting-memory-artifacts-with-rekall && rm -rf "$T"
manifest:
plugins/asi/skills/extracting-memory-artifacts-with-rekall/SKILL.mdsource content
Extracting Memory Artifacts with Rekall
When to Use
- When performing authorized security testing that involves extracting memory artifacts with rekall
- When analyzing malware samples or attack artifacts in a controlled environment
- When conducting red team exercises or penetration testing engagements
- When building detection capabilities based on offensive technique understanding
Prerequisites
- Familiarity with security operations concepts and tools
- Access to a test or lab environment for safe execution
- Python 3.8+ with required dependencies installed
- Appropriate authorization for any testing activities
Instructions
Use Rekall to analyze memory dumps for signs of compromise including process injection, hidden processes, and suspicious network connections.
from rekall import session from rekall import plugins # Create a Rekall session with a memory image s = session.Session( filename="/path/to/memory.raw", autodetect=["rsds"], profile_path=["https://github.com/google/rekall-profiles/raw/master"] ) # List processes for proc in s.plugins.pslist(): print(proc) # Detect injected code for result in s.plugins.malfind(): print(result)
Key analysis steps:
- Load memory image and auto-detect profile
- Run pslist and psscan to find hidden processes
- Use malfind to detect injected/hollowed code in process VADs
- Examine network connections with netscan
- Extract suspicious DLLs and drivers with dlllist/modules
Examples
from rekall import session s = session.Session(filename="memory.raw") # Compare pslist vs psscan for hidden processes pslist_pids = set(p.pid for p in s.plugins.pslist()) psscan_pids = set(p.pid for p in s.plugins.psscan()) hidden = psscan_pids - pslist_pids print(f"Hidden PIDs: {hidden}")