An SDK that enables agents to connect with each other, allowing them to perform identity authentication, end-to-end encrypted communication, automatic protocol negotiation based on LLMs, and efficient data exchange.
Project description
AgentConnect
What is AgentConnect
AgentConnect is an open-source SDK implementation of the Agent Network Protocol (ANP).
The goal of Agent Network Protocol (ANP) is to become the HTTP of the Intelligent Agent Internet Era, building an open, secure, and efficient collaborative network for billions of intelligent agents.
Core Modules
Authentication
Agent identity authentication system based on DID-WBA (Decentralized Identifier - Web-Based Authentication):
- Identity Management: Create and manage agent DID documents
- Identity Verification: Provide end-to-end identity authentication and authorization
- Secure Communication: Ensure security and trustworthiness of inter-agent communication
ANP Crawler (Agent Discovery & Interaction)
Discovery and interaction tools for the agent network:
- Agent Discovery: Automatically discover and parse agent description documents
- Interface Parsing: Parse JSON-RPC interfaces and convert them to callable tools
- Protocol Interaction: Support communication with agents that comply with ANP protocol
- Direct JSON-RPC: Execute JSON-RPC requests directly without interface discovery
FastANP (Fast Development Framework)
Plugin-based framework for building ANP agents with FastAPI:
- Plugin Architecture: FastAPI as main framework, FastANP as helper plugin
- Automatic OpenRPC: Generate OpenRPC documents from Python functions
- Context Injection: Automatic session and Request object injection
- DID WBA Authentication: Built-in authentication middleware with wildcard path exemption
- Flexible Routing: Full control over all routes including ad.json
- Session Management: Built-in session management based on DID
For complete documentation, see FastANP README
Usage
Option 1: Install via pip
pip install agent-connect
Option 2: Source Installation (Recommended for Developers)
# 下载源码
git clone https://github.com/agent-network-protocol/AgentConnect.git
cd AgentConnect
# 使用UV配置环境
uv sync
# 运行示例
uv run python examples/python/did_wba_examples/create_did_document.py
Example Demonstration
DID-WBA Authentication Example
Location: examples/python/did_wba_examples/
Main Examples
-
Create DID Document (
create_did_document.py)
Demonstrate how to generate DID documents and key pairs for agents -
Authenticate and Verify (
authenticate_and_verify.py)
Demonstrate the complete DID-WBA authentication and verification process
Running Examples
# Create DID Document
uv run python examples/python/did_wba_examples/create_did_document.py
# Authentication Demonstration
uv run python examples/python/did_wba_examples/authenticate_and_verify.py
Detailed Documentation: DID-WBA Example
ANP Crawler Agent Interaction Example
Location: examples/python/anp_crawler_examples/
Main Examples
-
Simple Example (
simple_amap_example.py)
Quick Start: Connect to AMAP service and call the map search interface -
Complete Example (
amap_crawler_example.py)
Complete Demonstration: Agent discovery, interface parsing, and tool calling
Running Examples
# Quick Experience
uv run python examples/python/anp_crawler_examples/simple_amap_example.py
# Complete Function Demonstration
uv run python examples/python/anp_crawler_examples/amap_crawler_example.py
Detailed Documentation: ANP Crawler Example
FastANP Agent Development Example
Location: examples/python/fastanp_examples/
Main Examples
-
Simple Agent (
simple_agent.py) Minimal FastANP setup with single interface method -
Hotel Booking Agent (
hotel_booking_agent.py) Complete example with multiple interfaces, Pydantic models, and session management
Running Examples
# Simple Agent
uv run python examples/python/fastanp_examples/simple_agent.py
# Hotel Booking Agent
uv run python examples/python/fastanp_examples/hotel_booking_agent.py
Testing Examples
# Test with Python client
uv run python examples/python/fastanp_examples/test_hotel_booking_client.py
# Or test manually with curl
# Get Agent Description
curl http://localhost:8000/ad.json | jq
# Call JSON-RPC method
curl -X POST http://localhost:8000/rpc \
-H "Content-Type: application/json" \
-d '{"jsonrpc": "2.0", "id": 1, "method": "search_rooms", "params": {"query": {"check_in_date": "2025-01-01", "check_out_date": "2025-01-05", "guest_count": 2, "room_type": "deluxe"}}}'
Detailed Documentation: FastANP Examples
Tool Recommendations
ANP Network Explorer Tool
Use the web interface to explore the agent network using natural language: ANP Network Explorer Tool
DID Document Generator Tool
Command line tool to quickly generate DID documents:
uv run python tools/did_generater/generate_did_doc.py <did> [--agent-description-url URL]
Contact Us
- Author:GaoWei Chang
- Email:chgaowei@gmail.com
- Website:https://agent-network-protocol.com/
- Discord:https://discord.gg/sFjBKTY7sB
- GitHub:https://github.com/agent-network-protocol/AgentNetworkProtocol
- WeChat:flow10240
License
This project is open-sourced under the MIT License. Detailed information please refer to LICENSE file.
Copyright (c) 2024 GaoWei Chang
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file anp-0.4.4-py3-none-any.whl.
File metadata
- Download URL: anp-0.4.4-py3-none-any.whl
- Upload date:
- Size: 155.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.5.4
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f49a6f51da610a40c06558f4fef4d239ab24886441c0c2de70d6be14247db2ed
|
|
| MD5 |
9766417fb3f5134b2ab7a1fa6d27b99b
|
|
| BLAKE2b-256 |
fde09fa89c773f449149d5d4b98902ee9f9ddeea51d30a499692ec06ecfd4f13
|