Python library for the StackCoin API
Project description
stackcoin-python
Python library for the StackCoin API. Provides a typed async REST client and a WebSocket gateway for real-time events.
Install
pip install stackcoin
Requires Python 3.13+. Dependencies: httpx, pydantic>=2, websockets.
Quick start
import asyncio
import stackcoin
async def main():
async with stackcoin.Client(token="...") as client:
me = await client.get_me()
print(f"{me.username}: {me.balance} STK")
events = await client.get_events()
for event in events:
print(f"[{event.type}] {event.data}")
asyncio.run(main())
Gateway (real-time events)
import stackcoin
gateway = stackcoin.Gateway(token="...")
@gateway.on("transfer.completed")
async def on_transfer(event: stackcoin.TransferCompletedEvent):
print(f"Transfer of {event.data.amount} STK from #{event.data.from_id} to #{event.data.to_id}")
@gateway.on("request.accepted")
async def on_accepted(event: stackcoin.RequestAcceptedEvent):
print(f"Request #{event.data.request_id} accepted")
await gateway.connect()
Catching up on missed events
If your bot persists its cursor position and reconnects with a last_event_id,
the server replays up to 100 missed events. If more than 100 were missed, the
join is rejected — pass a client so the Gateway can automatically catch up
via the REST API. Without a client, a TooManyMissedEventsError is raised.
async with stackcoin.Client(token="...") as client:
gateway = stackcoin.Gateway(
token="...",
client=client,
last_event_id=saved_cursor,
on_event_id=lambda eid: save_cursor(eid),
)
@gateway.on("transfer.completed")
async def on_transfer(event: stackcoin.TransferCompletedEvent):
...
await gateway.connect()
Examples
examples/basic_usage.py-- REST client basics (balance, requests, transactions)examples/simple_cli.py-- interactive REPL with live gateway events
Testing
Tests for this library live in the main StackCoin/StackCoin repository as end-to-end tests that boot a real StackCoin server:
cd /path/to/StackCoin/test/e2e/py
uv sync
uv run pytest
The E2E suite covers the REST client, WebSocket gateway, event pagination, and the LuckyPot bot integration.
Development
Models are generated from the StackCoin OpenAPI spec using datamodel-codegen:
STACKCOIN_ROOT=/path/to/StackCoin just generate
This regenerates src/stackcoin/models.py from openapi.json.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file stackcoin-0.1.3.tar.gz.
File metadata
- Download URL: stackcoin-0.1.3.tar.gz
- Upload date:
- Size: 21.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.8.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b5d9240170cb9b250877770e15efc7c42b367501c9fb8aa1ab6658d41def049d
|
|
| MD5 |
dfa9842e83112c1a27bff0cbe82750ff
|
|
| BLAKE2b-256 |
784dbe69da85871ccb3c0600b2a73da025a19fe47c601d4550d62ada3e3ad9d3
|
File details
Details for the file stackcoin-0.1.3-py3-none-any.whl.
File metadata
- Download URL: stackcoin-0.1.3-py3-none-any.whl
- Upload date:
- Size: 10.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.8.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bfd68cb656f78fde0e75eaa408dfd0106e22492b42dd2798d25f35bdd576cdd8
|
|
| MD5 |
10a03a774cbfd0c5ebd09020f17d01ef
|
|
| BLAKE2b-256 |
494d33164a4f6617a7816dc77861b33e8ea5cda775a406cc31649c3d68ae86dd
|