Skip to main content

Python SDK for ATI (Agent Tools Interface) — token utilities and orchestrator provisioning

Project description

ati-client

Python SDK for ATI (Agent Tools Interface) — orchestrator provisioning and JWT token utilities.

Install

pip install ati-client

Quick Start

Orchestrator Provisioning

from ati import AtiOrchestrator

orch = AtiOrchestrator(
    proxy_url="https://ati-proxy.example.com",
    secret="17332cf135d362f79a2ed700b13e1215978be1d6ae6e133d25b6b3f21fa10299",
)

# Generate env vars to inject into a sandboxed agent
env_vars = orch.provision_sandbox(
    agent_id=f"sandbox:{sandbox_id}",
    tools=["finnhub_quote", "web_search", "github:*"],
    skills=["financial-analysis"],
    ttl_seconds=7200,
    rate={"tool:github:*": "10/hour"},
)

# env_vars = {
#     "ATI_PROXY_URL": "https://ati-proxy.example.com",
#     "ATI_SESSION_TOKEN": "eyJ...",
# }

Token Utilities

from ati import issue_token, validate_token, inspect_token

# Issue a token
token = issue_token(
    secret="17332cf135d362f79a...",
    sub="agent-7",
    scope="tool:web_search tool:finnhub_quote",
    ttl_seconds=3600,
)

# Validate (checks signature, expiry, audience)
claims = validate_token(token, secret="17332cf135d362f79a...")
print(claims.sub)      # "agent-7"
print(claims.scopes()) # ["tool:web_search", "tool:finnhub_quote"]

# Inspect without validation (debugging)
claims = inspect_token(token)

Scope Utilities

from ati import build_scope_string, check_scope, matches_wildcard

# Build scope strings
scope = build_scope_string(
    tools=["web_search", "github:*"],
    skills=["research-*"],
    extra=["help"],
)
# "tool:web_search tool:github:* skill:research-* help"

# Check if a tool is allowed
check_scope("tool:github:search_repos", ["tool:github:*"])  # True
check_scope("tool:secret_api", ["tool:web_search"])            # False

# Wildcard matching
matches_wildcard("tool:github:search", "tool:github:*")  # True
matches_wildcard("anything", "*")                           # True

JWT Format

Tokens are HS256-signed JWTs compatible with the ATI Rust proxy. The secret must be a hex-encoded 32-byte key (64 hex characters).

Claims payload:

{
  "sub": "agent-7",
  "aud": "ati-proxy",
  "iat": 1700000000,
  "exp": 1700003600,
  "jti": "550e8400-e29b-41d4-a716-446655440000",
  "iss": "ati-orchestrator",
  "scope": "tool:web_search tool:github:*",
  "ati": {
    "v": 1,
    "rate": {
      "tool:github:*": "10/hour"
    }
  }
}

Development

cd ati-client
pip install -e ".[dev]"
pytest

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

ati_client-0.7.9.tar.gz (17.5 kB view details)

Uploaded Source

Built Distribution

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

ati_client-0.7.9-py3-none-any.whl (13.2 kB view details)

Uploaded Python 3

File details

Details for the file ati_client-0.7.9.tar.gz.

File metadata

  • Download URL: ati_client-0.7.9.tar.gz
  • Upload date:
  • Size: 17.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for ati_client-0.7.9.tar.gz
Algorithm Hash digest
SHA256 04f2c203fc3d98534e6df547ba73d12e5aa6e15007d84dfc7f663f9fd0a36d23
MD5 ca77a42d46fbf2b6e2f724306561c1b2
BLAKE2b-256 c58dc39ffb75f307f46ef2b988730769bad2eab72144b1716663faf1b7216aab

See more details on using hashes here.

Provenance

The following attestation bundles were made for ati_client-0.7.9.tar.gz:

Publisher: release.yml on Parcha-ai/ati

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

File details

Details for the file ati_client-0.7.9-py3-none-any.whl.

File metadata

  • Download URL: ati_client-0.7.9-py3-none-any.whl
  • Upload date:
  • Size: 13.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for ati_client-0.7.9-py3-none-any.whl
Algorithm Hash digest
SHA256 f3a821f1244f1207c12a8838f096973cf6424bce1d3947698c1077a4a3e976a9
MD5 529a906e0f9b8f09c43e271a2a1e832d
BLAKE2b-256 c0d6f32e76aba15c8e29a23b827a887459fadc804a5cdcf405cd69b7552c61c8

See more details on using hashes here.

Provenance

The following attestation bundles were made for ati_client-0.7.9-py3-none-any.whl:

Publisher: release.yml on Parcha-ai/ati

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