E5BotForSQLite/README_zhCN.md

161 lines
4.8 KiB
Markdown
Raw Permalink Normal View History

2020-06-17 17:40:15 +08:00
# E5SubBot
![](https://img.shields.io/github/go-mod/go-version/iyear/E5SubBot?style=flat-square)
![](https://img.shields.io/badge/license-GPL-lightgrey.svg?style=flat-square)
![](https://img.shields.io/github/v/release/iyear/E5SubBot?color=green&style=flat-square)
2021-07-06 21:21:49 +08:00
[English](https://github.com/iyear/E5SubBot) | 简体中文 | [交流群组](https://t.me/e5subbot)
2020-06-17 17:40:15 +08:00
A Simple Telebot for E5 Renewal
`Golang` + `MySQL`
2021-07-06 21:21:49 +08:00
DEMO: https://t.me/E5Sub_bot
2020-06-17 17:40:15 +08:00
## 特性
- 自动续订E5订阅(可自定义的调用频率)
- 可管理的简易账户系统
- 完善的任务执行反馈
- 极为方便的授权方式
2021-07-06 21:21:49 +08:00
- 使用并发加快运行速度
2020-06-17 17:40:15 +08:00
## 原理
E5订阅为开发者订阅只要调用相关API就有可能续期
调用 [Outlook ReadMail API](https://docs.microsoft.com/zh-cn/graph/api/user-list-messages?view=graph-rest-1.0&tabs=http) 实现玄学的续订方式,不保证续订效果。
## 使用方法
1. 在机器人对话框输入 **/bind**
2. 注册应用使用E5主账号或同域账号登录跳转页面获得client_secret。**点击回到快速启动**,获得client_id
3. 复制client_secret和client_id`client_id client_secret`格式回复
4. 获得授权链接使用E5主账号或同域账号登录
5. 授权后会跳转至`http://localhost/e5sub……` (会提示网页错误,复制链接即可)
6. 复制整个浏览框内容,在机器人对话框回复 `链接+空格+别名(用于管理账户)`
例如:`http://localhost/e5sub/?code=abcd MyE5`,等待机器人绑定后即完成
## 自行部署
Bot创建教程:[Google](https://www.google.com/search?q=telegram+Bot%E5%88%9B%E5%BB%BA%E6%95%99%E7%A8%8B)
### Docker部署
感谢 [@kzw200015](https://github.com/kzw200015) 提供`Dockerfile`以及`Docker`方面的帮助
第一次启动不行,使用 `docker-compose restart`重启一次
```bash
mkdir ./e5bot && wget --no-check-certificate -O ./e5bot/config.yml https://raw.githubusercontent.com/iyear/E5SubBot/master/config.yml.example
vi ./e5bot/config.yml
wget --no-check-certificate https://raw.githubusercontent.com/iyear/E5SubBot/master/docker-compose.yml
docker-compose up -d
```
### 二进制文件
在[Releases](https://github.com/iyear/E5SubBot/releases)页面下载对应系统的二进制文件,上传至服务器
2021-07-06 21:21:49 +08:00
Windows: 启动 `E5SubBot.exe`
2020-06-17 17:40:15 +08:00
2021-07-06 21:21:49 +08:00
Linux:
2020-06-17 17:40:15 +08:00
```bash
screen -S e5sub
2021-07-06 21:21:49 +08:00
chmod +x E5SubBot
2020-06-17 17:40:15 +08:00
./E5SubBot
(Ctrl A+D)
```
### 编译
下载源码安装GO环境
```shell
2021-07-06 21:21:49 +08:00
git clone https://github.com/iyear/E5SubBot.git && cd E5SubBot && go build
2020-06-17 17:40:15 +08:00
```
## 部署配置
在同目录下创建`config.yml`,编码为`UTF-8`
配置模板:
```yaml
bot_token: YOUR_BOT_TOKEN
socks5: 127.0.0.1:1080
notice: "第一行\n第二行"
admin: 66666,77777,88888
2021-07-06 21:21:49 +08:00
goroutine: 10
2020-06-17 17:40:15 +08:00
errlimit: 5
cron: "1 */3 * * *"
bindmax: 3
mysql:
host: 127.0.0.1
port: 3306
user: e5sub
password: e5sub
database: e5sub
2021-07-06 21:21:49 +08:00
table: users
2020-06-17 17:40:15 +08:00
```
2021-07-06 21:21:49 +08:00
`bindmax`,`notice`,`admin`,`goroutine`,`errlimit`可热更新,直接更新`config.yml`保存即可
| 配置项 | 说明 |默认值|
| ---- | ---- | ---- |
| bot_token | 更换为自己的`BotToken` | -|
| socks5 | `Socks5`代理,不需要删去即可.例如:`127.0.0.1:1080` |-|
|notice|公告.合并至`/help`|-|
|admin|管理员`tgid`,前往 https://t.me/userinfobot 获取,用`,`隔开;管理员权限: 手动调用任务,获得任务总反馈|-|
|goroutine|并发数,不要过大|10|
|errlimit|单账户最大出错次数,满后自动解绑单账户并发送通知,不限制错误次数将值改为负数`(-1)`即可;bot重启后会清零所有错误次数|5|
|cron|API调用频率使用cron表达式|-|
|bindmax|最大可绑定数|5|
|mysql|mysql配置请提前创建数据库(旧版本升级请设置table为users否则读不到数据表)|-|
2020-06-17 17:40:15 +08:00
### 命令
2021-07-06 21:21:49 +08:00
2020-06-17 17:40:15 +08:00
```
/my 查看已绑定账户信息
/bind 绑定新账户
/unbind 解绑账户
/export 导出账户信息(JSON格式)
/help 帮助
/task 手动执行一次任务(Bot管理员)
/log 获取最近日志文件(Bot管理员)
```
## 注意事项
> 更新时间与北京时间不符
更改服务器时区为`Asia/Shanghai`,然后使用`/task`手动执行一次任务刷新时间
> 绑定格式错误
不要带"+"号
> 错误:Can't create more than max_prepared_stmt_count statements (current value: 16382)
没有关闭`db`导致触发`mysql`并发上限,请更新至`v0.1.9`
> 长时间运行崩溃
疑似内存泄露,尚未解决,请自行采用守护进程运行或定时重启`Bot`
2020-07-27 15:55:42 +08:00
> 无法通过Bot创建应用程序
https://t.me/e5subbot/5201
2021-07-06 21:21:49 +08:00
2020-07-03 12:53:04 +08:00
## 更多功能
2020-06-17 17:40:15 +08:00
2021-07-06 21:21:49 +08:00
如果你还想支持新的特性请发起issue.
2020-07-03 12:53:04 +08:00
2020-06-17 17:40:15 +08:00
## 做出贡献
2021-07-06 21:21:49 +08:00
2020-06-17 17:40:15 +08:00
- 提供其他语言的文档
- 为代码运行提供帮助
- 对用户交互提出建议
- ……
## License
2020-06-17 17:42:56 +08:00
GPLv3