This library works by injecting a new module in the Web3.py instance, which allows
submitting "private transactions" or "bundles" of transactions directly to miners.
This is done by also creating a middleware which captures calls to
eth_sendRawTransaction / eth_sendPrivateTransaction and eth_sendBundle,
sending them to OpenMev RPC endpoint, which corresponds to mev-geth.
To apply correct headers we use OpenmevProvider which injects the correct header on post.
from eth_account.signers.local import LocalAccount
from web3 import Web3, HTTPProvider
from openmev import openmev
from eth_account.account import Account
import os
ETH_ACCOUNT_SIGNATURE: LocalAccount = Account.from_key(os.environ.get("ETH_SIGNATURE_KEY"))
w3 = Web3(HTTPProvider(os.environ.get("ETH_RPC_URL")))
openmev(w3, ETH_ACCOUNT_SIGNATURE)Avaliable methods:
w3.openmev.sendBundleLook inexamples/bundle.pyfor usage examplesw3.openmev.sendPrivateTransactionLook inexamples/private_swap.pyfor usage examples
Generate new eth wallet
python3 generate_private_key.py
Export private key and rpc url as env vars
export ETH_SIGNATURE_KEY=<0x...>
export ETH_RPC_URL=<http...>
Setup pre-reqs
./pre-install
Install Openmev
pip3.10 install
Run examples
python3.10 examples/private_swap.py