Skip to main content

An EVM symbolic execution tool and vulnerability scanner

Project description

Pakala

PyPI Build States

"ilo Pakala li pakala e mani sona"

  • Pakala is a tool to search for exploitable bugs in Ethereum smart contracts.
  • Pakala is a symbolic execution engine for the Ethereum Virtual Machine.

The intended public for the tool are security researchers interested by Ethereum / the EVM.

Installation

pip3 install pakala

It works only with python 3.

Usage

Let's look at 0xeBE6c7a839A660a0F04BdF6816e2eA182F5d542C: it has a transfer(address _to, uint256 _value) function. It is supposedly protected by a require(call.value - _value) >= 0 but that condition always holds because we are substracting two unsigned integers, so the result is also an unsigned integer.

Let's scan it:

./pakala.py 0xeBE6c7a839A660a0F04BdF6816e2eA182F5d542C --force-balance="1 ether"

The contract balance being 0, we won't be able to have it send us some ethers. So we override the balance to be 1 ETH: then it has some "virtual" money to send us.

The tool with tell you a bug was found, and dump you a path of "states". Each state corresponds to a transaction, with constraints that needs to be respected for that code path to be taken, storage that has been read/written...

Advice: look at calldata[0] in the constraints to see the function signature for each transaction.

See ./pakala.py help for more complete usage information.

How does it works? What does it do?

See the introductory article for more information and a demo.

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

pakala-1.0.11.tar.gz (31.0 kB view details)

Uploaded Source

Built Distribution

pakala-1.0.11-py3-none-any.whl (36.5 kB view details)

Uploaded Python 3

File details

Details for the file pakala-1.0.11.tar.gz.

File metadata

  • Download URL: pakala-1.0.11.tar.gz
  • Upload date:
  • Size: 31.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.28.1 CPython/3.7.2

File hashes

Hashes for pakala-1.0.11.tar.gz
Algorithm Hash digest
SHA256 b36858ae905f68f62b45f636e608784c4bce557624d6f5ebebab21c541193a3b
MD5 f1a98d6ffaca80af21fdd2dcaa165ef4
BLAKE2b-256 e5e6f9d3ffa8d68ba56b7d95b6782e26022b1c803f7f42a8d11868364b3b28d6

See more details on using hashes here.

File details

Details for the file pakala-1.0.11-py3-none-any.whl.

File metadata

  • Download URL: pakala-1.0.11-py3-none-any.whl
  • Upload date:
  • Size: 36.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.28.1 CPython/3.7.2

File hashes

Hashes for pakala-1.0.11-py3-none-any.whl
Algorithm Hash digest
SHA256 c49d5adfb8b68bf8a5648ec99f2b381b15e9e89a7449700a67372b180b6b239a
MD5 9e920832a348d2f70f093185b6975fa8
BLAKE2b-256 48d0e54e91c0506fd42440a631b25841644c81066244e0afe20e87701df8ec18

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