Skip to main content

CDP Python SDK

Project description

CDP Python SDK

The CDP Python SDK enables the simple integration of crypto into your app. By calling Coinbase's CDP APIs, the SDK allows you to provision crypto wallets, send crypto into/out of those wallets, track wallet balances, and trade crypto from one asset into another.

CDP SDK v0 is a pre-alpha release, which means that the APIs and SDK methods are subject to change. We will continuously release updates to support new capabilities and improve the developer experience.

Documentation

Requirements

  • Python 3.10+

Checking Python Version

Before using the SDK, ensure that you have the correct version of Python installed. The SDK requires Python 3.10 or higher. You can check your Python version by running the following code:

python --version
pip --version

If you need to upgrade your Python version, you can download and install the latest version of Python from the official Python website. For pip, refer to the official pip documentation for installation instructions.

Installation

pip install cdp-sdk

Starting a Python REPL

To start a Python REPL:

python

Creating a Wallet

To start, create a CDP API key. Then, initialize the CDP SDK by passing your API key name and API key's private key via the configure method:

from cdp import *

api_key_name = "Copy your API key name here."
# Ensure that you are using double-quotes here.
api_key_private_key = "Copy your API key's private key here."

Cdp.configure(api_key_name, api_key_private_key)

print("CDP SDK has been successfully configured with CDP API key.")

Another way to initialize the SDK is by sourcing the API key from the JSON file that contains your API key, downloaded from the CDP portal.

Cdp.configure_from_json("~/Downloads/cdp_api_key.json")

print("CDP SDK has been successfully configured from JSON file.")

This will allow you to authenticate with the Platform APIs.

If you are using a CDP Server-Signer to manage your private keys, enable it with

Cdp.use_server_signer = True

Now create a wallet. Wallets are created with a single default address.

# Create a wallet with one address by default.
wallet1 = Wallet.create()

Wallets come with a single default address, accessible via default_address:

# A wallet has a default address.
address = wallet1.default_address

Funding a Wallet

Wallets do not have funds on them to start. For Base Sepolia testnet, we provide a faucet method to fund your wallet with testnet ETH. You are allowed one faucet claim per 24-hour window.

# Fund the wallet with a faucet transaction.
faucet_tx = wallet1.faucet()

print(f"Faucet transaction successfully completed: {faucet_tx}")

Transferring Funds

See Transfers for more information.

Now that your faucet transaction has successfully completed, you can send the funds in your wallet to another wallet. The code below creates another wallet, and uses the transfer function to send testnet ETH from the first wallet to the second:

# Create a new wallet wallet2 to transfer funds to.
wallet2 = Wallet.create()

print(f"Wallet successfully created: {wallet2}")

transfer = wallet1.transfer(0.00001, "eth", wallet2).wait()

print(f"Transfer successfully completed: {transfer}")

Gasless USDC Transfers

To transfer USDC without needing to hold ETH for gas, you can use the transfer method with the gasless option set to True.

# Create a new wallet wallet3 to transfer funds to.
wallet3 = Wallet.create()

print(f"Wallet successfully created: {wallet3}")

transfer = wallet1.transfer(0.00001, "usdc", wallet3, gasless=True).wait()

Listing Transfers

# Return list of all transfers. This will paginate and fetch all transfers for the address.
address.transfers()

Trading Funds

See Trades for more information.

wallet = Wallet.create("base-mainnet")

print(f"Wallet successfully created: {wallet}")
print(f"Send `base-mainnet` ETH to wallets default address: {wallet.default_address.address_id}")

trade = wallet.trade(0.00001, "eth", "usdc").wait()

print(f"Trade successfully completed: {trade}")

Listing Trades

# Return list of all trades. This will paginate and fetch all trades for the address.
address.trades()

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

cdp_sdk-0.0.3.tar.gz (106.3 kB view details)

Uploaded Source

Built Distribution

cdp_sdk-0.0.3-py3-none-any.whl (228.6 kB view details)

Uploaded Python 3

File details

Details for the file cdp_sdk-0.0.3.tar.gz.

File metadata

  • Download URL: cdp_sdk-0.0.3.tar.gz
  • Upload date:
  • Size: 106.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.6

File hashes

Hashes for cdp_sdk-0.0.3.tar.gz
Algorithm Hash digest
SHA256 754ece70986a973945a4ceabe5a475620be5b72996c527bdef759ca4b4d24ce1
MD5 58eb1ce3c7318c43894b8a3f594f91b1
BLAKE2b-256 1d4ecc4abcce098db1d98e90624fd0fea5b75221d78dadadc9d32222eba48d80

See more details on using hashes here.

File details

Details for the file cdp_sdk-0.0.3-py3-none-any.whl.

File metadata

  • Download URL: cdp_sdk-0.0.3-py3-none-any.whl
  • Upload date:
  • Size: 228.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.6

File hashes

Hashes for cdp_sdk-0.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 6435a564b78c02dfeeeb82a43433e8b2327f1d5e34c10d56b9abadc2382951bc
MD5 69315e989241131a29ce24426f7ae2af
BLAKE2b-256 9d73402c186df81e50cbe4f8fec1c7cfcad161513e81ca629c314f1d0afaadba

See more details on using hashes here.

Supported by

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