LIEF
docker-packing-box
Our great sponsors
LIEF | docker-packing-box | |
---|---|---|
4 | 1 | |
4,137 | 42 | |
2.1% | - | |
9.4 | 9.4 | |
18 days ago | 4 days ago | |
C++ | Python | |
Apache License 2.0 | GNU General Public License v3.0 only |
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
LIEF
-
What's the Most Portable Way to Include Binary Blobs in an Executable?
My team is working on this problem in the context of creating Node.js single-executable applications. While the naive approach of just appending data at the end of the binary works, it is not friendly with code-signature in macOS and Windows given that signing operates on PE and Mach-O sections.
We have recently open-sourced a small tool called Postject (https://github.com/postmanlabs/postject), which is able to inject arbitrary data as proper ELF/Mach-O/PE sections for all major operating systems (with AIX support coming). The tool also provides C/C++ cross-platform headers for easily traversing the final binary and introspect whether the segment is present or not.
The tool is based on the LIEF (https://github.com/lief-project/LIEF) project.
At Postman, we are making use of this on our custom Node.js single-executable applications and soon on our custom Electron.js builds too.
-
Pefile python module features
https://github.com/lief-project/LIEF https://lief-project.github.io/doc/latest/api/python/index.html
-
Collection of tools for executable packing detection
Bintropy: Entropy-based packing detection featuring multiple modes (whole binary, per section or segment). Based on the awesome LIEF library, therefore supports ELF, PE, Mach-O.
-
rabin2 for scraping ELF to JSON
I've been looking at LIEF toolkit for similar purposes (https://github.com/lief-project/LIEF). It's a python framework for cross platform binary analysis. I'm curious, does rabin2 support dll format?
docker-packing-box
-
Collection of tools for executable packing detection
All these are automated/mechanized in a Docker image that allows to do far more than just playing with some packing detectors.
What are some alternatives?
dll-proxy-generator - Creates a proxy dll which sits between the game and original dll
windbg-code-tracing - Pykd script to perform simple code tracing and so inspecting control flow executed (CFE).
radare2 - UNIX-like reverse engineering framework and command-line toolset
bintropy - Analysis tool for estimating the likelihood that a binary contains compressed or encrypted bytes
tree-sitter-html - HTML grammar for Tree-sitter
vivaldi_modding - Custom modifications for Vivaldi web browser.
pe - A :zap: lightweight Go package to parse, analyze and extract metadata from Portable Executable (PE) binaries. Designed for malware analysis tasks and robust against PE malformations.
goblin - An impish, cross-platform binary parsing crate, written in Rust
the-backdoor-factory - Patch PE, ELF, Mach-O binaries with shellcode new version in development, available only to sponsors
XAPKDetector - APK/DEX detector for Windows, Linux and MacOS.
PyPackerDetect - A malware dataset curation tool which helps identify packed samples.