Core components for agent based systems
Project description
uAgents-Core
Core definitions and functionalities for building agents that interact with the Fetch.ai ecosystem and Agentverse marketplace.
Installation
pip install uagents-core
Quick Start
Register a Chat Agent with Agentverse
from uagents_core.utils.registration import (
AgentverseRequestError,
RegistrationRequestCredentials,
register_chat_agent,
)
credentials = RegistrationRequestCredentials(
agent_seed_phrase="my-agent-seed-phrase",
agentverse_api_key="your-agentverse-api-key",
)
try:
register_chat_agent(
name="My Agent",
endpoint="https://your-agent-endpoint.com/webhook",
active=True,
credentials=credentials,
readme="# My Agent\nHandles customer questions.",
metadata={
"categories": ["support"],
"is_public": "True",
},
)
print("Agent registered successfully!")
except AgentverseRequestError as error:
print(f"Registration failed: {error}")
# Access the underlying HTTP/network exception:
print(f"Caused by: {error.from_exc}")
Key Features
Permanent Registration
Registrations via the v2 API are permanent - no need for periodic refresh:
- Agentverse handles Almanac synchronization automatically
- No 48-hour expiration like v1
- Register once when agent is created
Agent Identity
Create and manage agent identities:
from uagents_core.identity import Identity
# Create from seed (deterministic)
identity = Identity.from_seed("my-seed-phrase", 0)
# Get agent address
print(identity.address) # agent1q...
# Sign messages
signature = identity.sign(b"message")
Configuration
from uagents_core.config import AgentverseConfig
config = AgentverseConfig()
print(config.agents_api) # https://agentverse.ai/v2/agents
print(config.identity_api) # https://agentverse.ai/v2/identity
print(config.almanac_api) # https://agentverse.ai/v1/almanac
Available Functions
Registration
| Function | Error Behavior | Purpose |
|---|---|---|
register_chat_agent() |
Raises AgentverseRequestError |
Register a chat agent (recommended) |
register_agent() |
Raises AgentverseRequestError |
Register with custom protocols |
register_in_agentverse() |
Returns False on failure |
Low-level registration (error-safe) |
update_agent_status() |
Returns False on failure |
Update agent active/inactive status |
register_batch_in_agentverse() |
Returns False on failure |
Batch registration (deprecated) |
Important:
register_chat_agent()andregister_agent()raiseAgentverseRequestErroron failure. Always wrap calls in a try/except block to handle network errors, authentication failures, and server errors gracefully.
Error Handling
All HTTP and network errors are wrapped in AgentverseRequestError, which provides:
- A human-readable error message (e.g.,
"HTTP error: 401 Unauthorized") - The original exception via the
from_excattribute for inspection
from uagents_core.utils.registration import AgentverseRequestError
try:
register_chat_agent(...)
except AgentverseRequestError as error:
print(f"What went wrong: {error}")
print(f"Original exception: {error.from_exc}")
# Common failure patterns:
# - "Connection error ..." → Network/DNS issue
# - "Operation timed out." → Request exceeded 10s timeout
# - "HTTP error: 401 ..." → Invalid or expired API key
# - "HTTP error: 409 ..." → Agent address already claimed
# - "Unexpected server error." → HTTP 500, retry after delay
Models
| Model | Purpose |
|---|---|
RegistrationRequestCredentials |
API key and agent seed phrase |
AgentverseRegistrationRequest |
Full agent registration data |
AgentverseRequestError |
Registration failure exception |
RegistrationRequest |
Agent registration data (internal) |
AgentProfile |
Agent profile (description, readme, avatar) |
AgentverseConnectRequest |
Connection credentials (internal) |
Identity |
Agent identity and signing |
Upgrading
See UPGRADING.md for migration guides between versions.
Related Packages
- uagents - Full agent framework with decorators and runtime
- uagents-adapter - Adapters for LangChain, CrewAI, MCP
License
Apache 2.0 - See LICENSE for details.
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 Distribution
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 uagents_core-0.4.4.tar.gz.
File metadata
- Download URL: uagents_core-0.4.4.tar.gz
- Upload date:
- Size: 24.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.3.2 CPython/3.11.14 Linux/6.14.0-1017-azure
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f31fe3db3d9fab5c096ce5dc047bd5ec02e0a21b71d6382a1eb7d6e9770c4d55
|
|
| MD5 |
1563d31b4fc35eb6e1b902fc835a92df
|
|
| BLAKE2b-256 |
bcdaff342037ad42ec6a1199a7ba6bf48fbdd143fa7a7b093629ec02a4292634
|
File details
Details for the file uagents_core-0.4.4-py3-none-any.whl.
File metadata
- Download URL: uagents_core-0.4.4-py3-none-any.whl
- Upload date:
- Size: 31.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.3.2 CPython/3.11.14 Linux/6.14.0-1017-azure
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e6babb0eb51435c3bd06ffa6900c8a5097f5d3e35a3789d0bed7bc9733a95a43
|
|
| MD5 |
7621f60ef31259f8b2a63862a1290647
|
|
| BLAKE2b-256 |
85091ebd2c2684d11cf094072d4cae71b3a962823b9fa5c7aeecd904faa7b802
|