Skip to main content

Solana Python API

Project description


Actions Status PyPI version Codecov License: MIT Code style: black

Solana.py

🐍 The Solana Python SDK 🐍

Solana.py is the base Python library for interacting with Solana. You can use it to build transactions and interact with the Solana JSON RPC API, much like you would do with solana-web3.js

It also covers the SPL Token Program.

Latest Documentation.

⚓︎ See also: AnchorPy, a Python client for Anchor-based programs on Solana. ⚓︎

⚡ Quickstart

Installation

pip install solana

General Usage

Note: check out the Solana Cookbook for more detailed examples!

import solana

API Client

from solana.rpc.api import Client

http_client = Client("https://api.devnet.solana.com")

Async API Client

import asyncio
from solana.rpc.async_api import AsyncClient

async def main():
    async with AsyncClient("https://api.devnet.solana.com") as client:
        res = await client.is_connected()
    print(res)  # True

    # Alternatively, close the client explicitly instead of using a context manager:
    client = AsyncClient("https://api.devnet.solana.com")
    res = await client.is_connected()
    print(res)  # True
    await client.close()

asyncio.run(main())

Websockets Client

import asyncio
from asyncstdlib import enumerate
from solana.rpc.websocket_api import connect

async def main():
    async with connect("ws://api.devnet.solana.com") as websocket:
        await websocket.logs_subscribe()
        first_resp = await websocket.recv()
        subscription_id = first_resp.result
        next_resp = await websocket.recv()
        print(next_resp)
        await websocket.logs_unsubscribe(subscription_id)

    # Alternatively, use the client as an infinite asynchronous iterator:
    async with connect("ws://api.devnet.solana.com") as websocket:
        await websocket.logs_subscribe()
        first_resp = await websocket.recv()
        subscription_id = first_resp.result
        async for idx, msg in enumerate(websocket):
            if idx == 3:
                break
            print(msg)
        await websocket.logs_unsubscribe(subscription_id)

asyncio.run(main())

🔨 Development

Setup

  1. Install poetry
  2. Install dev dependencies:
poetry install
  1. Activate the poetry shell.
poetry shell

Lint

make lint

Tests

# All tests
make tests
# Unit tests only
make unit-tests
# Integration tests only
make int-tests

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

solana-0.23.2.tar.gz (73.5 kB view details)

Uploaded Source

Built Distribution

solana-0.23.2-py3-none-any.whl (89.2 kB view details)

Uploaded Python 3

File details

Details for the file solana-0.23.2.tar.gz.

File metadata

  • Download URL: solana-0.23.2.tar.gz
  • Upload date:
  • Size: 73.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.12 CPython/3.7.9 Darwin/21.1.0

File hashes

Hashes for solana-0.23.2.tar.gz
Algorithm Hash digest
SHA256 57c98be97d944440146780a4e175c0dbf50a988d75f05d81b5083620bf4331b0
MD5 5e45224f9b0acdaef3ab9bc4fa329a42
BLAKE2b-256 fd854917f511a813f99fd2a6fe9294be3b06ea1c574791f896d24a92d16279f4

See more details on using hashes here.

File details

Details for the file solana-0.23.2-py3-none-any.whl.

File metadata

  • Download URL: solana-0.23.2-py3-none-any.whl
  • Upload date:
  • Size: 89.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.12 CPython/3.7.9 Darwin/21.1.0

File hashes

Hashes for solana-0.23.2-py3-none-any.whl
Algorithm Hash digest
SHA256 6c43a6013bc0b5358cafd94a4fa091d30f7917fe578960329a8977b9dd1b21a5
MD5 41973dfe996ec03c48ddeeb5a9eb2158
BLAKE2b-256 dd8130fe68f16091a1bd432088d421edd6780dc31193b0a5e254e4755f9016b2

See more details on using hashes here.

Supported by

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