Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix #66 and update website #68

Merged
merged 3 commits into from
Jun 20, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
## Agent Chatroom
#### An extensible multi-agent platform built on top of AutoGen.Net and Orleans.
#### 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/chatroom-webui.png)
![Agent Chatroom](assets/agent-chatroom-switch-theme.gif)

## 🌟 Highlights
- **Multi-Agent WebUI**: Chat with multiple agents simultaneously in a web browser.
Expand Down
Binary file added assets/agent-chatroom-switch-theme.gif
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file modified chatroom-ui/public/favicon.ico
Binary file not shown.
1 change: 0 additions & 1 deletion configuration/chatroom-client.json
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,6 @@
"openai_model_id": "gpt-3.5-turbo"
}
},
"enable_console_app": true,
"server_config": {
"urls": "http://localhost:51234;https://localhost:51235"
},
Expand Down
2 changes: 1 addition & 1 deletion nuget/NUGET.md
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
### Agent ChatRoom
An extensible multi-agent platform built on top of AutoGen.Net and Orleans.

[![webui](../assets/chatroom-webui.png)](https://github.com/LittleLittleCloud/Agent-ChatRoom/blob/main/assets/chatroom-webui.png)
![webui](https://github.com/LittleLittleCloud/Agent-ChatRoom/blob/main/assets/chatroom-webui.png)

---
### Getting Start
Expand Down
7 changes: 0 additions & 7 deletions website/get_start/Install_agents.md

This file was deleted.

23 changes: 23 additions & 0 deletions website/get_start/agent_chatroom_overview.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
Agent Chatroom is a multi-agent platform built on top of AutoGen.Net, shadcn and Orleans. It comes with a webui that allows you to chat with multiple agents simultaneously in a web browser. You can also run `ChatRoom.Client` as a restful server. Agent Chatroom is extensible, allowing you to create your own agents and orchestrators and integrate them into the chatroom.

![switch-theme](../assets/agent-chatroom-switch-theme.gif)

## Key Concept
### Agent
In Agent Chatroom, an agent is a conversational agent that can send and receive messages. An agent can be a human (e.g. You) or an LLM chatbot. You can add agents to the room by installing agent packages (e.g `ChatRoom.OpenAI`) or by developing your own agents using `ChatRoom.SDK`.

## Channel
A channel is simply a "group chat" for agents to communicate with. Each agent can send and receive messages as long as they are in the same channel. In Agent Chatroom, you chat with multiple agents by creating a channel and adding agents to it.

## Channel orchestrator
A channel orchestrator manages how agents interact with each other in a channel. For example, a `RoundRobinOrchestrator` will send messages to agents in a round-robin fashion.

Agent Chatroom provides the following channel orchestrators:
- `RoundRobinOrchestrator`: Sends messages to agents in a round-robin fashion.
- `DynamicGroupChat`: The dynamic group chat orchestrator from AutoGen.Net dynamically orchestrate conversation among agents based on conversation history.
- `Human-Bot`: An orchestrator that drives conversation between human and bot agents in an alternating fashion.

You can also create your own orchestrators using `ChatRoom.SDK`.

## Room
A room is a collection of channels.
26 changes: 0 additions & 26 deletions website/get_start/bing_search_agent.md

This file was deleted.

35 changes: 35 additions & 0 deletions website/get_start/chat_with_openai.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
This example shows how to set up `AutoGen Chatroom` with OpenAI agent.

> [!NOTE]
> You can find the complete configuration in [OpenAI-Chatroom](https://github.com/LittleLittleCloud/OpenAI-Chatroom) repository.

![gif](https://github.com/LittleLittleCloud/OpenAI-Chatroom/blob/main/assets/agent-chatroom-openai.gif?raw=true)


## Getting Started

1. Clone the [OpenAI-Chatroom](https://github.com/LittleLittleCloud/OpenAI-Chatroom) repository and navigate to the repository folder.

```bash
git clone https://github.com/LittleLittleCloud/OpenAI-Chatroom
cd OpenAI-Chatroom
```

2. Install the `ChatRoom.Client` and `ChatRoom.OpenAI` tools by running `dotnet tool restore`.

```bash
dotnet tool restore
```

3. Set up OpenAI API key in [client.json](https://github.com/LittleLittleCloud/OpenAI-Chatroom/blob/main/client.json) and [openai.json](https://github.com/LittleLittleCloud/OpenAI-Chatroom/blob/main/openai.json)

4. Start the `ChatRoom.Client` with the following command:

```bash
dotnet chatroom -c client.json
```

You will see the following output similar to the following, then you can navigate to the web UI in your browser and start chatting with the agents.
```bash
web ui is available at: http://localhost:51234;https://localhost:51235
```
41 changes: 41 additions & 0 deletions website/get_start/chat_with_powershell_helpers.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
This example shows how to set up `AutoGen Chatroom` with Powershell helper agents.

> [!NOTE]
> You can find the complete configuration in [Powershell-Chatroom](https://github.com/LittleLittleCloud/Powershell-ChatRoom) repository.

![gif](https://github.com/LittleLittleCloud/Powershell-ChatRoom/blob/main/asset/switch-theme.gif?raw=true)



## About Chatroom.Powershell package
[Chatroom.Powershell](https://www.nuget.org/packages/ChatRoom.Powershell) is an agent package for `Agent Chatroom` that provides the following Powershell helper agents:
- `ps-gpt`: A Powershell agent that write powershell scripts to resolve your tasks.
- `ps-runner`: An agent that run powershell scripts from chat history.

## Getting Started

1. Clone the [Powershell-Chatroom](https://github.com/LittleLittleCloud/Powershell-ChatRoom) repository and navigate to the repository folder.

```bash
git clone https://github.com/LittleLittleCloud/Powershell-ChatRoom
cd Powershell-ChatRoom
```

2. Install the `ChatRoom.Client` and `ChatRoom.Powershell` tools by running `dotnet tool restore`.

```bash
dotnet tool restore
```

3. Set up OpenAI API key in [client.json](https://github.com/LittleLittleCloud/Powershell-ChatRoom/blob/main/client.json) and [powershell.json](https://github.com/LittleLittleCloud/Powershell-ChatRoom/blob/main/powershell.json)

4. Start the `ChatRoom.Client` with the following command:

```bash
dotnet chatroom -c client.json
```

You will see the following output similar to the following, then you can navigate to the web UI in your browser and start chatting with the agents.
```bash
web ui is available at: http://localhost:51234;https://localhost:51235
```
1 change: 1 addition & 0 deletions website/get_start/coming_soon.md
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
# Coming soon
39 changes: 0 additions & 39 deletions website/get_start/install_client.md

This file was deleted.

26 changes: 0 additions & 26 deletions website/get_start/install_openai_agent.md

This file was deleted.

46 changes: 46 additions & 0 deletions website/get_start/installation.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
`Agent Chatroom` is published as dotnet tool on nuget.org.

> [!NOTE]
> To use `Agent Chatroom`, make sure you have [.NET 8.0](https://dotnet.microsoft.com/download/dotnet/8.0) installed.

## Package overview
- [ChatRoom.Client](https://www.nuget.org/packages/ChatRoom.Client): The client for `Agent Chatroom`. It contains the multi-agent webui, chatroom server and an optional console ui for chatroom client.
- [ChatRoom.SDK](https://www.nuget.org/packages/ChatRoom.SDK): The SDK for developing agents and orchestrators for `Agent Chatroom`.

### Agent packages
- [ChatRoom.OpenAI](https://www.nuget.org/packages/ChatRoom.OpenAI): An agent package for `Agent Chatroom` that provides OpenAI agents.
- [ChatRoom.Powershell](https://www.nuget.org/packages/ChatRoom.Powershell): An agent package for `Agent Chatroom` that provides Powershell helper agents.
- [ChatRoom.BingSearch](https://www.nuget.org/packages/ChatRoom.BingSearch): An agent package for `Agent Chatroom` that provides Bing search agents.


## Install client
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
```

Optionally, you can install the latest `Agent Chatroom` client locally by removing the `--global` flag:
```bash
dotnet tool install ChatRoom.Client
```

## Configure client
After installation, you need to create a configuration file for the `Agent Chatroom` client. The configuration file is a JSON file that contains the configuration for the client, including the agent packages and server configuration.

> [!Tip]
> You can find the schema for configuration files under the [schema](https://github.com/LittleLittleCloud/Agent-ChatRoom/tree/main/schema) folder in the `Agent Chatroom` repository.

Here is an example configuration file for the `Agent Chatroom` client, which starts webui on `http://localhost:51234` and `https://localhost:51235` and uses the `ChatRoom.OpenAI` agent package.

[!code-json[](../../configuration/chatroom-client.json)]

## Usage
After installation, you can start the `Agent Chatroom` client by running the following command:
```bash
chatroom -c /path/to/your/client_configuration.json
```

You will see the following output similar to the following, then you can navigate to the web UI in your browser and start chatting with the agents.
```bash
web ui is available at: http://localhost:51234;https://localhost:51235
```
29 changes: 0 additions & 29 deletions website/get_start/powershell_agent.md

This file was deleted.

36 changes: 18 additions & 18 deletions website/get_start/toc.yml
Original file line number Diff line number Diff line change
@@ -1,20 +1,20 @@
- name: Install client
href: install_client.md

- name: Configure client
href: configure_client.md

- name: Use client
href: use_client.md

- name: Install agents
href: install_agents.md
- name: Getting started
items:
- name: Overview
href: agent_chatroom_overview.md
- name: Installation
href: installation.md
- name: Configuration Examples
items:
- name: Chat with OpenAI
href: chat_with_openai.md
- name: Chat with Powershell helpers
href: chat_with_powershell_helpers.md

- name: Agents
- name: Guide
items:
- name: OpenAI agent
href: install_openai_agent.md
- name: Bing Search agent
href: bing_search_agent.md
- name: Powershell agent
href: powershell_agent.md
- name: Develop an agent
href: coming_soon.md
- name: Develop an orchestrator
href: coming_soon.md

Loading
Loading