base on Analyze ELF binaries like a boss 😼🕵️‍♂️ <p align="center"> <img src="https://raw.githubusercontent.com/orhun/binsider/main/website/src/assets/binsider-logo-dark.png#gh-dark-mode-only" width="300"></a> <img src="https://raw.githubusercontent.com/orhun/binsider/main/website/src/assets/binsider-logo-light.png#gh-light-mode-only" width="300"></a> <br> <img src="https://raw.githubusercontent.com/orhun/binsider/main/website/src/assets/binsider-text-dark.png#gh-dark-mode-only" width="170"></a> <img src="https://raw.githubusercontent.com/orhun/binsider/main/website/src/assets/binsider-text-light.png#gh-light-mode-only" width="170"></a> <br> <br> <em>"Swiss army knife for reverse engineers."</em> <br> <br> <a href="https://github.com/orhun/binsider/releases"> <img src="https://img.shields.io/github/v/release/orhun/binsider?style=flat&labelColor=1d1d1d&color=f8be75&logo=GitHub&logoColor=white"></a> <a href="https://crates.io/crates/binsider/"> <img src="https://img.shields.io/crates/v/binsider?style=flat&labelColor=1d1d1d&color=f8be75&logo=Rust&logoColor=white"></a> <br> <a href="https://github.com/orhun/binsider/actions?query=workflow%3A%22CI%22"> <img src="https://img.shields.io/github/actions/workflow/status/orhun/binsider/ci.yml?style=flat&labelColor=1d1d1d&color=white&logo=GitHub%20Actions&logoColor=white"></a> <a href="https://github.com/orhun/binsider/actions?query=workflow%3A%22CD%22"> <img src="https://img.shields.io/github/actions/workflow/status/orhun/binsider/cd.yml?style=flat&labelColor=1d1d1d&color=white&logo=GitHub%20Actions&logoColor=white&label=deploy"></a> <a href="https://hub.docker.com/r/orhunp/binsider"> <img src="https://img.shields.io/github/actions/workflow/status/orhun/binsider/docker.yml?style=flat&labelColor=1d1d1d&color=white&label=docker&logo=Docker&logoColor=white"></a> <a href="https://docs.rs/binsider/"> <img src="https://img.shields.io/docsrs/binsider?style=flat&labelColor=1d1d1d&color=white&logo=Rust&logoColor=white"></a> <br> <a href="https://discord.gg/zphNxEcEK7"> <img src="https://img.shields.io/discord/1289166752311148554?color=f8be75&label=discord&labelColor=1d1d1d&logo=discord&logoColor=white"></a> </p> <h4 align="center"> <a href="https://binsider.dev/getting-started/">Documentation</a> | <a href="https://binsider.dev/">Website</a> </h4> 😼🕵️‍♂️ **Binsider** can perform static and dynamic analysis, inspect strings, examine linked libraries, and perform hexdumps, all within a user-friendly terminal user interface! ## Quickstart > [!TIP] > Watch the quickstart video to get a glimpse of what `binsider` can do: [https://youtu.be/InhVCQoc5ZE](https://youtu.be/InhVCQoc5ZE) Install `binsider` with `cargo`: ```bash cargo install binsider ``` > [!NOTE] > See the other [installation methods](https://binsider.dev/installation/other/) 📦 After the installation, you are pretty much set! 💯 Just dive into the binaries by running `binsider`: ```bash binsider <binary> ``` ![Demo](website/src/content/assets/quickstart.gif) ## Features > [!NOTE] > The detailed documentation is available at <https://binsider.dev> 📚 ### General Analysis You can retrieve general binary file information, including file size, ownership, permissions, date, and linked shared libraries (similar to [`stat(1)`](https://www.man7.org/linux/man-pages/man1/stat.1.html) and [`ldd(1)`](https://www.man7.org/linux/man-pages/man1/ldd.1.html)). [![General analysis](website/src/assets/demo/binsider-general-analysis.gif)](https://binsider.dev/usage/general-analysis) ➡️ <https://binsider.dev/usage/general-analysis> ### Static Analysis You can analyze the ELF layout (such as sections, segments, symbols, and relocations) and navigate through them to get an in-depth understanding of the binary. [![Static analysis](website/src/assets/demo/binsider-static-analysis.gif)](https://binsider.dev/usage/static-analysis) ➡️ <https://binsider.dev/usage/static-analysis> ### Dynamic Analysis It is possible to execute the binary and trace the system calls, signals, and the program's execution flow similar to [`strace(1)`](https://man7.org/linux/man-pages/man1/strace.1.html) and [`ltrace(1)`](https://man7.org/linux/man-pages/man1/ltrace.1.html). [![Dynamic analysis](website/src/assets/demo/binsider-dynamic-analysis.gif)](https://binsider.dev/usage/dynamic-analysis) ➡️ <https://binsider.dev/usage/dynamic-analysis> ### String Extraction Similar to the [`strings(1)`](https://linux.die.net/man/1/strings) command, `binsider` is able to extract strings from the binary file with the purpose of discovering interesting strings such as URLs, passwords, and other sensitive information. [![String extraction](website/src/assets/demo/binsider-strings.gif)](https://binsider.dev/usage/strings) ➡️ <https://binsider.dev/usage/strings> ### Hexdump `binsider` provides a rich dashboard along with a hexdump view to analyze the binary content in a structured manner. [![Hexdump](website/src/assets/demo/binsider-hexdump.gif)](https://binsider.dev/usage/hexdump) ➡️ <https://binsider.dev/usage/hexdump> ## Acknowledgements Shoutout to [@harunocaksiz](https://github.com/harunocaksiz) for sticking with me during our military service in the summer of 2024 and creating the awesome **binsider** logo! (o7) ## Contributing See the [contribution guidelines](CONTRIBUTING.md). <a href="https://discord.gg/zphNxEcEK7"> <img src="https://discord.com/api/guilds/1289166752311148554/embed.png?style=banner2"></a> ## License Licensed under either of [Apache License Version 2.0](./LICENSE-APACHE) or [The MIT License](./LICENSE-MIT) at your option. 🦀 ノ( º \_ º ノ) - respect crables! ## Copyright Copyright © 2024, [Orhun Parmaksız](mailto:[email protected]) ", Assign "at most 3 tags" to the expected json: {"id":"11731","tags":[]} "only from the tags list I provide: []" returns me the "expected json"