-
Notifications
You must be signed in to change notification settings - Fork 9
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat(docs): add Agent with proxy guide
- Loading branch information
1 parent
5944486
commit 7d5951a
Showing
6 changed files
with
101 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,96 @@ | ||
# Agent with Proxy | ||
|
||
## Introduction | ||
|
||
A Proxy serves as a bridge between your Agent and the Agentverse, allowing the Agent to publish interaction data and configure traffic rules efficiently without the need of a [Mailbox ↗️](/guides/agents/intermediate/mailbox). This setup is particularly beneficial for Agents requiring continuous operation and visibility in the Agentverse Marketplace. | ||
|
||
## Prerequisites | ||
|
||
Make sure you have read the following resources before going on with this guide: | ||
|
||
- [Quick Start Guide for uAgents Framework ↗️](/guides/agents/quickstart) | ||
- [Creating your first agent ↗️](/guides/agents/getting-started/create-a-uagent) | ||
- [Agents address ↗️](/guides/agents/getting-started/getting-uagent-address) | ||
- [Almanac contract ↗️](/concepts/fetch-network/almanac) | ||
- [Register in Almanac ↗️](/guides/agents/register-in-almanac) | ||
- [Agent Mailboxes ↗️](/guides/agents/intermediate/mailbox) | ||
- [Local Agent Inspector ↗️](/guides/agents/intermediate/local-agent-inspector) | ||
|
||
## The Agent setup | ||
|
||
An Agent connected via a Proxy uses the Agentverse as an intermediary to manage rules for incoming traffic. This is also the simplest way to publish your Agent's interaction data. | ||
|
||
The following code demonstrates how to connect a local Agent to the Agentverse using a Proxy: | ||
|
||
```py copy filename="agent-with-proxy.py" | ||
from uagents import Agent, Context, Model | ||
|
||
class Message(Model): | ||
message: str | ||
|
||
# Now your agent is ready to join the agentverse! | ||
agent = Agent( | ||
name="alice", | ||
seed="your_agent_seed_phrase" | ||
proxy=True | ||
) | ||
|
||
# Copy the address shown below | ||
print(f"Your agent's address is: {agent.address}") | ||
|
||
if __name__ == "__main__": | ||
agent.run() | ||
``` | ||
|
||
The Agent is initialized with multiple parameters: `name`, `seed` and `proxy`. Remember to correctly specify these parameters in order to successfully run the Agent. By running the above Agent code, you should be able to see the following output within your terminal: | ||
|
||
``` | ||
Your agent's address is: agent1qtx288pfqm9e5qausyzdy6zmmn65ytwygqdq2h7d4g0q00ft04rygg96jtt | ||
INFO: [alice]: Starting agent with address: agent1qtx288pfqm9e5qausyzdy6zmmn65ytwygqdq2h7d4g0q00ft04rygg96jtt | ||
INFO: [alice]: Agent inspector available at https://agentverse.ai/inspect/?uri=http%3A//127.0.0.1%3A8000&address=agent1qtx288pfqm9e5qausyzdy6zmmn65ytwygqdq2h7d4g0q00ft04rygg96jtt | ||
INFO: [alice]: Starting server on http://0.0.0.0:8000 (Press CTRL+C to quit) | ||
INFO: [alice]: Registration on Almanac API successful | ||
INFO: [alice]: Registering on almanac contract... | ||
INFO: [alice]: Registering on almanac contract...complete | ||
``` | ||
|
||
Now, you are ready to connect the Agent using a Proxy. To connect your Agent using a Proxy, obtain the IP address where your Agent is accessible. Use the Agent Inspector URL from the terminal output to access the Inspector UI. **Log in** to the Agentverse and click the **Connect** button. | ||
|
||
data:image/s3,"s3://crabby-images/d2097/d20975738d98f612d6089218073660ffeed1f52a" alt="" | ||
|
||
Then, select **Proxy** as your connection method, provide your Agent's **IP address** followed by `/submit`. Once it is being validated, click **Next**. | ||
|
||
data:image/s3,"s3://crabby-images/101b3/101b3492e839c3769dc79a984ddd9e3471fa1844" alt="" | ||
|
||
Now, you will need to provide an **IP address** for your Agent. | ||
|
||
_**Make sure you are running the latest [uagents package ↗️](https://pypi.org/project/uagents/) version on your end!**_ | ||
|
||
data:image/s3,"s3://crabby-images/29159/2915980acd8b7b97b2019ade3ab73f5bcce74827" alt="" | ||
|
||
Once you do so, and the Agent IP address will be verified, you will be asked to verify your Agent configuration and finalize the setup process. | ||
|
||
data:image/s3,"s3://crabby-images/df2f8/df2f8add5e8427e3610930dcd9928511e0ef2b9e" alt="" | ||
|
||
Great! You successfully set up a proxy for your local Agent! | ||
|
||
You should be able to see the following updated output in your terminal: | ||
|
||
``` | ||
Your agent's address is: agent1qtx288pfqm9e5qausyzdy6zmmn65ytwygqdq2h7d4g0q00ft04rygg96jtt | ||
INFO: [alice]: Starting agent with address: agent1qtx288pfqm9e5qausyzdy6zmmn65ytwygqdq2h7d4g0q00ft04rygg96jtt | ||
INFO: [alice]: Agent inspector available at https://agentverse.ai/inspect/?uri=http%3A//127.0.0.1%3A8000&address=agent1qtx288pfqm9e5qausyzdy6zmmn65ytwygqdq2h7d4g0q00ft04rygg96jtt | ||
INFO: [alice]: Starting server on http://0.0.0.0:8000 (Press CTRL+C to quit) | ||
INFO: [alice]: Registration on Almanac API successful | ||
INFO: [alice]: Registering on almanac contract... | ||
INFO: [alice]: Registering on almanac contract...complete | ||
INFO: [mailbox]: Successfully registered as proxy agent in Agentverse | ||
``` | ||
|
||
Now that your Agent is connected through the Proxy to the Agentverse, it is able to receive messages from any other Agents. | ||
|
||
Using a Proxy enables your Agent to seamlessly interact with the Agentverse, tracking interactions and displaying them on the [Marketplace ↗️](/concepts/agent-services/agent-explorer). These interactions are showcased on the Agent's dedicated page within the [Agentverse My Agents ↗️](/concepts/agent-services/agent-hosting.) tab, providing visibility and engagement opportunities for users exploring the Marketplace. | ||
|
||
A Proxy differs from a [Mailbox ↗️](/guides/agents/intermediate/mailbox) in key ways. While a Mailbox stores messages for offline Agents, a Proxy requires the Agent to be online to process incoming messages in real-time. Messages sent to an offline Proxy Agent are dropped, making it suitable for Agents that are continuously running and accessible through a public endpoint. | ||
|
||
Setting up a Proxy benefits agents that require consistent operation and visibility in the Agentverse. It tracks interactions, showcases activity in the Marketplace, and ensures that Agents remain discoverable to other users, enhancing engagement and utility. |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.