Your AI Assistant in Memory Forensics
Overview
Volatility MCP seamlessly integrates Volatility 3's powerful memory analysis with FastAPI and the Model Context Protocol (MCP). Experience memory forensics without barriers as plugins like pslist and netscan become accessible through clean REST APIs, connecting memory artifacts directly to AI assistants and web applications
Features
- Volatility 3 Integration: Leverages the Volatility 3 framework for memory image analysis.
- FastAPI Backend: Provides RESTful APIs to interact with Volatility plugins.
- Web Front End Support (future feature): Designed to connect with a web-based front end for interactive analysis.
- Model Context Protocol (MCP): Enables standardized communication with MCP clients like Claude Desktop.
- Plugin Support: Supports various Volatility plugins, including
pslistfor process listing andnetscanfor network connection analysis.
Architecture
The project architecture consists of the following components:
- MCP Client: MCP client like Claude Desktop that interacts with the FastAPI backend.
- FastAPI Server: A Python-based server that exposes Volatility plugins as API endpoints.
- Volatility 3: The memory forensics framework performing the analysis.
This architecture allows users to analyze memory images through MCP clients like Claude Desktop. Users can use natural language prompts to perform memory forensics analysis such as show me the list of the processes in memory image x, or show me all the external connections made
Getting Started
Prerequisites
- Python 3.7+ installed on your system
- Volatility 3 binary installed (see Volatility 3 Installation Guide) and added to your env path called VOLATILITY_BIN
Installation
-
Clone the repository:
git clone <repository_url> cd <repository_directory> ```
-
Install the required Python dependencies:
pip install -r requirements.txt ```
-
Start the FastAPI server to expose Volatility 3 APIs:
uvicorn volatility_fastapi_server:app
```
4. Install Claude Desktop (see Claude Desktop
5. To configure Claude Desktop as a volatility MCP client, navigate to Claude → Settings → Developer → Edit Config, locate the claude_desktop_config.json file, and insert the following configuration details
6. Please note that the -i option in the config.json file specifies the directory path of your memory image file.
{
"mcpServers": {
"vol": {
"command": "python",
"args": [
"/ABSOLUTE_PATH_TO_MCP-SERVER/vol_mcp_server.py", "-i",
"/ABSOLUTE_PATH_TO_MEMORY_IMAGE/<memory_image>"
]
}
}
}
Alternatively, update this file directly:
/Users/YOUR_USER/Library/Application Support/Claude/claude_desktop_config.json
Usage
- Start the FastAPI server as described above.
- Connect an MCP client (e.g., Claude Desktop) to the FastAPI server.
- Start the prompt by asking questions regarding the memory image in scope, such as showing me the running processes, creating a tree relationship graph for process x, or showing me all external RFC1918 connections.
Future Features and Enhancements
- Native Volatility Python Integration: Incorporate Volatility Python SDK directly in the code base as opposed to subprocess volatility binary
- Yara Integration: Implement functionality to dump a process from memory and scan it with Yara rules for malware analysis.
- Multi-Image Analysis: Enable the analysis of multiple memory images simultaneously to correlate events and identify patterns across different systems.
- Adding more Volatility Plugins: add more volatility plugins to expand the scope of memory analysis
- GUI Enhancements: Develop a user-friendly web interface for interactive memory analysis and visualization.
- Automated Report Generation: Automate the generation of detailed reports summarizing the findings of memory analysis.
- Advanced Threat Detection: Incorporate advanced techniques for detecting sophisticated threats and anomalies in memory.
Contributing
Contributions are welcome! Please follow these steps to contribute:
- Fork this repository.
- Create a new branch (
git checkout -b feature/my-feature). - Commit your changes (
git commit -m 'Add some feature'). - Push to your branch (
git push origin feature/my-feature). - Open a pull request.
Recommend MCP Servers 💡
serper-mcp-server
A Model Context Protocol server that provides Google Search via Serper, enabling LLMs to get search result information from Google.
MathsIA API
A FastAPI application providing a RESTful API for MathsIA, a flashcard system for learning mathematics, with integrated Model Control Protocol (MCP) for AI control.
notion-server
MCP server for seamless integration with Notion workspace operations
OpsLevel
OpsLevel is an internal developer portal that acts as an MCP server, providing real-time, unified context from your entire tech stack to power AI assistants and streamline software development.
sneharao/wheather-mcp-server
A custom weather MCP server that provides weather alerts and information through Claude Desktop by location prompts.
google-pse-mcp
An MCP server integrating Google Programmable Search Engine (PSE) API to provide web search tools for MCP clients
