mirror of
https://github.com/OpenHands/OpenHands.git
synced 2025-12-26 05:48:36 +08:00
* simplify readme * Update config.toml.template * Update vite.config.ts (#372) * Update vite.config.ts * Update frontend/vite.config.ts --------- Co-authored-by: Robert Brennan <accounts@rbren.io> * remove old langchains infra * remove refs to OPENAI_API_KEY * simplify opendevin readme --------- Co-authored-by: Engel Nyst <enyst@users.noreply.github.com>
2.9 KiB
2.9 KiB
OpenDevin Server
This is a WebSocket server that executes tasks using an agent.
Install
Create a .env file with the contents
LLM_API_KEY=<YOUR OPENAI API KEY>
Install requirements:
python3.12 -m venv venv
source venv/bin/activate
python -m pip install -r requirements.txt
Start the Server
uvicorn opendevin.server.listen:app --reload --port 3000
Test the Server
You can use websocat to test the server: https://github.com/vi/websocat
websocat ws://127.0.0.1:3000/ws
{"action": "start", "args": {"task": "write a bash script that prints hello"}}
Supported Environment Variables
LLM_API_KEY=sk-... # Your OpenAI API Key
LLM_MODEL=gpt-4-0125-preview # Default model for the agent to use
WORKSPACE_DIR=/path/to/your/workspace # Default path to model's workspace
API Schema
There are two types of messages that can be sent to, or received from, the server:
- Actions
- Observations
Actions
An action has three parts:
action: The action to be takenargs: The arguments for the actionmessage: A friendly message that can be put in the chat log
There are several kinds of actions. Their arguments are listed below. This list may grow over time.
initialize- initializes the agent. Only sent by client.model- the name of the model to usedirectory- the path to the workspaceagent_cls- the class of the agent to use
start- starts a new development task. Only sent by the client.task- the task to start
read- reads the contents of a file.path- the path of the file to read
write- writes the contents to a file.path- the path of the file to writecontents- the contents to write to the file
run- runs a command.command- the command to runbackground- if true, run the command in the background
kill- kills a background commandid- the ID of the background command to kill
browse- opens a web page.url- the URL to open
recall- searches long-term memoryquery- the query to search for
think- Allows the agent to make a plan, set a goal, or record thoughtsthought- the thought to record
finish- agent signals that the task is completed
Observations
An observation has four parts:
observation: The observation typecontent: A string representing the observed dataextras: additional structured datamessage: A friendly message that can be put in the chat log
There are several kinds of observations. Their extras are listed below. This list may grow over time.
read- the contents of a filepath- the path of the file read
browse- the HTML contents of a urlurl- the URL opened
run- the output of a commandcommand- the command runexit_code- the exit code of the command
recall- the result of a searchquery- the query searched for
chat- a message from the user