mirror of
https://github.com/ChatGPTNextWeb/ChatGPT-Next-Web.git
synced 2025-06-01 02:10:22 +09:00
240 lines
8.2 KiB
Markdown
240 lines
8.2 KiB
Markdown
<div align="center">
|
||
<img src="./docs/images/icon.svg" alt="icon"/>
|
||
<h1 align="center">ChatGPT Next Web LangChain</h1>
|
||
一键免费部署你的跨平台私人 ChatGPT 应用。基于 LangChain 实现的插件功能。
|
||
|
||
[![Web][Web-image]][web-url]
|
||
[![Windows][Windows-image]][download-url]
|
||
[![MacOS][MacOS-image]][download-url]
|
||
[![Linux][Linux-image]][download-url]
|
||
|
||
[网页版](https://chat-gpt-next-web-git-dev-gosuto.vercel.app/#/) / [客户端](https://github.com/Hk-Gosuto/ChatGPT-Next-Web-LangChain/releases) / [反馈](https://github.com/Hk-Gosuto/ChatGPT-Next-Web-LangChain/issues)
|
||
|
||
[web-url]: https://chat-gpt-next-web-git-dev-gosuto.vercel.app/#/
|
||
[download-url]: https://github.com/Hk-Gosuto/ChatGPT-Next-Web-LangChain/releases
|
||
[Web-image]: https://img.shields.io/badge/Web-PWA-orange?logo=microsoftedge
|
||
[Windows-image]: https://img.shields.io/badge/-Windows-blue?logo=windows
|
||
[MacOS-image]: https://img.shields.io/badge/-MacOS-black?logo=apple
|
||
[Linux-image]: https://img.shields.io/badge/-Linux-333?logo=ubuntu
|
||
|
||
[](https://vercel.com/new/clone?repository-url=https%3A%2F%2Fgithub.com%2FHk-Gosuto%2FChatGPT-Next-Web-LangChain&env=OPENAI_API_KEY,CODE,SERPAPI_API_KEY&project-name=chatgpt-next-web-langchain&repository-name=ChatGPT-Next-Web-LangChain)
|
||
|
||
[](https://gitpod.io/#https://github.com/Hk-Gosuto/ChatGPT-Next-Web-LangChain)
|
||
|
||

|
||
|
||

|
||
|
||
</div>
|
||
|
||
## 主要功能
|
||
|
||
- 除插件工具外,与原项目保持一致 [ChatGPT-Next-Web 主要功能](https://github.com/Yidadaa/ChatGPT-Next-Web#主要功能)
|
||
- 基于 [LangChain](https://github.com/hwchase17/langchainjs) 实现的插件功能,目前支持以下插件,未来会添加更多
|
||
- [SerpAPI](https://js.langchain.com/docs/api/tools/classes/SerpAPI)
|
||
- [RequestsGetTool](https://js.langchain.com/docs/api/tools/classes/RequestsGetTool)
|
||
- [RequestsPostTool](https://js.langchain.com/docs/api/tools/classes/RequestsPostTool)
|
||
- [Calculator](https://js.langchain.com/docs/api/tools_calculator/classes/Calculator)
|
||
|
||
|
||
## 开发计划
|
||
|
||
- [x] 支持使用 DuckDuckGo 作为默认搜索引擎
|
||
|
||
当前配置 `SERPAPI_API_KEY` 时优先使用 `serpapi` 作为搜索插件,不配置时默认使用 `duckduckgo` 作为搜索插件。
|
||
|
||
- [ ] 插件列表页面开发
|
||
- [ ] 支持开关指定插件
|
||
- [ ] 支持添加自定义插件
|
||
- [ ] 支持 Agent 参数配置( agentType, maxIterations, returnIntermediateSteps 等)
|
||
- [ ] 支持 ChatSession 级别插件工具开关
|
||
|
||
## 已知问题
|
||
- [ ] 使用插件时需将模型切换为 `0613` 版本模型,如:`gpt-3.5-turbo-0613`
|
||
- [x] `SERPAPI_API_KEY` 目前为必填,后续会支持使用 DuckDuckGo 替换搜索插件
|
||
- [ ] Agent 不支持自定义接口地址
|
||
- [ ] 部分场景下插件会调用失败
|
||
- [ ] 插件调用失败后无反馈
|
||
|
||
## 最新动态
|
||
|
||
- 🚀 v2.9.1-plugin-preview 预览版发布。
|
||
|
||
## 开始使用
|
||
|
||
1. 准备好你的 [OpenAI API Key](https://platform.openai.com/account/api-keys);
|
||
2. 点击右侧按钮开始部署:
|
||
[](https://vercel.com/new/clone?repository-url=https%3A%2F%2Fgithub.com%2FHk-Gosuto%2FChatGPT-Next-Web-LangChain&env=OPENAI_API_KEY,CODE,SERPAPI_API_KEY&project-name=chatgpt-next-web-langchain&repository-name=ChatGPT-Next-Web-LangChain),直接使用 Github 账号登录即可,记得在环境变量页填入 API Key 和[页面访问密码](#配置页面访问密码) CODE;
|
||
3. 部署完毕后,即可开始使用;
|
||
4. (可选)[绑定自定义域名](https://vercel.com/docs/concepts/projects/domains/add-a-domain):Vercel 分配的域名 DNS 在某些区域被污染了,绑定自定义域名即可直连。
|
||
|
||
## FAQ
|
||
|
||
[简体中文 > 常见问题](./docs/faq-cn.md)
|
||
|
||
[English > FAQ](./docs/faq-en.md)
|
||
|
||
## Keep Updated
|
||
|
||
> [简体中文 > 如何保持代码更新](./README_CN.md#保持更新)
|
||
|
||
If you have deployed your own project with just one click following the steps above, you may encounter the issue of "Updates Available" constantly showing up. This is because Vercel will create a new project for you by default instead of forking this project, resulting in the inability to detect updates correctly.
|
||
|
||
We recommend that you follow the steps below to re-deploy:
|
||
|
||
- Delete the original repository;
|
||
- Use the fork button in the upper right corner of the page to fork this project;
|
||
- Choose and deploy in Vercel again, [please see the detailed tutorial](./docs/vercel-cn.md).
|
||
|
||
### Enable Automatic Updates
|
||
|
||
> If you encounter a failure of Upstream Sync execution, please manually sync fork once.
|
||
|
||
After forking the project, due to the limitations imposed by GitHub, you need to manually enable Workflows and Upstream Sync Action on the Actions page of the forked project. Once enabled, automatic updates will be scheduled every hour:
|
||
|
||

|
||
|
||

|
||
|
||
### Manually Updating Code
|
||
|
||
If you want to update instantly, you can check out the [GitHub documentation](https://docs.github.com/en/pull-requests/collaborating-with-pull-requests/working-with-forks/syncing-a-fork) to learn how to synchronize a forked project with upstream code.
|
||
|
||
You can star or watch this project or follow author to get release notifictions in time.
|
||
|
||
## Access Password
|
||
|
||
> [简体中文 > 如何增加访问密码](./README_CN.md#配置页面访问密码)
|
||
|
||
This project provides limited access control. Please add an environment variable named `CODE` on the vercel environment variables page. The value should be passwords separated by comma like this:
|
||
|
||
```
|
||
code1,code2,code3
|
||
```
|
||
|
||
After adding or modifying this environment variable, please redeploy the project for the changes to take effect.
|
||
|
||
## Environment Variables
|
||
|
||
> [简体中文 > 如何配置 api key、访问密码、接口代理](./README_CN.md#环境变量)
|
||
|
||
### `OPENAI_API_KEY` (required)
|
||
|
||
Your openai api key.
|
||
|
||
### `SERPAPI_API_KEY` (required)
|
||
|
||
[SerpApi: Google Search API](https://serpapi.com/)
|
||
|
||
### `CODE` (optional)
|
||
|
||
Access passsword, separated by comma.
|
||
|
||
### `BASE_URL` (optional)
|
||
|
||
> Default: `https://api.openai.com`
|
||
|
||
> Examples: `http://your-openai-proxy.com`
|
||
|
||
Override openai api request base url.
|
||
|
||
### `OPENAI_ORG_ID` (optional)
|
||
|
||
Specify OpenAI organization ID.
|
||
|
||
### `HIDE_USER_API_KEY` (optional)
|
||
|
||
> Default: Empty
|
||
|
||
If you do not want users to input their own API key, set this value to 1.
|
||
|
||
### `DISABLE_GPT4` (optional)
|
||
|
||
> Default: Empty
|
||
|
||
If you do not want users to use GPT-4, set this value to 1.
|
||
|
||
### `HIDE_BALANCE_QUERY` (optional)
|
||
|
||
> Default: Empty
|
||
|
||
If you do not want users to query balance, set this value to 1.
|
||
|
||
## Requirements
|
||
|
||
NodeJS >= 18, Docker >= 20
|
||
|
||
## Development
|
||
|
||
> [简体中文 > 如何进行二次开发](./README_CN.md#开发)
|
||
|
||
[](https://gitpod.io/#https://github.com/Yidadaa/ChatGPT-Next-Web)
|
||
|
||
Before starting development, you must create a new `.env.local` file at project root, and place your api key into it:
|
||
|
||
```
|
||
OPENAI_API_KEY=<your api key here>
|
||
|
||
# if you are not able to access openai service, use this BASE_URL
|
||
BASE_URL=https://chatgpt1.nextweb.fun/api/proxy
|
||
```
|
||
|
||
### Local Development
|
||
|
||
```shell
|
||
# 1. install nodejs and yarn first
|
||
# 2. config local env vars in `.env.local`
|
||
# 3. run
|
||
yarn install
|
||
yarn dev
|
||
```
|
||
|
||
## Deployment
|
||
|
||
> [简体中文 > 如何部署到私人服务器](./README_CN.md#部署)
|
||
|
||
### Docker (Recommended)
|
||
|
||
```shell
|
||
docker pull gosuto/chatgpt-next-web-langchain
|
||
|
||
docker run -d -p 3000:3000 \
|
||
-e OPENAI_API_KEY="sk-xxxx" \
|
||
-e CODE="your-password" \
|
||
gosuto/chatgpt-next-web-langchain
|
||
```
|
||
|
||
You can start service behind a proxy:
|
||
|
||
```shell
|
||
docker run -d -p 3000:3000 \
|
||
-e OPENAI_API_KEY="sk-xxxx" \
|
||
-e CODE="your-password" \
|
||
-e PROXY_URL="http://localhost:7890" \
|
||
gosuto/chatgpt-next-web-langchain
|
||
```
|
||
|
||
If your proxy needs password, use:
|
||
|
||
```shell
|
||
-e PROXY_URL="http://127.0.0.1:7890 user pass"
|
||
```
|
||
|
||
## Screenshots
|
||
|
||

|
||
|
||

|
||
|
||
## Translation
|
||
|
||
If you want to add a new translation, read this [document](./docs/translation.md).
|
||
|
||
## Donation
|
||
|
||
[请项目原作者喝杯咖啡](https://www.buymeacoffee.com/yidadaa)
|
||
|
||
## LICENSE
|
||
|
||
[MIT](https://opensource.org/license/mit/)
|