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.

Examples

Runnable scripts in examples/ — each is self-contained and runs against the live API:

Script What it does Key
find_top_whales.py Top smart-money whales in a category, via the leaderboard No
track_wallet.py A wallet's profile, stats and open positions No
find_consensus_markets.py Markets where smart whales are clustering, with filters No
whale_alerts_feed.py Recent smart-whale trades feed (shows the Premium path) Yes

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.3.tar.gz (12.1 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.3-py3-none-any.whl (9.8 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: orcalayer-0.1.3.tar.gz
  • Upload date:
  • Size: 12.1 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.3.tar.gz
Algorithm Hash digest
SHA256 c0bc473433df184058a3d6e51796349662026ad0ee1a5196540491088a78c097
MD5 bd6ace598ce5148ace2742f62610b3c1
BLAKE2b-256 42025912c104d0f2f6286bd1c3b1f4bc88172f083e586015ea70003f3956eb39

See more details on using hashes here.

File details

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

File metadata

  • Download URL: orcalayer-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 9.8 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.3-py3-none-any.whl
Algorithm Hash digest
SHA256 2d26f78ed331de1231546aa6bfef6f64e3df96401ce839379483d19e45b2de19
MD5 f65e59a2b7ba5976eb50cbad9a35c7f4
BLAKE2b-256 cc1a2187a6081de38ad4bc2893467ead84bcf6a22d0070307ee56ddba92c76be

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