Skip to main content

Python library for client-side interactions with Arbitrum

Project description

Arbitrum Python SDK

npm version License: Apache 2.0

A TypeScript library for client-side interactions with Arbitrum. The Arbitrum Python SDK provides essential helper functionality and direct access to underlying smart contract interfaces, enabling developers to build powerful applications on the Arbitrum network.

[!IMPORTANT]

This is the code and documentation here are based on the official @arbitrum/sdk v4 and have been rewritten in Python. Based release version: v4.0.2

This repository is a community effort and is not officially supported by Offchain Labs. Please see the disclaimer at the end of this document.

Table of Contents

Overview

Arbitrum Python SDK simplifies the process of interacting with Arbitrum chains, offering a robust set of tools for asset bridging and cross-chain messaging.

Installation

pip3 install arbitrum_py

Key Features

Bridging Assets

Arbitrum Python SDK facilitates the bridging of assets between an Arbitrum chain and its parent chain. Currently supported asset bridgers:

  • EthBridger: For bridging ETH to and from an Arbitrum chain (L2 or L3)
  • Erc20Bridger: For bridging ERC-20 tokens to and from an Arbitrum chain (L2 or L3)
  • EthL1L3Bridger: For bridging ETH to an L3 directly from L1
  • Erc20L1L3Bridger: For bridging ERC-20 tokens to an L3 directly from L1

Cross-Chain Messages

Cross-chain communication is handled through ParentToChildMessage and ChildToParentMessage classes. These encapsulate the lifecycle of messages sent between chains, typically created from transaction receipts that initiate cross-chain messages.

Network Configuration

The SDK comes preconfigured for Arbitrum One, Arbitrum Nova and Arbitrum Sepolia. Custom Arbitrum networks can be registered using register_custom_arbitrum_network, which is required before utilizing other SDK features.

Usage

Here's a basic example of using the SDK to bridge ETH:

from web3 import Web3
from eth_account import Account
from arbitrum_py.data_entities.networks import get_arbitrum_network
from arbitrum_py.asset_bridger.eth_bridger import EthBridger
from arbitrum_py.data_entities.signer_or_provider import SignerOrProvider

def bridge_eth(parent_signer: SignerOrProvider, child_chain_id: int):
    child_network = get_arbitrum_network(child_chain_id)
    eth_bridger = EthBridger(child_network)

    deposit = eth_bridger.deposit({
        'amount': Web3.to_wei(0.1, 'ether'),
        'parentSigner': parent_signer,
    })

    print(f"Deposit initiated: {deposit['transactionHash'].hex()}")

For more detailed usage examples and API references, please refer to the Arbitrum Python SDK documentation or check out the tutorials

Running Tests

  1. Set up test nodes by following the instructions here or below quick setup:
# Make sure docker is installed
git clone -b release --recurse-submodules https://github.com/OffchainLabs/nitro-testnode.git && cd nitro-testnode
chmod +x ./test-node.bash && && ./test-node.bash --init --tokenbridge --l3node --l3-token-bridge --blockscout --detach

# (Optional) You can fund default accounts with ETH using the following command
# https://docs.arbitrum.io/run-arbitrum-node/run-local-full-chain-simulation#blockscout

# Send 5 ETH to the dev account in L2 network. 
./test-node.bash script send-l2 --to 0x3f1Eae7D46d88F08fc2F8ed27FCb2AB183EB2d0E --ethamount 5

# Send 5 ETH to the dev account in 12 network. 
./test-node.bash script send-l1 --to 0x3f1Eae7D46d88F08fc2F8ed27FCb2AB183EB2d0E --ethamount 5
  1. Copy .env.example to .env and update relevant environment variables.

  2. Install dependencies:

pip install -r requirements.txt
  1. Generate the network configuration against your active Nitro test node:
python3 -m scripts.gen_network
  1. Execute the integration tests:
pytest tests

Documentation

For comprehensive guides and API documentation, visit the Arbitrum Python SDK Documentation. You can also find tutorials in the Arbitrum Python Tutorials

License

Arbitrum Python SDK is released under the Apache 2.0 License.

Disclaimer

The code contained within this package is meant for testing purposes only and does not guarantee any level of security. It has not undergone any formal audit or security analysis. Use it at your own risk. Any potential damages or security breaches occurring from the use of this code are not the responsibility of the author(s) or contributor(s) of this repository. Please exercise caution and due diligence while using this code in any environment.

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

arbitrum_sdk-0.2.1.tar.gz (134.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

arbitrum_sdk-0.2.1-py3-none-any.whl (162.1 kB view details)

Uploaded Python 3

File details

Details for the file arbitrum_sdk-0.2.1.tar.gz.

File metadata

  • Download URL: arbitrum_sdk-0.2.1.tar.gz
  • Upload date:
  • Size: 134.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.8.18

File hashes

Hashes for arbitrum_sdk-0.2.1.tar.gz
Algorithm Hash digest
SHA256 eb743b231abb400f8b66d1d531269eda7d841136bf3ed3ac56205745470f1891
MD5 8695bc76024fc6014e2b2da99e527103
BLAKE2b-256 bfb671cab047f041c001eb53a10bbd4597ab57632bdb5eb09ce15ba1e2e0bd1f

See more details on using hashes here.

File details

Details for the file arbitrum_sdk-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: arbitrum_sdk-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 162.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.8.18

File hashes

Hashes for arbitrum_sdk-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 c6aef41d71fa13ed02fe155e2f67c53dae5584fc05ed9629b718ce9a0559e993
MD5 90945a7d60359ac93ef03d744ccf76eb
BLAKE2b-256 aae587e61821828b2fb4343e0f28fa10445fc2c268dc21d5c80ae537e68716e3

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page