rikune
v1.2.0
Published
MCP server for Windows binary reverse engineering, PE triage, Ghidra-assisted analysis, and reconstruction workflows.
Downloads
36
Maintainers
Readme
Rikune
Rikune is an MCP server for reverse engineering Windows executables and related binary formats. It combines sample intake, static triage, Ghidra-assisted function recovery, plugin-driven specialist tooling, artifact management, and optional isolated Windows runtime execution behind a Model Context Protocol interface.
The current server is organized around a staged analysis pipeline:
- Import a sample with
sample.ingestor request a durable upload session withsample.request_upload. - Start analysis with
workflow.analyze.start. - Poll with
workflow.analyze.status. - Promote deeper stages with
workflow.analyze.promote. - Inspect artifacts with
artifact.*,analysis.context.get, reporting tools, or semantic review workflows.
workflow.triage is still available as a compatibility and quick-profile facade, but new clients should prefer workflow.analyze.start/status/promote.
What Rikune Provides
- MCP stdio server for AI clients and agent runtimes.
- Optional HTTP API and dashboard for uploads, downloads, health checks, SSE events, and artifact access.
- SHA-256 based sample workspaces with durable original files, cache directories, analysis artifacts, and upload sessions.
- SQLite-backed persistence for samples, analyses, jobs, evidence, artifacts, batches, debug sessions, and scheduler telemetry.
- Plugin architecture with 56 built-in plugins and external plugin discovery.
- Progressive tool surface: core tools are always visible, specialist tools are exposed according to sample type, findings, or explicit discovery.
- Static analysis and enrichment for PE, ELF, Mach-O, APK/DEX, Office, firmware, strings, YARA, SBOM, signatures, packers, .NET, Go, Rust, and more.
- Ghidra, Rizin, RetDec, angr, Capstone, Graphviz, Qiling, PANDA, Speakeasy, Wine, Frida, and dynamic-runtime integration where available.
- Optional Analyzer/Runtime split for live Windows execution through a Windows Host Agent, Windows Sandbox, or Hyper-V VM.
- Policy gates for live execution, network access, external upload, and bulk decompilation.
Quick Start
Static Docker Analyzer
Static Docker is the safest default. It does not execute samples.
.\rikune.ps1 install -Profile static -DataRoot "D:\Docker\rikune"./rikune.sh install --profile static --data-root "$HOME/.rikune"Manual equivalent:
npm install
npm run build
npm run docker:generate:all
docker compose --env-file .docker-runtime.env -f docker-compose.analyzer.yml up -d --build analyzerHybrid Docker + Windows Runtime
Hybrid mode runs the Analyzer in Docker and delegates live Windows work to a Windows Host Agent. The Host Agent can start Windows Sandbox on demand or control a configured Hyper-V VM.
.\rikune.ps1 install -Profile hybrid -InstallRuntimeFrom Linux/macOS with a remote Windows runtime host:
./rikune.sh install --profile hybrid --windows-host <windows-host> --windows-user <windows-user>Connecting an MCP client does not start Windows Sandbox or run a sample. Live runtime work only starts when a tool explicitly requests it, such as runtime.debug.session.start, runtime.debug.command, sandbox.execute, or a promoted dynamic execution stage.
Native Development
npm install
npm run build
npm test
node dist/index.jsThe root package requires Node.js 22 or newer. Some runtime subpackages can run on older Node versions, but repository development and the published root CLI should use Node 22+.
Primary MCP Flow
Upload Or Ingest
Use one of:
sample.ingestwith a server-readable path orbytes_b64.sample.request_uploadto create an upload URL, then POST raw bytes to the embedded HTTP server.POST /api/v1/sampleswhen the HTTP API is enabled.
Successful ingest returns a sample_id. Analysis tools should use sample_id, not a local path, after import.
Start Analysis
Call workflow.analyze.start with the sample_id. The first stage performs a fast profile and creates or reuses an analysis run.
Promote Stages
Use workflow.analyze.promote to request deeper stages. The pipeline currently models these stages:
fast_profileenrich_staticfunction_mapreconstructsemantic_reviewsdynamic_plandynamic_executesummarize
Long-running work is queued through the job system. Poll with workflow.analyze.status and task.status.
workflow.analyze.status is the primary staged-run view. Large historical stage payloads may be pruned with a top-level warning; use artifact.read for full artifacts. task.status is the raw queue/process view and includes external_active_* memory telemetry for analyzer subprocesses.
Review Results
Useful follow-up surfaces:
sample.profile.getanalysis.context.getartifact.list,artifact.read,artifact.diff,artifact.downloadreport.summarize,report.generate,workflow.summarizeworkflow.semantic_name_reviewworkflow.function_explanation_reviewworkflow.module_reconstruction_reviewtools.discoverandtool.readiness
Architecture
The current code path is:
src/index.ts
-> loadConfig()
-> WorkspaceManager / DatabaseManager / PolicyGuard / CacheManager / StorageManager / JobQueue
-> optional RuntimeClient or Windows sandbox bootstrap
-> registerAllTools()
-> MCP stdio serverCore server modules live under src/core/:
| Area | Current file |
| --- | --- |
| MCP server wrapper | src/core/server.ts |
| MCP tool/prompt/resource registry | src/core/mcp-registry.ts |
| Tool execution, validation, hooks | src/core/tool-executor.ts |
| Registry orchestration | src/core/tool-registry.ts |
| Built-in registry slices | src/core/tool-registry/*.ts |
| Plugin manager facade | src/core/plugins.ts |
| Plugin discovery/loading | src/core/plugin-orchestrator.ts |
| Progressive tool exposure | src/core/tool-surface-manager.ts |
Some root-level files such as src/server.ts, src/tool-registry.ts, and src/plugins.ts remain compatibility forwarders. New code should target src/core/*.
Deployment Planes
| Plane | Purpose | Key code |
| --- | --- | --- |
| Analyzer | MCP stdio server, HTTP API, storage, jobs, static tools, plugin orchestration | src/index.ts, src/core/* |
| Runtime Node | Isolated task executor inside sandbox or VM | packages/runtime-node/* |
| Windows Host Agent | Starts/stops Windows Sandbox or Hyper-V runtime and exposes runtime control endpoints | packages/windows-host-agent/* |
| Agent Gateway | MCP gateway/proxy for analyzer/runtime connection management | src/rikune-agent-gateway.ts |
Runtime modes are configured through runtime.mode or environment variables:
disabled: no runtime delegation.manual: connect to a supplied runtime endpoint.remote-sandbox: delegate to a Windows Host Agent.auto-sandbox: Windows-native analyzer launches Windows Sandbox locally.
Docker/WSL analyzers should use remote-sandbox, not auto-sandbox.
Plugin System
Rikune currently includes 56 built-in plugins under src/plugins/<id>/. Plugins can register tools, declare dependencies, expose configuration schema, participate in lifecycle hooks, and provide Docker metadata.
Plugin loading is controlled by PLUGINS:
PLUGINS=* # all built-ins
PLUGINS=pe-analysis,yara # selected plugins
PLUGINS=-dynamic # all except dynamicUse these MCP tools at runtime:
plugin.listplugin.enableplugin.disabletools.discovertool.readiness
See docs/PLUGINS.md and packages/plugin-sdk/README.md.
HTTP API
When api.enabled is true, the embedded file server exposes:
| Endpoint | Purpose |
| --- | --- |
| /dashboard and / | Dashboard UI |
| /api/v1/health | Liveness |
| /api/v1/ready | Readiness across database, queue, runtime, and plugin backends |
| /api/v1/events | SSE events |
| /api/v1/samples | Direct sample upload |
| /api/v1/samples/:id | Sample metadata |
| /api/v1/samples/:id/download | Original sample download |
| /api/v1/artifacts | Artifact listing |
| /api/v1/artifacts/:id | Artifact read/delete |
| /api/v1/uploads/:token | Durable upload session POST/status |
API key auth, rate limiting, security headers, and limited CORS are handled by the HTTP layer.
Prerequisites
Minimum development baseline:
- Node.js 22+
- npm
- Python 3.11+ recommended for workers and analysis scripts
- Docker 20.10+ and Docker Compose v2 for Docker profiles
- Java 21+ for modern Ghidra releases
- Ghidra for decompiler-backed function analysis
- Windows 10/11 Pro, Enterprise, or equivalent VM support for Windows Sandbox and Hyper-V runtime paths
Optional tools are plugin-specific. Run system.health, system.setup.guide, tool.readiness, and plugin.list to see what is missing in a given environment.
Project Layout
src/
index.ts main server entry
core/ MCP server, registry, executor, plugin orchestration
core/tool-registry/ built-in tool/prompt/resource registration slices
tools/ core tool implementations
workflows/ staged analysis, triage, reconstruction, review workflows
analysis/ run state and background task runner
plugins/ 56 built-in plugins
persistence/ SQLite and workspace persistence
sample/ sample finalization and workspace inspection
storage/ artifacts, uploads, retention
runtime-client/ analyzer-side runtime delegation client
worker/ Ghidra and Python worker orchestration
packages/
plugin-sdk/ public plugin SDK
shared/ runtime and tool contract types
runtime-node/ isolated runtime executor
windows-host-agent/ Windows Sandbox / Hyper-V host agent
workers/ Python worker scripts and YARA rules
docker/ generated Dockerfile templates and profile files
docs/ architecture, plugin, runtime, deployment docs
tests/ unit, integration, and e2e testsDevelopment Commands
npm install
npm run build
npm test
npm run typecheck
npm run validate
npm run docker:generate:allUseful focused checks:
npm run test:unit
npm run test:integration
npm run test:e2e
npm run build:runtimeMCP Client Configuration
Local build:
{
"mcpServers": {
"rikune": {
"command": "node",
"args": ["D:/Playground/windows-exe-decompiler-mcp-server/dist/index.js"],
"env": {
"API_ENABLED": "true",
"API_PORT": "18080",
"PLUGINS": "*"
}
}
}
}Docker stdio:
{
"mcpServers": {
"rikune": {
"command": "docker",
"args": ["exec", "-i", "rikune-analyzer", "node", "dist/index.js"]
}
}
}Published package:
npm install -g rikune
rikune
rikune docker-stdio
rikune agentStorage
By default Rikune stores persistent data under the user-level Rikune root. Docker installers usually map that root to a host directory such as D:\Docker\rikune.
Common subdirectories:
samples/artifacts/uploads/cache/logs/- SQLite database file
- audit log JSONL
Sample workspaces are bucketed by SHA-256 to avoid path collisions and preserve immutable originals.
Security Boundaries
Rikune is designed for malware and untrusted binary analysis, but it is not a magic safety boundary by itself.
- Static Docker mode should be the default for routine analysis.
- Live Windows execution must happen inside Windows Sandbox or an isolated VM.
- Runtime Node refuses unsafe startup unless explicitly overridden.
- Dangerous actions are guarded by
PolicyGuard. - Command execution uses structured process APIs and allowlisted command validation.
- Do not run unknown samples on a host workstation outside the runtime isolation model.
See SECURITY.md and TROUBLESHOOTING.md.
Documentation Map
- INSTALL.md: Docker installer guide in Chinese.
- DEPLOYMENT.md: deployment profiles and runtime topology.
- docs/ARCHITECTURE.md: current code architecture.
- docs/PLUGINS.md: plugin list, SDK concepts, lifecycle, discovery.
- docs/ANALYSIS-RUNTIME.md: staged runtime and analysis execution model.
- docs/ASYNC-JOB-PATTERN.md: async job and polling pattern.
- docs/MIGRATION-ASYNC.md: migration notes for staged async workflows.
- docs/DYNAMIC-RUNTIME-ROADMAP.md: runtime roadmap and status.
- CONTRIBUTING.md: development and contribution flow.
- packages/plugin-sdk/README.md: plugin authoring package.
- workers/README.md: Python worker contract.
License
MIT
