Skip to main content

Python client for the OrcaLayer API — Polymarket whale and market analytics

Project description

orcalayer

CI PyPI

Official Python client for the OrcaLayer API — Polymarket whale and market analytics: wallet P&L, open positions, smart-whale leaderboard, market search and real-time whale alerts.

Install

pip install orcalayer

Requires Python 3.10+. Single dependency: httpx.

Quickstart

Three lines to a first result — no API key needed for public endpoints:

from orcalayer import OrcaLayer

ol = OrcaLayer()
print(ol.leaderboard(limit=5))

Anonymous access is limited to 200 requests/min per IP, and wallet endpoints (wallet_overview, wallet_positions) additionally to 300 requests/day per IP. With a Premium API key (get one here) you get 600 req/min, no daily cap, and access to Premium endpoints such as whale alerts:

ol = OrcaLayer(api_key="ol_your_key")
alerts = ol.whale_alerts(minutes=30, min_usd=1000)

Methods

Method Endpoint Access
leaderboard(sort, category, limit, ...) Smart-whale leaderboard with server-side filters Public
wallet_overview(address) Wallet profile + trading stats (accepts 0x address or nickname) Public
wallet_positions(address, limit, offset) Open positions, sorted by current value Public
markets(q, category, min_volume, ...) Market search (accepts free text or a Polymarket URL) Public
whale_alerts(minutes, min_usd, ...) Recent smart-whale trades feed Premium

All methods return the JSON response as a plain dict, exactly as the API sends it. Full field reference: orcalayer.com/docs.

Behavior notes

  • Rate limits: on HTTP 429 the client reads Retry-After and retries with exponential backoff (default 3 attempts). Disable with OrcaLayer(retry_on_rate_limit=False). A Retry-After beyond 5 minutes signals the anonymous daily cap rather than a burst — the client then raises RateLimitError immediately instead of retrying.
  • Transient 502 responses are retried once automatically.
  • Premium endpoints without a key raise PremiumRequiredError with a link to pricing — no network call is made.
  • Wallet overview freshness: responses include as_of (data timestamp) and degraded (heavy side-stats timed out, core stats still present).
  • Cold heavy wallets answer HTTP 202 while their stats are computed server-side. The client retries once automatically after the server's Retry-After interval; if the wallet is still not ready it raises WalletComputingError (carrying retry_after) so a 202 body is never mistaken for wallet data.

Errors

All exceptions inherit from orcalayer.OrcaLayerError, so one except catches everything:

from orcalayer import OrcaLayer, OrcaLayerError, RateLimitError

ol = OrcaLayer()
try:
    data = ol.wallet_overview("0x...")
except RateLimitError as e:
    print(f"rate limited, retry in {e.retry_after:.0f}s")
except OrcaLayerError as e:
    print(f"request failed: {e}")
Exception Raised on
PremiumRequiredError Premium endpoint called without a key (no network call made)
AuthenticationError Key rejected (HTTP 401/403)
RateLimitError HTTP 429 after retries, or immediately for the daily cap; carries retry_after
WalletComputingError Heavy wallet still computing (HTTP 202 twice); carries retry_after
APIError Unhandled 4xx (404/400/422) or a non-JSON body; carries status_code and body
ServerError Unexpected 5xx

The package ships type hints (py.typed).

License

MIT. See LICENSE.

Data is provided for informational purposes only and is not financial advice.

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

orcalayer-0.1.1.tar.gz (9.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

orcalayer-0.1.1-py3-none-any.whl (9.2 kB view details)

Uploaded Python 3

File details

Details for the file orcalayer-0.1.1.tar.gz.

File metadata

  • Download URL: orcalayer-0.1.1.tar.gz
  • Upload date:
  • Size: 9.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for orcalayer-0.1.1.tar.gz
Algorithm Hash digest
SHA256 b625b010222f9a76c836a281d47e0154b05ca80f081075d3f3129eb16f0d4c36
MD5 bcce076bb95e509b458a8a1779edabc8
BLAKE2b-256 a4cc80f556d80e605c68a97a002a8a644f5554c59628cfd8bf03e9e893cd6781

See more details on using hashes here.

File details

Details for the file orcalayer-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: orcalayer-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 9.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for orcalayer-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 96ec12336614922de20ee4bb2f543042ad1d7261ed230bdc4190dfae1c51b1bf
MD5 6414ccd2f614a722bffffe856e8f20f0
BLAKE2b-256 03d257850f0be29b48b9ee13b333ec22b7238bfaf8fa2e51d02ee225aeee6ac8

See more details on using hashes here.

Supported by

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