Skip to main content

A package for decoding and analyzing EVM transactions and logs

Project description

EVM Decoder

EVM Decoder is a Python package for decoding and analyzing Ethereum Virtual Machine (EVM) transactions and logs. It provides tools to help developers and researchers understand and work with EVM-based blockchain data.

Features

  • Decode EVM transaction input data
  • Decode EVM event logs
  • Analyze balance changes in transactions
  • Support for custom ABI and fixed types
  • Retrieve chain information for various EVM-compatible networks

Installation

You can install the EVM Decoder package using pip:

bash
pip install evm-decoder

Usage

It can decode logs: event_data = { 'topics': [ '0x0c2a2f565c7774c59e49ef6b3c255329f4d254147e06e724d3a8569bb7bd21ad', None, None, None ], 'data': '0x000000000000000000000000000000000000000000000000000388f27d8d3000000000000000000000000000c68bff79073939c96c8edb1c539b5362be1f64d1' }

Here's a quick example of how to use EVM Decoder:

python from evm_decoder import DecoderManager, AnalyzerManager Initialize managers decoder_manager = DecoderManager() analyzer_manager = AnalyzerManager() Example transaction data transaction_data = { 'input': '0x23b872dd000000000000000000000000...', 'from': '0xb8faa80fe04a4afd30c89f40e4fcdc6dafb274d9', 'to': '0xa0b86991c6218b36c1d19d4a2e9eb0ce3606eb48', 'value': '0', 'chain_id': 1, 'logs': [...] } Decode the transaction decode_result = decoder_manager.decode(transaction_data) print("Transaction decode result:", decode_result) Analyze the transaction analysis_result = analyzer_manager.analyze_transaction(transaction_data, {}) print("Transaction analysis result:", analysis_result)

For more detailed examples, check the examples directory in the repository.

Configuration

EVM Decoder uses a configuration file to set up decoders. You can customize this file to add support for specific contracts or event types. The default configuration file is located at evm_decoder/config/decoder_config.json.

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/AmazingFeature)
  3. Commit your changes (git commit -m 'Add some AmazingFeature')
  4. Push to the branch (git push origin feature/AmazingFeature)
  5. Open a Pull Request

License

This project is licensed under the MIT License - see the LICENSE file for details.

Acknowledgments

  • Thanks to all contributors who have helped to improve this project.
  • This project makes use of several open-source libraries, including Web3.py and eth-abi.

Contact

If you have any questions or feedback, please open an issue on the GitHub repository.

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

evm_decoder-0.3.0.tar.gz (17.1 kB view details)

Uploaded Source

Built Distribution

evm_decoder-0.3.0-py3-none-any.whl (21.9 kB view details)

Uploaded Python 3

File details

Details for the file evm_decoder-0.3.0.tar.gz.

File metadata

  • Download URL: evm_decoder-0.3.0.tar.gz
  • Upload date:
  • Size: 17.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for evm_decoder-0.3.0.tar.gz
Algorithm Hash digest
SHA256 b23f918ff353d4d2b3ce7326e08ad78636fe19e13901c2fde4aadf3ccd1809ec
MD5 aea05d76cdf368b0bac740e6ad12ae40
BLAKE2b-256 5f948753553e7a8d51ad6f2d91fe53c2210497413b32f31f1ea082d1a37ea366

See more details on using hashes here.

File details

Details for the file evm_decoder-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: evm_decoder-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 21.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for evm_decoder-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 77fee1a1085bb97d386161bde2b002a54b0249a5654ffda619209bedb42a5b44
MD5 67e73adbf121da00053a78a1168ab6b5
BLAKE2b-256 a49271c02f1475151377a09f1d98e75d19b14aab335f972eabbb3cd217fe9baa

See more details on using hashes here.

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