Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/LittleLittleCloud/Agent-ChatRoom
A multi-agent chatroom for AutoGen agents
https://github.com/LittleLittleCloud/Agent-ChatRoom
agent agent-platform agent-ui agentic-framework agentic-workflow autogen llm llm-agent llm-agents multi-agent-webui next react semantic-kernel typescript webui
Last synced: 2 months ago
JSON representation
A multi-agent chatroom for AutoGen agents
- Host: GitHub
- URL: https://github.com/LittleLittleCloud/Agent-ChatRoom
- Owner: LittleLittleCloud
- License: mit
- Created: 2024-05-18T07:10:56.000Z (8 months ago)
- Default Branch: main
- Last Pushed: 2024-09-06T20:26:48.000Z (4 months ago)
- Last Synced: 2024-09-07T23:13:36.932Z (4 months ago)
- Topics: agent, agent-platform, agent-ui, agentic-framework, agentic-workflow, autogen, llm, llm-agent, llm-agents, multi-agent-webui, next, react, semantic-kernel, typescript, webui
- Language: C#
- Homepage: https://littlelittlecloud.github.io/Agent-ChatRoom/
- Size: 2.08 MB
- Stars: 25
- Watchers: 3
- Forks: 2
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Security: SECURITY.md
- Support: SUPPORT.md
Awesome Lists containing this project
- awesome-semantickernel - A cli chatroom for AutoGen agents
README
## Agent Chatroom
#### An extensible multi-agent platform built on top of AutoGen.Net, shadcn and Orleans.[![NuGet version](https://badge.fury.io/nu/ChatRoom.SDK.svg)](https://badge.fury.io/nu/ChatRoom.Client) | [website](https://littlelittlecloud.github.io/Agent-ChatRoom/) | Join our [Discord](https://discord.gg/UYwcVfGaeq)
![Agent Chatroom](assets/agent-chatroom-switch-theme.gif)
## 🌟 Highlights
- **Multi-Agent WebUI**: Chat with multiple agents simultaneously in a web browser.
- **Code-First**: Use code-first approach to add agents to the chatroom, see [code-first examples](https://github.com/LittleLittleCloud/Agent-ChatRoom/tree/main/example) for more information.
- **Server mode**: You can run `ChatRoom.Client` as a restful server. For more information, see [Server mode](#-server-mode).## Quick Start with code-first approach
You can create an agent by writing code and add it to chatroom. See [code-first examples](https://github.com/LittleLittleCloud/Agent-ChatRoom/tree/main/example) for how to do it.## Quick Start with template
Other than the code-first approach, `Agent Chatroom` also provides a series of templates to help you get started quickly. Use the `list-templates` command to list all available templates and the `create` command to create a configuration from the selected template.### Step 1 - Install ChatRoom.Client from NuGet
`Agent Chatroom` is published as a dotnet tool on nuget.org. You can install the latest `Agent Chatroom` client from nuget.org by running the following command, this will install the `ChatRoom.Client` globally:```bash
dotnet tool install --global ChatRoom.Client
```> [!TIP]
> `create` command also generates a json schema file for this configuration to provide intellisense in your editor. Use it wisely can greatly save your effort on writing configuration.### Step 2 - Choose from one of the available templates to get started.
```bash
chatroom list-templates # list all available templates
```The command will list all available templates.
![list-templates](assets/list-templates.png)
### Step 3 - Create configuration from the selected template.```bash
# Create
chatroom create -t chatroom_openai -o chatroom_openai.json
```![fill key](assets/fill-openai-key.png)
### Step 4 - Start the chatroom client with the OpenAI agent.
After filling in the OpenAI key in the configuration file, you can start the chatroom client with the following command.
```bash
# start chatroom server
chatroom run -c chatroom_openai.json
```You will see the following output from chatroom client which indicates the web UI is available at `http://localhost:51237` and `https://localhost:51238`. You can navigate to the web UI in your browser and start chatting with the agents.
```bash
web ui is available at: http://localhost:51237;https://localhost:51238
```## 📦 Pre-configured Chatrooms
We provide the following configuration to help you get started quickly. More configurations will be added in the future.
- [OpenAI-Chatroom](https://github.com/LittleLittleCloud/OpenAI-Chatroom): chat with OpenAI gpt.
- [Powershell-Chatroom](https://github.com/LittleLittleCloud/Powershell-ChatRoom): chat with `ps-gpt` and `ps-runner` to help you write and run PowerShell scripts.## 🌐 Server mode
To start a restful backend from `ChatRoom.Client`, add a `server_config` section to the client configuration file.```json
// file: chatroom-client-server.json
"server_config": {
"environment": "Development", // one of Development, Staging, Production.
"urls": "http://localhost:51234;https://localhost:51235"
}
```Then, run the following command to start the server. And the server will start on the `http://localhost:51234` and `https://localhost:51235`.
```bash
chatroom -c chatroom-client-server.json
```### Swagger UI for the server
When the environment is set to `Development`, the server will automatically start the Swagger UI at `/swagger` and `/swagger/index.html`. You can also access the complete swagger schema at `/swagger/v1/swagger.json`, or visit [swagger-schema.json](schema/chatroom_client_swagger_schema.json) in this repository.