Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/mborgerson/mdec

Decompilation as a Service. Explore multiple decompilers and compare their output with minimal effort. Upload binary, get decompilation.
https://github.com/mborgerson/mdec

angr binary-ninja decompilation decompiler ghidra ida jeb r2dec reko retdec snowman

Last synced: 2 months ago
JSON representation

Decompilation as a Service. Explore multiple decompilers and compare their output with minimal effort. Upload binary, get decompilation.

Awesome Lists containing this project

README

        

**Update:** mdec is now deprecated in favor of the community maintained [decompiler-explorer](https://github.com/decompiler-explorer/decompiler-explorer) project!

mdec
====

Explore multiple decompilers and compare their output with minimal effort. Upload binary, get decompilation.

![](screenshot.png)

Supported Decompilers
---------------------
* [angr](https://angr.io/)
* [Binary Ninja](https://binary.ninja/)[1]
* [Ghidra](https://ghidra-sre.org/)
* [Hex-Rays](https://hex-rays.com/decompiler/)[1]
* [JEB CE](https://www.pnfsoftware.com/jeb/community-edition)[2]
* [r2dec](https://github.com/wargio/r2dec-js)
* [Reko](https://github.com/uxmal/reko)
* [RetDec](https://github.com/avast/retdec)
* [Snowman](https://github.com/yegord/snowman)

**Notes:**
1. Hex-Rays and Binary Ninja require license and binaries; other decompilers will be downloaded automatically.
2. JEB CE requires a license code. It's free. More info [here](backend/jeb/private/README.md).

Components
----------
* Each decompiler is a service that runs in its own container
* A frontend web service proxies requests to backend service

Install
-------
You'll need to add your proprietary packages in `backend/*/private`. Then just:
```
COMPOSE_DOCKER_CLI_BUILD=1 DOCKER_BUILDKIT=1 docker compose build
```

**Tip:** If you want to build only a few services, append the service names to the above command. For example, to build only the free/open source decompilers you can specify:

```
COMPOSE_DOCKER_CLI_BUILD=1 DOCKER_BUILDKIT=1 docker compose build \
frontend \
angr \
ghidra \
r2dec \
reko \
retdec \
snowman
```

Run
---
```
docker compose up
```

Point your browser at http://127.0.0.1.

**Tip:** If you want to start only a few services, append the service names to the above command (e.g. frontend, angr, etc.)

API
---
You can also request decomp like:
```
curl -F '[email protected]' http://127.0.0.1/hexrays/decompile
```