MCP wrapper for JPEXS Free Flash Decompiler (FFDec) - expose SWF decompilation tools to AI assistants
Project description
ffdecmcp
MCP (Model Context Protocol) wrapper for JPEXS Free Flash Decompiler (FFDec) - expose SWF decompilation and analysis tools to AI assistants like Claude.
Tools
1. decompile_swf
Decompile all ActionScript code from a SWF file to organized directory structure.
Parameters:
swf_path(required): Absolute path to SWF fileoutput_dir(required): Directory for decompiled scriptstimeout(optional): Timeout in seconds (default: 60)
2. extract_actionscript
Extract specific ActionScript classes by name (AS3 only). Faster than full decompilation when you only need specific classes.
Parameters:
swf_path(required): Absolute path to SWF fileclass_names(required): List of class names (e.g.,['com.example.Main'])output_dir(required): Directory for extracted classestimeout(optional): Timeout in seconds (default: 60)
3. list_symbols
List all ActionScript classes and symbols in a SWF file. Great for exploring a SWF before full decompilation.
Parameters:
swf_path(required): Absolute path to SWF file
Returns: Structured JSON with packages, classes, and total count
4. extract_assets
Extract images, sounds, fonts, shapes, movie clips, and binary data from SWF.
Parameters:
swf_path(required): Absolute path to SWF fileoutput_dir(required): Directory for extracted assetsasset_types(optional): Types to extract -image,sound,font,shape,movie,binaryData,all(default:["all"])timeout(optional): Timeout in seconds (default: 60)
5. get_swf_metadata
Extract SWF header information (dimensions, frame rate, compression, etc.). Fast and doesn't require decompilation.
Parameters:
swf_path(required): Absolute path to SWF file
Returns: JSON with version, width, height, frame_rate, frame_count, compression
6. deobfuscate
Run FFDec's deobfuscation algorithms to remove obfuscation and anti-decompilation tricks.
Parameters:
swf_path(required): Absolute path to obfuscated SWFoutput_path(required): Path for deobfuscated SWFlevel(optional): Deobfuscation level -traps,deadcode,max(default:max)timeout(optional): Timeout in seconds (default: 60)
Quick Start
Prerequisites: Python 3.10+ and Java (for running the FFDec JAR).
Claude Code
claude mcp add ffdecmcp -- uvx ffdecmcp
That's it. On first run, FFDec will be auto-downloaded if not already installed.
Claude Desktop
Add to your config file (~/Library/Application Support/Claude/claude_desktop_config.json on macOS, %APPDATA%\Claude\claude_desktop_config.json on Windows):
{
"mcpServers": {
"ffdecmcp": {
"command": "uvx",
"args": ["ffdecmcp"]
}
}
}
Standalone
# Just run it - FFDec will be auto-downloaded to ~/.ffdecmcp/ if needed
uvx ffdecmcp
# Or point to an existing FFDec installation
uvx ffdecmcp --ffdec-path /path/to/ffdec.jar
Installation
No installation is required when using uvx. For a permanent install:
uv pip install ffdecmcp
# or
pip install ffdecmcp
FFDec
FFDec is automatically downloaded on first run if not found. You can also install it manually.
The server finds FFDec in this order:
--ffdec-pathCLI arg /FFDEC_PATHenv var- Previously auto-downloaded JAR (
~/.ffdecmcp/ffdec.jar) - Common install locations and PATH
- Auto-download from GitHub
CLI Options
ffdecmcp [--ffdec-path PATH] [--timeout SECONDS]
| Option | Env Var | Description |
|---|---|---|
--ffdec-path |
FFDEC_PATH |
Path to FFDec (JAR, native binary, or WSL path) |
--timeout |
FFDEC_TIMEOUT |
Default timeout in seconds (default: 60) |
CLI arguments take precedence over environment variables.
Development
git clone https://github.com/sublimnl/ffdecmcp.git
cd ffdecmcp
uv pip install -e ".[dev]"
Example Usage in Claude
You: Can you analyze this SWF file for me?
Path: C:\Users\foo\game.swf
Claude will:
1. Use get_swf_metadata to check dimensions, version, etc.
2. Use list_symbols to see what classes are present
3. Use decompile_swf to extract all ActionScript code
4. Analyze the decompiled code and provide insights
References
- FFDec: https://github.com/jindrapetrik/jpexs-decompiler
- FFDec CLI Docs: https://github.com/jindrapetrik/jpexs-decompiler/wiki/Commandline-arguments
- Model Context Protocol: https://modelcontextprotocol.io
- FastMCP: https://github.com/jlowin/fastmcp
License
MIT License - see LICENSE file for details
Contributing
Contributions welcome! Please open an issue or PR on GitHub.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file ffdecmcp-0.1.1.tar.gz.
File metadata
- Download URL: ffdecmcp-0.1.1.tar.gz
- Upload date:
- Size: 18.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.26 {"installer":{"name":"uv","version":"0.9.26","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"20.04","id":"focal","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
72d5f005dcc977188391ad6b9fd83f0fc2bfb16d6af18802dfd0e26f361d8042
|
|
| MD5 |
1d4118142da2e60b9f435daf8b54ee72
|
|
| BLAKE2b-256 |
68319eaf693eb92abfe89cdeac74a4cf3a5b7d9365aeeb9a268f0060bf8e05a8
|
File details
Details for the file ffdecmcp-0.1.1-py3-none-any.whl.
File metadata
- Download URL: ffdecmcp-0.1.1-py3-none-any.whl
- Upload date:
- Size: 17.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.26 {"installer":{"name":"uv","version":"0.9.26","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"20.04","id":"focal","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fd3e63bb0fbff74b5a573054f853bcf291bdee6088d6034331f6d43f5c9ffdfe
|
|
| MD5 |
53f77249f078c53e6d8ba1b5ddd9ad56
|
|
| BLAKE2b-256 |
c8f3328957fe7cb09d1b2ef8a25ffcf3ee7962c0012fdbf406f486ed05095383
|