Skip to main content

Developer SDK + CLI for building, packaging, and deploying A2A agents.

Project description

a2a-pack

Developer SDK + CLI for building, packaging, and deploying A2A agents.

One Python class becomes a sandboxed, discoverable, MCP-compatible AI agent on the a2a cloud platform. Other agents reach yours via HMAC-signed grants. The platform owns deployment, execution, permissions, and (when you're ready) billing.

pip install a2a-pack
a2a signup --email you@example.com --password ...
a2a init research-agent
cd research-agent
a2a deploy
# → https://research-agent.a2acloud.io   (TLS, MCP, OpenAPI, all wired)

What an agent looks like

from pydantic import BaseModel
from a2a_pack import (
    A2AAgent, LLMProvisioning, NoAuth, Pricing, RunContext, skill,
)


class GreeterConfig(BaseModel):
    suffix: str = "!"


class Greeter(A2AAgent[GreeterConfig, NoAuth]):
    name = "greeter"
    description = "Say hi."
    version = "0.1.0"
    config_model = GreeterConfig
    auth_model = NoAuth

    # Use the caller's own LLM key (forwarded by the platform) — the
    # author's price stays small; the LLM bill goes to the caller's
    # provider directly.
    llm_provisioning = LLMProvisioning.CALLER_PROVIDED
    pricing = Pricing(price_per_call_usd=0.01, caller_pays_llm=True)

    @skill(description="Greet someone.")
    async def greet(self, ctx: RunContext[NoAuth], who: str) -> str:
        await ctx.emit_progress(f"greeting {who}")
        return f"hello {who}{self.config.suffix}"

That's it. a2a deploy packages the source, the control plane builds the image, ArgoCD reconciles, you get a public URL.

Public surface

Concept Where
A2AAgent base class + @skill decorator a2a_pack.agent
RunContext, ctx.llm, ctx.ask, ctx.request_scope a2a_pack.context
Grant mint/verify (HMAC, audience-bound, glob-filtered, time-limited) a2a_pack.grants
Workspace negotiation surface a2a_pack.workspace
Sandbox client (microVM via libkrun) a2a_pack.sandbox
Agent-to-agent client (HTTP, in-memory, custom) a2a_pack.a2a_client
MCP server (skills → tools, mountable into your FastAPI app) a2a_pack.mcp
Lifecycle / Resources / Pricing / LLMProvisioning declarations a2a_pack.runtime
Card schema (auto-derived from your class) a2a_pack.card

Full reference + auto-generated docs at https://docs.a2acloud.io.

Self-hosting

The platform pieces (control plane, sandbox runtime, gitea, ArgoCD, MinIO, LiteLLM) live at gitea.a2acloud.io — the SDK is the only piece you need on PyPI. If you want to run the whole stack locally or in your own cluster, the bootstrap recipe is in the platform README.

License

MIT — see LICENSE.

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

a2a_pack-0.1.4.tar.gz (56.4 kB view details)

Uploaded Source

Built Distribution

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

a2a_pack-0.1.4-py3-none-any.whl (76.8 kB view details)

Uploaded Python 3

File details

Details for the file a2a_pack-0.1.4.tar.gz.

File metadata

  • Download URL: a2a_pack-0.1.4.tar.gz
  • Upload date:
  • Size: 56.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for a2a_pack-0.1.4.tar.gz
Algorithm Hash digest
SHA256 fdbb219b2e77c3aeed786af61b8cc82af336808cd11ef04fcf0df02cfccee4e1
MD5 f81c2b8c183570b324cef8f2b6b6d2dc
BLAKE2b-256 c4fd0ecee3692927e9b283bd2c0df923ef4c86f1fb0ec478ec64a262d0dfa1fd

See more details on using hashes here.

File details

Details for the file a2a_pack-0.1.4-py3-none-any.whl.

File metadata

  • Download URL: a2a_pack-0.1.4-py3-none-any.whl
  • Upload date:
  • Size: 76.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for a2a_pack-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 b27040d1a0caec3a5c17c9910b957f463b23687969890577bb5ef884251a6929
MD5 3c91ec0c102d0140537d1ee6b106f2a4
BLAKE2b-256 e46d62555d917df65f61206d16f4fc4f35e43dbd08b9c9f3a2d0283e35f25c96

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