Skip to main content

Official Python SDK for tierproxy — premium multi-provider proxy infrastructure for AI/ML pipelines.

Project description

tierproxy — Python SDK

PyPI version Python versions Downloads CI codecov License: Apache 2.0 OpenAPI 3.1 MCP compatible

Premium multi-provider proxy infrastructure for AI/ML pipelines. Built for engineers who measure cost, latency, and success rate twice — and write Python.

Install

pip install tierproxy

Quickstart — five-second flavor

import tierproxy
r = tierproxy.get("https://example.com", country="US")
print(r.text)

That's it. (Set TIERPROXY_API_KEY env var first.)

Three lines, persistent session

from tierproxy import TierProxy
with TierProxy() as g:
    print(g.me.get().client_id)
    r = g.get("https://example.com", country="US", session_id="s1")

Auto-pick the cheapest healthy upstream every request

g = TierProxy(routing="cheapest")  # also: "fastest", "most_reliable", "balanced"
g.get("https://example.com")     # picks via /v1/health/upstreams under the hood

Cost guardrails + 80% usage alert

def alert(pct: float) -> None:
    print(f"Used {pct:.0f}% of monthly quota")

g = TierProxy(
    monthly_budget_usd=200.0,    # raises BudgetExceededError before going over
    on_usage_pct=80,             # fires the callback once you cross 80%
    on_usage_callback=alert,
)

Power-user knobs

import httpx
from tierproxy import TierProxy
from tierproxy.retry import RetryPolicy

g = TierProxy(
    api_key="tp_live_...",
    base_url="https://my-self-hosted-gw:8444",
    timeout=10.0,
    retry_policy=RetryPolicy(max_retries=5, retry_on_status=frozenset({500, 502})),
    http_client=httpx.Client(verify=False),  # custom transport
    user_agent_suffix="my-app/2.3",          # attribution
)

Raw modes (Playwright, curl, etc.)

from tierproxy import ProxyURL

p = ProxyURL(api_key="tp_live_...", country="US", mode="username_encoding")
print(p.http_url())  # http://customer-tp_live_...-cc-US:x@gw.tierproxy.com:443

How tierproxy compares

tierproxy Smartproxy SDK Bright Data SDK Oxylabs SDK DataImpulse
Multi-provider routing
Client-side smart selector (cost-aware)
Live usage streaming (SSE)
MCP server (Claude/Cursor/Cline)
OpenTelemetry built-in
Sync + async parity partial partial partial partial
AI/ML framework examples shipped 10 0 1 0 0
Type-safe (Pydantic v2 + mypy strict) partial
OpenAPI 3.1 spec
Pip-installable CLI (tierproxy doctor)
License Apache 2.0 proprietary proprietary proprietary proprietary

Features

  • Five-second quickstartimport tierproxy; tierproxy.get(url, country="US")
  • Layered API — five integration levels from one-liner to power-user knobs
  • Smart routingrouting="cheapest" auto-picks healthy upstream per request
  • Cost guardrailsmonthly_budget_usd= refuses requests that would exceed budget
  • Usage alertson_usage_pct=80 fires callback at 80% of quota
  • Live SSE streamfor delta in g.usage.stream() tails month-to-date bytes
  • MCP servertierproxy-mcp exposes proxy as tools to Claude/Cursor/Cline
  • 10 framework integrations — LangChain, LlamaIndex, Crawl4AI, Playwright, Firecrawl, Browser-Use, ScrapeGraphAI, CrewAI, GPT-Researcher
  • OpenTelemetry opt-inpip install tierproxy[otel] for distributed tracing
  • Geo + sticky sessions — countries, cities, 1-1440min session pins
  • Dual URL syntax — headers (httpx/requests) AND username-encoding (Playwright)
  • Type-safe end-to-end — Pydantic v2 models, mypy strict, full IDE autocomplete

See examples/ for LangChain/LlamaIndex/Crawl4AI/Playwright and examples/levels.py for a runnable demo of every level.

Use with your favorite AI/agent framework

Framework Example Notes
LangChain with_langchain.py RAG document loaders through proxy
LlamaIndex with_llamaindex.py SimpleWebPageReader through proxy
Crawl4AI with_crawl4ai.py Playwright crawler + tierproxy
Firecrawl (hot) with_firecrawl.py Self-hosted Firecrawl + residential IPs
Browser-Use (hot) with_browser_use.py LLM-driven autonomous browser
CrewAI (hot) with_crewai.py Multi-agent scraper crew + cost-aware routing
ScrapeGraphAI with_scrapegraphai.py LLM-driven extraction in plain English
GPT-Researcher with_gpt_researcher.py Multi-region research with geo rotation
Playwright with_playwright.py Direct Playwright with tierproxy
MCP (Claude/Cursor/Cline/Windsurf) (unique) mcp_claude_desktop.md Native tool integration via tierproxy-mcp

MCP server (Claude Desktop / Cursor / Cline / Windsurf)

pip install tierproxy[mcp]

Then add to your MCP client config:

{
  "mcpServers": {
    "tierproxy": {
      "command": "tierproxy-mcp",
      "env": { "TIERPROXY_API_KEY": "tp_live_..." }
    }
  }
}

Now your AI assistant can call fetch_url(url, country="US"), inspect health and usage, and route through the cheapest healthy upstream — no glue code, no httpx imports, no boilerplate.

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

tierproxy-0.1.1.tar.gz (70.5 kB view details)

Uploaded Source

Built Distribution

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

tierproxy-0.1.1-py3-none-any.whl (35.1 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: tierproxy-0.1.1.tar.gz
  • Upload date:
  • Size: 70.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for tierproxy-0.1.1.tar.gz
Algorithm Hash digest
SHA256 99e9090914baee1ef61fd1d9d2b3c05de765d1e9e34a25d5a26662c50a606bc3
MD5 fa12cac3e5c1e9b5af8de603579a6594
BLAKE2b-256 4cf031dbb64fcdc28505d63fa197c5058097990e45379c4de5e39548f73ac75c

See more details on using hashes here.

Provenance

The following attestation bundles were made for tierproxy-0.1.1.tar.gz:

Publisher: release.yml on tierproxy/python-sdk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

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

File metadata

  • Download URL: tierproxy-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 35.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for tierproxy-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 14a98513d6592dbdc18615d8ef046ca7bd44a7a2c5d868539645847fa8c2bdd4
MD5 2e092f5f8e6101c203350a3f7efaf822
BLAKE2b-256 0cd035b1e4898f688214bf2102b9ef6ea2d12fda390da813571dac28498b75f5

See more details on using hashes here.

Provenance

The following attestation bundles were made for tierproxy-0.1.1-py3-none-any.whl:

Publisher: release.yml on tierproxy/python-sdk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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