No project description provided
Project description
This library works by injecting a new module in the Web3.py instance, which allows
submitting "bundles" of transactions directly to miners. This is done by also creating
a middleware which captures calls to eth_sendBundle
and eth_callBundle
, and sends
them to an RPC endpoint which you have specified, which corresponds to mev-geth
.
To apply correct headers we use FlashbotProvider which injects the correct header on post
Example
from eth_account.signers.local import LocalAccount
from web3 import Web3, HTTPProvider
from flashbots import flashbot
from eth_account.account import Account
import os
ETH_ACCOUNT_SIGNATURE: LocalAccount = Account.from_key(os.environ.get("ETH_SIGNATURE_KEY"))
w3 = Web3(HTTPProvider("http://localhost:8545"))
flashbot(w3, ETH_ACCOUNT_SIGNATURE)
Now the w3.flashbots.sendBundle
method should be available to you. Look in examples/simple.py
for usage examples
Development and testing
Setup and run (mev-)geth with Websocket support:
geth --http --http.api eth,net,web3,txpool --syncmode full
Install poetry
Poetry will automatically fix your venv and all packages needed
poetry install
Tips: PyCharm has a poetry plugin
Linting
It's advisable to run black with default rules for linting
sudo pip install black # Black should be installed with a global entrypoint
black .
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
Hashes for flashbots-0.4.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | b73ad2deea2f387cd7e398f8eac70eda49f89c50260e82f128923f248eb7aa68 |
|
MD5 | ee96768334c062db995d9637ce7cb968 |
|
BLAKE2b-256 | eedba3af45b2bde4173eccab079fdb4c13b1a87bb614bf66cef47781c2997781 |