Unofficial Python Client for the OP-Stack
Project description
Optimism-Python: Unofficial Python Client for the OP-Stack
:construction: DISCLAIMER: Reference SDK is still under active development so the repository might be temporarily out of date.
This library is a Python implementation of the OP-Stack SDK. It tries to mirror some of the core functionalities such as:
- providing easy access to the OP-Stack contracts
- bridging of assets from L1 to L2 (deposits) and vice-versa (withdrawls)
- creating withdrawl proofs
Getting started
Installation
pip install optimism-python
Deposit ETH to L2
from web3 import Web3
from optimism import CrossChainMessenger
# Create a node provider for each chain
provider_l1 = Web3(Web3.HTTPProvider("https://eth-mainnet.g.alchemy.com/v2/<your-alchemy-key>"))
provider_l2 = Web3(Web3.HTTPProvider("https://optimism-mainnet.g.alchemy.com/v2/<your-alchemy-key>"))
# Specify an account for each chain (can be the same)
account_l1 = provider_l1.eth.account.from_key("<your-private-key>")
account_l2 = provider_l2.eth.account.from_key("<your-private-key>")
# Create a messenger instance
messenger = CrossChainMessenger(chain_id_l1=1, # Ethereum Mainnet
chain_id_l2=10, # Optimism Mainnet
account_l1=account_l1,
account_l2=account_l2,
provider_l1=provider_l1,
provider_l2=provider_l2)
# Deposit 1 ETH to L2
messenger.deposit_eth(10**18)
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
optimism_python-0.2.3.tar.gz
(14.1 kB
view hashes)
Built Distribution
Close
Hashes for optimism_python-0.2.3-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | f7bf99b359290e636516fc9528fb60c0abffdd10996325474b6923ca2911d586 |
|
MD5 | 7ab1e25470f2f16e6e74659209002f73 |
|
BLAKE2b-256 | 5caa79b4b59564b62600b5bf0c494347efdb2694dbb8101d5c178de86b7d121d |