Official Thirdweb sdk
Project description
NFTLabs Python SDK
PyPi package found here.
Deprecation Notices
1 of 2
The
nftlabs-sdk
pypi package will be deprecated on November 30th, 2021Please make sure you install the new
thirdweb-sdk
package found hereIn your code, update all imports to use the
thirdweb
package and switch to using theThirdwebSdk
package (instead of theNftlabsSdk
package)
2 of 2
The
collection
module has been renamed tobundle
and will be deprecated on November 30th, 2021All references to
collection
module and its associated classes should be updated tobundle
and its newely created classes.You can find the detailed documentation for the
bundle
module here
Docs
API Reference
https://python-docs.nftlabs.co/
Installing the SDK
$ pip install thirdweb-sdk
Package Structure
nftlabs
├── abi // contains autogenerated ABI contract wrappers
├── errors // commonly thrown errors
├── modules // NFT, Currency, Marketplace, Pack, Bundle, etc modules
├── options // Options classes used throughout the SDK
├── sdk.py // NftlabsSdk class, wrapper for the entire package
├── storage // Distributed file storage helper classes
└── types // Types consumed by some of the methods exposed in the modules
Calling the modules
You can call the NFTLabs modules by instantiating an SDK object and fetching the module with your contract address like this:
import os
from nftlabs import NftlabsSdk, SdkOptions
sdk = NftlabsSdk(SdkOptions(), "https://rpc-mumbai.maticvigil.com") # polygon testnet as an example
# Assumes your private key is assigned to the `PKEY` environment variable
sdk.set_private_key(os.getenv("PKEY"))
# Put your NFT contract address here if you want to mint your own NFTs!
nft_module = sdk.get_nft_module("0xbDfF8fb43688fB4D2184DF8029A7238ac1413A24")
print(nft_module.total_supply())
Development
Generating ABI wrappers
The abi
package contains autogenerated code compiled by the
0xchain abi-gen
tool found here.
Our protocols are developer at this repo.
Install the abi-gen
cli tool and use it to compile abi wrappers like this:
$ # assumes you have the nftlabs-protocols repo cloned in the parent directory
$ abi-gen --language Python -o nftlabs/abi --abis ../nftlabs-protocols/abi/NFT.json
Anytime there are ABI contract changes, you should regenerate the abi wrappers.
Writing Documentation
This package uses PyDoctor
to auto-generate docs. Each method, class and variable should have a detailed description of what it is meant for as a comment enclosed in triple quoation marks (""" """
) just below the line they are defined.
Example:
Do:
def my_method(self, arg1, arg2):
"""
This part goes into the documentation.
"""
return arg1 + arg2
Don't:
"""
This part will not go into the documentation.
"""
def my_method(self, arg1, arg2):
return arg1 + arg2
Addtionally, each module should also have a docstring at the top of the file. This will be used as a breif descroption of the module on the homepage of the documentation.
Example:
1 """Interact with the NFT module of the app""" # docstring
2 # Module code starts from here
3 # ...
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
File details
Details for the file nftlabs-sdk-0.4.0.tar.gz
.
File metadata
- Download URL: nftlabs-sdk-0.4.0.tar.gz
- Upload date:
- Size: 73.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.6.0 importlib_metadata/4.8.2 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.10.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a0f102e233ae0f2bf0227c4a2a22e11a6e74497f6922a9c68455f6ae306c639a |
|
MD5 | b8cee5ee065c183b23843d68c16303be |
|
BLAKE2b-256 | ebc468af92224fbddee3d24b5174a73250f07936c2a9bb398697219b11d6f9aa |
File details
Details for the file nftlabs_sdk-0.4.0-py3-none-any.whl
.
File metadata
- Download URL: nftlabs_sdk-0.4.0-py3-none-any.whl
- Upload date:
- Size: 88.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.6.0 importlib_metadata/4.8.2 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.10.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2c691dd7fe36710e2dd4cab3bc42ea7c2bf6457995f67895d6660225fbad088e |
|
MD5 | e372bc60438782fbef98f5e0e70f5a4d |
|
BLAKE2b-256 | c6f9cc3563331a912a3fcde98f69ee140cf59c43b0b606fa8f36226ba9ddfd6f |