Files
OpenHands/opendevin/server/agent/manager.py
Robert Brennan 9fd7068204 Fix for setting LLM model, frontend settings refactor (#1169)
* simplify frontend settings management

* add debug info to llm.py

* always reinitialize agent

* remove old config stuff

* delint

* fix first initialize event

* refactor settings management

* remove logs

* change endpoint to remove litellm reference

* actually fix socket issues

* refactor a bit

* delint

* remove isFirstRun

* delint

* delint python

* fix export

* fix up socket handshake

* fix types

* fix lint errors

* delint

* fix test names

* moar lint

* fix build errors

* remove newline

* Update frontend/src/services/settingsService.test.ts

* Update frontend/src/services/settingsService.test.ts
2024-04-17 17:49:38 +00:00

40 lines
1.2 KiB
Python

import atexit
from opendevin.server.session import session_manager
from opendevin.logger import opendevin_logger as logger
from .agent import AgentUnit
class AgentManager:
sid_to_agent: dict[str, 'AgentUnit'] = {}
def __init__(self):
atexit.register(self.close)
def register_agent(self, sid: str):
"""Registers a new agent.
Args:
sid: The session ID of the agent.
"""
if sid not in self.sid_to_agent:
self.sid_to_agent[sid] = AgentUnit(sid)
return
# TODO: confirm whether the agent is alive
async def dispatch(self, sid: str, action: str | None, data: dict):
"""Dispatches actions to the agent from the client."""
if sid not in self.sid_to_agent:
# self.register_agent(sid) # auto-register agent, may be opened later
logger.error(f'Agent not registered: {sid}')
await session_manager.send_error(sid, 'Agent not registered')
return
await self.sid_to_agent[sid].dispatch(action, data)
def close(self):
logger.info(f'Closing {len(self.sid_to_agent)} agent(s)...')
for sid, agent in self.sid_to_agent.items():
agent.close()