No project description provided
Project description
thirdweb Python SDK
Best in class Web3 SDK for Python 3.7+
Installation
pip install thirdweb-sdk
Getting Started
To start using this SDK, you just need to pass in a provider configuration.
Instantiating the SDK
Once you have all the necessary dependencies, you can follow the following setup steps to get started with the SDK read-only functions:
from thirdweb import ThirdwebSDK
# You can create a new instance of the SDK to use by just passing in a network name
sdk = ThirdwebSDK("mumbai")
The SDK supports the mainnet
, rinkeby
, goerli
, polygon
, mumbai
, fantom
, and avalanche
networks.
Alternatively, if you want to use your own custom RPC URL, you can pass in the RPC URL directly as follows:
from thirdweb import ThirdwebSDK
# Set your RPC_URL
RPC_URL = "https://rpc-mainnet.matic.network"
# And now you can instantiate the SDK with it
sdk = ThirdwebSDK(RPC_URL)
Working With Contracts
Once you instantiate the SDK, you can use it to access your thirdweb contracts. You can use the SDK's contract getter functions like get_token
, get_edition
, get_nft_collection
, and get_marketplace
to get the respective SDK contract instances. To use an NFT Collection contract for example, you can do the following.
# Add your NFT Collection contract address here
NFT_COLLECTION_ADDRESS = "0x.."
# And you can instantiate your contract with just one line
nft_collection = sdk.get_nft_collection(NFT_COLLECTION_ADDRESS)
# Now you can use any of the read-only SDK contract functions
nfts = nft_collection.get_all()
print(nfts)
Signing Transactions
:warning: Never commit private keys to file tracking history, or your account could be compromised.
Meanwhile, if you want to use write functions as well and connect a signer, you can use the following setup:
from thirdweb import ThirdwebSDK
from thirdweb.types.nft import NFTMetadataInput
import os
# This PRIVATE KEY is coming from your environment variables. Make sure to never put it in a tracked file or share it with anyone.
PRIVATE_KEY = os.environ.get("PRIVATE_KEY")
# Now you can create a new instance of the SDK with your private key
sdk = ThirdwebSDK.from_private_key(PRIVATE_KEY, "mumbai")
# Instantiate a new NFT Collection contract as described above.
NFT_COLLECTION_ADDRESS = "0x.."
nft_collection = sdk.get_nft_collection(NFT_COLLECTION_ADDRESS)
# Now you can use any of the SDK contract functions including write functions
nft_collection.mint(NFTMetadataInput.from_json({ "name": "Cool NFT", "description": "Minted with the Python SDK!" }))
Development Environment
In this section, we'll go over the steps to get started with running the Python SDK repository locally and contributing to the code. If you aren't interested in contributing to the thirdweb Python SDK, you can ignore this section.
Poetry Environment Setup
If you want to work with this repository, make sure to setup Poetry, you're virtual environment, and the code styling tools.
Assuming you've installed and setup poetry, you can setup this repository with:
$ poetry shell
$ poetry install
$ poetry run yarn global add ganache
$ poetry run yarn add hardhat
Alternatively, if your system can run .sh files, you can set everything up by running the following bash script:
$ bash scripts/env/setup.sh
Running Tests
Before running tests, make sure you've already run poetry shell
and are in the poetry virutal environment with all dependencies installed.
Once you have checked that this you have all the dependencies, you can run the following:
$ poetry run brownie test --network hardhat
To properly setup testing, you'll also need to add your private key to the .env
file as follows (do NOT use a private key of one of your actual wallets):
PRIVATE_KEY=...
Code Style Setup
Make sure you have mypy
, pylint
, and black
installed (all included in the dev dependencies with poetry install
.
If you're working in VSCode, there a few steps to get everything working with the poetry .venv:
- To setup poetry virtual environment inside your VSCode so it gets recognized as part of your project (import for linters), you can take the following steps from this stack overflow answer. You need to run
poetry config virtualenvs.in-project true
and then make sure you delete/create a new poetry env. - In
.vscode/settings.json
, you should have the following:
{
"python.linting.mypyEnabled": true,
"python.linting.enabled": true,
"python.linting.pylintEnabled": false
}
- Make sure to set your VSCode
Python: Interpreter
setting to the Python version inside your poetry virtual environment.
Generate Python ABI Wrappers
Use the abi-gen package to create the Python ABIs. You can install it with the following command:
$ npm install -g @0x/abi-gen
Assuming you have the thirdweb contract ABIs in this directory at /abi
, you can run the following command to generate the necessary ABIs.
$ bash scripts/abi/generate.sh
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 thirdweb_sdk-2.0.16a0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | e64ae9ff4d7839d0940d4d6ec4a5602a919e3976069a9b264a56ccef98f61387 |
|
MD5 | 1d8b93db950dd4d29bb9e8dc7e3ca8f9 |
|
BLAKE2b-256 | 521c35262930207cf3f8cf3340df6dea29480a126d56c9c7951ce7ba44727009 |