suna/agent.py

99 lines
2.8 KiB
Python
Raw Normal View History

2024-10-17 19:44:10 +08:00
import asyncio
2024-10-28 05:04:42 +08:00
import json
2024-10-17 19:44:10 +08:00
from agentpress.thread_manager import ThreadManager
from tools.files_tool import FilesTool
2024-10-30 00:21:19 +08:00
from agentpress.state_manager import StateManager
from tools.terminal_tool import TerminalTool
2024-10-10 22:21:39 +08:00
2024-10-23 09:42:38 +08:00
async def run_agent(
thread_manager: ThreadManager,
thread_id: int,
2024-10-28 05:04:42 +08:00
state_manager: StateManager,
2024-10-23 09:42:38 +08:00
max_iterations: int = 10
):
async def init():
pass
async def pre_iteration():
2024-10-30 00:21:19 +08:00
# Update files state
files_tool = FilesTool()
await files_tool._init_workspace_state()
terminal_tool = TerminalTool()
await terminal_tool.get_command_history()
2024-10-23 09:42:38 +08:00
async def after_iteration():
2024-10-30 00:21:19 +08:00
await thread_manager.add_message(thread_id, {
"role": "user",
"content": "Continue developing. "
})
2024-10-23 09:42:38 +08:00
async def finalizer():
pass
await init()
iteration = 0
while iteration < max_iterations:
iteration += 1
await pre_iteration()
2024-10-28 05:04:42 +08:00
# Get entire state store
state = await state_manager.export_store()
2024-10-30 00:21:19 +08:00
state_info = f"Current workspace state:\n{json.dumps(state, indent=2)}"
2024-10-28 05:04:42 +08:00
system_message = {
"role": "system",
2024-10-30 00:21:19 +08:00
"content": f"""You are a web developer who can create, read, update, and delete files,
and execute terminal commands. You write clean, well-structured code and explain your changes.
2024-10-23 09:42:38 +08:00
2024-10-30 00:21:19 +08:00
Current workspace state:
{state_info}
Explain what you're doing before making changes."""
}
model_name = "anthropic/claude-3-5-sonnet-latest"
2024-10-28 05:04:42 +08:00
2024-10-23 09:42:38 +08:00
response = await thread_manager.run_thread(
thread_id=thread_id,
system_message=system_message,
model_name=model_name,
temperature=0.7,
2024-10-30 00:21:19 +08:00
max_tokens=4096,
2024-10-23 09:42:38 +08:00
tool_choice="auto",
execute_tools_async=False,
2024-10-23 10:43:57 +08:00
use_tools=True,
2024-10-23 09:42:38 +08:00
execute_model_tool_calls=True
)
await after_iteration()
await finalizer()
2024-10-17 19:44:10 +08:00
2024-10-17 04:08:46 +08:00
if __name__ == "__main__":
2024-10-23 09:42:38 +08:00
async def main():
thread_manager = ThreadManager()
2024-10-28 05:04:42 +08:00
state_manager = StateManager("state.json")
2024-10-23 09:42:38 +08:00
thread_id = await thread_manager.create_thread()
2024-10-28 05:04:42 +08:00
2024-10-23 09:42:38 +08:00
thread_manager.add_tool(FilesTool)
2024-10-30 00:21:19 +08:00
thread_manager.add_tool(TerminalTool)
2024-10-23 09:42:38 +08:00
2024-10-30 00:21:19 +08:00
await thread_manager.add_message(
thread_id,
{
"role": "user",
"content": "Let's create a marketing website."
}
)
2024-10-23 09:42:38 +08:00
await run_agent(
thread_manager=thread_manager,
thread_id=thread_id,
2024-10-28 05:04:42 +08:00
state_manager=state_manager,
2024-10-23 09:42:38 +08:00
max_iterations=5
)
asyncio.run(main())