LN Markets API Python SDK
Project description
LN Markets SDK
Python SDK for the LN Markets API. Ships two clients:
- REST v3 (
lnmarkets_sdk.rest.v3) — request/response API. - Stream v1 (
lnmarkets_sdk.stream.v1) — JSON-RPC WebSocket with subscriptions.
REST v3
For public endpoints, you can just do this:
from lnmarkets_sdk.rest.v3.http.client import LNMClient
import asyncio
async with LNMClient() as client:
ticker = await client.futures.get_ticker()
await asyncio.sleep(1)
leaderboard = await client.futures.get_leaderboard()
Remember to sleep between requests, as the rate limit is 1 requests per second for public endpoints.
For endpoints that need authentication, you need to create an instance of the LNMClient class and provide your API credentials:
from lnmarkets_sdk.rest.v3.http.client import APIAuthContext, APIClientConfig, LNMClient
config = APIClientConfig(
authentication=APIAuthContext(
key=your_key,
secret=your_secret,
passphrase=your_passphrase,
),
network="mainnet",
timeout=60.0, # 60 second timeout (default is 30s)
)
async with LNMClient(config) as client:
account = await client.account.get_account()
For endpoints that requires input parameters, you can find the corresponding models in the lnmarkets_sdk.rest.v3.models module.
from lnmarkets_sdk.rest.v3.http.client import APIAuthContext, APIClientConfig, LNMClient
from lnmarkets_sdk.rest.v3.models.account import GetLightningDepositsParams
config = APIClientConfig(
authentication=APIAuthContext(
key=your_key,
secret=your_secret,
passphrase=your_passphrase,
),
network="mainnet",
timeout=60.0, # 60 second timeout (default is 30s)
)
async with LNMClient(config) as client:
deposits = await client.account.get_lightning_deposits(
GetLightningDepositsParams(limit=5)
)
Check our REST example for more details.
Available Methods
🔒 = requires API credentials
# Ping
client.ping()
# Account 🔒
client.account.get_account()
client.account.get_bitcoin_address()
client.account.add_bitcoin_address()
client.account.deposit_lightning()
client.account.withdraw_lightning()
client.account.withdraw_on_chain()
client.account.get_lightning_deposits()
client.account.get_lightning_withdrawals()
client.account.get_on_chain_deposits()
client.account.get_on_chain_withdrawals()
client.account.read_notifications()
# Futures
client.futures.get_ticker()
client.futures.get_leaderboard()
client.futures.get_candles()
client.futures.get_funding_settlements()
# Futures Isolated 🔒
client.futures.isolated.new_trade()
client.futures.isolated.get_running_trades()
client.futures.isolated.get_open_trades()
client.futures.isolated.get_closed_trades()
client.futures.isolated.close()
client.futures.isolated.cancel()
client.futures.isolated.cancel_all()
client.futures.isolated.add_margin()
client.futures.isolated.cash_in()
client.futures.isolated.update_stoploss()
client.futures.isolated.update_takeprofit()
client.futures.isolated.get_funding_fees()
# Futures Cross 🔒
client.futures.cross.new_order()
client.futures.cross.get_position()
client.futures.cross.get_open_orders()
client.futures.cross.get_filled_orders()
client.futures.cross.close()
client.futures.cross.cancel()
client.futures.cross.cancel_all()
client.futures.cross.deposit()
client.futures.cross.withdraw()
client.futures.cross.set_leverage()
client.futures.cross.get_transfers()
client.futures.cross.get_funding_fees()
# Oracle
client.oracle.get_index()
client.oracle.get_last_price()
# Synthetic USD
client.synthetic_usd.get_best_price()
client.synthetic_usd.get_swaps() # 🔒
client.synthetic_usd.new_swap() # 🔒
Stream v1
WebSocket JSON-RPC client. Connect, subscribe to topics, register event listeners.
Public stream:
import asyncio
from lnmarkets_sdk.stream.v1 import StreamClientConfig, create_stream_client
from lnmarkets_sdk.stream.v1.models import SubscribeParams
async def main():
config = StreamClientConfig(network="mainnet")
client = create_stream_client(config)
client.on(
"futures/inverse/btc_usd/ticker",
lambda data: print(data["lastPrice"]),
)
await client.connect()
await client.subscription.subscribe(
SubscribeParams(topics=["futures/inverse/btc_usd/ticker"]),
)
await asyncio.sleep(30)
await client.close()
asyncio.run(main())
Authenticated stream (private topics: trades, orders, position, wallet):
from lnmarkets_sdk.stream.v1 import StreamClientConfig, create_stream_client
from lnmarkets_sdk.stream.v1.models import AuthenticateParams, SubscribeParams
config = StreamClientConfig(
network="mainnet",
reconnect_enabled=True,
reconnect_interval=5.0,
max_reconnect_attempts=5,
)
client = create_stream_client(config)
await client.connect()
await client.auth.authenticate(
AuthenticateParams(key=your_key, secret=your_secret, passphrase=your_passphrase),
)
await client.subscription.subscribe(
SubscribeParams(topics=[
"futures/inverse/btc_usd/isolated/trades",
"wallet/deposit",
"wallet/withdrawal",
]),
)
Server rate-limits to 10 messages/sec per socket — pace RPC calls accordingly.
Check our Stream example for full RPC + topic coverage.
Available RPCs and Topics
🔒 = requires authentication
# Public RPCs
client.public.hello()
client.public.ping()
client.public.time()
# Auth RPCs 🔒
client.auth.authenticate()
client.auth.whoami()
# Subscription RPCs
client.subscription.subscribe()
client.subscription.unsubscribe()
client.subscription.unsubscribe_all()
# Lifecycle events
client.on("open", ...)
client.on("close", ...)
client.on("error", ...)
client.on("reconnected", ...)
# Public topics
"announcements"
"futures/inverse/btc_usd/ticker"
"futures/inverse/btc_usd/lastPrice"
"futures/inverse/btc_usd/index"
"futures/inverse/btc_usd/buckets"
"futures/inverse/btc_usd/funding"
"futures/inverse/btc_usd/ohlc/1m"
"futures/inverse/btc_usd/ohlc/5m"
# Private topics 🔒
"futures/inverse/btc_usd/isolated/trades"
"futures/inverse/btc_usd/cross/orders"
"futures/inverse/btc_usd/cross/position"
"wallet/deposit"
"wallet/withdrawal"
API Reference
Contributing
Contributions are welcome! If you find any issues or have suggestions for improvements, please open an issue or submit a pull request.
License
This project is licensed under the MIT License. See the LICENSE file for details.
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
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 lnmarkets_sdk-0.1.0.tar.gz.
File metadata
- Download URL: lnmarkets_sdk-0.1.0.tar.gz
- Upload date:
- Size: 251.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
683e1e9f89d5b95f155d2793b48ca8e53df83af9051ff8aa5a6ff92aaec143be
|
|
| MD5 |
f06f0f8b3b5188ceb61180dffe173619
|
|
| BLAKE2b-256 |
15f95a76a8e927108f9cd5dbcf693f113c386cdf619ec146c717561983d96a0b
|
File details
Details for the file lnmarkets_sdk-0.1.0-py3-none-any.whl.
File metadata
- Download URL: lnmarkets_sdk-0.1.0-py3-none-any.whl
- Upload date:
- Size: 49.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
36682137c2b7fc4643c634711a6acae3a0582b9b57de079f8ae7f8fc65ce2a04
|
|
| MD5 |
2b773d061ef5beb2a3d4c3d00fc8f527
|
|
| BLAKE2b-256 |
f5deb9db26251fe2fee877d1761800d477ac375ef9199f3ec675b5fa5ee6279d
|