Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/houko/wechatgpt
wechatgpt golang版 chatgpt机器人(可docker部署),目前支持wechat,telegram
https://github.com/houko/wechatgpt
chatgpt golang slack wechat
Last synced: 1 day ago
JSON representation
wechatgpt golang版 chatgpt机器人(可docker部署),目前支持wechat,telegram
- Host: GitHub
- URL: https://github.com/houko/wechatgpt
- Owner: houko
- License: mit
- Created: 2022-12-07T03:37:33.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2024-04-05T04:38:34.000Z (9 months ago)
- Last Synced: 2025-01-05T13:04:21.838Z (8 days ago)
- Topics: chatgpt, golang, slack, wechat
- Language: Go
- Homepage:
- Size: 14.2 MB
- Stars: 865
- Watchers: 8
- Forks: 191
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- Awesome-ChatGPT - wechatgpt
- awesome-ChatGPT-repositories - wechatgpt - wechatgpt golang版 chatgpt机器人(可docker部署),目前支持wechat,telegram (Others)
- awesome-chatgpt - wechatgpt
README
## 欢迎使用`wechatgpt`智能机器人,Let's Chat with ChatGPT
如果觉得不错,请麻烦点个`Star`,非常感谢。(最新己经添加了docker部署的方式)
## 介绍
基于 OpenAI 官方 API 开发的微信智能机器人。
功能:
- 多模态对话
- gpt4-vision-preview 识别图片并回复
- DALL·E 生成图片(“生成图片” 关键字)感谢 https://github.com/houko/wechatgpt 提供的基础代码
在 `wechatgpt` 的基础上,我增加了多模态对话的功能,以及修复一些问题。
## 运行命令
```bash
git clone https://github.com/t3ls/wechatgpt.git
cd wechatgpt && docker compose up -d
```## 修改你的token
打开 [openai](https://beta.openai.com/account/api-keys) 并注册一个账号,
生成一个api_key并把api_key放到`local/config.yaml`
的token下,请看如下示例(说了是示例别试了,内容乱写的,也感谢@那些担心泄漏key的):```
chatgpt:
wechat: 小莫
token: sk-pKHZD1fLYqXDjjsdsdsdUvIODTT3ssjdfadsJC2gTuqqhTum
telegram: your telegram token
```大陆用户注册`openai`请参考 [注册ChatGPT详细指南](https://sms-activate.org/cn/info/ChatGPT)
## 运行App
### 环境变量
| 变量名 | 值 | 作用 |
|----------------|-------------------|------------------|
| api_key | "chatgpt的api_key" | 必填项 |
|openai_text_model| "gpt-3.5-turbo" | 可选项,不填默认为gpt-3.5-turbo |
| openai_vision_model| "gpt4-vision-preview" | 可选项,不填默认为gpt4-vision-preview |
| openai_image_model| "dall-e-2" | 可选项,不填默认为dall-e-2 |
| wechat | "true" 或缺省 | 如果为true就会启动微信机器人 |
| wechat_keyword | "关键字"或缺省 | 如果缺省则发任何消息机器都会回复 |
| telegram | telegram的token或缺省 | 如果要启动tg机器人需要填写 |
| tg_keyword | telegram触发关键字或缺省 | 如果需要关键字触发就填写 |
| tg_whitelist | telegram的触发白名单 | 白名单以外的用户名发消息不会触发 |```
go run main.go
```或者修改 docker-compose.yml 文件中的环境变量后运行
## 运行`telegram`智能机器人(暂不对 telegram 相关原始代码进行维护)
运行`telegram`智能机器人的话运行下面这段代码
```
docker run -d \
--name wechatgpt \
-e api_key="你的chatgpt api_key" \
-e telegram="你的telegram token" \
xiaomoinfo/wechatgpt:latest```
如果运行`telegram`智能机器人时只希望指定的人使用,白名单以外的人发消息机器人不会回复
```
docker run -d \
--name wechatgpt \
-e api_key="你的chatgpt api_key" \
-e telegram="你的telegram token" \
-e tg_whitelist="username1,username2" \
xiaomoinfo/wechatgpt:latest```
如果运行`telegram`智能机器人时希望在群里回复别人消息,可以指定一个关键字触发
```
docker run -d \
--name wechatgpt \
-e api_key="你的chatgpt api_key" \
-e telegram="你的telegram token" \
-e tg_keyword="小莫" \
xiaomoinfo/wechatgpt:latest```
### 微信
```
ain.go #gosetup
go: downloading github.com/eatmoreapple/openwechat v1.2.1
go: downloading github.com/sirupsen/logrus v1.6.0
go: downloading github.com/spf13/afero v1.9.2
go: downloading github.com/pelletier/go-toml/v2 v2.0.5
go: downloading golang.org/x/sys v0.0.0-20220908164124-27713097b956
/private/var/folders/8t/0nvj_2kn4dl517vhbc4rmb9h0000gn/T/GoLand/___go_build_main_go
访问下面网址扫描二维码登录
https://login.weixin.qq.com/qrcode/QedkOe1I4w==
```会自动打开默认浏览器,如果没有打开也可以手动点击上面的链接打开二维码扫微信
```
2022/12/09 15:15:00 登录成功
2022/12/09 15:15:01 RetCode:0 Selector:2
2022/12/09 15:15:04 RetCode:0 Selector:2
INFO[0099] 0
INFO[0099] 1
INFO[0099] 2
INFO[0099] 3
```登陆成功后会拉取微信的好友和群组
### 如何使用
默认为`chatgpt`,如果想设置其他的触发方式可以修改`local/config.yaml`的wechat。此时,如果别人给你发消息带有关键字`chatgpt`
,你的微信就会调用`chatGPT`AI自动回复你的好友。
当然,在群里也是可以的。## Q&A
### 1. 返回错误`invalid_api_key`
这是因为`openai`的`API`
需要付费,价格非常便宜具体可以官网查看。按照如下参考绑定一下信息卡就可以正常使用了,如果还是有错就把`API Key`删掉重新建一个。
![img.png](screenshots/billing.png)### 2. Cannot load io/fs: malformed module path "io/fs": missing dot in first path element
golang版本太低,需要`1.16`以上,查看方式为`go version`
```
$ go version
go version go1.17.3 linux/amd64
```### 3. 扫码登陆时出现错误 FATA【0023】write token.json: bad file descriptor
删除项目根目录下的`token.json`后重新扫码登陆即可
### 4. go mod tidy时connect: connection refused
```
go: github.com/eatmoreapple/[email protected]: Get https://proxy.golang.org/github.com/eatmoreapple/openwechat/@v/v1.2.1.mod: dial tcp 142.251.43.17:443:
```自身网络环境问题,请排查网络设置
## 协议
[MIT LICENSE](LICENSE)