Skip to main content

Python wrapper to manipulate binexport files (protobuf)

Project description

Python-Binexport

python-binexport is a python module aiming to give a friendly interface to load and manipulate binexport files.

What is binexport ?

Binexport is a protobuf format used by Bindiff to extract IDA database and to process them outside. It gives a very optimizated (in size) representation of the program.

Dependencies

Python-binexport can load any .BinExport files generated from the supported disassemblers IDA, Ghidra and Binary Ninja.

However to perform the export with binexporter or from the API ProgramBinexport.from_binary_file() the IDA plugin must be installed as it is the only supported at the moment. For that it has to be installed first from the github page. To use the feature python-binexport requires IDA >=7.2 (as it calls the BinExportBinary IDC function).

[!WARNING] If you export files from python-binexport make sure the IDA Pro binexport plugin is properly installed and works when running it manually before trying to use it from the python library (it can hang if not properly installed).

[!NOTE] The possibility to export files using Ghidra, or Binary Ninja from python-binexport might be supported in the future.

Installation

pip install python-binexport

Python module usage

The main intended usage of python-binexport is as a python module. The main entry point is the class ProgramBinExport which triggers the loading of the whole file. Here is a snippet to iterate on every expression of every instruction in the program:

from binexport import ProgramBinExport

p = ProgramBinExport("myprogram.BinExport")
for fun_addr, fun in p.items():
    with fun:  # Preload all the basic blocks
        for bb_addr, bb in fun.items():
            for inst_addr, inst in bb.instructions.items():
                for operand in inst.operands:
                    for exp in operand.expressions:
                        pass  # Do whatever at such deep level

Obviously ProgramBinExport, FunctionBinExport, InstructionBinExport and OperandBinExport all provides various attributes and method to get their type, and multiple other infos.

If the module idascript is installed you can directly generate a BinExport file using the Program.from_binary_file static method.

Command line usage

The executable script binexporter provides a very basic utility to export a BinExport file straight from the command line (without having to launch IDA etc..). This is basically a wrapper for Program.from_binary_file.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

python_binexport-0.3.4.tar.gz (20.7 kB view details)

Uploaded Source

Built Distribution

python_binexport-0.3.4-py3-none-any.whl (23.6 kB view details)

Uploaded Python 3

File details

Details for the file python_binexport-0.3.4.tar.gz.

File metadata

  • Download URL: python_binexport-0.3.4.tar.gz
  • Upload date:
  • Size: 20.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.11.9

File hashes

Hashes for python_binexport-0.3.4.tar.gz
Algorithm Hash digest
SHA256 5f76e4070b9f5ba2e3c9c4861f367704a612d5541b4552aa695a9df0ed2e6b5a
MD5 23211c59320f060573f9bf0d7f2deeaa
BLAKE2b-256 269d7d37f40f3fe2bfd06e4f24914c182c6a329a1392c0aa04fcdf06ebbdd1f5

See more details on using hashes here.

Provenance

File details

Details for the file python_binexport-0.3.4-py3-none-any.whl.

File metadata

File hashes

Hashes for python_binexport-0.3.4-py3-none-any.whl
Algorithm Hash digest
SHA256 7b7c768b096f98aa4f4dcdcd82e2c23f4c74eae0fe8dde80eff7e0d9073b1eb8
MD5 16a1d737fa0f82589c416deff7a2bd04
BLAKE2b-256 5f47d2c275d6148ea66f59bfe5c89e59f7b1b499c0dd136e2970535598557669

See more details on using hashes here.

Provenance

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page