Skip to main content

Python SDK + CLI for the Agent Identity Registry (AIR) — agentidentityregistry.org

Project description

agent-identity-registry

Async Python SDK + air CLI for the Agent Identity Registry (AIR).

AIR is a W3C-aligned identity layer for AI agents: every agent gets a stable identifier (AIR-XXXX-XXXX-XXXX), a public-key-backed DID document, and a graduated trust score that counterparties can verify before transacting.

Install

pip install agent-identity-registry

Requires Python 3.10+. Installs both the Python SDK and the air command-line tool.

air CLI

Pretty terminal access to every public endpoint — useful for demos, scripting, and exploration.

air health                           # Check registry liveness
air list                             # List agents (sorted by trust score)
air list --limit 5                   # Paginate
air lookup AIR-XXXX-XXXX-XXXX        # Full agent record
air score AIR-XXXX-XXXX-XXXX         # Trust-score breakdown with bar chart
air did-doc AIR-XXXX-XXXX-XXXX       # W3C DID Core JSON-LD
air check WeatherBot                 # Is this name taken?
air register --name MyBot --public-key <ed25519-base64url> --open-source

Global flags:

Flag Effect
--json Output raw JSON instead of human-friendly format (for scripting)
--base-url URL Point at a different registry (also AIR_BASE_URL env var)
--no-color Disable ANSI color codes (also NO_COLOR env var)

Exit codes: 0 on success, 1 on AIR-level error (404, rate-limit, server error, network failure — friendly message printed to stderr), 2 on usage error (argparse).

Quick start

import asyncio
from agent_identity_registry import AIRClient

async def main():
    async with AIRClient() as client:
        # Public lookup — no auth
        agent = await client.get_agent("AIR-XXXX-XXXX-XXXX")
        print(agent.name, agent.trust_score, agent.trust_grade)

        # Trust-score breakdown (5 components)
        score = await client.get_trust_score("AIR-XXXX-XXXX-XXXX")
        print(score.components.provenance, score.components.behavioral)

        # W3C DID document (publicKeyMultibase + service endpoints)
        did_doc = await client.get_did_document("AIR-XXXX-XXXX-XXXX")
        print(did_doc.id, did_doc.verification_method[0].public_key_multibase)

asyncio.run(main())

Register a new agent

Returns an agent_secret you must store yourself — it's shown only once and is required for later updates.

async with AIRClient() as client:
    result = await client.register_agent(
        name="WeatherBot",
        description="Forecasts weather in 70 cities",
        public_key="...43-char-base64url-Ed25519-key...",  # AIR will mint a did:wba
        creator_type="individual",
        capabilities=["weather", "forecast"],
        open_source=True,
        code_repository="https://github.com/example/weatherbot",
    )

    print(result.air_id)          # AIR-XXXX-XXXX-XXXX
    print(result.agent_secret)    # SAVE THIS — required for PUT
    print(result.air_minted_did)  # True if AIR minted a did:wba

Update an agent

Pass the secret you stored at registration.

async with AIRClient() as client:
    update = await client.update_agent(
        air_id="AIR-XXXX-XXXX-XXXX",
        agent_secret="...32-char-hex-secret-from-registration...",
        description="Updated description",
        capabilities=["weather", "forecast", "alerts"],
    )
    print(update.trust_score)  # Recalculated after update

Errors

All errors derive from AirError:

Status Exception Notes
400 ValidationError Bad input (invalid public_key, missing required field)
401 / 403 AuthenticationError Missing/invalid agent_secret or admin key
404 AgentNotFoundError Unknown AIR ID
409 ConflictError Rare ID collision — retry registration
429 RateLimitedError Exposes retry_after_seconds
5xx ServerError Upstream registry issue
connection failures NetworkError httpx layer (timeout, DNS, TLS)
from agent_identity_registry import AIRClient, AgentNotFoundError, RateLimitedError

async with AIRClient() as client:
    try:
        agent = await client.get_agent("AIR-DOES-NOTX-IST0")
    except AgentNotFoundError as e:
        print(f"No such agent: {e.air_id}")
    except RateLimitedError as e:
        print(f"Slow down. Retry in {e.retry_after_seconds}s")

License

Apache 2.0 — see the registry repo for full text.

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

agent_identity_registry-0.2.0.tar.gz (28.1 kB view details)

Uploaded Source

Built Distribution

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

agent_identity_registry-0.2.0-py3-none-any.whl (22.5 kB view details)

Uploaded Python 3

File details

Details for the file agent_identity_registry-0.2.0.tar.gz.

File metadata

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

File hashes

Hashes for agent_identity_registry-0.2.0.tar.gz
Algorithm Hash digest
SHA256 f8564f0ae604650bf1176c2c8e596f085552cb9b431f400a3d714e4744d5a2d9
MD5 2205100db8bfce9c2bf0abc92879b14d
BLAKE2b-256 a10efba7618e0f0f98644641aa7d2af3c24da74a17a2bd5440496469430cb3c2

See more details on using hashes here.

Provenance

The following attestation bundles were made for agent_identity_registry-0.2.0.tar.gz:

Publisher: release.yml on AgentIdentityRegistry/agent-identity-registry-python

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

File details

Details for the file agent_identity_registry-0.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for agent_identity_registry-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 62d69f885c3458dca82a7dcd7a24bfaf27ec46313193832cca8e9d736e8d3e4f
MD5 5bdd2297f3514dd686074c118d4ae3f3
BLAKE2b-256 a64a2a3312db1a4f85d252c12de514d3efe5f198a8375efa70b52fded5a6913f

See more details on using hashes here.

Provenance

The following attestation bundles were made for agent_identity_registry-0.2.0-py3-none-any.whl:

Publisher: release.yml on AgentIdentityRegistry/agent-identity-registry-python

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