Skip to main content

A library for building A2A agents with routing capabilities

Project description

A2A Agent Library

A Python library for building A2A (Agent-to-Agent) agents with routing capabilities, DynamoDB-backed registry, and LangChain integration.

Features

  • StatusAgent: Base agent implementation with status tracking and structured responses
  • RoutingAgentExecutor: Agent executor with intelligent routing capabilities
  • DynamoDB Registry: Dynamic agent card registry with heartbeat mechanism
  • Server Utilities: FastAPI application builder with A2A protocol support
  • LangChain Integration: Built on LangChain for flexible model integration

Installation

pip install distributed-a2a

Quick Start

from distributed_a2a import load_app
from a2a.types import AgentSkill

# Define your agent's skills
skills = [
    AgentSkill(
        id='example_skill',
        name='Example Skill',
        description='An example skill',
        tags=['example']
    )
]

# Create your agent application
app = load_app(
    name="MyAgent",
    description="My specialized agent",
    skills=skills,
    api_key="your-api-key",
    system_prompt="You are a helpful assistant...",
    host="http://localhost:8000"
)

Components

StatusAgent

A base agent class that provides status tracking and structured responses:

from distributed_a2a import StatusAgent, StringResponse

agent = StatusAgent[StringResponse](
    system_prompt="Your system prompt",
    name="AgentName",
    api_key="your-api-key",
    is_routing=False,
    tools=[]
)

response = await agent("User message", context_id="context-123")

RoutingAgentExecutor

An executor that can handle requests directly or route them to specialized agents:

from distributed_a2a import RoutingAgentExecutor

executor = RoutingAgentExecutor(
    api_key="your-api-key",
    system_prompt="Your system prompt",
    routing_tool=routing_tool
)

DynamoDB Registry

Dynamic agent registry with automatic heartbeat and expiration:

from distributed_a2a import DynamoDbRegistryLookup

registry = DynamoDbRegistryLookup(agent_card_tabel="agent-cards")
tool = registry.as_tool()

Requirements

  • Python 3.10+
  • langchain
  • langchain-core
  • langchain-openai
  • langgraph
  • pydantic
  • boto3
  • a2a

License

MIT

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

Project details


Release history Release notifications | RSS feed

This version

0.1.2

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

distributed_a2a-0.1.2.tar.gz (9.1 kB view details)

Uploaded Source

Built Distribution

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

distributed_a2a-0.1.2-py3-none-any.whl (9.4 kB view details)

Uploaded Python 3

File details

Details for the file distributed_a2a-0.1.2.tar.gz.

File metadata

  • Download URL: distributed_a2a-0.1.2.tar.gz
  • Upload date:
  • Size: 9.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.2

File hashes

Hashes for distributed_a2a-0.1.2.tar.gz
Algorithm Hash digest
SHA256 5803ca8440a8cef16507e991d11076131305c8b9173c67611d303a06a92f2475
MD5 ceb0909cdd2c60668c2ca9a6e86a5cfe
BLAKE2b-256 8ca10bc7d44ea00693611ab5a5f11b8fdb0c80980f3da8d81742f4d2370b7716

See more details on using hashes here.

File details

Details for the file distributed_a2a-0.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for distributed_a2a-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 f77bb3716cbd475defe942e843c79100b7dfefbc3eb9efea9c1e568a623687a5
MD5 f7e01c0b13dbbbc52d227d296cd7232c
BLAKE2b-256 06da6ef485ae129b54ddedc92fd885644aaf813ee727c504c5e4e38ffb94cff4

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