An EVM symbolic execution tool and vulnerability scanner
Project description
Pakala
"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 0x612f1BDbe93523b7f5036EfA87493B76341726E3: the constructor doesn't have the same name as the contract. Anybody can call HT() and become owner, then call withdraw.
Let's scan it:
./pakala.py 0x612f1BDbe93523b7f5036EfA87493B76341726E3 --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
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file pakala-1.0.5.tar.gz
.
File metadata
- Download URL: pakala-1.0.5.tar.gz
- Upload date:
- Size: 28.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.20.1 setuptools/40.6.3 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.7.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c345b50ed7083f81adb968664fd2a6e6053349bf7846425277c4cb27cdf1c302 |
|
MD5 | 9d267d137b93c2a4d811cf9c7b728a6e |
|
BLAKE2b-256 | 3162ad5cc611104063786b643deab1e07ae4ba26a5b6de9a76704a9d6d0512e2 |
File details
Details for the file pakala-1.0.5-py3-none-any.whl
.
File metadata
- Download URL: pakala-1.0.5-py3-none-any.whl
- Upload date:
- Size: 33.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.20.1 setuptools/40.6.3 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.7.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b7b3833473e3b4c7c68df794634d2b8f60625a010357bebc2d3c9902dfe8f696 |
|
MD5 | 8513591714eda41e2d5f02ff244a6f8e |
|
BLAKE2b-256 | 0c6275e0e021a207184a13ca1a4c5f4c18348511a5cd3093a0d5e6e23e9ca10a |