Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/swuecho/chat
chat web app for teams, sass with user management and ratelimit, support chatgpt(openai & azure), claude, gemini and ollama model
https://github.com/swuecho/chat
chatgpt claude-ai ollama sass teams
Last synced: 1 day ago
JSON representation
chat web app for teams, sass with user management and ratelimit, support chatgpt(openai & azure), claude, gemini and ollama model
- Host: GitHub
- URL: https://github.com/swuecho/chat
- Owner: swuecho
- Created: 2023-03-18T11:32:14.000Z (almost 2 years ago)
- Default Branch: master
- Last Pushed: 2025-01-03T02:34:56.000Z (10 days ago)
- Last Synced: 2025-01-04T05:12:19.304Z (8 days ago)
- Topics: chatgpt, claude-ai, ollama, sass, teams
- Language: Vue
- Homepage:
- Size: 3.53 MB
- Stars: 521
- Watchers: 10
- Forks: 91
- Open Issues: 22
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-ChatGPT-repositories - chat - chat web app for teams, sass with user management and ratelimit, support chatgpt(openai & azure), claude or custom model (Openai)
- awesome-gpt - Chat - chat web app for teams, sass with user management and rate limit, support openai, claude model or custom model (Applications and Demos / LLM (Large Language Model))
- Awesome-Ollama - chat: chat web app for teams
- StarryDivineSky - swuecho/chat
README
## Demo
## 规则
- 第一个消息是系统消息(prompt)
- 上下文默认附带最新创建的4条消息
- 第一个注册的用户是管理员
- 默认限流 100 chatGPT call /10分钟 (OPENAI_RATELIMIT=100)
- 根据对话生成可以分享的静态页面(like ShareGPT), 也可以继续会话.
- 对话快照目录(对话集), 支持全文查找(Enlgish), 方便整理, 搜索会话记录.
- 支持OPEN AI, Claude 模型
- 支持Ollama host模型, 配置参考: https://github.com/swuecho/chat/discussions/396
- 支持上传文本文件
- 支持多媒体文件, 需要模型支持
- 提示词管理, 提示词快捷键 '/'## 参与开发
1. git clone
2. golang dev```bash
cd chat; cd api
go install github.com/cosmtrek/air@latest
go mod tidy# export env var, change base on your env
export DATABASE_URL= postgres://user:[email protected]:5432/db?sslmode=disable# export OPENAI_API_KEY=sk-xxx, not required if you use `debug` model
# export OPENAI_RATELIMIT=100make serve
```3. node env
```bash
cd ..; cd web
npm install
npm run dev
```4. e2e test
```bash
cd ..; cd e2e
# export env var, change base on your env
export DATABASE_URL= postgres://user:[email protected]:5432/db?sslmode=disable
npm install
npx playwright test # --ui
```Ask in issue or discussion if unclear.
## 如何部署
参考 `docker-compose.yaml`
[![Deploy on Railway](https://railway.app/button.svg)](https://railway.app/template/tk7jWU?referralCode=5DMfQv)
然后配置环境变量就可以了.
```
PORT=8080
OPENAI_RATELIMIT=0
```别的两个 api key 有就填.
部署之后, 注册用户, 第一个用户是管理员, 然后到 ,
设置 ratelimit, 公网部署, 只对信任的email 增加 ratelimit, 这样即使有人注册, 也是不能用的.## 使用本地Ollama 模型
1. 安装ollama 并下载模型
```
curl -fsSL https://ollama.com/install.sh | sh
ollama pull mistral
```linux 下,默认的systemd 的配置限制了本机访问, 需要改HOST 能远程访问,如果ollama 和chat 在同一个host, 则不存在这个问题
![image](https://github.com/swuecho/chat/assets/666683/3695c088-4dcd-4ff4-9a75-6b9d44186a4b)
2. 在 Chat Admin 页面配置模型
![image](https://github.com/swuecho/chat/assets/666683/bc1d111f-7bd4-458d-bfed-0a0a5611809f)```
id: ollama-{modelName} # modelName 与 pull的 ollama 模型 一致, 比如 mistral, ollama3, ollama2
name: does not matter, naming as you like,
baseUrl: http://hostname:11434/api/chat
other fields is irrelevant.
```
id 和 baseUrl 这两个地方配置对即可。enjoy!
## 致谢
- web: [ChatGPT-Web](https://github.com/Chanzhaoyu/chatgpt-web) 复制过来的 。
- api : 参考 [Kerwin1202](https://github.com/Kerwin1202)'s [Chanzhaoyu/chatgpt-web#589](https://github.com/Chanzhaoyu/chatgpt-web/pull/589) 的node版本在chatgpt帮助下写的## LICENCE: MIT
## How to Use
- The first message is a system message (prompt)
- by default, the latest 4 messages are context
- First user is superuser.
- 100 chatgpt api call / 10 mins (OPENAI_RATELIMIT=100)
- Snapshot conversation and Share (like ShareGPT)
- Support OPEN AI, Claude model
- Support Upload File
- Support MultiMedia File (rely on Model support)## How to Deploy
Refer to `docker-compose.yaml`
[![Deploy on Railway](https://railway.app/button.svg)](https://railway.app/template/tk7jWU?referralCode=5DMfQv)
Then configure the environment variables.
```
PORT=8080
OPENAI_RATELIMIT=0
```Fill in the other two keys if you have them.
After deployment, registering users, the first user is an administrator, then go to
to set rate limiting. Public deployment,
only adds rate limiting to trusted emails, so even if someone registers, it will not be available.This helps ensure only authorized users can access the deployed system by limiting registration to trusted emails and enabling rate limiting controls.
1. download ollama and pull mistral model.
```
curl -fsSL https://ollama.com/install.sh | sh
ollama pull mistral
```
![image](https://github.com/swuecho/chat/assets/666683/bc1d111f-7bd4-458d-bfed-0a0a5611809f)2. config ollama model in chat admin
```
id: ollama-{modelName}
name: does not matter, naming as you like
baseUrl: http://hostname:11434/api/chat
other fields is irrelevant.
```enjoy!
## Dev locally
1. git clone
2. golang dev```bash
cd chat; cd api
go install github.com/cosmtrek/air@latest
go mod tidy
# export env var, change base on your env
export PG_HOST=192.168.0.135
export PG_DB=hwu
export PG_USER=hwu
export PG_PASS=pass
export PG_PORT=5432
# export DATABASE_URL= postgres://user:[email protected]:5432/db?sslmode=disable# export OPENAI_API_KEY=sk-xxx, not required if you use `debug` model
# export OPENAI_RATELIMIT=100
#
make serve
```3. node env
```bash
cd ..; cd web
npm install
npm run dev
```4. e2e test
```bash
cd ..; cd e2e
# export env var, change base on your env
export PG_HOST=192.168.0.135
export PG_DB=hwu
export PG_USER=hwu
export PG_PASS=pass
export PG_PORT=5432
npm install
npx playwright test # --ui
```The instruction might not be accurate, ask in issue or discussion if unclear.
## Acknowledgments
- web: copied from chatgpt-web
- api: based on the node version of [Kerwin1202](https://github.com/Kerwin1202)'s [Chanzhaoyu/chatgpt-web#589](https://github.com/Chanzhaoyu/chatgpt-web/pull/589)
and written with the help of chatgpt.